mirror of
https://github.com/django/django.git
synced 2025-10-31 09:41:08 +00:00
Fixed #35530 -- Deprecated request.user fallback in auth.login and auth.alogin.
This commit is contained in:
@@ -1,7 +1,8 @@
|
||||
from django.contrib import auth
|
||||
from django.contrib.auth.models import User
|
||||
from django.contrib.auth.models import AnonymousUser, User
|
||||
from django.http import HttpRequest
|
||||
from django.test import TestCase
|
||||
from django.utils.deprecation import RemovedInDjango61Warning
|
||||
|
||||
|
||||
class TestLogin(TestCase):
|
||||
@@ -23,3 +24,49 @@ class TestLogin(TestCase):
|
||||
|
||||
auth.login(self.request, self.user)
|
||||
self.assertEqual(self.request.session[auth.SESSION_KEY], str(self.user.pk))
|
||||
|
||||
# RemovedInDjango61Warning: When the deprecation ends, replace with:
|
||||
# def test_without_user(self):
|
||||
def test_without_user_no_request_user(self):
|
||||
# RemovedInDjango61Warning: When the deprecation ends, replace with:
|
||||
# with self.assertRaisesMessage(
|
||||
# AttributeError,
|
||||
# "'NoneType' object has no attribute 'get_session_auth_hash'",
|
||||
# ):
|
||||
# auth.login(self.request, None)
|
||||
with (
|
||||
self.assertRaisesMessage(
|
||||
AttributeError,
|
||||
"'HttpRequest' object has no attribute 'user'",
|
||||
),
|
||||
self.assertWarnsMessage(
|
||||
RemovedInDjango61Warning,
|
||||
"Fallback to request.user when user is None will be removed.",
|
||||
),
|
||||
):
|
||||
auth.login(self.request, None)
|
||||
|
||||
# RemovedInDjango61Warning: When the deprecation ends, remove completely.
|
||||
def test_without_user_anonymous_request(self):
|
||||
self.request.user = AnonymousUser()
|
||||
with (
|
||||
self.assertRaisesMessage(
|
||||
AttributeError,
|
||||
"'AnonymousUser' object has no attribute '_meta'",
|
||||
),
|
||||
self.assertWarnsMessage(
|
||||
RemovedInDjango61Warning,
|
||||
"Fallback to request.user when user is None will be removed.",
|
||||
),
|
||||
):
|
||||
auth.login(self.request, None)
|
||||
|
||||
# RemovedInDjango61Warning: When the deprecation ends, remove completely.
|
||||
def test_without_user_authenticated_request(self):
|
||||
self.request.user = self.user
|
||||
self.assertNotIn(auth.SESSION_KEY, self.request.session)
|
||||
|
||||
msg = "Fallback to request.user when user is None will be removed."
|
||||
with self.assertWarnsMessage(RemovedInDjango61Warning, msg):
|
||||
auth.login(self.request, None)
|
||||
self.assertEqual(self.request.session[auth.SESSION_KEY], str(self.user.pk))
|
||||
|
||||
Reference in New Issue
Block a user