Loading django/contrib/auth/backends.py +1 −1 Original line number Diff line number Diff line Loading @@ -64,8 +64,8 @@ class ModelBackend(object): return False def get_user(self, user_id): try: UserModel = get_user_model() try: return UserModel._default_manager.get(pk=user_id) except UserModel.DoesNotExist: return None Loading django/contrib/auth/tests/test_auth_backends.py +24 −0 Original line number Diff line number Diff line Loading @@ -508,3 +508,27 @@ class TypeErrorBackendTest(TestCase): @override_settings(AUTHENTICATION_BACKENDS=(backend, )) def test_type_error_raised(self): self.assertRaises(TypeError, authenticate, username='test', password='test') @skipIfCustomUser class ImproperlyConfiguredUserModelTest(TestCase): """ Tests that an exception from within get_user_model is propagated and doesn't raise an UnboundLocalError. Regression test for ticket #21439 """ def setUp(self): self.user1 = User.objects.create_user('test', 'test@example.com', 'test') self.client.login( username='test', password='test' ) @override_settings(AUTH_USER_MODEL='thismodel.doesntexist') def test_does_not_shadow_exception(self): # Prepare a request object request = HttpRequest() request.session = self.client.session self.assertRaises(ImproperlyConfigured, get_user, request) Loading
django/contrib/auth/backends.py +1 −1 Original line number Diff line number Diff line Loading @@ -64,8 +64,8 @@ class ModelBackend(object): return False def get_user(self, user_id): try: UserModel = get_user_model() try: return UserModel._default_manager.get(pk=user_id) except UserModel.DoesNotExist: return None Loading
django/contrib/auth/tests/test_auth_backends.py +24 −0 Original line number Diff line number Diff line Loading @@ -508,3 +508,27 @@ class TypeErrorBackendTest(TestCase): @override_settings(AUTHENTICATION_BACKENDS=(backend, )) def test_type_error_raised(self): self.assertRaises(TypeError, authenticate, username='test', password='test') @skipIfCustomUser class ImproperlyConfiguredUserModelTest(TestCase): """ Tests that an exception from within get_user_model is propagated and doesn't raise an UnboundLocalError. Regression test for ticket #21439 """ def setUp(self): self.user1 = User.objects.create_user('test', 'test@example.com', 'test') self.client.login( username='test', password='test' ) @override_settings(AUTH_USER_MODEL='thismodel.doesntexist') def test_does_not_shadow_exception(self): # Prepare a request object request = HttpRequest() request.session = self.client.session self.assertRaises(ImproperlyConfigured, get_user, request)