mirror of
				https://github.com/django/django.git
				synced 2025-10-24 14:16:09 +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_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.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 | ||||
|     the module. A list of 'extra' tests may also be provided; these tests | ||||
|     will be added to the test suite. | ||||
|      | ||||
|     Returns the number of tests that failed. | ||||
|     """ | ||||
|     setup_test_environment() | ||||
|      | ||||
| @@ -77,7 +79,10 @@ def run_tests(module_list, verbosity=1, extra_tests=[]): | ||||
|  | ||||
|     old_name = settings.DATABASE_NAME | ||||
|     create_test_db(verbosity) | ||||
|     unittest.TextTestRunner(verbosity=verbosity).run(suite) | ||||
|     result = unittest.TextTestRunner(verbosity=verbosity).run(suite) | ||||
|     destroy_test_db(old_name, verbosity) | ||||
|      | ||||
|     teardown_test_environment() | ||||
|      | ||||
|     return len(result.failures) | ||||
|      | ||||
| @@ -417,7 +417,10 @@ failed:: | ||||
|  | ||||
|     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 | ||||
| =================================== | ||||
| @@ -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. | ||||
|  | ||||
| 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: | ||||
|  | ||||
| #. 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 | ||||
| #. 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 | ||||
| #. Destroying the test database. | ||||
| #. Destroying the test database | ||||
| #. Performing global post-test teardown | ||||
|  | ||||
| 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, | ||||
|     and `2` is verbose output. | ||||
|      | ||||
|     This method should return the number of tests that failed. | ||||
|  | ||||
| Testing utilities | ||||
| ----------------- | ||||
|  | ||||
|   | ||||
| @@ -124,7 +124,9 @@ def django_tests(verbosity, tests_to_run): | ||||
|  | ||||
|     # Run the test suite, including the extra validation 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. | ||||
|     settings.INSTALLED_APPS = old_installed_apps | ||||
|   | ||||
		Reference in New Issue
	
	Block a user