mirror of
https://github.com/django/django.git
synced 2025-09-27 12:39:17 +00:00
Fixed #12057 -- Corrected regression of caching performance when a model contained a callable default. Thanks to Michael Thornhill for the excellent assistance tracking this problem.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@11681 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
c5c7791e91
commit
96658ef2d2
4 changed files with 64 additions and 3 deletions
42
tests/regressiontests/cache/tests.py
vendored
42
tests/regressiontests/cache/tests.py
vendored
|
@ -16,6 +16,7 @@ from django.core.cache.backends.base import InvalidCacheBackendError
|
|||
from django.http import HttpResponse, HttpRequest
|
||||
from django.utils.cache import patch_vary_headers, get_cache_key, learn_cache_key
|
||||
from django.utils.hashcompat import md5_constructor
|
||||
from regressiontests.cache.models import Poll, expensive_calculation
|
||||
|
||||
# functions/classes for complex data type tests
|
||||
def f():
|
||||
|
@ -211,6 +212,47 @@ class BaseCacheTests(object):
|
|||
self.cache.set("stuff", stuff)
|
||||
self.assertEqual(self.cache.get("stuff"), stuff)
|
||||
|
||||
def test_cache_read_for_model_instance(self):
|
||||
# Don't want fields with callable as default to be called on cache read
|
||||
expensive_calculation.num_runs = 0
|
||||
Poll.objects.all().delete()
|
||||
my_poll = Poll.objects.create(question="Well?")
|
||||
self.assertEqual(Poll.objects.count(), 1)
|
||||
pub_date = my_poll.pub_date
|
||||
self.cache.set('question', my_poll)
|
||||
cached_poll = self.cache.get('question')
|
||||
self.assertEqual(cached_poll.pub_date, pub_date)
|
||||
# We only want the default expensive calculation run once
|
||||
self.assertEqual(expensive_calculation.num_runs, 1)
|
||||
|
||||
def test_cache_write_for_model_instance_with_deferred(self):
|
||||
# Don't want fields with callable as default to be called on cache write
|
||||
expensive_calculation.num_runs = 0
|
||||
Poll.objects.all().delete()
|
||||
my_poll = Poll.objects.create(question="What?")
|
||||
self.assertEqual(expensive_calculation.num_runs, 1)
|
||||
defer_qs = Poll.objects.all().defer('question')
|
||||
self.assertEqual(defer_qs.count(), 1)
|
||||
self.assertEqual(expensive_calculation.num_runs, 1)
|
||||
self.cache.set('deferred_queryset', defer_qs)
|
||||
# cache set should not re-evaluate default functions
|
||||
self.assertEqual(expensive_calculation.num_runs, 1)
|
||||
|
||||
def test_cache_read_for_model_instance_with_deferred(self):
|
||||
# Don't want fields with callable as default to be called on cache read
|
||||
expensive_calculation.num_runs = 0
|
||||
Poll.objects.all().delete()
|
||||
my_poll = Poll.objects.create(question="What?")
|
||||
self.assertEqual(expensive_calculation.num_runs, 1)
|
||||
defer_qs = Poll.objects.all().defer('question')
|
||||
self.assertEqual(defer_qs.count(), 1)
|
||||
self.cache.set('deferred_queryset', defer_qs)
|
||||
self.assertEqual(expensive_calculation.num_runs, 1)
|
||||
runs_before_cache_read = expensive_calculation.num_runs
|
||||
cached_polls = self.cache.get('deferred_queryset')
|
||||
# We only want the default expensive calculation run on creation and set
|
||||
self.assertEqual(expensive_calculation.num_runs, runs_before_cache_read)
|
||||
|
||||
def test_expiration(self):
|
||||
# Cache values can be set to expire
|
||||
self.cache.set('expire1', 'very quickly', 1)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue