mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Improved runtests.py to normalize MIDDLEWARE_CLASSES during test execution. Some tests were failing for me because my custom MIDDLEWARE_CLASSES setting didn't have sessions or authentication installed
git-svn-id: http://code.djangoproject.com/svn/django/trunk@4473 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -77,13 +77,19 @@ def django_tests(verbosity, tests_to_run): | |||||||
|     old_root_urlconf = settings.ROOT_URLCONF |     old_root_urlconf = settings.ROOT_URLCONF | ||||||
|     old_template_dirs = settings.TEMPLATE_DIRS |     old_template_dirs = settings.TEMPLATE_DIRS | ||||||
|     old_use_i18n = settings.USE_I18N |     old_use_i18n = settings.USE_I18N | ||||||
|  |     old_middleware_classes = settings.MIDDLEWARE_CLASSES | ||||||
|  |  | ||||||
|     # Redirect some settings for the duration of these tests |     # Redirect some settings for the duration of these tests. | ||||||
|     settings.TEST_DATABASE_NAME = TEST_DATABASE_NAME |     settings.TEST_DATABASE_NAME = TEST_DATABASE_NAME | ||||||
|     settings.INSTALLED_APPS = ALWAYS_INSTALLED_APPS |     settings.INSTALLED_APPS = ALWAYS_INSTALLED_APPS | ||||||
|     settings.ROOT_URLCONF = 'urls' |     settings.ROOT_URLCONF = 'urls' | ||||||
|     settings.TEMPLATE_DIRS = (os.path.join(os.path.dirname(__file__), TEST_TEMPLATE_DIR),) |     settings.TEMPLATE_DIRS = (os.path.join(os.path.dirname(__file__), TEST_TEMPLATE_DIR),) | ||||||
|     settings.USE_I18N = True |     settings.USE_I18N = True | ||||||
|  |     settings.MIDDLEWARE_CLASSES = ( | ||||||
|  |         'django.contrib.sessions.middleware.SessionMiddleware', | ||||||
|  |         'django.contrib.auth.middleware.AuthenticationMiddleware', | ||||||
|  |         'django.middleware.common.CommonMiddleware', | ||||||
|  |     ) | ||||||
|  |  | ||||||
|     # Load all the ALWAYS_INSTALLED_APPS. |     # Load all the ALWAYS_INSTALLED_APPS. | ||||||
|     # (This import statement is intentionally delayed until after we |     # (This import statement is intentionally delayed until after we | ||||||
| @@ -91,7 +97,7 @@ def django_tests(verbosity, tests_to_run): | |||||||
|     from django.db.models.loading import get_apps, load_app |     from django.db.models.loading import get_apps, load_app | ||||||
|     get_apps() |     get_apps() | ||||||
|  |  | ||||||
|     # Load all the test model apps |     # Load all the test model apps. | ||||||
|     test_models = [] |     test_models = [] | ||||||
|     for model_dir, model_name in get_test_models(): |     for model_dir, model_name in get_test_models(): | ||||||
|         model_label = '.'.join([model_dir, model_name]) |         model_label = '.'.join([model_dir, model_name]) | ||||||
| @@ -109,7 +115,7 @@ def django_tests(verbosity, tests_to_run): | |||||||
|             sys.stderr.write("Error while importing %s:" % model_name + ''.join(traceback.format_exception(*sys.exc_info())[1:])) |             sys.stderr.write("Error while importing %s:" % model_name + ''.join(traceback.format_exception(*sys.exc_info())[1:])) | ||||||
|             continue |             continue | ||||||
|  |  | ||||||
|     # Add tests for invalid models |     # Add tests for invalid models. | ||||||
|     extra_tests = [] |     extra_tests = [] | ||||||
|     for model_dir, model_name in get_invalid_models(): |     for model_dir, model_name in get_invalid_models(): | ||||||
|         model_label = '.'.join([model_dir, model_name]) |         model_label = '.'.join([model_dir, model_name]) | ||||||
| @@ -120,12 +126,13 @@ def django_tests(verbosity, tests_to_run): | |||||||
|     from django.test.simple import run_tests |     from django.test.simple import run_tests | ||||||
|     run_tests(test_models, verbosity, extra_tests=extra_tests) |     run_tests(test_models, verbosity, extra_tests=extra_tests) | ||||||
|  |  | ||||||
|     # Restore the old settings |     # Restore the old settings. | ||||||
|     settings.INSTALLED_APPS = old_installed_apps |     settings.INSTALLED_APPS = old_installed_apps | ||||||
|     settings.TESTS_DATABASE_NAME = old_test_database_name |     settings.TESTS_DATABASE_NAME = old_test_database_name | ||||||
|     settings.ROOT_URLCONF = old_root_urlconf |     settings.ROOT_URLCONF = old_root_urlconf | ||||||
|     settings.TEMPLATE_DIRS = old_template_dirs |     settings.TEMPLATE_DIRS = old_template_dirs | ||||||
|     settings.USE_I18N = old_use_i18n |     settings.USE_I18N = old_use_i18n | ||||||
|  |     settings.MIDDLEWARE_CLASSES = old_middleware_classes | ||||||
|  |  | ||||||
| if __name__ == "__main__": | if __name__ == "__main__": | ||||||
|     from optparse import OptionParser |     from optparse import OptionParser | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user