django-tos/tos/tests/test_middleware.py
2022-12-30 15:18:05 -07:00

180 lines
6.1 KiB
Python

from django.conf import settings
from django.contrib.auth import REDIRECT_FIELD_NAME, get_user_model
from django.core.cache import caches
from django.test import TestCase
from django.test.utils import modify_settings
from django.urls import reverse
from tos.middleware import UserAgreementMiddleware
from tos.models import TermsOfService, UserAgreement
from tos.signal_handlers import invalidate_cached_agreements
@modify_settings(
MIDDLEWARE={
'append': 'tos.middleware.UserAgreementMiddleware',
},
)
class TestMiddleware(TestCase):
def setUp(self):
# Clear cache between tests
cache = caches[getattr(settings, 'TOS_CACHE_NAME', 'default')]
cache.clear()
# User that has agreed to TOS
self.user1 = get_user_model().objects.create_user('user1', 'user1@example.com', 'user1pass')
# User that has not yet agreed to TOS
self.user2 = get_user_model().objects.create_user('user2', 'user2@example.com', 'user2pass')
self.user3 = get_user_model().objects.create_user('user3', 'user3@example.com', 'user3pass')
self.tos1 = TermsOfService.objects.create(
content="first edition of the terms of service",
active=True
)
self.tos2 = TermsOfService.objects.create(
content="second edition of the terms of service",
active=False
)
self.login_url = getattr(settings, 'LOGIN_URL', '/login/')
UserAgreement.objects.create(
terms_of_service=self.tos1,
user=self.user1
)
self.redirect_page = '{0}?{1}={2}'.format(
reverse('tos_check_tos'),
REDIRECT_FIELD_NAME,
reverse('index'),
)
def test_middleware_redirects(self):
"""
User that hasn't accepted TOS should be redirected to confirm. Also make sure
confirm works.
"""
self.client.login(username='user2', password='user2pass')
response = self.client.get(reverse('index'))
self.assertRedirects(response, self.redirect_page)
# Make sure confirm works after middleware redirect.
response = self.client.post(reverse('tos_check_tos'), {'accept': 'accept'})
# Confirm redirects.
self.assertEqual(response.status_code, 302)
def test_invalidate_cache_on_accept_fix_redirect_loop(self):
"""
Make sure accepting doesnt send you right back to tos page.
"""
self.assertFalse(UserAgreement.objects.filter(terms_of_service=self.tos1, user=self.user2).exists())
self.client.login(username='user2', password='user2pass')
response = self.client.get(reverse('index'))
self.assertRedirects(response, self.redirect_page)
# Make sure confirm works after middleware redirect.
response = self.client.post(reverse('tos_check_tos'), {'accept': 'accept'})
self.assertTrue(UserAgreement.objects.filter(terms_of_service=self.tos1, user=self.user2).exists())
response = self.client.get(reverse('index'))
self.assertEqual(response.status_code, 200)
self.assertIn('index', str(response.content))
def test_middleware_doesnt_redirect(self):
"""User that has accepted TOS should get 200."""
self.client.login(username='user1', password='user1pass')
response = self.client.get(reverse('index'))
self.assertEqual(response.status_code, 200)
def test_anonymous_user_200(self):
response = self.client.get(reverse('index'))
self.assertEqual(response.status_code, 200)
def test_accept_after_middleware_redirects_properly(self):
self.client.login(username='user3', password='user3pass')
response = self.client.get(reverse('index'), follow=True)
self.assertRedirects(response, self.redirect_page)
# Agree
response = self.client.post(self.redirect_page, {'accept': 'accept'})
# Confirm redirects back to the index page
self.assertEqual(response.status_code, 302)
self.assertEqual(response.url.replace('http://testserver', ''), str(reverse('index')))
@modify_settings(
MIDDLEWARE={
'append': 'tos.middleware.UserAgreementMiddleware',
},
)
class BumpCoverage(TestCase):
def setUp(self):
# User that has agreed to TOS
self.user1 = get_user_model().objects.create_user('user1', 'user1@example.com', 'user1pass')
self.tos1 = TermsOfService.objects.create(
content="first edition of the terms of service",
active=True
)
self.tos2 = TermsOfService.objects.create(
content="second edition of the terms of service",
active=False
)
self.login_url = getattr(settings, 'LOGIN_URL', '/login/')
UserAgreement.objects.create(
terms_of_service=self.tos1,
user=self.user1
)
def test_ajax_request(self):
class Request(object):
method = 'GET'
META = {
'HTTP_X_REQUESTED_WITH': 'XMLHttpRequest'
}
def is_ajax(self):
return True
mw = UserAgreementMiddleware()
response = mw.process_request(Request())
self.assertIsNone(response)
def test_skip_for_user(self):
cache = caches[getattr(settings, 'TOS_CACHE_NAME', 'default')]
key_version = cache.get('django:tos:key_version')
cache.set(f'django:tos:skip_tos_check:{self.user1.id}', True, version=key_version)
self.client.login(username='user1', password='user1pass')
response = self.client.get(reverse('index'))
self.assertEqual(response.status_code, 200)
def test_invalidate_cached_agreements(self):
cache = caches[getattr(settings, 'TOS_CACHE_NAME', 'default')]
invalidate_cached_agreements(TermsOfService)
key_version = cache.get('django:tos:key_version')
invalidate_cached_agreements(TermsOfService)
self.assertEqual(cache.get('django:tos:key_version'), key_version+1)
invalidate_cached_agreements(TermsOfService, raw=True)
self.assertEqual(cache.get('django:tos:key_version'), key_version+1)