diff options
author | Michael Lissner <mlissner@michaeljaylissner.com> | 2021-05-25 09:31:26 -0700 |
---|---|---|
committer | Mariusz Felisiak <felisiak.mariusz@gmail.com> | 2021-05-26 11:21:11 +0200 |
commit | 5a8e8f80bb82a867eab7e4d9d099f21d0a976d22 (patch) | |
tree | d59a000cab2fda9925951d2c5ed3b942a94a3bd4 /tests/cache | |
parent | 12b19a1d76e1a6f80923c8358290d605dacd65d4 (diff) | |
download | django-5a8e8f80bb82a867eab7e4d9d099f21d0a976d22.tar.gz |
Fixed #32772 -- Made database cache count size once per set.
Diffstat (limited to 'tests/cache')
-rw-r--r-- | tests/cache/tests.py | 13 |
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. |