Fixed #27124 -- Excluded cull-related cache configs from memcached tests.

Since the `cull` and `zero_cull` test cache configs set `MAX_ENTRIES`
and `CULL_FREQUENCY` in `OPTIONS`, which are only intended for use with
the locmem, filesystem, and database backends. This prevents test
failures once refs #20892 is fixed.
This commit is contained in:
Ed Morley 2016-08-26 19:29:22 +01:00 committed by Tim Graham
parent 42dcceba61
commit 606a303856
1 changed files with 21 additions and 10 deletions

31
tests/cache/tests.py vendored
View File

@ -239,14 +239,17 @@ _caches_setting_base = {
} }
def caches_setting_for_tests(base=None, **params): def caches_setting_for_tests(base=None, exclude=None, **params):
# `base` is used to pull in the memcached config from the original settings, # `base` is used to pull in the memcached config from the original settings,
# `exclude` is a set of cache names denoting which `_caches_setting_base` keys
# should be omitted.
# `params` are test specific overrides and `_caches_settings_base` is the # `params` are test specific overrides and `_caches_settings_base` is the
# base config for the tests. # base config for the tests.
# This results in the following search order: # This results in the following search order:
# params -> _caches_setting_base -> base # params -> _caches_setting_base -> base
base = base or {} base = base or {}
setting = {k: base.copy() for k in _caches_setting_base.keys()} exclude = exclude or set()
setting = {k: base.copy() for k in _caches_setting_base.keys() if k not in exclude}
for key, cache_params in setting.items(): for key, cache_params in setting.items():
cache_params.update(_caches_setting_base[key]) cache_params.update(_caches_setting_base[key])
cache_params.update(params) cache_params.update(params)
@ -1148,15 +1151,15 @@ for _cache_params in settings.CACHES.values():
if _cache_params['BACKEND'].startswith('django.core.cache.backends.memcached.'): if _cache_params['BACKEND'].startswith('django.core.cache.backends.memcached.'):
memcached_params = _cache_params memcached_params = _cache_params
memcached_never_expiring_params = memcached_params.copy() # The memcached backends don't support cull-related options like `MAX_ENTRIES`.
memcached_never_expiring_params['TIMEOUT'] = None memcached_excluded_caches = {'cull', 'zero_cull'}
memcached_far_future_params = memcached_params.copy()
memcached_far_future_params['TIMEOUT'] = 31536000 # 60*60*24*365, 1 year
@unittest.skipUnless(memcached_params, "memcached not available") @unittest.skipUnless(memcached_params, "memcached not available")
@override_settings(CACHES=caches_setting_for_tests(base=memcached_params)) @override_settings(CACHES=caches_setting_for_tests(
base=memcached_params,
exclude=memcached_excluded_caches,
))
class MemcachedCacheTests(BaseCacheTests, TestCase): class MemcachedCacheTests(BaseCacheTests, TestCase):
def test_invalid_keys(self): def test_invalid_keys(self):
@ -1186,13 +1189,21 @@ class MemcachedCacheTests(BaseCacheTests, TestCase):
self.assertEqual(caches[cache_key]._cache.pickleProtocol, self.assertEqual(caches[cache_key]._cache.pickleProtocol,
pickle.HIGHEST_PROTOCOL) pickle.HIGHEST_PROTOCOL)
@override_settings(CACHES=caches_setting_for_tests(base=memcached_never_expiring_params)) @override_settings(CACHES=caches_setting_for_tests(
base=memcached_params,
exclude=memcached_excluded_caches,
TIMEOUT=None,
))
def test_default_never_expiring_timeout(self): def test_default_never_expiring_timeout(self):
# Regression test for #22845 # Regression test for #22845
cache.set('infinite_foo', 'bar') cache.set('infinite_foo', 'bar')
self.assertEqual(cache.get('infinite_foo'), 'bar') self.assertEqual(cache.get('infinite_foo'), 'bar')
@override_settings(CACHES=caches_setting_for_tests(base=memcached_far_future_params)) @override_settings(CACHES=caches_setting_for_tests(
base=memcached_params,
exclude=memcached_excluded_caches,
TIMEOUT=31536000, # 60*60*24*365, 1 year
))
def test_default_far_future_timeout(self): def test_default_far_future_timeout(self):
# Regression test for #22845 # Regression test for #22845
cache.set('future_foo', 'bar') cache.set('future_foo', 'bar')