mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #3253 -- Exposed the number of failed tests as a return code in manage.py and runtests.py.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@4608 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -1240,7 +1240,10 @@ def test(app_labels, verbosity=1): | |||||||
|     test_module = __import__(test_module_name, {}, {}, test_path[-1]) |     test_module = __import__(test_module_name, {}, {}, test_path[-1]) | ||||||
|     test_runner = getattr(test_module, test_path[-1]) |     test_runner = getattr(test_module, test_path[-1]) | ||||||
|  |  | ||||||
|     test_runner(app_list, verbosity) |     failures = test_runner(app_list, verbosity) | ||||||
|  |     if failures: | ||||||
|  |         sys.exit(failures) | ||||||
|  |          | ||||||
| test.help_doc = 'Runs the test suite for the specified applications, or the entire site if no apps are specified' | test.help_doc = 'Runs the test suite for the specified applications, or the entire site if no apps are specified' | ||||||
| test.args = '[--verbosity] ' + APP_ARGS | test.args = '[--verbosity] ' + APP_ARGS | ||||||
|  |  | ||||||
|   | |||||||
| @@ -63,6 +63,8 @@ def run_tests(module_list, verbosity=1, extra_tests=[]): | |||||||
|     looking for doctests and unittests in models.py or tests.py within |     looking for doctests and unittests in models.py or tests.py within | ||||||
|     the module. A list of 'extra' tests may also be provided; these tests |     the module. A list of 'extra' tests may also be provided; these tests | ||||||
|     will be added to the test suite. |     will be added to the test suite. | ||||||
|  |      | ||||||
|  |     Returns the number of tests that failed. | ||||||
|     """ |     """ | ||||||
|     setup_test_environment() |     setup_test_environment() | ||||||
|      |      | ||||||
| @@ -77,7 +79,10 @@ def run_tests(module_list, verbosity=1, extra_tests=[]): | |||||||
|  |  | ||||||
|     old_name = settings.DATABASE_NAME |     old_name = settings.DATABASE_NAME | ||||||
|     create_test_db(verbosity) |     create_test_db(verbosity) | ||||||
|     unittest.TextTestRunner(verbosity=verbosity).run(suite) |     result = unittest.TextTestRunner(verbosity=verbosity).run(suite) | ||||||
|     destroy_test_db(old_name, verbosity) |     destroy_test_db(old_name, verbosity) | ||||||
|      |      | ||||||
|     teardown_test_environment() |     teardown_test_environment() | ||||||
|  |      | ||||||
|  |     return len(result.failures) | ||||||
|  |      | ||||||
| @@ -417,7 +417,10 @@ failed:: | |||||||
|  |  | ||||||
|     FAILED (failures=1) |     FAILED (failures=1) | ||||||
|  |  | ||||||
| When the tests have all been executed, the test database is destroyed. | The return code for the script will indicate the number of tests that failed. | ||||||
|  |  | ||||||
|  | Regardless of whether the tests pass or fail, the test database is destroyed when | ||||||
|  | all the tests have been executed.  | ||||||
|  |  | ||||||
| Using a different testing framework | Using a different testing framework | ||||||
| =================================== | =================================== | ||||||
| @@ -428,7 +431,8 @@ it does provide a mechanism to allow you to invoke tests constructed for | |||||||
| an alternative framework as if they were normal Django tests. | an alternative framework as if they were normal Django tests. | ||||||
|  |  | ||||||
| When you run ``./manage.py test``, Django looks at the ``TEST_RUNNER`` | When you run ``./manage.py test``, Django looks at the ``TEST_RUNNER`` | ||||||
| setting to determine what to do. By default, ``TEST_RUNNER`` points to ``django.test.simple.run_tests``. This method defines the default Django | setting to determine what to do. By default, ``TEST_RUNNER`` points to  | ||||||
|  | ``django.test.simple.run_tests``. This method defines the default Django | ||||||
| testing behavior. This behavior involves: | testing behavior. This behavior involves: | ||||||
|  |  | ||||||
| #. Performing global pre-test setup | #. Performing global pre-test setup | ||||||
| @@ -436,7 +440,7 @@ testing behavior. This behavior involves: | |||||||
| #. Running ``syncdb`` to install models and initial data into the test database | #. Running ``syncdb`` to install models and initial data into the test database | ||||||
| #. Looking for Unit Tests and Doctests in ``models.py`` and ``tests.py`` file for each installed application | #. Looking for Unit Tests and Doctests in ``models.py`` and ``tests.py`` file for each installed application | ||||||
| #. Running the Unit Tests and Doctests that are found | #. Running the Unit Tests and Doctests that are found | ||||||
| #. Destroying the test database. | #. Destroying the test database | ||||||
| #. Performing global post-test teardown | #. Performing global post-test teardown | ||||||
|  |  | ||||||
| If you define your own test runner method and point ``TEST_RUNNER`` | If you define your own test runner method and point ``TEST_RUNNER`` | ||||||
| @@ -458,6 +462,8 @@ arguments: | |||||||
|     will be printed to the console; `0` is no output, `1` is normal output, |     will be printed to the console; `0` is no output, `1` is normal output, | ||||||
|     and `2` is verbose output. |     and `2` is verbose output. | ||||||
|      |      | ||||||
|  |     This method should return the number of tests that failed. | ||||||
|  |  | ||||||
| Testing utilities | Testing utilities | ||||||
| ----------------- | ----------------- | ||||||
|  |  | ||||||
|   | |||||||
| @@ -124,7 +124,9 @@ def django_tests(verbosity, tests_to_run): | |||||||
|  |  | ||||||
|     # Run the test suite, including the extra validation tests. |     # Run the test suite, including the extra validation tests. | ||||||
|     from django.test.simple import run_tests |     from django.test.simple import run_tests | ||||||
|     run_tests(test_models, verbosity, extra_tests=extra_tests) |     failures = run_tests(test_models, verbosity, extra_tests=extra_tests) | ||||||
|  |     if failures: | ||||||
|  |         sys.exit(failures) | ||||||
|  |  | ||||||
|     # Restore the old settings. |     # Restore the old settings. | ||||||
|     settings.INSTALLED_APPS = old_installed_apps |     settings.INSTALLED_APPS = old_installed_apps | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user