mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Refs #32508 -- Raised ImproperlyConfigured instead of using "assert" in middlewares.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							dc86a25a67
						
					
				
				
					commit
					a2d5ea626e
				
			| @@ -1,4 +1,5 @@ | |||||||
| from django.conf import settings | from django.conf import settings | ||||||
|  | from django.core.exceptions import ImproperlyConfigured | ||||||
| from django.http import HttpResponse | from django.http import HttpResponse | ||||||
| from django.utils.deprecation import MiddlewareMixin | from django.utils.deprecation import MiddlewareMixin | ||||||
|  |  | ||||||
| @@ -16,11 +17,12 @@ class XViewMiddleware(MiddlewareMixin): | |||||||
|         header indicating the view function. This is used to lookup the view |         header indicating the view function. This is used to lookup the view | ||||||
|         function for an arbitrary page. |         function for an arbitrary page. | ||||||
|         """ |         """ | ||||||
|         assert hasattr(request, 'user'), ( |         if not hasattr(request, 'user'): | ||||||
|             "The XView middleware requires authentication middleware to be " |             raise ImproperlyConfigured( | ||||||
|             "installed. Edit your MIDDLEWARE setting to insert " |                 "The XView middleware requires authentication middleware to " | ||||||
|             "'django.contrib.auth.middleware.AuthenticationMiddleware'." |                 "be installed. Edit your MIDDLEWARE setting to insert " | ||||||
|         ) |                 "'django.contrib.auth.middleware.AuthenticationMiddleware'." | ||||||
|  |             ) | ||||||
|         if request.method == 'HEAD' and (request.META.get('REMOTE_ADDR') in settings.INTERNAL_IPS or |         if request.method == 'HEAD' and (request.META.get('REMOTE_ADDR') in settings.INTERNAL_IPS or | ||||||
|                                          (request.user.is_active and request.user.is_staff)): |                                          (request.user.is_active and request.user.is_staff)): | ||||||
|             response = HttpResponse() |             response = HttpResponse() | ||||||
|   | |||||||
| @@ -14,12 +14,14 @@ def get_user(request): | |||||||
|  |  | ||||||
| class AuthenticationMiddleware(MiddlewareMixin): | class AuthenticationMiddleware(MiddlewareMixin): | ||||||
|     def process_request(self, request): |     def process_request(self, request): | ||||||
|         assert hasattr(request, 'session'), ( |         if not hasattr(request, 'session'): | ||||||
|             "The Django authentication middleware requires session middleware " |             raise ImproperlyConfigured( | ||||||
|             "to be installed. Edit your MIDDLEWARE setting to insert " |                 "The Django authentication middleware requires session " | ||||||
|             "'django.contrib.sessions.middleware.SessionMiddleware' before " |                 "middleware to be installed. Edit your MIDDLEWARE setting to " | ||||||
|             "'django.contrib.auth.middleware.AuthenticationMiddleware'." |                 "insert " | ||||||
|         ) |                 "'django.contrib.sessions.middleware.SessionMiddleware' before " | ||||||
|  |                 "'django.contrib.auth.middleware.AuthenticationMiddleware'." | ||||||
|  |             ) | ||||||
|         request.user = SimpleLazyObject(lambda: get_user(request)) |         request.user = SimpleLazyObject(lambda: get_user(request)) | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| from django.contrib.auth.models import User | from django.contrib.auth.models import User | ||||||
|  | from django.core.exceptions import ImproperlyConfigured | ||||||
| from django.test import override_settings | from django.test import override_settings | ||||||
|  |  | ||||||
| from .tests import AdminDocsTestCase, TestDataMixin | from .tests import AdminDocsTestCase, TestDataMixin | ||||||
| @@ -54,5 +55,5 @@ class XViewMiddlewareTest(TestDataMixin, AdminDocsTestCase): | |||||||
|             "installed. Edit your MIDDLEWARE setting to insert " |             "installed. Edit your MIDDLEWARE setting to insert " | ||||||
|             "'django.contrib.auth.middleware.AuthenticationMiddleware'." |             "'django.contrib.auth.middleware.AuthenticationMiddleware'." | ||||||
|         ) |         ) | ||||||
|         with self.assertRaisesMessage(AssertionError, msg): |         with self.assertRaisesMessage(ImproperlyConfigured, msg): | ||||||
|             self.client.head('/xview/func/') |             self.client.head('/xview/func/') | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| from django.contrib.auth.middleware import AuthenticationMiddleware | from django.contrib.auth.middleware import AuthenticationMiddleware | ||||||
| from django.contrib.auth.models import User | from django.contrib.auth.models import User | ||||||
|  | from django.core.exceptions import ImproperlyConfigured | ||||||
| from django.http import HttpRequest, HttpResponse | from django.http import HttpRequest, HttpResponse | ||||||
| from django.test import TestCase | from django.test import TestCase | ||||||
|  |  | ||||||
| @@ -38,5 +39,5 @@ class TestAuthenticationMiddleware(TestCase): | |||||||
|             "'django.contrib.sessions.middleware.SessionMiddleware' before " |             "'django.contrib.sessions.middleware.SessionMiddleware' before " | ||||||
|             "'django.contrib.auth.middleware.AuthenticationMiddleware'." |             "'django.contrib.auth.middleware.AuthenticationMiddleware'." | ||||||
|         ) |         ) | ||||||
|         with self.assertRaisesMessage(AssertionError, msg): |         with self.assertRaisesMessage(ImproperlyConfigured, msg): | ||||||
|             self.middleware(HttpRequest()) |             self.middleware(HttpRequest()) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user