mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Refs #31621 -- Added more tests for test --parallel option.
This commit is contained in:
		| @@ -2,6 +2,9 @@ | |||||||
| Tests for django test runner | Tests for django test runner | ||||||
| """ | """ | ||||||
| import collections.abc | import collections.abc | ||||||
|  | import multiprocessing | ||||||
|  | import os | ||||||
|  | import sys | ||||||
| import unittest | import unittest | ||||||
| from unittest import mock | from unittest import mock | ||||||
|  |  | ||||||
| @@ -358,7 +361,8 @@ class DependencyOrderingTests(unittest.TestCase): | |||||||
|  |  | ||||||
| class MockTestRunner: | class MockTestRunner: | ||||||
|     def __init__(self, *args, **kwargs): |     def __init__(self, *args, **kwargs): | ||||||
|         pass |         if parallel := kwargs.get('parallel'): | ||||||
|  |             sys.stderr.write(f'parallel={parallel}') | ||||||
|  |  | ||||||
|  |  | ||||||
| MockTestRunner.run_tests = mock.Mock(return_value=[]) | MockTestRunner.run_tests = mock.Mock(return_value=[]) | ||||||
| @@ -381,6 +385,65 @@ class ManageCommandTests(unittest.TestCase): | |||||||
|         self.assertIn('Total run took', stderr.getvalue()) |         self.assertIn('Total run took', stderr.getvalue()) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # Isolate from the real environment. | ||||||
|  | @mock.patch.dict(os.environ, {}, clear=True) | ||||||
|  | @mock.patch.object(multiprocessing, 'cpu_count', return_value=12) | ||||||
|  | # Python 3.8 on macOS defaults to 'spawn' mode. | ||||||
|  | @mock.patch.object(multiprocessing, 'get_start_method', return_value='fork') | ||||||
|  | class ManageCommandParallelTests(SimpleTestCase): | ||||||
|  |     def test_parallel_default(self, *mocked_objects): | ||||||
|  |         with captured_stderr() as stderr: | ||||||
|  |             call_command( | ||||||
|  |                 'test', | ||||||
|  |                 '--parallel', | ||||||
|  |                 testrunner='test_runner.tests.MockTestRunner', | ||||||
|  |             ) | ||||||
|  |         self.assertIn('parallel=12', stderr.getvalue()) | ||||||
|  |  | ||||||
|  |     def test_parallel_auto(self, *mocked_objects): | ||||||
|  |         with captured_stderr() as stderr: | ||||||
|  |             call_command( | ||||||
|  |                 'test', | ||||||
|  |                 '--parallel=auto', | ||||||
|  |                 testrunner='test_runner.tests.MockTestRunner', | ||||||
|  |             ) | ||||||
|  |         self.assertIn('parallel=12', stderr.getvalue()) | ||||||
|  |  | ||||||
|  |     def test_no_parallel(self, *mocked_objects): | ||||||
|  |         with captured_stderr() as stderr: | ||||||
|  |             call_command('test', testrunner='test_runner.tests.MockTestRunner') | ||||||
|  |         # Parallel is disabled by default. | ||||||
|  |         self.assertEqual(stderr.getvalue(), '') | ||||||
|  |  | ||||||
|  |     def test_parallel_spawn(self, mocked_get_start_method, mocked_cpu_count): | ||||||
|  |         mocked_get_start_method.return_value = 'spawn' | ||||||
|  |         with captured_stderr() as stderr: | ||||||
|  |             call_command( | ||||||
|  |                 'test', | ||||||
|  |                 '--parallel=auto', | ||||||
|  |                 testrunner='test_runner.tests.MockTestRunner', | ||||||
|  |             ) | ||||||
|  |         self.assertIn('parallel=1', stderr.getvalue()) | ||||||
|  |  | ||||||
|  |     def test_no_parallel_spawn(self, mocked_get_start_method, mocked_cpu_count): | ||||||
|  |         mocked_get_start_method.return_value = 'spawn' | ||||||
|  |         with captured_stderr() as stderr: | ||||||
|  |             call_command( | ||||||
|  |                 'test', | ||||||
|  |                 testrunner='test_runner.tests.MockTestRunner', | ||||||
|  |             ) | ||||||
|  |         self.assertEqual(stderr.getvalue(), '') | ||||||
|  |  | ||||||
|  |     @mock.patch.dict(os.environ, {'DJANGO_TEST_PROCESSES': 'invalid'}) | ||||||
|  |     def test_django_test_processes_env_non_int(self, *mocked_objects): | ||||||
|  |         with self.assertRaises(ValueError): | ||||||
|  |             call_command( | ||||||
|  |                 'test', | ||||||
|  |                 '--parallel', | ||||||
|  |                 testrunner='test_runner.tests.MockTestRunner', | ||||||
|  |             ) | ||||||
|  |  | ||||||
|  |  | ||||||
| class CustomTestRunnerOptionsSettingsTests(AdminScriptTestCase): | class CustomTestRunnerOptionsSettingsTests(AdminScriptTestCase): | ||||||
|     """ |     """ | ||||||
|     Custom runners can add command line arguments. The runner is specified |     Custom runners can add command line arguments. The runner is specified | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user