mirror of
https://github.com/gentoo-mirror/gentoo.git
synced 2025-12-21 21:17:37 -08:00
dev-python/pymongo: Bump to 4.15.5
Signed-off-by: Michał Górny <mgorny@gentoo.org>
This commit is contained in:
parent
864eb6470c
commit
897c830f7b
@ -2,3 +2,4 @@ DIST mongo-python-driver-4.13.1.gh.tar.gz 2225917 BLAKE2B 2c02e608f54c68abebb69c
|
|||||||
DIST mongo-python-driver-4.13.2.gh.tar.gz 2227437 BLAKE2B 3aa6d0feedc6a33eb4e9299d85eeab2a9638bf713cfadf9f4018f6bd668758d3afd5b9b4b71dec037fb3f99e89cc34e299e1d9b4521c8ace9da9ce50ae95142b SHA512 845cf92e702a9970f2ef1b5085fffcca96021e0f2fc5133e24b2860482dafabe7770d9421922659d0c6008aac1d5a70834ee4f1728a648fd83e6d33bc33568b0
|
DIST mongo-python-driver-4.13.2.gh.tar.gz 2227437 BLAKE2B 3aa6d0feedc6a33eb4e9299d85eeab2a9638bf713cfadf9f4018f6bd668758d3afd5b9b4b71dec037fb3f99e89cc34e299e1d9b4521c8ace9da9ce50ae95142b SHA512 845cf92e702a9970f2ef1b5085fffcca96021e0f2fc5133e24b2860482dafabe7770d9421922659d0c6008aac1d5a70834ee4f1728a648fd83e6d33bc33568b0
|
||||||
DIST mongo-python-driver-4.14.1.gh.tar.gz 2271379 BLAKE2B 5a1ce13c5275657ee3d64fc0450a20e9c6c3bbfd91bfde6e6e3e8f143b95ea63d18b5cf2b8ba3b707f642eea900894a56889d6bf1d7d9f11f6cfa556a9b7b10b SHA512 087c0450ee1d261cdcb8558d75b4749395058773a33849d94824e2fca0157d0eb4c3f5545a4ddfc0b1bc645a52988f515a90be978f4f88c6a3db4dffa2f9ff9e
|
DIST mongo-python-driver-4.14.1.gh.tar.gz 2271379 BLAKE2B 5a1ce13c5275657ee3d64fc0450a20e9c6c3bbfd91bfde6e6e3e8f143b95ea63d18b5cf2b8ba3b707f642eea900894a56889d6bf1d7d9f11f6cfa556a9b7b10b SHA512 087c0450ee1d261cdcb8558d75b4749395058773a33849d94824e2fca0157d0eb4c3f5545a4ddfc0b1bc645a52988f515a90be978f4f88c6a3db4dffa2f9ff9e
|
||||||
DIST mongo-python-driver-4.15.4.gh.tar.gz 2537291 BLAKE2B 3c269b75156714f8f36cc46ad1c58b11b027ac7fa9ac352240362224e8eeec54cddeeead4446e1e869b4de55a8c5f250b3000f8a64328020f9c4109aaff5f333 SHA512 ee91f55b8d8203aac5be6cf573143778a0250384fb2dd751ccceb8fdaf32923ce55165ee4ab5b9d0aecefd4230a59dbbc0c7c4a890672445115aaf15a5a2c926
|
DIST mongo-python-driver-4.15.4.gh.tar.gz 2537291 BLAKE2B 3c269b75156714f8f36cc46ad1c58b11b027ac7fa9ac352240362224e8eeec54cddeeead4446e1e869b4de55a8c5f250b3000f8a64328020f9c4109aaff5f333 SHA512 ee91f55b8d8203aac5be6cf573143778a0250384fb2dd751ccceb8fdaf32923ce55165ee4ab5b9d0aecefd4230a59dbbc0c7c4a890672445115aaf15a5a2c926
|
||||||
|
DIST mongo-python-driver-4.15.5.gh.tar.gz 2537732 BLAKE2B db699b91c89d6252c265abbc9d65f9b4733258f8a407ff98d3d24aa67989bf66c4879c8b44c0b59cddcd6da05c5fbf3d43fa222a8b3e1a63d27824513f6146d5 SHA512 bc627cf7d2fbbfc64f27c84ff620bf4c2d6d3abba72db0ba25a2158d4a020785a9539c4e3f3b383e75cba4d7150e7d84ec08faf94dfb109d68debbf190cae6e6
|
||||||
|
|||||||
201
dev-python/pymongo/pymongo-4.15.5.ebuild
Normal file
201
dev-python/pymongo/pymongo-4.15.5.ebuild
Normal file
@ -0,0 +1,201 @@
|
|||||||
|
# Copyright 1999-2025 Gentoo Authors
|
||||||
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
|
EAPI=8
|
||||||
|
|
||||||
|
DISTUTILS_EXT=1
|
||||||
|
DISTUTILS_USE_PEP517=hatchling
|
||||||
|
PYTHON_COMPAT=( pypy3_11 python3_{11..14} )
|
||||||
|
|
||||||
|
inherit check-reqs distutils-r1
|
||||||
|
|
||||||
|
MY_P=mongo-python-driver-${PV}
|
||||||
|
DESCRIPTION="Python driver for MongoDB"
|
||||||
|
HOMEPAGE="
|
||||||
|
https://github.com/mongodb/mongo-python-driver/
|
||||||
|
https://pypi.org/project/pymongo/
|
||||||
|
"
|
||||||
|
SRC_URI="
|
||||||
|
https://github.com/mongodb/mongo-python-driver/archive/${PV}.tar.gz
|
||||||
|
-> ${MY_P}.gh.tar.gz
|
||||||
|
"
|
||||||
|
S=${WORKDIR}/${MY_P}
|
||||||
|
|
||||||
|
LICENSE="Apache-2.0"
|
||||||
|
SLOT="0"
|
||||||
|
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
|
||||||
|
IUSE="doc kerberos +native-extensions +test-full"
|
||||||
|
|
||||||
|
RDEPEND="
|
||||||
|
<dev-python/dnspython-3.0.0[${PYTHON_USEDEP}]
|
||||||
|
kerberos? ( dev-python/kerberos[${PYTHON_USEDEP}] )
|
||||||
|
"
|
||||||
|
BDEPEND="
|
||||||
|
dev-python/setuptools[${PYTHON_USEDEP}]
|
||||||
|
test? (
|
||||||
|
test-full? (
|
||||||
|
>=dev-db/mongodb-2.6.0
|
||||||
|
)
|
||||||
|
)
|
||||||
|
"
|
||||||
|
|
||||||
|
distutils_enable_sphinx doc
|
||||||
|
|
||||||
|
EPYTEST_PLUGINS=( pytest-asyncio )
|
||||||
|
EPYTEST_RERUNS=5
|
||||||
|
distutils_enable_tests pytest
|
||||||
|
|
||||||
|
reqcheck() {
|
||||||
|
if use test && use test-full; then
|
||||||
|
# During the tests, database size reaches 1.5G.
|
||||||
|
local CHECKREQS_DISK_BUILD=1536M
|
||||||
|
|
||||||
|
check-reqs_${1}
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_pretend() {
|
||||||
|
reqcheck pkg_pretend
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_setup() {
|
||||||
|
reqcheck pkg_setup
|
||||||
|
}
|
||||||
|
|
||||||
|
src_prepare() {
|
||||||
|
distutils-r1_src_prepare
|
||||||
|
# we do not want hatch-requirements-txt and its ton of NIH deps
|
||||||
|
sed -i -e '/requirements/d' pyproject.toml || die
|
||||||
|
}
|
||||||
|
|
||||||
|
python_compile() {
|
||||||
|
# causes build errors to be fatal
|
||||||
|
local -x TOX_ENV_NAME=whatever
|
||||||
|
local DISTUTILS_ARGS=()
|
||||||
|
# unconditionally implicitly disabled on pypy3
|
||||||
|
if ! use native-extensions; then
|
||||||
|
export NO_EXT=1
|
||||||
|
else
|
||||||
|
export PYMONGO_C_EXT_MUST_BUILD=1
|
||||||
|
unset NO_EXT
|
||||||
|
fi
|
||||||
|
|
||||||
|
distutils-r1_python_compile
|
||||||
|
|
||||||
|
# upstream forces setup.py build_ext -i in their setuptools hack
|
||||||
|
find -name '*.so' -delete || die
|
||||||
|
}
|
||||||
|
|
||||||
|
python_test() {
|
||||||
|
rm -rf bson pymongo || die
|
||||||
|
|
||||||
|
local EPYTEST_DESELECT=(
|
||||||
|
# network-sandbox
|
||||||
|
test/asynchronous/test_async_loop_unblocked.py::TestClientLoopUnblocked::test_client_does_not_block_loop
|
||||||
|
test/asynchronous/test_client.py::AsyncClientUnitTest::test_connection_timeout_ms_propagates_to_DNS_resolver
|
||||||
|
test/asynchronous/test_client.py::AsyncClientUnitTest::test_detected_environment_logging
|
||||||
|
test/asynchronous/test_client.py::AsyncClientUnitTest::test_detected_environment_warning
|
||||||
|
test/asynchronous/test_client.py::TestClient::test_service_name_from_kwargs
|
||||||
|
test/asynchronous/test_client.py::TestClient::test_srv_max_hosts_kwarg
|
||||||
|
test/test_client.py::ClientUnitTest::test_connection_timeout_ms_propagates_to_DNS_resolver
|
||||||
|
test/test_client.py::ClientUnitTest::test_detected_environment_logging
|
||||||
|
test/test_client.py::ClientUnitTest::test_detected_environment_warning
|
||||||
|
test/test_client.py::TestClient::test_service_name_from_kwargs
|
||||||
|
test/test_client.py::TestClient::test_srv_max_hosts_kwarg
|
||||||
|
test/test_dns.py::TestCaseInsensitive::test_connect_case_insensitive
|
||||||
|
test/asynchronous/test_dns.py::IsolatedAsyncioTestCaseInsensitive::test_connect_case_insensitive
|
||||||
|
test/test_srv_polling.py
|
||||||
|
test/asynchronous/test_srv_polling.py
|
||||||
|
test/test_uri_spec.py::TestAllScenarios::test_test_uri_options_srv-options_SRV_URI_with_custom_srvServiceName
|
||||||
|
test/test_uri_spec.py::TestAllScenarios::test_test_uri_options_srv-options_SRV_URI_with_invalid_type_for_srvMaxHosts
|
||||||
|
test/test_uri_spec.py::TestAllScenarios::test_test_uri_options_srv-options_SRV_URI_with_negative_integer_for_srvMaxHosts
|
||||||
|
test/test_uri_spec.py::TestAllScenarios::test_test_uri_options_srv-options_SRV_URI_with_positive_srvMaxHosts_and_loadBalanced=fa
|
||||||
|
test/test_uri_spec.py::TestAllScenarios::test_test_uri_options_srv-options_SRV_URI_with_srvMaxHosts
|
||||||
|
test/test_uri_spec.py::TestAllScenarios::test_test_uri_options_srv-options_SRV_URI_with_srvMaxHosts=0_and_loadBalanced=true
|
||||||
|
test/test_uri_spec.py::TestAllScenarios::test_test_uri_options_srv-options_SRV_URI_with_srvMaxHosts=0_and_replicaSet
|
||||||
|
|
||||||
|
# broken regularly by changes in mypy
|
||||||
|
test/test_typing.py::TestMypyFails::test_mypy_failures
|
||||||
|
|
||||||
|
# fragile to timing? fails because we're getting too many logs
|
||||||
|
test/test_connection_logging.py::TestConnectionLoggingConnectionPoolOptions::test_maxConnecting_should_be_included_in_connection_pool_created_message_when_specified
|
||||||
|
|
||||||
|
# hangs?
|
||||||
|
test/asynchronous/test_grid_file.py::AsyncTestGridFile::test_small_chunks
|
||||||
|
|
||||||
|
# broken async tests?
|
||||||
|
test/asynchronous/test_encryption.py
|
||||||
|
|
||||||
|
# -Werror
|
||||||
|
test/test_read_preferences.py::TestMongosAndReadPreference::test_read_preference_hedge_deprecated
|
||||||
|
test/asynchronous/test_read_preferences.py::TestMongosAndReadPreference::test_read_preference_hedge_deprecated
|
||||||
|
|
||||||
|
# fragile to timing? Internet?
|
||||||
|
test/test_client.py::TestClient::test_repr_srv_host
|
||||||
|
test/asynchronous/test_client.py::TestClient::test_repr_srv_host
|
||||||
|
test/asynchronous/test_ssl.py::TestSSL::test_pyopenssl_ignored_in_async
|
||||||
|
)
|
||||||
|
|
||||||
|
if ! use test-full; then
|
||||||
|
# .invalid is guaranteed to return NXDOMAIN per RFC 6761
|
||||||
|
local -x DB_IP=mongodb.invalid
|
||||||
|
epytest -p asyncio
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Yes, we need TCP/IP for that...
|
||||||
|
local -x DB_IP=127.0.0.1
|
||||||
|
local -x DB_PORT=27000
|
||||||
|
|
||||||
|
local dbpath=${TMPDIR}/mongo.db
|
||||||
|
local logpath=${TMPDIR}/mongod.log
|
||||||
|
|
||||||
|
local failed=
|
||||||
|
mkdir -p "${dbpath}" || die
|
||||||
|
while true; do
|
||||||
|
ebegin "Trying to start mongod on port ${DB_PORT}"
|
||||||
|
|
||||||
|
# mongodb is extremely inefficient
|
||||||
|
# https://www.mongodb.com/docs/manual/reference/ulimit/#review-and-set-resource-limits
|
||||||
|
ulimit -n 64000 || die
|
||||||
|
|
||||||
|
local mongod_options=(
|
||||||
|
--dbpath "${dbpath}"
|
||||||
|
--bind_ip "${DB_IP}"
|
||||||
|
--port "${DB_PORT}"
|
||||||
|
--unixSocketPrefix "${TMPDIR}"
|
||||||
|
--logpath "${logpath}"
|
||||||
|
--fork
|
||||||
|
|
||||||
|
# try to reduce resource use
|
||||||
|
--wiredTigerCacheSizeGB 0.25
|
||||||
|
)
|
||||||
|
|
||||||
|
LC_ALL=C mongod "${mongod_options[@]}" && sleep 2
|
||||||
|
|
||||||
|
# Now we need to check if the server actually started...
|
||||||
|
if [[ ${?} -eq 0 && -S "${TMPDIR}"/mongodb-${DB_PORT}.sock ]]; then
|
||||||
|
# yay!
|
||||||
|
eend 0
|
||||||
|
break
|
||||||
|
elif grep -q 'Address already in use' "${logpath}"; then
|
||||||
|
# ay, someone took our port!
|
||||||
|
eend 1
|
||||||
|
: $(( DB_PORT += 1 ))
|
||||||
|
continue
|
||||||
|
else
|
||||||
|
eend 1
|
||||||
|
eerror "Unable to start mongod for tests. See the server log:"
|
||||||
|
eerror " ${logpath}"
|
||||||
|
die "Unable to start mongod for tests."
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
nonfatal epytest -m "default or default_async or encryption" || failed=1
|
||||||
|
|
||||||
|
mongod --dbpath "${dbpath}" --shutdown || die
|
||||||
|
|
||||||
|
[[ ${failed} ]] && die "Tests fail with ${EPYTHON}"
|
||||||
|
|
||||||
|
rm -rf "${dbpath}" || die
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user