summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorRussell Keith-Magee <russell@keith-magee.com>2010-04-21 12:05:15 +0000
committerRussell Keith-Magee <russell@keith-magee.com>2010-04-21 12:05:15 +0000
commite8eac3290126d94580618cb4dac44cd2a7d258d6 (patch)
tree7b8119e6a83233c0bc3495a1ac2543a8cb838961 /tests
parentb131561112c6e48cc73f692d022f8911ca74eb38 (diff)
downloaddjango-e8eac3290126d94580618cb4dac44cd2a7d258d6.tar.gz
Fixed #13389 -- Ensured that the app_loading test clears out the app cache at the end of each test, so that it doesn't interact badly with flush and other introspected database commands. Thanks to Karen for the report, and Ramiro Morales for the debugging hints.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@13011 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'tests')
-rw-r--r--tests/regressiontests/app_loading/tests.py13
1 files changed, 11 insertions, 2 deletions
diff --git a/tests/regressiontests/app_loading/tests.py b/tests/regressiontests/app_loading/tests.py
index 198fa72bcf..111ed46925 100644
--- a/tests/regressiontests/app_loading/tests.py
+++ b/tests/regressiontests/app_loading/tests.py
@@ -1,10 +1,11 @@
+import copy
import os
import sys
import time
from unittest import TestCase
from django.conf import Settings
-from django.db.models.loading import load_app
+from django.db.models.loading import cache, load_app
__test__ = {"API_TESTS": """
Test the globbing of INSTALLED_APPS.
@@ -33,8 +34,16 @@ class EggLoadingTest(TestCase):
self.old_path = sys.path
self.egg_dir = '%s/eggs' % os.path.dirname(__file__)
+ # This test adds dummy applications to the app cache. These
+ # need to be removed in order to prevent bad interactions
+ # with the flush operation in other tests.
+ self.old_app_models = copy.deepcopy(cache.app_models)
+ self.old_app_store = copy.deepcopy(cache.app_store)
+
def tearDown(self):
sys.path = self.old_path
+ cache.app_models = self.old_app_models
+ cache.app_store = self.old_app_store
def test_egg1(self):
"""Models module can be loaded from an app in an egg"""
@@ -63,7 +72,7 @@ class EggLoadingTest(TestCase):
sys.path.append(egg_name)
models = load_app('omelet.app_no_models')
self.failUnless(models is None)
-
+
def test_egg5(self):
"""Loading an app from an egg that has an import error in its models module raises that error"""
egg_name = '%s/brokenapp.egg' % self.egg_dir