summaryrefslogtreecommitdiff
path: root/tests/migrate_signals
diff options
context:
space:
mode:
authorTim Graham <timograham@gmail.com>2013-09-03 11:51:34 -0400
committerTim Graham <timograham@gmail.com>2013-09-03 11:51:34 -0400
commit3db66b1d65c12a94476017cbcc86e72fd842d29e (patch)
treeef333f7ca61a877e129bfd040a510045972d8b3b /tests/migrate_signals
parent8f7f8bf6884ada8622bc3696c7465c904164d314 (diff)
Updated syncdb -> migrate in tests.
Diffstat (limited to 'tests/migrate_signals')
-rw-r--r--tests/migrate_signals/__init__.py0
-rw-r--r--tests/migrate_signals/models.py0
-rw-r--r--tests/migrate_signals/tests.py79
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')