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)