mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Refs #31811 -- Added optional timing outputs to the test runner.
This commit is contained in:
		
				
					committed by
					
						 Carlton Gibson
						Carlton Gibson
					
				
			
			
				
	
			
			
			
						parent
						
							21768a99f4
						
					
				
				
					commit
					61a0ba43cf
				
			| @@ -1523,6 +1523,12 @@ Django automatically calls :func:`faulthandler.enable()` when starting the | ||||
| tests, which allows it to print a traceback if the interpreter crashes. Pass | ||||
| ``--no-faulthandler`` to disable this behavior. | ||||
|  | ||||
| .. django-admin-option:: --timing | ||||
|  | ||||
| .. versionadded:: 3.2 | ||||
|  | ||||
| Outputs timings, including including database setup and total run time. | ||||
|  | ||||
| ``testserver`` | ||||
| -------------- | ||||
|  | ||||
|   | ||||
| @@ -330,6 +330,11 @@ Tests | ||||
|   :py:mod:`faulthandler` by default. This can be disabled by using the | ||||
|   :option:`test --no-faulthandler` option. | ||||
|  | ||||
| * :class:`~django.test.runner.DiscoverRunner` and the | ||||
|   :djadmin:`test` management command can now track timings, including database | ||||
|   setup and total run time. This can be enabled by using the :option:`test | ||||
|   --timing` option. | ||||
|  | ||||
| * :class:`~django.test.Client` now preserves the request query string when | ||||
|   following 307 and 308 redirects. | ||||
|  | ||||
| @@ -454,6 +459,9 @@ Miscellaneous | ||||
|  | ||||
| * Instantiating an abstract model now raises ``TypeError``. | ||||
|  | ||||
| * Keyword arguments to :func:`~django.test.utils.setup_databases` are now | ||||
|   keyword-only. | ||||
|  | ||||
| .. _deprecated-features-3.2: | ||||
|  | ||||
| Features deprecated in 3.2 | ||||
|   | ||||
| @@ -510,7 +510,7 @@ behavior. This class defines the ``run_tests()`` entry point, plus a | ||||
| selection of other methods that are used to by ``run_tests()`` to set up, | ||||
| execute and tear down the test suite. | ||||
|  | ||||
| .. class:: DiscoverRunner(pattern='test*.py', top_level=None, verbosity=1, interactive=True, failfast=False, keepdb=False, reverse=False, debug_mode=False, debug_sql=False, test_name_patterns=None, pdb=False, buffer=False, enable_faulthandler=True, **kwargs) | ||||
| .. class:: DiscoverRunner(pattern='test*.py', top_level=None, verbosity=1, interactive=True, failfast=False, keepdb=False, reverse=False, debug_mode=False, debug_sql=False, test_name_patterns=None, pdb=False, buffer=False, enable_faulthandler=True, timing=True, **kwargs) | ||||
|  | ||||
|     ``DiscoverRunner`` will search for tests in any file matching ``pattern``. | ||||
|  | ||||
| @@ -560,6 +560,9 @@ execute and tear down the test suite. | ||||
|     If ``enable_faulthandler`` is ``True``, :py:mod:`faulthandler` will be | ||||
|     enabled. | ||||
|  | ||||
|     If ``timing`` is ``True``, test timings, including database setup and total | ||||
|     run time, will be shown. | ||||
|  | ||||
|     Django may, from time to time, extend the capabilities of the test runner | ||||
|     by adding new arguments. The ``**kwargs`` declaration allows for this | ||||
|     expansion. If you subclass ``DiscoverRunner`` or write your own test | ||||
| @@ -576,7 +579,7 @@ execute and tear down the test suite. | ||||
|  | ||||
|     .. versionadded:: 3.2 | ||||
|  | ||||
|         The ``enable_faulthandler`` argument was added. | ||||
|         The ``enable_faulthandler`` and ``timing`` arguments were added. | ||||
|  | ||||
| Attributes | ||||
| ~~~~~~~~~~ | ||||
| @@ -659,7 +662,7 @@ Methods | ||||
|  | ||||
|     Returns a ``TestSuite`` instance ready to be run. | ||||
|  | ||||
| .. method:: DiscoverRunner.setup_databases(**kwargs) | ||||
| .. method:: DiscoverRunner.setup_databases(verbosity, interactive, **kwargs) | ||||
|  | ||||
|     Creates the test databases by calling | ||||
|     :func:`~django.test.utils.setup_databases`. | ||||
| @@ -723,7 +726,7 @@ utility methods in the ``django.test.utils`` module. | ||||
|     Performs global post-test teardown, such as removing instrumentation from | ||||
|     the template system and restoring normal email services. | ||||
|  | ||||
| .. function:: setup_databases(verbosity, interactive, keepdb=False, debug_sql=False, parallel=0, aliases=None, **kwargs) | ||||
| .. function:: setup_databases(verbosity, interactive, *, time_keeper, keepdb=False, debug_sql=False, parallel=0, aliases=None, **kwargs) | ||||
|  | ||||
|     Creates the test databases. | ||||
|  | ||||
| @@ -735,6 +738,11 @@ utility methods in the ``django.test.utils`` module. | ||||
|     databases should be setup for. If it's not provided, it defaults to all of | ||||
|     :setting:`DATABASES` aliases. | ||||
|  | ||||
|     .. versionchanged:: 3.2 | ||||
|  | ||||
|         The ``time_keeper`` kwarg was added, and all kwargs were made | ||||
|         keyword-only. | ||||
|  | ||||
| .. function:: teardown_databases(old_config, parallel=0, keepdb=False) | ||||
|  | ||||
|     Destroys the test databases, restoring pre-test conditions. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user