Replaced router.routers usage with override_settings(DATABASE_ROUTERS); refs #23933.
This commit is contained in:
parent
e6f19ec322
commit
9136ceb6fb
|
@ -8,9 +8,9 @@ import unittest
|
||||||
from unittest import skipUnless
|
from unittest import skipUnless
|
||||||
|
|
||||||
from django.contrib.gis.gdal import HAS_GDAL
|
from django.contrib.gis.gdal import HAS_GDAL
|
||||||
from django.db import connection, router
|
from django.db import connection
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.test import TestCase, skipUnlessDBFeature
|
from django.test import TestCase, override_settings, skipUnlessDBFeature
|
||||||
from django.utils._os import upath
|
from django.utils._os import upath
|
||||||
|
|
||||||
if HAS_GDAL:
|
if HAS_GDAL:
|
||||||
|
@ -328,15 +328,9 @@ class OtherRouter(object):
|
||||||
|
|
||||||
@skipUnless(HAS_GDAL, "LayerMapRouterTest needs GDAL support")
|
@skipUnless(HAS_GDAL, "LayerMapRouterTest needs GDAL support")
|
||||||
@skipUnlessDBFeature("gis_enabled")
|
@skipUnlessDBFeature("gis_enabled")
|
||||||
|
@override_settings(DATABASE_ROUTERS=[OtherRouter()])
|
||||||
class LayerMapRouterTest(TestCase):
|
class LayerMapRouterTest(TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
self.old_routers = router.routers
|
|
||||||
router.routers = [OtherRouter()]
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
router.routers = self.old_routers
|
|
||||||
|
|
||||||
@unittest.skipUnless(len(settings.DATABASES) > 1, 'multiple databases required')
|
@unittest.skipUnless(len(settings.DATABASES) > 1, 'multiple databases required')
|
||||||
def test_layermapping_default_db(self):
|
def test_layermapping_default_db(self):
|
||||||
lm = LayerMapping(City, city_shp, city_mapping)
|
lm = LayerMapping(City, city_shp, city_mapping)
|
||||||
|
|
|
@ -19,7 +19,7 @@ from django.core import management
|
||||||
from django.core.cache import (cache, caches, CacheKeyWarning,
|
from django.core.cache import (cache, caches, CacheKeyWarning,
|
||||||
InvalidCacheBackendError, DEFAULT_CACHE_ALIAS)
|
InvalidCacheBackendError, DEFAULT_CACHE_ALIAS)
|
||||||
from django.core.context_processors import csrf
|
from django.core.context_processors import csrf
|
||||||
from django.db import connection, connections, router, transaction
|
from django.db import connection, connections, transaction
|
||||||
from django.core.cache.utils import make_template_fragment_key
|
from django.core.cache.utils import make_template_fragment_key
|
||||||
from django.http import HttpResponse, StreamingHttpResponse
|
from django.http import HttpResponse, StreamingHttpResponse
|
||||||
from django.middleware.cache import (FetchFromCacheMiddleware,
|
from django.middleware.cache import (FetchFromCacheMiddleware,
|
||||||
|
@ -974,29 +974,25 @@ class DBCacheRouter(object):
|
||||||
class CreateCacheTableForDBCacheTests(TestCase):
|
class CreateCacheTableForDBCacheTests(TestCase):
|
||||||
multi_db = True
|
multi_db = True
|
||||||
|
|
||||||
|
@override_settings(DATABASE_ROUTERS=[DBCacheRouter()])
|
||||||
def test_createcachetable_observes_database_router(self):
|
def test_createcachetable_observes_database_router(self):
|
||||||
old_routers = router.routers
|
# cache table should not be created on 'default'
|
||||||
try:
|
with self.assertNumQueries(0, using='default'):
|
||||||
router.routers = [DBCacheRouter()]
|
management.call_command('createcachetable',
|
||||||
# cache table should not be created on 'default'
|
database='default',
|
||||||
with self.assertNumQueries(0, using='default'):
|
verbosity=0, interactive=False)
|
||||||
management.call_command('createcachetable',
|
# cache table should be created on 'other'
|
||||||
database='default',
|
# Queries:
|
||||||
verbosity=0, interactive=False)
|
# 1: check table doesn't already exist
|
||||||
# cache table should be created on 'other'
|
# 2: create savepoint (if transactional DDL is supported)
|
||||||
# Queries:
|
# 3: create the table
|
||||||
# 1: check table doesn't already exist
|
# 4: create the index
|
||||||
# 2: create savepoint (if transactional DDL is supported)
|
# 5: release savepoint (if transactional DDL is supported)
|
||||||
# 3: create the table
|
num = 5 if connections['other'].features.can_rollback_ddl else 3
|
||||||
# 4: create the index
|
with self.assertNumQueries(num, using='other'):
|
||||||
# 5: release savepoint (if transactional DDL is supported)
|
management.call_command('createcachetable',
|
||||||
num = 5 if connections['other'].features.can_rollback_ddl else 3
|
database='other',
|
||||||
with self.assertNumQueries(num, using='other'):
|
verbosity=0, interactive=False)
|
||||||
management.call_command('createcachetable',
|
|
||||||
database='other',
|
|
||||||
verbosity=0, interactive=False)
|
|
||||||
finally:
|
|
||||||
router.routers = old_routers
|
|
||||||
|
|
||||||
|
|
||||||
class PicklingSideEffect(object):
|
class PicklingSideEffect(object):
|
||||||
|
|
|
@ -7,8 +7,8 @@ from django.apps import apps
|
||||||
from django.core.management.color import no_style
|
from django.core.management.color import no_style
|
||||||
from django.core.management.sql import (sql_create, sql_delete, sql_indexes,
|
from django.core.management.sql import (sql_create, sql_delete, sql_indexes,
|
||||||
sql_destroy_indexes, sql_all)
|
sql_destroy_indexes, sql_all)
|
||||||
from django.db import connections, DEFAULT_DB_ALIAS, router
|
from django.db import connections, DEFAULT_DB_ALIAS
|
||||||
from django.test import TestCase
|
from django.test import TestCase, override_settings
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
|
||||||
# See also initial_sql_regress for 'custom_sql_for_model' tests
|
# See also initial_sql_regress for 'custom_sql_for_model' tests
|
||||||
|
@ -91,13 +91,8 @@ class TestRouter(object):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
@override_settings(DATABASE_ROUTERS=[TestRouter()])
|
||||||
class SQLCommandsRouterTestCase(TestCase):
|
class SQLCommandsRouterTestCase(TestCase):
|
||||||
def setUp(self):
|
|
||||||
self._old_routers = router.routers
|
|
||||||
router.routers = [TestRouter()]
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
router.routers = self._old_routers
|
|
||||||
|
|
||||||
def test_router_honored(self):
|
def test_router_honored(self):
|
||||||
app_config = apps.get_app_config('commands_sql')
|
app_config = apps.get_app_config('commands_sql')
|
||||||
|
|
|
@ -8,9 +8,9 @@ from django.contrib.contenttypes.fields import (
|
||||||
from django.contrib.contenttypes import management
|
from django.contrib.contenttypes import management
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.core import checks
|
from django.core import checks
|
||||||
from django.db import connections, models, router
|
from django.db import connections, models
|
||||||
from django.test import TestCase
|
from django.test import TestCase, override_settings
|
||||||
from django.test.utils import captured_stdout, override_settings
|
from django.test.utils import captured_stdout
|
||||||
from django.utils.encoding import force_str
|
from django.utils.encoding import force_str
|
||||||
|
|
||||||
from .models import Author, Article, SchemeIncludedURL
|
from .models import Author, Article, SchemeIncludedURL
|
||||||
|
@ -397,12 +397,10 @@ class TestRouter(object):
|
||||||
return 'default'
|
return 'default'
|
||||||
|
|
||||||
|
|
||||||
|
@override_settings(DATABASE_ROUTERS=[TestRouter()])
|
||||||
class ContentTypesMultidbTestCase(TestCase):
|
class ContentTypesMultidbTestCase(TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
self.old_routers = router.routers
|
|
||||||
router.routers = [TestRouter()]
|
|
||||||
|
|
||||||
# Whenever a test starts executing, only the "default" database is
|
# Whenever a test starts executing, only the "default" database is
|
||||||
# connected. We explicitly connect to the "other" database here. If we
|
# connected. We explicitly connect to the "other" database here. If we
|
||||||
# don't do it, then it will be implicitly connected later when we query
|
# don't do it, then it will be implicitly connected later when we query
|
||||||
|
@ -411,9 +409,6 @@ class ContentTypesMultidbTestCase(TestCase):
|
||||||
# "SET SQL_AUTO_IS_NULL = 0"), which will affect assertNumQueries().
|
# "SET SQL_AUTO_IS_NULL = 0"), which will affect assertNumQueries().
|
||||||
connections['other'].ensure_connection()
|
connections['other'].ensure_connection()
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
router.routers = self.old_routers
|
|
||||||
|
|
||||||
def test_multidb(self):
|
def test_multidb(self):
|
||||||
"""
|
"""
|
||||||
Test that, when using multiple databases, we use the db_for_read (see
|
Test that, when using multiple databases, we use the db_for_read (see
|
||||||
|
|
|
@ -8,13 +8,13 @@ except ImportError:
|
||||||
sqlparse = None
|
sqlparse = None
|
||||||
|
|
||||||
from django import test
|
from django import test
|
||||||
from django.test import override_settings
|
from django.db import connection, migrations, models
|
||||||
from django.db import connection, migrations, models, router
|
|
||||||
from django.db.migrations.migration import Migration
|
from django.db.migrations.migration import Migration
|
||||||
from django.db.migrations.state import ProjectState
|
from django.db.migrations.state import ProjectState
|
||||||
from django.db.models.fields import NOT_PROVIDED
|
from django.db.models.fields import NOT_PROVIDED
|
||||||
from django.db.transaction import atomic
|
from django.db.transaction import atomic
|
||||||
from django.db.utils import IntegrityError, DatabaseError
|
from django.db.utils import IntegrityError, DatabaseError
|
||||||
|
from django.test import override_settings
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
|
||||||
from .test_base import MigrationTestBase
|
from .test_base import MigrationTestBase
|
||||||
|
@ -1566,18 +1566,10 @@ class MigrateNothingRouter(object):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
@override_settings(DATABASE_ROUTERS=[MigrateNothingRouter()])
|
||||||
class MultiDBOperationTests(MigrationTestBase):
|
class MultiDBOperationTests(MigrationTestBase):
|
||||||
multi_db = True
|
multi_db = True
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
# Make the 'other' database appear to be a replica of the 'default'
|
|
||||||
self.old_routers = router.routers
|
|
||||||
router.routers = [MigrateNothingRouter()]
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
# Restore the 'other' database as an independent database
|
|
||||||
router.routers = self.old_routers
|
|
||||||
|
|
||||||
def test_create_model(self):
|
def test_create_model(self):
|
||||||
"""
|
"""
|
||||||
Tests that CreateModel honours multi-db settings.
|
Tests that CreateModel honours multi-db settings.
|
||||||
|
|
|
@ -883,18 +883,11 @@ class ConnectionRouterTestCase(TestCase):
|
||||||
['TestRouter', 'WriteRouter'])
|
['TestRouter', 'WriteRouter'])
|
||||||
|
|
||||||
|
|
||||||
|
# Make the 'other' database appear to be a replica of the 'default'
|
||||||
|
@override_settings(DATABASE_ROUTERS=[TestRouter()])
|
||||||
class RouterTestCase(TestCase):
|
class RouterTestCase(TestCase):
|
||||||
multi_db = True
|
multi_db = True
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
# Make the 'other' database appear to be a replica of the 'default'
|
|
||||||
self.old_routers = router.routers
|
|
||||||
router.routers = [TestRouter()]
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
# Restore the 'other' database as an independent database
|
|
||||||
router.routers = self.old_routers
|
|
||||||
|
|
||||||
def test_db_selection(self):
|
def test_db_selection(self):
|
||||||
"Check that querysets obey the router for db suggestions"
|
"Check that querysets obey the router for db suggestions"
|
||||||
self.assertEqual(Book.objects.db, 'other')
|
self.assertEqual(Book.objects.db, 'other')
|
||||||
|
@ -914,24 +907,22 @@ class RouterTestCase(TestCase):
|
||||||
self.assertTrue(router.allow_migrate('other', User))
|
self.assertTrue(router.allow_migrate('other', User))
|
||||||
self.assertTrue(router.allow_migrate('other', Book))
|
self.assertTrue(router.allow_migrate('other', Book))
|
||||||
|
|
||||||
# Add the auth router to the chain.
|
with override_settings(DATABASE_ROUTERS=[TestRouter(), AuthRouter()]):
|
||||||
# TestRouter is a universal synchronizer, so it should have no effect.
|
# Add the auth router to the chain. TestRouter is a universal
|
||||||
router.routers = [TestRouter(), AuthRouter()]
|
# synchronizer, so it should have no effect.
|
||||||
|
self.assertTrue(router.allow_migrate('default', User))
|
||||||
|
self.assertTrue(router.allow_migrate('default', Book))
|
||||||
|
|
||||||
self.assertTrue(router.allow_migrate('default', User))
|
self.assertTrue(router.allow_migrate('other', User))
|
||||||
self.assertTrue(router.allow_migrate('default', Book))
|
self.assertTrue(router.allow_migrate('other', Book))
|
||||||
|
|
||||||
self.assertTrue(router.allow_migrate('other', User))
|
with override_settings(DATABASE_ROUTERS=[AuthRouter(), TestRouter()]):
|
||||||
self.assertTrue(router.allow_migrate('other', Book))
|
# Now check what happens if the router order is reversed.
|
||||||
|
self.assertFalse(router.allow_migrate('default', User))
|
||||||
|
self.assertTrue(router.allow_migrate('default', Book))
|
||||||
|
|
||||||
# Now check what happens if the router order is the other way around
|
self.assertTrue(router.allow_migrate('other', User))
|
||||||
router.routers = [AuthRouter(), TestRouter()]
|
self.assertFalse(router.allow_migrate('other', Book))
|
||||||
|
|
||||||
self.assertFalse(router.allow_migrate('default', User))
|
|
||||||
self.assertTrue(router.allow_migrate('default', Book))
|
|
||||||
|
|
||||||
self.assertTrue(router.allow_migrate('other', User))
|
|
||||||
self.assertFalse(router.allow_migrate('other', Book))
|
|
||||||
|
|
||||||
def test_partial_router(self):
|
def test_partial_router(self):
|
||||||
"A router can choose to implement a subset of methods"
|
"A router can choose to implement a subset of methods"
|
||||||
|
@ -951,18 +942,17 @@ class RouterTestCase(TestCase):
|
||||||
self.assertTrue(router.allow_migrate('default', User))
|
self.assertTrue(router.allow_migrate('default', User))
|
||||||
self.assertTrue(router.allow_migrate('default', Book))
|
self.assertTrue(router.allow_migrate('default', Book))
|
||||||
|
|
||||||
router.routers = [WriteRouter(), AuthRouter(), TestRouter()]
|
with override_settings(DATABASE_ROUTERS=[WriteRouter(), AuthRouter(), TestRouter()]):
|
||||||
|
self.assertEqual(router.db_for_read(User), 'default')
|
||||||
|
self.assertEqual(router.db_for_read(Book), 'other')
|
||||||
|
|
||||||
self.assertEqual(router.db_for_read(User), 'default')
|
self.assertEqual(router.db_for_write(User), 'writer')
|
||||||
self.assertEqual(router.db_for_read(Book), 'other')
|
self.assertEqual(router.db_for_write(Book), 'writer')
|
||||||
|
|
||||||
self.assertEqual(router.db_for_write(User), 'writer')
|
self.assertTrue(router.allow_relation(dive, dive))
|
||||||
self.assertEqual(router.db_for_write(Book), 'writer')
|
|
||||||
|
|
||||||
self.assertTrue(router.allow_relation(dive, dive))
|
self.assertFalse(router.allow_migrate('default', User))
|
||||||
|
self.assertTrue(router.allow_migrate('default', Book))
|
||||||
self.assertFalse(router.allow_migrate('default', User))
|
|
||||||
self.assertTrue(router.allow_migrate('default', Book))
|
|
||||||
|
|
||||||
def test_database_routing(self):
|
def test_database_routing(self):
|
||||||
marty = Person.objects.using('default').create(name="Marty Alchin")
|
marty = Person.objects.using('default').create(name="Marty Alchin")
|
||||||
|
@ -1447,18 +1437,10 @@ class RouterTestCase(TestCase):
|
||||||
datetime.date(2009, 5, 4))
|
datetime.date(2009, 5, 4))
|
||||||
|
|
||||||
|
|
||||||
|
@override_settings(DATABASE_ROUTERS=[AuthRouter()])
|
||||||
class AuthTestCase(TestCase):
|
class AuthTestCase(TestCase):
|
||||||
multi_db = True
|
multi_db = True
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
# Make the 'other' database appear to be a replica of the 'default'
|
|
||||||
self.old_routers = router.routers
|
|
||||||
router.routers = [AuthRouter()]
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
# Restore the 'other' database as an independent database
|
|
||||||
router.routers = self.old_routers
|
|
||||||
|
|
||||||
def test_auth_manager(self):
|
def test_auth_manager(self):
|
||||||
"The methods on the auth manager obey database hints"
|
"The methods on the auth manager obey database hints"
|
||||||
# Create one user using default allocation policy
|
# Create one user using default allocation policy
|
||||||
|
@ -1522,15 +1504,7 @@ class FixtureTestCase(TestCase):
|
||||||
multi_db = True
|
multi_db = True
|
||||||
fixtures = ['multidb-common', 'multidb']
|
fixtures = ['multidb-common', 'multidb']
|
||||||
|
|
||||||
def setUp(self):
|
@override_settings(DATABASE_ROUTERS=[AntiPetRouter()])
|
||||||
# Install the anti-pet router
|
|
||||||
self.old_routers = router.routers
|
|
||||||
router.routers = [AntiPetRouter()]
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
# Restore the 'other' database as an independent database
|
|
||||||
router.routers = self.old_routers
|
|
||||||
|
|
||||||
def test_fixture_loading(self):
|
def test_fixture_loading(self):
|
||||||
"Multi-db fixtures are loaded correctly"
|
"Multi-db fixtures are loaded correctly"
|
||||||
# Check that "Pro Django" exists on the default database, but not on other database
|
# Check that "Pro Django" exists on the default database, but not on other database
|
||||||
|
@ -1571,6 +1545,7 @@ class FixtureTestCase(TestCase):
|
||||||
except Book.DoesNotExist:
|
except Book.DoesNotExist:
|
||||||
self.fail('"The Definitive Guide to Django" should exist on both databases')
|
self.fail('"The Definitive Guide to Django" should exist on both databases')
|
||||||
|
|
||||||
|
@override_settings(DATABASE_ROUTERS=[AntiPetRouter()])
|
||||||
def test_pseudo_empty_fixtures(self):
|
def test_pseudo_empty_fixtures(self):
|
||||||
"A fixture can contain entries, but lead to nothing in the database; this shouldn't raise an error (ref #14068)"
|
"A fixture can contain entries, but lead to nothing in the database; this shouldn't raise an error (ref #14068)"
|
||||||
new_io = StringIO()
|
new_io = StringIO()
|
||||||
|
@ -1609,19 +1584,8 @@ class WriteToOtherRouter(object):
|
||||||
class SignalTests(TestCase):
|
class SignalTests(TestCase):
|
||||||
multi_db = True
|
multi_db = True
|
||||||
|
|
||||||
def setUp(self):
|
def override_router(self):
|
||||||
self.old_routers = router.routers
|
return override_settings(DATABASE_ROUTERS=[WriteToOtherRouter()])
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
router.routers = self.old_routers
|
|
||||||
|
|
||||||
def _write_to_other(self):
|
|
||||||
"Sends all writes to 'other'."
|
|
||||||
router.routers = [WriteToOtherRouter()]
|
|
||||||
|
|
||||||
def _write_to_default(self):
|
|
||||||
"Sends all writes to the default DB"
|
|
||||||
router.routers = self.old_routers
|
|
||||||
|
|
||||||
def test_database_arg_save_and_delete(self):
|
def test_database_arg_save_and_delete(self):
|
||||||
"""
|
"""
|
||||||
|
@ -1684,33 +1648,29 @@ class SignalTests(TestCase):
|
||||||
# Test addition
|
# Test addition
|
||||||
b.authors.add(p)
|
b.authors.add(p)
|
||||||
self.assertEqual(receiver._database, DEFAULT_DB_ALIAS)
|
self.assertEqual(receiver._database, DEFAULT_DB_ALIAS)
|
||||||
self._write_to_other()
|
with self.override_router():
|
||||||
b.authors.add(p)
|
b.authors.add(p)
|
||||||
self._write_to_default()
|
|
||||||
self.assertEqual(receiver._database, "other")
|
self.assertEqual(receiver._database, "other")
|
||||||
|
|
||||||
# Test removal
|
# Test removal
|
||||||
b.authors.remove(p)
|
b.authors.remove(p)
|
||||||
self.assertEqual(receiver._database, DEFAULT_DB_ALIAS)
|
self.assertEqual(receiver._database, DEFAULT_DB_ALIAS)
|
||||||
self._write_to_other()
|
with self.override_router():
|
||||||
b.authors.remove(p)
|
b.authors.remove(p)
|
||||||
self._write_to_default()
|
|
||||||
self.assertEqual(receiver._database, "other")
|
self.assertEqual(receiver._database, "other")
|
||||||
|
|
||||||
# Test addition in reverse
|
# Test addition in reverse
|
||||||
p.book_set.add(b)
|
p.book_set.add(b)
|
||||||
self.assertEqual(receiver._database, DEFAULT_DB_ALIAS)
|
self.assertEqual(receiver._database, DEFAULT_DB_ALIAS)
|
||||||
self._write_to_other()
|
with self.override_router():
|
||||||
p.book_set.add(b)
|
p.book_set.add(b)
|
||||||
self._write_to_default()
|
|
||||||
self.assertEqual(receiver._database, "other")
|
self.assertEqual(receiver._database, "other")
|
||||||
|
|
||||||
# Test clearing
|
# Test clearing
|
||||||
b.authors.clear()
|
b.authors.clear()
|
||||||
self.assertEqual(receiver._database, DEFAULT_DB_ALIAS)
|
self.assertEqual(receiver._database, DEFAULT_DB_ALIAS)
|
||||||
self._write_to_other()
|
with self.override_router():
|
||||||
b.authors.clear()
|
b.authors.clear()
|
||||||
self._write_to_default()
|
|
||||||
self.assertEqual(receiver._database, "other")
|
self.assertEqual(receiver._database, "other")
|
||||||
|
|
||||||
|
|
||||||
|
@ -1726,47 +1686,41 @@ class AttributeErrorRouter(object):
|
||||||
class RouterAttributeErrorTestCase(TestCase):
|
class RouterAttributeErrorTestCase(TestCase):
|
||||||
multi_db = True
|
multi_db = True
|
||||||
|
|
||||||
def setUp(self):
|
def override_router(self):
|
||||||
self.old_routers = router.routers
|
return override_settings(DATABASE_ROUTERS=[AttributeErrorRouter()])
|
||||||
router.routers = [AttributeErrorRouter()]
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
router.routers = self.old_routers
|
|
||||||
|
|
||||||
def test_attribute_error_read(self):
|
def test_attribute_error_read(self):
|
||||||
"Check that the AttributeError from AttributeErrorRouter bubbles up"
|
"Check that the AttributeError from AttributeErrorRouter bubbles up"
|
||||||
router.routers = [] # Reset routers so we can save a Book instance
|
|
||||||
b = Book.objects.create(title="Pro Django",
|
b = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
router.routers = [AttributeErrorRouter()] # Install our router
|
with self.override_router():
|
||||||
self.assertRaises(AttributeError, Book.objects.get, pk=b.pk)
|
self.assertRaises(AttributeError, Book.objects.get, pk=b.pk)
|
||||||
|
|
||||||
def test_attribute_error_save(self):
|
def test_attribute_error_save(self):
|
||||||
"Check that the AttributeError from AttributeErrorRouter bubbles up"
|
"Check that the AttributeError from AttributeErrorRouter bubbles up"
|
||||||
dive = Book()
|
dive = Book()
|
||||||
dive.title = "Dive into Python"
|
dive.title = "Dive into Python"
|
||||||
dive.published = datetime.date(2009, 5, 4)
|
dive.published = datetime.date(2009, 5, 4)
|
||||||
self.assertRaises(AttributeError, dive.save)
|
with self.override_router():
|
||||||
|
self.assertRaises(AttributeError, dive.save)
|
||||||
|
|
||||||
def test_attribute_error_delete(self):
|
def test_attribute_error_delete(self):
|
||||||
"Check that the AttributeError from AttributeErrorRouter bubbles up"
|
"Check that the AttributeError from AttributeErrorRouter bubbles up"
|
||||||
router.routers = [] # Reset routers so we can save our Book, Person instances
|
|
||||||
b = Book.objects.create(title="Pro Django",
|
b = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
p = Person.objects.create(name="Marty Alchin")
|
p = Person.objects.create(name="Marty Alchin")
|
||||||
b.authors = [p]
|
b.authors = [p]
|
||||||
b.editor = p
|
b.editor = p
|
||||||
router.routers = [AttributeErrorRouter()] # Install our router
|
with self.override_router():
|
||||||
self.assertRaises(AttributeError, b.delete)
|
self.assertRaises(AttributeError, b.delete)
|
||||||
|
|
||||||
def test_attribute_error_m2m(self):
|
def test_attribute_error_m2m(self):
|
||||||
"Check that the AttributeError from AttributeErrorRouter bubbles up"
|
"Check that the AttributeError from AttributeErrorRouter bubbles up"
|
||||||
router.routers = [] # Reset routers so we can save our Book, Person instances
|
|
||||||
b = Book.objects.create(title="Pro Django",
|
b = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
p = Person.objects.create(name="Marty Alchin")
|
p = Person.objects.create(name="Marty Alchin")
|
||||||
router.routers = [AttributeErrorRouter()] # Install our router
|
with self.override_router():
|
||||||
self.assertRaises(AttributeError, setattr, b, 'authors', [p])
|
self.assertRaises(AttributeError, setattr, b, 'authors', [p])
|
||||||
|
|
||||||
|
|
||||||
class ModelMetaRouter(object):
|
class ModelMetaRouter(object):
|
||||||
|
@ -1776,16 +1730,10 @@ class ModelMetaRouter(object):
|
||||||
raise ValueError
|
raise ValueError
|
||||||
|
|
||||||
|
|
||||||
|
@override_settings(DATABASE_ROUTERS=[ModelMetaRouter()])
|
||||||
class RouterModelArgumentTestCase(TestCase):
|
class RouterModelArgumentTestCase(TestCase):
|
||||||
multi_db = True
|
multi_db = True
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
self.old_routers = router.routers
|
|
||||||
router.routers = [ModelMetaRouter()]
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
router.routers = self.old_routers
|
|
||||||
|
|
||||||
def test_m2m_collection(self):
|
def test_m2m_collection(self):
|
||||||
b = Book.objects.create(title="Pro Django",
|
b = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
|
@ -1840,13 +1788,9 @@ class MigrateTestCase(TestCase):
|
||||||
cts = ContentType.objects.using('other').filter(app_label='multiple_database')
|
cts = ContentType.objects.using('other').filter(app_label='multiple_database')
|
||||||
|
|
||||||
cts.delete()
|
cts.delete()
|
||||||
try:
|
with override_settings(DATABASE_ROUTERS=[SyncOnlyDefaultDatabaseRouter()]):
|
||||||
old_routers = router.routers
|
|
||||||
router.routers = [SyncOnlyDefaultDatabaseRouter()]
|
|
||||||
management.call_command('migrate', verbosity=0, interactive=False,
|
management.call_command('migrate', verbosity=0, interactive=False,
|
||||||
load_initial_data=False, database='other')
|
load_initial_data=False, database='other')
|
||||||
finally:
|
|
||||||
router.routers = old_routers
|
|
||||||
|
|
||||||
self.assertEqual(cts.count(), 0)
|
self.assertEqual(cts.count(), 0)
|
||||||
|
|
||||||
|
@ -1868,21 +1812,15 @@ class RouteForWriteTestCase(TestCase):
|
||||||
def db_for_write(self, model, **hints):
|
def db_for_write(self, model, **hints):
|
||||||
raise RouterUsed(mode=RouterUsed.WRITE, model=model, hints=hints)
|
raise RouterUsed(mode=RouterUsed.WRITE, model=model, hints=hints)
|
||||||
|
|
||||||
def setUp(self):
|
def override_router(self):
|
||||||
self._old_rtrs = router.routers
|
return override_settings(DATABASE_ROUTERS=[RouteForWriteTestCase.WriteCheckRouter()])
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
router.routers = self._old_rtrs
|
|
||||||
|
|
||||||
def enable_router(self):
|
|
||||||
router.routers = [RouteForWriteTestCase.WriteCheckRouter()]
|
|
||||||
|
|
||||||
def test_fk_delete(self):
|
def test_fk_delete(self):
|
||||||
owner = Person.objects.create(name='Someone')
|
owner = Person.objects.create(name='Someone')
|
||||||
pet = Pet.objects.create(name='fido', owner=owner)
|
pet = Pet.objects.create(name='fido', owner=owner)
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
pet.owner.delete()
|
with self.override_router():
|
||||||
|
pet.owner.delete()
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -1892,9 +1830,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
def test_reverse_fk_delete(self):
|
def test_reverse_fk_delete(self):
|
||||||
owner = Person.objects.create(name='Someone')
|
owner = Person.objects.create(name='Someone')
|
||||||
to_del_qs = owner.pet_set.all()
|
to_del_qs = owner.pet_set.all()
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
to_del_qs.delete()
|
with self.override_router():
|
||||||
|
to_del_qs.delete()
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -1903,9 +1841,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
|
|
||||||
def test_reverse_fk_get_or_create(self):
|
def test_reverse_fk_get_or_create(self):
|
||||||
owner = Person.objects.create(name='Someone')
|
owner = Person.objects.create(name='Someone')
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
owner.pet_set.get_or_create(name='fido')
|
with self.override_router():
|
||||||
|
owner.pet_set.get_or_create(name='fido')
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -1915,9 +1853,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
def test_reverse_fk_update(self):
|
def test_reverse_fk_update(self):
|
||||||
owner = Person.objects.create(name='Someone')
|
owner = Person.objects.create(name='Someone')
|
||||||
Pet.objects.create(name='fido', owner=owner)
|
Pet.objects.create(name='fido', owner=owner)
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
owner.pet_set.update(name='max')
|
with self.override_router():
|
||||||
|
owner.pet_set.update(name='max')
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -1928,9 +1866,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
book.authors.add(auth)
|
with self.override_router():
|
||||||
|
book.authors.add(auth)
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -1942,9 +1880,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
book.authors.clear()
|
with self.override_router():
|
||||||
|
book.authors.clear()
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -1956,9 +1894,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
book.authors.all().delete()
|
with self.override_router():
|
||||||
|
book.authors.all().delete()
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -1969,9 +1907,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
Person.objects.create(name='Someone')
|
Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
book.authors.get_or_create(name='Someone else')
|
with self.override_router():
|
||||||
|
book.authors.get_or_create(name='Someone else')
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -1983,10 +1921,10 @@ class RouteForWriteTestCase(TestCase):
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
self.enable_router()
|
|
||||||
self.assertRaisesMessage(AttributeError, self.RAISE_MSG, )
|
self.assertRaisesMessage(AttributeError, self.RAISE_MSG, )
|
||||||
try:
|
try:
|
||||||
book.authors.remove(auth)
|
with self.override_router():
|
||||||
|
book.authors.remove(auth)
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -1998,9 +1936,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
book.authors.all().update(name='Different')
|
with self.override_router():
|
||||||
|
book.authors.all().update(name='Different')
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -2011,9 +1949,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
auth.book_set.add(book)
|
with self.override_router():
|
||||||
|
auth.book_set.add(book)
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -2025,9 +1963,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
auth.book_set.clear()
|
with self.override_router():
|
||||||
|
auth.book_set.clear()
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -2039,9 +1977,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
auth.book_set.all().delete()
|
with self.override_router():
|
||||||
|
auth.book_set.all().delete()
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -2052,9 +1990,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
Book.objects.create(title="Pro Django",
|
Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
auth.book_set.get_or_create(title="New Book", published=datetime.datetime.now())
|
with self.override_router():
|
||||||
|
auth.book_set.get_or_create(title="New Book", published=datetime.datetime.now())
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -2066,9 +2004,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
auth.book_set.remove(book)
|
with self.override_router():
|
||||||
|
auth.book_set.remove(book)
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
@ -2080,9 +2018,9 @@ class RouteForWriteTestCase(TestCase):
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
self.enable_router()
|
|
||||||
try:
|
try:
|
||||||
auth.book_set.all().update(title='Different')
|
with self.override_router():
|
||||||
|
auth.book_set.all().update(title='Different')
|
||||||
self.fail('db_for_write() not invoked on router')
|
self.fail('db_for_write() not invoked on router')
|
||||||
except RouterUsed as e:
|
except RouterUsed as e:
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
|
|
|
@ -6,9 +6,10 @@ import unittest
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.db import transaction, connection, router
|
from django.db import transaction, connection, router
|
||||||
from django.db.utils import ConnectionHandler, DEFAULT_DB_ALIAS, DatabaseError
|
from django.db.utils import ConnectionHandler, DEFAULT_DB_ALIAS, DatabaseError
|
||||||
from django.test import (TransactionTestCase, skipIfDBFeature,
|
from django.test import (
|
||||||
skipUnlessDBFeature)
|
TransactionTestCase, override_settings, skipIfDBFeature,
|
||||||
from django.test import override_settings
|
skipUnlessDBFeature,
|
||||||
|
)
|
||||||
|
|
||||||
from multiple_database.routers import TestRouter
|
from multiple_database.routers import TestRouter
|
||||||
|
|
||||||
|
@ -257,14 +258,10 @@ class SelectForUpdateTests(TransactionTestCase):
|
||||||
self.assertIsInstance(status[-1], DatabaseError)
|
self.assertIsInstance(status[-1], DatabaseError)
|
||||||
|
|
||||||
@skipUnlessDBFeature('has_select_for_update')
|
@skipUnlessDBFeature('has_select_for_update')
|
||||||
|
@override_settings(DATABASE_ROUTERS=[TestRouter()])
|
||||||
def test_select_for_update_on_multidb(self):
|
def test_select_for_update_on_multidb(self):
|
||||||
old_routers = router.routers
|
query = Person.objects.select_for_update()
|
||||||
try:
|
self.assertEqual(router.db_for_write(Person), query.db)
|
||||||
router.routers = [TestRouter()]
|
|
||||||
query = Person.objects.select_for_update()
|
|
||||||
self.assertEqual(router.db_for_write(Person), query.db)
|
|
||||||
finally:
|
|
||||||
router.routers = old_routers
|
|
||||||
|
|
||||||
@skipUnlessDBFeature('has_select_for_update')
|
@skipUnlessDBFeature('has_select_for_update')
|
||||||
def test_select_for_update_with_get(self):
|
def test_select_for_update_with_get(self):
|
||||||
|
|
Loading…
Reference in New Issue