summaryrefslogtreecommitdiff
path: root/tests/cache
diff options
context:
space:
mode:
authorEmre Yilmaz <emre.yilmaz@markafoni.com>2015-12-02 12:34:31 +0200
committerTim Graham <timograham@gmail.com>2015-12-04 12:22:17 -0500
commit8e838d9c869083597dc9e161ae2fe37acaa90de9 (patch)
tree51143d2305901aa59d5b957655665dffdef9ef50 /tests/cache
parent25f5b5c19dc23c6c09877c9c652a934e9669573d (diff)
Fixed #25840 -- Fixed BaseCache.get_or_set() on the DummyCache backend.
This also fixes a possible data eviction race condition between setting and getting a key. Another thread could remove the key before get_and_set() accesses it again. In this case, now the default value will be returned instead of None.
Diffstat (limited to 'tests/cache')
-rw-r--r--tests/cache/tests.py9
1 files changed, 9 insertions, 0 deletions
diff --git a/tests/cache/tests.py b/tests/cache/tests.py
index ba3745847b..cd61690d34 100644
--- a/tests/cache/tests.py
+++ b/tests/cache/tests.py
@@ -202,6 +202,15 @@ class DummyCacheTests(SimpleTestCase):
self.assertRaises(ValueError, cache.decr_version, 'answer')
self.assertRaises(ValueError, cache.decr_version, 'does_not_exist')
+ def test_get_or_set(self):
+ self.assertEqual(cache.get_or_set('mykey', 'default'), 'default')
+
+ def test_get_or_set_callable(self):
+ def my_callable():
+ return 'default'
+
+ self.assertEqual(cache.get_or_set('mykey', my_callable), 'default')
+
def custom_key_func(key, key_prefix, version):
"A customized cache key function"