mirror of
https://github.com/django/django.git
synced 2024-12-22 17:16:24 +00:00
Added test for Apps.get_models() when models_ready=False.
This commit is contained in:
parent
136bf5c214
commit
1500573620
@ -45,9 +45,9 @@ class AppsTests(SimpleTestCase):
|
|||||||
Tests the ready property of the master registry.
|
Tests the ready property of the master registry.
|
||||||
"""
|
"""
|
||||||
# The master app registry is always ready when the tests run.
|
# The master app registry is always ready when the tests run.
|
||||||
self.assertTrue(apps.ready)
|
self.assertIs(apps.ready, True)
|
||||||
# Non-master app registries are populated in __init__.
|
# Non-master app registries are populated in __init__.
|
||||||
self.assertTrue(Apps().ready)
|
self.assertIs(Apps().ready, True)
|
||||||
|
|
||||||
def test_bad_app_config(self):
|
def test_bad_app_config(self):
|
||||||
"""
|
"""
|
||||||
@ -124,10 +124,10 @@ class AppsTests(SimpleTestCase):
|
|||||||
"""
|
"""
|
||||||
Tests apps.is_installed().
|
Tests apps.is_installed().
|
||||||
"""
|
"""
|
||||||
self.assertTrue(apps.is_installed('django.contrib.admin'))
|
self.assertIs(apps.is_installed('django.contrib.admin'), True)
|
||||||
self.assertTrue(apps.is_installed('django.contrib.auth'))
|
self.assertIs(apps.is_installed('django.contrib.auth'), True)
|
||||||
self.assertTrue(apps.is_installed('django.contrib.staticfiles'))
|
self.assertIs(apps.is_installed('django.contrib.staticfiles'), True)
|
||||||
self.assertFalse(apps.is_installed('django.contrib.admindocs'))
|
self.assertIs(apps.is_installed('django.contrib.admindocs'), False)
|
||||||
|
|
||||||
@override_settings(INSTALLED_APPS=SOME_INSTALLED_APPS)
|
@override_settings(INSTALLED_APPS=SOME_INSTALLED_APPS)
|
||||||
def test_get_model(self):
|
def test_get_model(self):
|
||||||
@ -184,6 +184,19 @@ class AppsTests(SimpleTestCase):
|
|||||||
new_apps.get_model("apps", "TotallyNormal")
|
new_apps.get_model("apps", "TotallyNormal")
|
||||||
self.assertEqual(new_apps.get_model("apps", "SoAlternative"), SoAlternative)
|
self.assertEqual(new_apps.get_model("apps", "SoAlternative"), SoAlternative)
|
||||||
|
|
||||||
|
def test_models_not_loaded(self):
|
||||||
|
"""
|
||||||
|
apps.get_models() raises an exception if apps.models_ready isn't True.
|
||||||
|
"""
|
||||||
|
apps.models_ready = False
|
||||||
|
try:
|
||||||
|
# The cache must be cleared to trigger the exception.
|
||||||
|
apps.get_models.cache_clear()
|
||||||
|
with self.assertRaisesMessage(AppRegistryNotReady, "Models aren't loaded yet."):
|
||||||
|
apps.get_models()
|
||||||
|
finally:
|
||||||
|
apps.models_ready = True
|
||||||
|
|
||||||
def test_dynamic_load(self):
|
def test_dynamic_load(self):
|
||||||
"""
|
"""
|
||||||
Makes a new model at runtime and ensures it goes into the right place.
|
Makes a new model at runtime and ensures it goes into the right place.
|
||||||
|
Loading…
Reference in New Issue
Block a user