From e8e6d99300529c2628d31350b5806589e7ee9ad8 Mon Sep 17 00:00:00 2001 From: zs-neo <48560952+zs-neo@users.noreply.github.com> Date: Mon, 30 Dec 2024 18:26:05 +0800 Subject: [PATCH] Fix incorrect attribute reuse (#3456) add CacheEntry Co-authored-by: zhousheng06 Co-authored-by: Vladyslav Vildanov <117659936+vladvildanov@users.noreply.github.com> --- redis/connection.py | 6 +++++- tests/test_connection.py | 5 +---- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/redis/connection.py b/redis/connection.py index 9d29b4aba6..ace1ed8727 100644 --- a/redis/connection.py +++ b/redis/connection.py @@ -904,9 +904,11 @@ def read_response( and self._cache.get(self._current_command_cache_key).status != CacheEntryStatus.IN_PROGRESS ): - return copy.deepcopy( + res = copy.deepcopy( self._cache.get(self._current_command_cache_key).cache_value ) + self._current_command_cache_key = None + return res response = self._conn.read_response( disable_decoding=disable_decoding, @@ -932,6 +934,8 @@ def read_response( cache_entry.cache_value = response self._cache.set(cache_entry) + self._current_command_cache_key = None + return response def pack_command(self, *args): diff --git a/tests/test_connection.py b/tests/test_connection.py index 65d80e2574..fbc23ae8c0 100644 --- a/tests/test_connection.py +++ b/tests/test_connection.py @@ -501,9 +501,9 @@ def test_read_response_returns_cached_reply(self, mock_cache, mock_connection): ) proxy_connection.send_command(*["GET", "foo"], **{"keys": ["foo"]}) assert proxy_connection.read_response() == b"bar" + assert proxy_connection._current_command_cache_key is None assert proxy_connection.read_response() == b"bar" - mock_connection.read_response.assert_called_once() mock_cache.set.assert_has_calls( [ call( @@ -530,9 +530,6 @@ def test_read_response_returns_cached_reply(self, mock_cache, mock_connection): call(CacheKey(command="GET", redis_keys=("foo",))), call(CacheKey(command="GET", redis_keys=("foo",))), call(CacheKey(command="GET", redis_keys=("foo",))), - call(CacheKey(command="GET", redis_keys=("foo",))), - call(CacheKey(command="GET", redis_keys=("foo",))), - call(CacheKey(command="GET", redis_keys=("foo",))), ] )