gentoo/dev-python/pymongocrypt/pymongocrypt-1.9.2.ebuild

162 lines
4.7 KiB
Bash

# Copyright 1999-2024 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 python3_{10..12} )
inherit distutils-r1 pypi
DESCRIPTION="Python bindings for libmongocrypt"
HOMEPAGE="
https://github.com/mongodb/libmongocrypt/
https://pypi.org/project/pymongocrypt
"
LICENSE="Apache-2.0"
SLOT="0"
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
RDEPEND="
dev-libs/libmongocrypt
dev-python/cffi[${PYTHON_USEDEP}]
dev-python/cryptography[${PYTHON_USEDEP}]
dev-python/packaging[${PYTHON_USEDEP}]
dev-python/httpx[${PYTHON_USEDEP}]
"
BDEPEND="
test? (
dev-python/cffi[${PYTHON_USEDEP}]
dev-python/pymongo[${PYTHON_USEDEP}]
dev-python/respx[${PYTHON_USEDEP}]
dev-python/unasync[${PYTHON_USEDEP}]
)
"
# adjust after 1.9.3
PATCHES=(
"${FILESDIR}/${P}-hatch.patch"
)
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
#}
#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
# DISTUTILS_ARGS+=( --no_ext )
# else
# export PYMONGO_C_EXT_MUST_BUILD=1
# 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/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
# )
# if ! use test-full; then
# .invalid is guaranteed to return NXDOMAIN per RFC 6761
# local -x DB_IP=mongodb.invalid
# epytest
# 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
# 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 failed
# nonfatal epytest || failed=1
# mongod --dbpath "${dbpath}" --shutdown || die
# [[ ${failed} ]] && die "Tests fail with ${EPYTHON}"
# rm -rf "${dbpath}" || die
#}