tests use cache versioning to keep isolation

This commit is contained in:
mdoglio 2013-03-28 00:40:42 +00:00
Родитель 5c5fa524b1
Коммит 9fd2f64542
2 изменённых файлов: 21 добавлений и 3 удалений

Просмотреть файл

@ -30,6 +30,9 @@ Set DJANGO_SETTINGS_MODULE and sets up a test database.
settings.DATABASES["default"]["TEST_NAME"] = "{0}test_treeherder".format(prefix) settings.DATABASES["default"]["TEST_NAME"] = "{0}test_treeherder".format(prefix)
# this sets up a clean test-only database # this sets up a clean test-only database
session.django_db_config = session.django_runner.setup_databases() session.django_db_config = session.django_runner.setup_databases()
increment_cache_key_prefix()
# init the datasource db # init the datasource db
call_command("init_master_db", interactive=False) call_command("init_master_db", interactive=False)
cache.clear() cache.clear()
@ -60,6 +63,8 @@ providing test isolation.
transaction.managed(True) transaction.managed(True)
disable_transaction_methods() disable_transaction_methods()
increment_cache_key_prefix()
def pytest_runtest_teardown(item): def pytest_runtest_teardown(item):
""" """
@ -81,3 +86,16 @@ Roll back the Django ORM transaction and delete all the dbs created between test
transaction.rollback() transaction.rollback()
transaction.leave_transaction_management() transaction.leave_transaction_management()
cache.clear() cache.clear()
def increment_cache_key_prefix():
"""Increment a cache prefix to effectively clear the cache."""
from django.core.cache import cache
cache.key_prefix = ""
prefix_counter_cache_key = "treeherder-tests-key-prefix-counter"
try:
key_prefix_counter = cache.incr(prefix_counter_cache_key)
except ValueError:
key_prefix_counter = 0
cache.set(prefix_counter_cache_key, key_prefix_counter)
cache.key_prefix = "t{0}".format(key_prefix_counter)

Просмотреть файл

@ -47,6 +47,6 @@ def test_datasource_db_created(jobs_ds, db_conn):
def test_memcached_setup(): def test_memcached_setup():
"Test memcached is properly setup" "Test memcached is properly setup"
cache.set('my_key', 'my_value') k, v = 'my_key', 'my_value'
cache.get('my_key', 'alternative') cache.set(k, v)
assert cache.get('my_key') == 'my_value' assert cache.get(k) == v