mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #16593 -- Refactored proxy_model_inheritance fixture setup to minimize the chances of leaving a modified INSTALLED_APPS setting for tests ran after it if setUp fails. Thanks Jim Dalton for the report and patch.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@16593 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -13,24 +13,25 @@ from django.conf import settings | ||||
| from django.core.management import call_command | ||||
| from django.db.models.loading import load_app | ||||
| from django.test import TransactionTestCase | ||||
| from django.test.utils import override_settings | ||||
|  | ||||
| # @override_settings(INSTALLED_APPS=('app1', 'app2')) | ||||
| class ProxyModelInheritanceTests(TransactionTestCase): | ||||
|  | ||||
|     def setUp(self): | ||||
|         self.old_sys_path = sys.path[:] | ||||
|         sys.path.append(os.path.dirname(os.path.abspath(__file__))) | ||||
|         self.old_installed_apps = settings.INSTALLED_APPS | ||||
|         settings.INSTALLED_APPS = ('app1', 'app2') | ||||
|         map(load_app, settings.INSTALLED_APPS) | ||||
|  | ||||
|     def tearDown(self): | ||||
|         sys.path = self.old_sys_path | ||||
|  | ||||
|     def test_table_exists(self): | ||||
|         call_command('syncdb', verbosity=0) | ||||
|         global ProxyModel, NiceModel | ||||
|         from app1.models import ProxyModel | ||||
|         from app2.models import NiceModel | ||||
|  | ||||
|     def tearDown(self): | ||||
|         settings.INSTALLED_APPS = self.old_installed_apps | ||||
|         sys.path = self.old_sys_path | ||||
|  | ||||
|     def test_table_exists(self): | ||||
|         self.assertEqual(NiceModel.objects.all().count(), 0) | ||||
|         self.assertEqual(ProxyModel.objects.all().count(), 0) | ||||
|  | ||||
| ProxyModelInheritanceTests = override_settings(INSTALLED_APPS=('app1', 'app2'))(ProxyModelInheritanceTests) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user