1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- import warnings
- from django.contrib.auth import authenticate
- from django.test import SimpleTestCase, override_settings
- mock_request = object()
- mock_backend = object()
- class NoRequestBackend:
- def authenticate(self, username=None, password=None):
-
- pass
- class RequestNotPositionArgBackend:
- def authenticate(self, username=None, password=None, request=None):
- assert username == 'username'
- assert password == 'pass'
- assert request is mock_request
- class RequestNotPositionArgWithUsedKwargBackend:
- def authenticate(self, username=None, password=None, request=None, backend=None):
- assert username == 'username'
- assert password == 'pass'
- assert request is mock_request
- assert backend is mock_backend
- class AcceptsRequestBackendTest(SimpleTestCase):
- """
- A deprecation warning is shown for backends that have an authenticate()
- method without a request parameter.
- """
- no_request_backend = '%s.NoRequestBackend' % __name__
- request_not_positional_backend = '%s.RequestNotPositionArgBackend' % __name__
- request_not_positional_with_used_kwarg_backend = '%s.RequestNotPositionArgWithUsedKwargBackend' % __name__
- @override_settings(AUTHENTICATION_BACKENDS=[no_request_backend])
- def test_no_request_deprecation_warning(self):
- with warnings.catch_warnings(record=True) as warns:
- warnings.simplefilter('always')
- authenticate(username='test', password='test')
- self.assertEqual(len(warns), 1)
- self.assertEqual(
- str(warns[0].message),
- "Update %s.authenticate() to accept a positional `request` "
- "argument." % self.no_request_backend
- )
- @override_settings(AUTHENTICATION_BACKENDS=[request_not_positional_backend])
- def test_request_keyword_arg_deprecation_warning(self):
- with warnings.catch_warnings(record=True) as warns:
- warnings.simplefilter('always')
- authenticate(username='username', password='pass', request=mock_request)
- self.assertEqual(len(warns), 1)
- self.assertEqual(
- str(warns[0].message),
- "In %s.authenticate(), move the `request` keyword argument to the "
- "first positional argument." % self.request_not_positional_backend
- )
- @override_settings(AUTHENTICATION_BACKENDS=[request_not_positional_backend, no_request_backend])
- def test_both_types_of_deprecation_warning(self):
- with warnings.catch_warnings(record=True) as warns:
- warnings.simplefilter('always')
- authenticate(mock_request, username='username', password='pass')
- self.assertEqual(len(warns), 2)
- self.assertEqual(
- str(warns[0].message),
- "In %s.authenticate(), move the `request` keyword argument to the "
- "first positional argument." % self.request_not_positional_backend
- )
- self.assertEqual(
- str(warns[1].message),
- "Update %s.authenticate() to accept a positional `request` "
- "argument." % self.no_request_backend
- )
- @override_settings(AUTHENTICATION_BACKENDS=[request_not_positional_with_used_kwarg_backend])
- def test_handles_backend_in_kwargs(self):
- with warnings.catch_warnings(record=True) as warns:
- warnings.simplefilter('always')
- authenticate(username='username', password='pass', request=mock_request, backend=mock_backend)
- self.assertEqual(len(warns), 1)
- self.assertEqual(
- str(warns[0].message),
- "In %s.authenticate(), move the `request` keyword argument to the "
- "first positional argument." % self.request_not_positional_with_used_kwarg_backend
- )
|