blob: 80bf518cb5fc3a18968322b6770566e134d1bc81 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
# Copyright 1999-2024 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
DISTUTILS_USE_PEP517=setuptools
PYTHON_COMPAT=( python3_{10..13} pypy3 )
inherit distutils-r1
MY_P="PyMySQL-${PV}"
DESCRIPTION="Pure-Python MySQL Driver"
HOMEPAGE="
https://github.com/PyMySQL/PyMySQL/
https://pypi.org/project/PyMySQL/
"
SRC_URI="
https://github.com/PyMySQL/PyMySQL/archive/v${PV}.tar.gz
-> ${MY_P}.gh.tar.gz
"
S=${WORKDIR}/${MY_P}
LICENSE="MIT"
SLOT="0"
KEYWORDS="~alpha amd64 arm arm64 ~hppa ~ia64 ~loong ppc ppc64 ~riscv ~s390 ~sparc x86"
# TODO: support other mysql variants
BDEPEND="
test? (
dev-db/mariadb[server]
)
"
distutils_enable_tests pytest
src_prepare() {
# Auth tests don't support socket auth
find tests/ -name '*_auth.py' -delete || die
distutils-r1_src_prepare
}
src_test() {
local -x USER=$(whoami)
local -x PATH="${BROOT}/usr/share/mariadb/scripts:${PATH}"
einfo "Creating mysql test instance ..."
mkdir -p "${T}"/mysql || die
mysql_install_db \
--no-defaults \
--auth-root-authentication-method=normal \
--basedir="${EPREFIX}/usr" \
--datadir="${T}"/mysql 1>"${T}"/mysqld_install.log || die
einfo "Starting mysql test instance ..."
# TODO: random port
mysqld \
--no-defaults \
--character-set-server=utf8 \
--bind-address=127.0.0.1 \
--port=43306 \
--pid-file="${T}"/mysqld.pid \
--socket="${T}"/mysqld.sock \
--datadir="${T}"/mysql 1>"${T}"/mysqld.log 2>&1 &
# wait for it to start
local i
for (( i = 0; i < 10; i++ )); do
[[ -S ${T}/mysqld.sock ]] && break
sleep 1
done
[[ ! -S ${T}/mysqld.sock ]] && die "mysqld failed to start"
einfo "Configuring test mysql instance ..."
# note: ed25519 was removed since it fails -- upstream README indicates
# it can fail if we used a different server version
mysql -uroot --socket="${T}"/mysqld.sock -s -e '
CREATE DATABASe test1 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_general_ci;
CREATE DATABASE test2 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_general_ci;
' || die "Failed to create test databases"
cat > pymysql/tests/databases.json <<-EOF || die
[{
"host": "localhost",
"user": "root",
"password": "",
"database": "test1",
"use_unicode": true,
"local_infile": true,
"unix_socket": "${T}/mysqld.sock"
}, {
"host": "localhost",
"user": "root",
"password": "",
"database": "test2",
"unix_socket": "${T}/mysqld.sock"
}]
EOF
nonfatal distutils-r1_src_test
local ret=${?}
einfo "Stopping mysql test instance ..."
pkill -F "${T}"/mysqld.pid || die
[[ ${ret} -ne 0 ]] && die
}
python_test() {
local EPYTEST_DESELECT=(
# requires some dialog plugin
pymysql/tests/test_connection.py::TestAuthentication::testDialogAuthThreeAttemptsQuestionsInstallPlugin
pymysql/tests/test_connection.py::TestAuthentication::testDialogAuthTwoQuestionsInstallPlugin
)
epytest
}
|