123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- from django.contrib.auth import authenticate
- from django.contrib.auth.context_processors import PermLookupDict, PermWrapper
- from django.contrib.auth.models import Permission, User
- from django.contrib.contenttypes.models import ContentType
- from django.db.models import Q
- from django.test import TestCase, override_settings
- from .settings import AUTH_MIDDLEWARE_CLASSES, AUTH_TEMPLATES
- class MockUser(object):
- def has_module_perms(self, perm):
- if perm == 'mockapp':
- return True
- return False
- def has_perm(self, perm):
- if perm == 'mockapp.someperm':
- return True
- return False
- class PermWrapperTests(TestCase):
- """
- Test some details of the PermWrapper implementation.
- """
- class EQLimiterObject(object):
- """
- This object makes sure __eq__ will not be called endlessly.
- """
- def __init__(self):
- self.eq_calls = 0
- def __eq__(self, other):
- if self.eq_calls > 0:
- return True
- self.eq_calls += 1
- return False
- def test_permwrapper_in(self):
- """
- Test that 'something' in PermWrapper works as expected.
- """
- perms = PermWrapper(MockUser())
-
- self.assertIn('mockapp', perms)
- self.assertNotIn('nonexisting', perms)
- self.assertIn('mockapp.someperm', perms)
- self.assertNotIn('mockapp.nonexisting', perms)
- def test_permlookupdict_in(self):
- """
- No endless loops if accessed with 'in' - refs #18979.
- """
- pldict = PermLookupDict(MockUser(), 'mockapp')
- with self.assertRaises(TypeError):
- self.EQLimiterObject() in pldict
- @override_settings(
- PASSWORD_HASHERS=['django.contrib.auth.hashers.SHA1PasswordHasher'],
- ROOT_URLCONF='auth_tests.urls',
- TEMPLATES=AUTH_TEMPLATES,
- USE_TZ=False,
- )
- class AuthContextProcessorTests(TestCase):
- """
- Tests for the ``django.contrib.auth.context_processors.auth`` processor
- """
- fixtures = ['context-processors-users.xml']
- @override_settings(MIDDLEWARE_CLASSES=AUTH_MIDDLEWARE_CLASSES)
- def test_session_not_accessed(self):
- """
- Tests that the session is not accessed simply by including
- the auth context processor
- """
- response = self.client.get('/auth_processor_no_attr_access/')
- self.assertContains(response, "Session not accessed")
- @override_settings(MIDDLEWARE_CLASSES=AUTH_MIDDLEWARE_CLASSES)
- def test_session_is_accessed(self):
- """
- Tests that the session is accessed if the auth context processor
- is used and relevant attributes accessed.
- """
- response = self.client.get('/auth_processor_attr_access/')
- self.assertContains(response, "Session accessed")
- def test_perms_attrs(self):
- u = User.objects.create_user(username='normal', password='secret')
- u.user_permissions.add(
- Permission.objects.get(
- content_type=ContentType.objects.get_for_model(Permission),
- codename='add_permission'))
- self.client.login(username='normal', password='secret')
- response = self.client.get('/auth_processor_perms/')
- self.assertContains(response, "Has auth permissions")
- self.assertContains(response, "Has auth.add_permission permissions")
- self.assertNotContains(response, "nonexisting")
- def test_perm_in_perms_attrs(self):
- u = User.objects.create_user(username='normal', password='secret')
- u.user_permissions.add(
- Permission.objects.get(
- content_type=ContentType.objects.get_for_model(Permission),
- codename='add_permission'))
- self.client.login(username='normal', password='secret')
- response = self.client.get('/auth_processor_perm_in_perms/')
- self.assertContains(response, "Has auth permissions")
- self.assertContains(response, "Has auth.add_permission permissions")
- self.assertNotContains(response, "nonexisting")
- def test_message_attrs(self):
- self.client.login(username='super', password='secret')
- response = self.client.get('/auth_processor_messages/')
- self.assertContains(response, "Message 1")
- def test_user_attrs(self):
- """
- Test that the lazy objects returned behave just like the wrapped objects.
- """
-
-
-
- self.client.login(username='super', password='secret')
- user = authenticate(username='super', password='secret')
- response = self.client.get('/auth_processor_user/')
- self.assertContains(response, "unicode: super")
- self.assertContains(response, "id: 100")
- self.assertContains(response, "username: super")
-
- self.assertContains(response, "url: /userpage/super/")
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Q(user=response.context['user']) & Q(someflag=True)
-
-
-
- self.assertEqual(response.context['user'], user)
- self.assertEqual(user, response.context['user'])
|