summaryrefslogtreecommitdiff
path: root/tests/cache
diff options
context:
space:
mode:
authorMichael Lissner <mlissner@michaeljaylissner.com>2021-05-25 09:31:26 -0700
committerMariusz Felisiak <felisiak.mariusz@gmail.com>2021-05-26 11:21:11 +0200
commit5a8e8f80bb82a867eab7e4d9d099f21d0a976d22 (patch)
treed59a000cab2fda9925951d2c5ed3b942a94a3bd4 /tests/cache
parent12b19a1d76e1a6f80923c8358290d605dacd65d4 (diff)
downloaddjango-5a8e8f80bb82a867eab7e4d9d099f21d0a976d22.tar.gz
Fixed #32772 -- Made database cache count size once per set.
Diffstat (limited to 'tests/cache')
-rw-r--r--tests/cache/tests.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/tests/cache/tests.py b/tests/cache/tests.py
index 65a8f12fc7..783055182d 100644
--- a/tests/cache/tests.py
+++ b/tests/cache/tests.py
@@ -40,6 +40,7 @@ from django.test import (
ignore_warnings, override_settings,
)
from django.test.signals import setting_changed
+from django.test.utils import CaptureQueriesContext
from django.utils import timezone, translation
from django.utils.cache import (
get_cache_key, learn_cache_key, patch_cache_control, patch_vary_headers,
@@ -1117,6 +1118,18 @@ class DBCacheTests(BaseCacheTests, TransactionTestCase):
with self.assertNumQueries(1):
cache.delete_many(['a', 'b', 'c'])
+ def test_cull_count_queries(self):
+ old_max_entries = cache._max_entries
+ # Force _cull to delete on first cached record.
+ cache._max_entries = -1
+ with CaptureQueriesContext(connection) as captured_queries:
+ try:
+ cache.set('force_cull', 'value', 1000)
+ finally:
+ cache._max_entries = old_max_entries
+ num_count_queries = sum('COUNT' in query['sql'] for query in captured_queries)
+ self.assertEqual(num_count_queries, 1)
+
def test_delete_cursor_rowcount(self):
"""
The rowcount attribute should not be checked on a closed cursor.