commit:     4dc20f895bf6e96633e3e9d6d808dce9509c0983
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 13 09:52:16 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Aug 13 10:39:38 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4dc20f89

dev-python/fakeredis: Bump to 2.31.0

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

 dev-python/fakeredis/Manifest                      |  1 +
 dev-python/fakeredis/fakeredis-2.31.0.ebuild       | 94 ++++++++++++++++++++++
 .../files/fakeredis-2.31.0-opt-valkey.patch        | 39 +++++++++
 3 files changed, 134 insertions(+)

diff --git a/dev-python/fakeredis/Manifest b/dev-python/fakeredis/Manifest
index 21a100bc1e0a..44d008503a07 100644
--- a/dev-python/fakeredis/Manifest
+++ b/dev-python/fakeredis/Manifest
@@ -1,2 +1,3 @@
 DIST fakeredis-2.30.1.tar.gz 167724 BLAKE2B 
7ddb8cbdeb4e3c5bcf9e5a6cd854cc55e39298934d097ec2401eb2226a45fa7e4d25ae666a3e34c22ebe75be6be0ad59c7722dbe7e15dac32f7822c5fd54cee7
 SHA512 
6d23a1e276b2a1ebc1846704f36296ab284b93e978c79358f2e73b6bb0b2c30ea133060dc6e8b9b7c82485c6fccca6efb53f67ecbb468029497e0fd7480dd8db
 DIST fakeredis-2.30.3.tar.gz 168472 BLAKE2B 
70133892f5d75f2f33b4d6ebee8fe1b7ad5b48793f02230fb15db2a731f3a43438f653c0962c9a8fd7e8313b5544bc6eaba295f2a340707835118da8a513177c
 SHA512 
239ac63d064e49c369d7114296e81afd03b6e3aa3a238eb59f0328e936d34b68746518de5f5bc3021a584bfd22b62ca4390b346717ca09c1171767c76e7be462
+DIST fakeredis-2.31.0.tar.gz 170163 BLAKE2B 
1d850e11166208a1c6437b7bc496c16f99f9ffd4497155a6ab5a6304db05ac16fa2b7f616c416e9f3986c7e95a48e21e55a5cbee76234025c2c3536a139eb55e
 SHA512 
e79bd841b9cf0a7ef0ea922c97b813a0666f9b282a223ccb64411727229bff21efd06a7573e223cb93472566b7a07d8a03d6f184218eb781fcd04cd9573f9320

diff --git a/dev-python/fakeredis/fakeredis-2.31.0.ebuild 
b/dev-python/fakeredis/fakeredis-2.31.0.ebuild
new file mode 100644
index 000000000000..24b487dfe304
--- /dev/null
+++ b/dev-python/fakeredis/fakeredis-2.31.0.ebuild
@@ -0,0 +1,94 @@
+# Copyright 2020-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+DISTUTILS_USE_PEP517=hatchling
+PYTHON_COMPAT=( pypy3_11 python3_{11..14} )
+
+inherit distutils-r1 pypi
+
+DESCRIPTION="Fake implementation of redis API for testing purposes"
+HOMEPAGE="
+       https://github.com/cunla/fakeredis-py/
+       https://pypi.org/project/fakeredis/
+"
+
+LICENSE="BSD"
+SLOT="0"
+KEYWORDS="~amd64 ~arm ~arm64 ~ppc ~ppc64 ~riscv ~sparc ~x86"
+
+RDEPEND="
+       >=dev-python/redis-4.3[${PYTHON_USEDEP}]
+       <dev-python/sortedcontainers-3[${PYTHON_USEDEP}]
+       >=dev-python/sortedcontainers-2[${PYTHON_USEDEP}]
+"
+BDEPEND="
+       test? (
+               dev-db/redis
+               dev-python/packaging[${PYTHON_USEDEP}]
+       )
+"
+
+EPYTEST_PLUGINS=( pytest-{asyncio,mock} )
+EPYTEST_XDIST=1
+distutils_enable_tests pytest
+
+PATCHES=(
+       # https://github.com/cunla/fakeredis-py/pull/405
+       "${FILESDIR}/${P}-opt-valkey.patch"
+)
+
+EPYTEST_DESELECT=(
+       # TODO
+       
"test/test_mixins/test_pubsub_commands.py::test_pubsub_channels[StrictRedis2]"
+       
"test/test_mixins/test_pubsub_commands.py::test_pubsub_channels[StrictRedis3]"
+       
"test/test_mixins/test_pubsub_commands.py::test_published_message_to_shard_channel[StrictRedis3]"
+       test/test_mixins/test_set_commands.py::test_smismember_wrong_type
+       
"test/test_mixins/test_pubsub_commands.py::test_pubsub_shardnumsub[StrictRedis2]"
+       
"test/test_mixins/test_pubsub_commands.py::test_pubsub_shardnumsub[StrictRedis3]"
+       # json ext
+       test/test_json/test_json.py
+       test/test_json/test_json_arr_commands.py
+)
+EPYTEST_IGNORE=(
+       # these tests fail a lot...
+       test/test_hypothesis
+       test/test_hypothesis_joint.py
+       # require valkey package
+       test/test_valkey
+)
+
+src_prepare() {
+       distutils-r1_src_prepare
+
+       # do not install duplicate license
+       sed -i -e '\@fakeredis/LICENSE@d' pyproject.toml || die
+}
+
+src_test() {
+       local redis_pid="${T}"/redis.pid
+       local redis_port=6390
+
+       einfo "Spawning Redis"
+       einfo "NOTE: Port ${redis_port} must be free"
+       "${EPREFIX}"/usr/sbin/redis-server - <<- EOF || die "Unable to start 
redis server"
+               daemonize yes
+               pidfile ${redis_pid}
+               port ${redis_port}
+               bind 127.0.0.1
+       EOF
+
+       # Run the tests
+       distutils-r1_src_test
+
+       # Clean up afterwards
+       kill "$(<"${redis_pid}")" || die
+}
+
+python_test() {
+       # we can run "fake" tests in parallel, but "real" seem to share
+       # the same connection
+       epytest -m "not real"
+       EPYTEST_XDIST= epytest -m "real"
+}

diff --git a/dev-python/fakeredis/files/fakeredis-2.31.0-opt-valkey.patch 
b/dev-python/fakeredis/files/fakeredis-2.31.0-opt-valkey.patch
new file mode 100644
index 000000000000..41048113ce40
--- /dev/null
+++ b/dev-python/fakeredis/files/fakeredis-2.31.0-opt-valkey.patch
@@ -0,0 +1,39 @@
+From dff0d4548fdf13f31c48477597f222455063beaa Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Micha=C5=82=20G=C3=B3rny?= <[email protected]>
+Date: Wed, 13 Aug 2025 10:46:01 +0200
+Subject: [PATCH] test: Make valkey optional for testing
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+Make it possible to run the test suite without `valkey` package,
+by moving the relevant imports out of the global `conftest.py` scope
+into the spot where it is used.  This is helpful for downstreams
+that currently do not package `valkey`.
+
+Signed-off-by: Michał Górny <[email protected]>
+---
+ test/conftest.py | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+diff --git a/test/conftest.py b/test/conftest.py
+index b6868f79..4ac9934e 100644
+--- a/test/conftest.py
++++ b/test/conftest.py
+@@ -3,7 +3,6 @@
+ import pytest
+ import pytest_asyncio
+ import redis
+-import valkey
+ 
+ import fakeredis
+ from fakeredis._server import _create_version
+@@ -119,6 +118,8 @@ def factory(**kwargs: Any) -> redis.Redis:
+             return cls(decode_responses=decode_responses, server=fake_server, 
lua_modules=lua_modules, **kwargs)
+         # Real
+         if valkey_client_test:
++            import valkey
++
+             cls = getattr(valkey, cls_name)
+         else:
+             cls = getattr(redis, cls_name)

Reply via email to