django-cachalot/cachalot/tests/signals.py

115 lines
4 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# coding: utf-8
from __future__ import unicode_literals
from unittest import skipIf
from django.conf import settings
from django.contrib.auth.models import User
from django.db import DEFAULT_DB_ALIAS, transaction
from django.test import TransactionTestCase
from ..api import invalidate
from ..signals import post_invalidation
from .models import Test
class SignalsTestCase(TransactionTestCase):
def test_table_invalidated(self):
l = []
def receiver(sender, **kwargs):
db_alias = kwargs['db_alias']
l.append((sender, db_alias))
post_invalidation.connect(receiver)
self.assertListEqual(l, [])
list(Test.objects.all())
self.assertListEqual(l, [])
Test.objects.create(name='test1')
self.assertListEqual(l, [('cachalot_test', DEFAULT_DB_ALIAS)])
post_invalidation.disconnect(receiver)
del l[:] # Empties the list
post_invalidation.connect(receiver, sender=User._meta.db_table)
Test.objects.create(name='test2')
self.assertListEqual(l, [])
User.objects.create_user('user')
self.assertListEqual(l, [('auth_user', DEFAULT_DB_ALIAS)])
post_invalidation.disconnect(receiver, sender=User._meta.db_table)
def test_table_invalidated_in_transaction(self):
"""
Checks that the ``post_invalidation`` signal is triggered only after
the end of a transaction.
"""
l = []
def receiver(sender, **kwargs):
db_alias = kwargs['db_alias']
l.append((sender, db_alias))
post_invalidation.connect(receiver)
self.assertListEqual(l, [])
with transaction.atomic():
Test.objects.create(name='test1')
self.assertListEqual(l, [])
self.assertListEqual(l, [('cachalot_test', DEFAULT_DB_ALIAS)])
del l[:] # Empties the list
self.assertListEqual(l, [])
with transaction.atomic():
Test.objects.create(name='test2')
with transaction.atomic():
Test.objects.create(name='test3')
self.assertListEqual(l, [])
self.assertListEqual(l, [])
self.assertListEqual(l, [('cachalot_test', DEFAULT_DB_ALIAS)])
post_invalidation.disconnect(receiver)
def test_table_invalidated_once_per_transaction_or_invalidate(self):
"""
Checks that the ``post_invalidation`` signal is triggered only after
the end of a transaction.
"""
l = []
def receiver(sender, **kwargs):
db_alias = kwargs['db_alias']
l.append((sender, db_alias))
post_invalidation.connect(receiver)
self.assertListEqual(l, [])
with transaction.atomic():
Test.objects.create(name='test1')
self.assertListEqual(l, [])
Test.objects.create(name='test2')
self.assertListEqual(l, [])
self.assertListEqual(l, [('cachalot_test', DEFAULT_DB_ALIAS)])
del l[:] # Empties the list
self.assertListEqual(l, [])
invalidate(Test, db_alias=DEFAULT_DB_ALIAS)
self.assertListEqual(l, [('cachalot_test', DEFAULT_DB_ALIAS)])
post_invalidation.disconnect(receiver)
@skipIf(len(settings.DATABASES) == 1,
'We cant change the DB used since theres only one configured')
def test_table_invalidated_multi_db(self):
db_alias2 = next(alias for alias in settings.DATABASES
if alias != DEFAULT_DB_ALIAS)
l = []
def receiver(sender, **kwargs):
db_alias = kwargs['db_alias']
l.append((sender, db_alias))
post_invalidation.connect(receiver)
self.assertListEqual(l, [])
Test.objects.using(DEFAULT_DB_ALIAS).create(name='test')
self.assertListEqual(l, [('cachalot_test', DEFAULT_DB_ALIAS)])
Test.objects.using(db_alias2).create(name='test')
self.assertListEqual(l, [
('cachalot_test', DEFAULT_DB_ALIAS),
('cachalot_test', db_alias2)])
post_invalidation.disconnect(receiver)