Fixed #18417 -- Raised exception when unittest.TestCase is decorated with override_settings
This commit is contained in:
parent
f3a0ecc9ee
commit
9f7cefd505
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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')
|
||||||
|
|
Loading…
Reference in New Issue