summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorJacob Walls <jacobtylerwalls@gmail.com>2021-10-16 17:15:50 -0400
committerMariusz Felisiak <felisiak.mariusz@gmail.com>2021-10-26 07:47:40 +0200
commitdef09bf4126d4886413adf7388882eca8e32576b (patch)
tree12c6876312bba01cbcaac63b505acee832f432fa /tests
parentcbd9f8531d70a0f975cf57595f3b5684d16c4b3c (diff)
Fixed #27079 -- Avoided multiple setUpClass()/tearDownClass() calls in LiveServerTestCase tests.
Diffstat (limited to 'tests')
-rw-r--r--tests/servers/tests.py40
-rw-r--r--tests/staticfiles_tests/test_liveserver.py20
2 files changed, 17 insertions, 43 deletions
diff --git a/tests/servers/tests.py b/tests/servers/tests.py
index cea25b9920..2b2eab20aa 100644
--- a/tests/servers/tests.py
+++ b/tests/servers/tests.py
@@ -127,18 +127,12 @@ class LiveServerTestCaseSetupTest(LiveServerBase):
super().setUpClass()
except RuntimeError:
# LiveServerTestCase's change to ALLOWED_HOSTS should be reverted.
+ cls.doClassCleanups()
cls.check_allowed_hosts(['testserver'])
else:
raise RuntimeError('Server did not fail.')
cls.set_up_called = True
- @classmethod
- def tearDownClass(cls):
- # Make tearDownClass() a no-op because setUpClass() was already cleaned
- # up, and because the error inside setUpClass() was handled, which will
- # cause tearDownClass() to be called when it normally wouldn't.
- pass
-
def test_set_up_class(self):
self.assertIs(self.set_up_called, True)
@@ -334,7 +328,7 @@ class LiveServerPort(LiveServerBase):
"""
TestCase = type("TestCase", (LiveServerBase,), {})
try:
- TestCase.setUpClass()
+ TestCase._start_server_thread()
except OSError as e:
if e.errno == errno.EADDRINUSE:
# We're out of ports, LiveServerTestCase correctly fails with
@@ -342,15 +336,12 @@ class LiveServerPort(LiveServerBase):
return
# Unexpected error.
raise
- try:
- # We've acquired a port, ensure our server threads acquired
- # different addresses.
- self.assertNotEqual(
- self.live_server_url, TestCase.live_server_url,
- "Acquired duplicate server addresses for server threads: %s" % self.live_server_url
- )
- finally:
- TestCase.tearDownClass()
+ self.assertNotEqual(
+ self.live_server_url,
+ TestCase.live_server_url,
+ f'Acquired duplicate server addresses for server threads: '
+ f'{self.live_server_url}',
+ )
def test_specified_port_bind(self):
"""LiveServerTestCase.port customizes the server's port."""
@@ -360,14 +351,13 @@ class LiveServerPort(LiveServerBase):
s.bind(('', 0))
TestCase.port = s.getsockname()[1]
s.close()
- TestCase.setUpClass()
- try:
- self.assertEqual(
- TestCase.port, TestCase.server_thread.port,
- 'Did not use specified port for LiveServerTestCase thread: %s' % TestCase.port
- )
- finally:
- TestCase.tearDownClass()
+ TestCase._start_server_thread()
+ self.assertEqual(
+ TestCase.port,
+ TestCase.server_thread.port,
+ f'Did not use specified port for LiveServerTestCase thread: '
+ f'{TestCase.port}',
+ )
class LiveServerThreadedTests(LiveServerBase):
diff --git a/tests/staticfiles_tests/test_liveserver.py b/tests/staticfiles_tests/test_liveserver.py
index 970121f2da..38d1513c9a 100644
--- a/tests/staticfiles_tests/test_liveserver.py
+++ b/tests/staticfiles_tests/test_liveserver.py
@@ -29,22 +29,8 @@ class LiveServerBase(StaticLiveServerTestCase):
# Override settings
cls.settings_override = override_settings(**TEST_SETTINGS)
cls.settings_override.enable()
- try:
- super().setUpClass()
- except Exception:
- # Clean up since tearDownClass() isn't called on errors.
- cls._tearDownLiveServerBase()
- raise
-
- @classmethod
- def _tearDownLiveServerBase(cls):
- # Restore original settings
- cls.settings_override.disable()
-
- @classmethod
- def tearDownClass(cls):
- super().tearDownClass()
- cls._tearDownLiveServerBase()
+ cls.addClassCleanup(cls.settings_override.disable)
+ super().setUpClass()
class StaticLiveServerChecks(LiveServerBase):
@@ -74,8 +60,6 @@ class StaticLiveServerChecks(LiveServerBase):
# app without having set the required STATIC_URL setting.")
pass
else:
- # super().setUpClass() cleans up after itself on a failure.
- super().tearDownClass()
raise Exception('setUpClass() should have raised an exception.')
def test_test_test(self):