Fixed #18417 -- Raised exception when unittest.TestCase is decorated with override_settings

This commit is contained in:
Claude Paroz 2012-11-24 23:43:13 +01:00
parent f3a0ecc9ee
commit 9f7cefd505
2 changed files with 20 additions and 10 deletions

View File

@ -188,7 +188,11 @@ class override_settings(object):
def __call__(self, test_func): def __call__(self, test_func):
from django.test import TransactionTestCase from django.test import TransactionTestCase
if isinstance(test_func, type) and issubclass(test_func, TransactionTestCase): if isinstance(test_func, type):
if not issubclass(test_func, TransactionTestCase):
raise Exception(
"Only subclasses of Django TransactionTestCase can be decorated "
"with override_settings")
original_pre_setup = test_func._pre_setup original_pre_setup = test_func._pre_setup
original_post_teardown = test_func._post_teardown original_post_teardown = test_func._post_teardown

View File

@ -6,6 +6,7 @@ from django.core.exceptions import ImproperlyConfigured
from django.http import HttpRequest from django.http import HttpRequest
from django.test import TransactionTestCase, TestCase, signals from django.test import TransactionTestCase, TestCase, signals
from django.test.utils import override_settings from django.test.utils import override_settings
from django.utils import unittest, six
@override_settings(TEST='override') @override_settings(TEST='override')
@ -67,11 +68,6 @@ class ClassDecoratedTestCase(ClassDecoratedTestCaseSuper):
self.fail() self.fail()
class SettingGetter(object):
def __init__(self):
self.test = getattr(settings, 'TEST', 'undefined')
class SettingsTests(TestCase): class SettingsTests(TestCase):
def setUp(self): def setUp(self):
self.testvalue = None self.testvalue = None
@ -122,10 +118,20 @@ class SettingsTests(TestCase):
self.assertRaises(AttributeError, getattr, settings, 'TEST') self.assertRaises(AttributeError, getattr, settings, 'TEST')
def test_class_decorator(self): def test_class_decorator(self):
self.assertEqual(SettingGetter().test, 'undefined') # TransactionTestCase can be decorated by override_settings, but not ut.TestCase
DecoratedSettingGetter = override_settings(TEST='override')(SettingGetter) class TransactionTestCaseSubclass(TransactionTestCase):
self.assertEqual(DecoratedSettingGetter().test, 'override') pass
self.assertRaises(AttributeError, getattr, settings, 'TEST')
class UnittestTestCaseSubclass(unittest.TestCase):
pass
decorated = override_settings(TEST='override')(TransactionTestCaseSubclass)
self.assertIsInstance(decorated, type)
self.assertTrue(issubclass(decorated, TransactionTestCase))
with six.assertRaisesRegex(self, Exception,
"Only subclasses of Django TransactionTestCase*"):
decorated = override_settings(TEST='override')(UnittestTestCaseSubclass)
def test_signal_callback_context_manager(self): def test_signal_callback_context_manager(self):
self.assertRaises(AttributeError, getattr, settings, 'TEST') self.assertRaises(AttributeError, getattr, settings, 'TEST')