diff options
| author | Tim Graham <timograham@gmail.com> | 2013-09-03 11:51:34 -0400 |
|---|---|---|
| committer | Tim Graham <timograham@gmail.com> | 2013-09-03 11:51:34 -0400 |
| commit | 3db66b1d65c12a94476017cbcc86e72fd842d29e (patch) | |
| tree | ef333f7ca61a877e129bfd040a510045972d8b3b /tests/migrate_signals | |
| parent | 8f7f8bf6884ada8622bc3696c7465c904164d314 (diff) | |
Updated syncdb -> migrate in tests.
Diffstat (limited to 'tests/migrate_signals')
| -rw-r--r-- | tests/migrate_signals/__init__.py | 0 | ||||
| -rw-r--r-- | tests/migrate_signals/models.py | 0 | ||||
| -rw-r--r-- | tests/migrate_signals/tests.py | 79 |
3 files changed, 79 insertions, 0 deletions
diff --git a/tests/migrate_signals/__init__.py b/tests/migrate_signals/__init__.py new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/tests/migrate_signals/__init__.py diff --git a/tests/migrate_signals/models.py b/tests/migrate_signals/models.py new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/tests/migrate_signals/models.py diff --git a/tests/migrate_signals/tests.py b/tests/migrate_signals/tests.py new file mode 100644 index 0000000000..9daa7ae376 --- /dev/null +++ b/tests/migrate_signals/tests.py @@ -0,0 +1,79 @@ +from django.db.models import signals +from django.test import TestCase +from django.core import management +from django.utils import six + +from . import models + + +PRE_MIGRATE_ARGS = ['app', 'create_models', 'verbosity', 'interactive', 'db'] +MIGRATE_DATABASE = 'default' +MIGRATE_VERBOSITY = 1 +MIGRATE_INTERACTIVE = False + + +class PreMigrateReceiver(object): + def __init__(self): + self.call_counter = 0 + self.call_args = None + + def __call__(self, signal, sender, **kwargs): + self.call_counter = self.call_counter + 1 + self.call_args = kwargs + + +class OneTimeReceiver(object): + """ + Special receiver for handle the fact that test runner calls migrate for + several databases and several times for some of them. + """ + + def __init__(self): + self.call_counter = 0 + self.call_args = None + + def __call__(self, signal, sender, **kwargs): + # Although test runner calls migrate for several databases, + # testing for only one of them is quite sufficient. + if kwargs['db'] == MIGRATE_DATABASE: + self.call_counter = self.call_counter + 1 + self.call_args = kwargs + # we need to test only one call of migrate + signals.pre_migrate.disconnect(pre_migrate_receiver, sender=models) + + +# We connect receiver here and not in unit test code because we need to +# connect receiver before test runner creates database. That is, sequence of +# actions would be: +# +# 1. Test runner imports this module. +# 2. We connect receiver. +# 3. Test runner calls migrate for create default database. +# 4. Test runner execute our unit test code. +pre_migrate_receiver = OneTimeReceiver() +signals.pre_migrate.connect(pre_migrate_receiver, sender=models) + + +class MigrateSignalTests(TestCase): + + available_apps = [ + 'migrate_signals', + ] + + def test_pre_migrate_call_time(self): + self.assertEqual(pre_migrate_receiver.call_counter, 1) + + def test_pre_migrate_args(self): + r = PreMigrateReceiver() + signals.pre_migrate.connect(r, sender=models) + management.call_command('migrate', database=MIGRATE_DATABASE, + verbosity=MIGRATE_VERBOSITY, interactive=MIGRATE_INTERACTIVE, + load_initial_data=False, stdout=six.StringIO()) + + args = r.call_args + self.assertEqual(r.call_counter, 1) + self.assertEqual(set(args), set(PRE_MIGRATE_ARGS)) + self.assertEqual(args['app'], models) + self.assertEqual(args['verbosity'], MIGRATE_VERBOSITY) + self.assertEqual(args['interactive'], MIGRATE_INTERACTIVE) + self.assertEqual(args['db'], 'default') |
