commit:     d2c827c3ab398fe66814aef22a79b16a4b9a6498
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 23 05:46:39 2023 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jun 23 06:06:22 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d2c827c3

dev-python/mysqlclient: Bump to 2.2.0

Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>

 dev-python/mysqlclient/Manifest                 |  1 +
 dev-python/mysqlclient/mysqlclient-2.2.0.ebuild | 91 +++++++++++++++++++++++++
 2 files changed, 92 insertions(+)

diff --git a/dev-python/mysqlclient/Manifest b/dev-python/mysqlclient/Manifest
index b6daf5fb0e4f..16337db4e649 100644
--- a/dev-python/mysqlclient/Manifest
+++ b/dev-python/mysqlclient/Manifest
@@ -1 +1,2 @@
 DIST mysqlclient-2.1.1.tar.gz 88138 BLAKE2B 
fdd044f2703af874dc0ca67b2fe07fcac3ceed5a4543aa15a0daa852ddf5ad6940a43675c0f104d9aa173e96da946e33054e1cc4c1b9812487558af64cc8fd43
 SHA512 
d8aed044b651aabb8d28d2df085f84e4d824ef0f147216d111425a9c8024f55634236ec131debf46660084c5a8fd67c944db60ffbf89e1d712cdca80c0726a06
+DIST mysqlclient-2.2.0.tar.gz 89543 BLAKE2B 
1e75d37825b81300103d980174d12986d7d02fa2f958ebbdb3d8a2ecea498a8afd9f43c2e3d46a88109364bc0ba172f91c7d5853ed4bd173ef34bc451d31c7b3
 SHA512 
c392bfc173c2a2e20821b862c3f23621bcd0c20884f58623c345921aaa4f0557b3f75e75e5577a0df150adf119ec008af5ad1fcbfe11248d73918c0a211e8df9

diff --git a/dev-python/mysqlclient/mysqlclient-2.2.0.ebuild 
b/dev-python/mysqlclient/mysqlclient-2.2.0.ebuild
new file mode 100644
index 000000000000..b474537386c1
--- /dev/null
+++ b/dev-python/mysqlclient/mysqlclient-2.2.0.ebuild
@@ -0,0 +1,91 @@
+# Copyright 1999-2023 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+DISTUTILS_EXT=1
+DISTUTILS_USE_PEP517=setuptools
+PYTHON_COMPAT=( python3_{10..12} )
+
+inherit distutils-r1 pypi
+
+DESCRIPTION="Python interface to MySQL"
+HOMEPAGE="
+       https://pypi.org/project/mysqlclient/
+       https://github.com/PyMySQL/mysqlclient/
+"
+
+LICENSE="GPL-2+"
+SLOT="0"
+KEYWORDS="~amd64 ~arm ~arm64 ~hppa ~ia64 ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86 
~amd64-linux ~x86-linux"
+
+DEPEND="
+       dev-db/mysql-connector-c:0=
+"
+RDEPEND="
+       ${DEPEND}
+"
+BDEPEND="
+       test? (
+               dev-db/mariadb[server]
+       )
+"
+
+distutils_enable_sphinx doc
+distutils_enable_tests pytest
+
+src_test() {
+       local datadir="${T}/mysql" \
+               install_log="${T}/mysqld_install.log" \
+               pidfile="${T}/mysqld.pid" \
+               socket="${T}/mysqld.sock" \
+               log="${T}/mysqld.log"
+       einfo "Creating test MySQL instance ..."
+       if ! mysql_install_db \
+               --no-defaults \
+               --auth-root-authentication-method=normal \
+               --basedir="${EPREFIX}/usr" \
+               --datadir="${datadir}" >& "${install_log}"
+       then
+               cat "${install_log}"
+               die "Failed to create database"
+       fi
+
+       einfo "Starting test MySQL instance ..."
+       mysqld \
+               --no-defaults \
+               --character-set-server=utf8 \
+               --pid-file="${pidfile}" \
+               --socket="${socket}" \
+               --skip-networking \
+               --datadir="${datadir}" >& "${log}" &
+
+       local i timeout=10
+       einfo "Waiting for MySQL to start for up to ${timeout} seconds ..."
+       for i in seq 1 ${timeout}; do
+               [[ -S "${socket}" ]] && break
+               sleep 1
+       done
+       if [[ ! -S "${socket}" ]]; then
+               cat "${log}"
+               die "MySQL failed to start in ${timeout} seconds"
+       fi
+
+       cat > "${T}/mysql.cnf" <<- EOF
+               [MySQLdb-tests]
+               socket = ${socket}
+               user = root
+               database = test
+       EOF
+
+       distutils-r1_src_test
+
+       einfo "Stopping test MySQL instance ..."
+       pkill -F "${pidfile}" &>/dev/null
+}
+
+python_test() {
+       local -x TESTDB="${T}/mysql.cnf"
+       rm -rf MySQLdb || die
+       epytest
+}

Reply via email to