commit:     45e5562e608fefa1be877fe717b224df002e2bf5
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 19 06:23:48 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Mar 19 07:32:00 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=45e5562e

dev-python/pymongo: Bump to 4.11.3

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

 dev-python/pymongo/Manifest              |   1 +
 dev-python/pymongo/pymongo-4.11.3.ebuild | 237 +++++++++++++++++++++++++++++++
 2 files changed, 238 insertions(+)

diff --git a/dev-python/pymongo/Manifest b/dev-python/pymongo/Manifest
index 7a7903ce54f1..380bae909032 100644
--- a/dev-python/pymongo/Manifest
+++ b/dev-python/pymongo/Manifest
@@ -1,3 +1,4 @@
 DIST mongo-python-driver-4.11.1.gh.tar.gz 2111810 BLAKE2B 
120168770b1f4a61f7f6327bb7b933e1bf848871ed7a6cb152837a95b438b17236e6b10b1fe54fc29a0791d8ad785033b2d726129dae69e9403ff5b1e3c2b929
 SHA512 
64f7d2baa90c23f3b5d91192cc4bcc6d3199f81b6b2844c19a1059779a5e6681a45e65872452230b6c1c8c193749324eb30af75f080f8830f9642f575da80bf9
 DIST mongo-python-driver-4.11.2.gh.tar.gz 2112201 BLAKE2B 
261dcdacab32b516db4f980947dbf73005c9b972186c3720100495707bc96ed21ec4a8b251c1278f9b315d011ba87a6976e0033c768164abf7228efb061d703c
 SHA512 
210a868c8e6dff923b03683e457085d631153bec2b6ddef85407c04c3f4399bb235331e3851b1193d9a2bed46a77f273ccb5ebf0fde437693a141a7a81673ce9
+DIST mongo-python-driver-4.11.3.gh.tar.gz 2112671 BLAKE2B 
2c19b974461657b805484ad58bb7a3678950be716cbfc0e68853699560221dc3b8094eb8546e3b42efbc933596ebd98da35cc7a195f9690a02e4ff15855dd292
 SHA512 
f8e282085467b1ef6272ce13859ef7a88fdce9a674a3c40cf6f7e1352baecd80cf3394904834805e0921ce1c339bbc4ff54d1e33eadba7ee9c5f3f7a05e6fd99
 DIST mongo-python-driver-4.7.2.gh.tar.gz 1548375 BLAKE2B 
a40dbe153f36cdf2836583aa0116f447d08376ce7980a09d0f21cea37a34ab318e5ff0b34b7fe1721cf7fc5d5443a1dbe0982d59cb941b0da8a4a99abdc7b19d
 SHA512 
1de8bd14301e365eb53252dedaaaf8c9056dd534662543e2a500511e5f5f67a69e1f11a8a8575efdbd8852bb47b632d59762f66024d32973d20dc17c4448b9be

diff --git a/dev-python/pymongo/pymongo-4.11.3.ebuild 
b/dev-python/pymongo/pymongo-4.11.3.ebuild
new file mode 100644
index 000000000000..ce28e987eef6
--- /dev/null
+++ b/dev-python/pymongo/pymongo-4.11.3.ebuild
@@ -0,0 +1,237 @@
+# 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 pypy3_11 python3_{10..13} )
+
+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? (
+               dev-python/pytest-asyncio[${PYTHON_USEDEP}]
+               test-full? (
+                       >=dev-db/mongodb-2.6.0
+               )
+       )
+"
+
+distutils_enable_sphinx doc
+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
+}
+
+python_test() {
+       rm -rf bson pymongo || die
+
+       local -x PYTEST_DISABLE_PLUGIN_AUTOLOAD=1
+       local EPYTEST_DESELECT=(
+               # network-sandbox
+               
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/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
+       )
+
+       local run_separately=(
+               # need to run some tests separately and then restart mongodb
+               # to prevent it from crashing
+               # https://bugs.gentoo.org/934389
+               # note that this list must not overlap with EPYTEST_DESELECT
+               test/test_bulk.py
+               test/test_change_stream.py
+               test/test_collection.py
+               test/test_crud_unified.py
+               test/test_gridfs.py
+       )
+       local run_separately2=(
+               test/test_command_monitoring.py
+               test/test_connection_monitoring.py
+               test/test_cursor.py
+               test/test_database.py
+               test/test_grid_file.py
+       )
+       local run_separately3=(
+               test/test_gridfs_bucket.py
+               test/test_monitoring.py
+       )
+       local run_separately_async=(
+               test/asynchronous/test_database.py
+               test/asynchronous/test_grid_file.py
+       )
+
+       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 stage failed=
+       for stage in {1..6}; do
+               # Now, the hard part: we need to find a free port for mongod.
+               # We're just trying to run it random port numbers and check the 
log
+               # for bind errors. It shall be noted that 'mongod --fork' does 
not
+               # return failure when it fails to bind.
+
+               mkdir -p "${dbpath}" || die
+               while true; do
+                       ebegin "Trying to start mongod on port ${DB_PORT}"
+
+                       LC_ALL=C \
+                       mongod --dbpath "${dbpath}" --nojournal \
+                               --bind_ip ${DB_IP} --port ${DB_PORT} \
+                               --unixSocketPrefix "${TMPDIR}" \
+                               --logpath "${logpath}" --fork \
+                       && 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
+
+               local async=( -p asyncio -m default_async )
+               local def=( -p asyncio -m "default or encryption" )
+               case ${stage} in
+                       1)
+                               nonfatal epytest "${def[@]}" 
"${run_separately[@]}" || failed=1
+                               ;;
+                       2)
+                               nonfatal epytest "${def[@]}" 
"${run_separately2[@]}" || failed=1
+                               ;;
+                       3)
+                               nonfatal epytest "${def[@]}" 
"${run_separately3[@]}" || failed=1
+                               ;;
+                       4)
+                               EPYTEST_DESELECT+=(
+                                       "${run_separately[@]}"
+                                       "${run_separately2[@]}"
+                                       "${run_separately3[@]}"
+                               )
+                               nonfatal epytest "${def[@]}" || failed=1
+                               ;;
+                       5)
+                               nonfatal epytest "${async[@]}" 
"${run_separately_async[@]}" || failed=1
+                               ;;
+                       6)
+                               EPYTEST_DESELECT+=(
+                                       "${run_separately_async[@]}"
+                               )
+                               nonfatal epytest "${async[@]}" || failed=1
+                               ;;
+               esac
+
+               mongod --dbpath "${dbpath}" --shutdown || die
+       done
+
+       [[ ${failed} ]] && die "Tests fail with ${EPYTHON}"
+
+       rm -rf "${dbpath}" || die
+}

Reply via email to