123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- from django.conf import settings
- from django.contrib.auth.models import User
- from django.contrib.flatpages.models import FlatPage
- from django.test import TestCase, modify_settings, override_settings
- from .settings import FLATPAGES_TEMPLATES
- @modify_settings(INSTALLED_APPS={'append': 'django.contrib.flatpages'})
- @override_settings(
- LOGIN_URL='/accounts/login/',
- MIDDLEWARE_CLASSES=[
- 'django.middleware.common.CommonMiddleware',
- 'django.contrib.sessions.middleware.SessionMiddleware',
- 'django.middleware.csrf.CsrfViewMiddleware',
- 'django.contrib.auth.middleware.AuthenticationMiddleware',
- 'django.contrib.messages.middleware.MessageMiddleware',
- 'django.contrib.flatpages.middleware.FlatpageFallbackMiddleware',
- ],
- ROOT_URLCONF='flatpages_tests.urls',
- TEMPLATES=FLATPAGES_TEMPLATES,
- SITE_ID=1,
- )
- class FlatpageMiddlewareTests(TestCase):
- fixtures = ['sample_flatpages', 'example_site']
- def test_view_flatpage(self):
- "A flatpage can be served through a view, even when the middleware is in use"
- response = self.client.get('/flatpage_root/flatpage/')
- self.assertEqual(response.status_code, 200)
- self.assertContains(response, "<p>Isn't it flat!</p>")
- def test_view_non_existent_flatpage(self):
- "A non-existent flatpage raises 404 when served through a view, even when the middleware is in use"
- response = self.client.get('/flatpage_root/no_such_flatpage/')
- self.assertEqual(response.status_code, 404)
- def test_view_authenticated_flatpage(self):
- "A flatpage served through a view can require authentication"
- response = self.client.get('/flatpage_root/sekrit/')
- self.assertRedirects(response, '/accounts/login/?next=/flatpage_root/sekrit/')
- User.objects.create_user('testuser', 'test@example.com', 's3krit')
- self.client.login(username='testuser', password='s3krit')
- response = self.client.get('/flatpage_root/sekrit/')
- self.assertEqual(response.status_code, 200)
- self.assertContains(response, "<p>Isn't it sekrit!</p>")
- def test_fallback_flatpage(self):
- "A flatpage can be served by the fallback middleware"
- response = self.client.get('/flatpage/')
- self.assertEqual(response.status_code, 200)
- self.assertContains(response, "<p>Isn't it flat!</p>")
- def test_fallback_non_existent_flatpage(self):
- "A non-existent flatpage raises a 404 when served by the fallback middleware"
- response = self.client.get('/no_such_flatpage/')
- self.assertEqual(response.status_code, 404)
- def test_fallback_authenticated_flatpage(self):
- "A flatpage served by the middleware can require authentication"
- response = self.client.get('/sekrit/')
- self.assertRedirects(response, '/accounts/login/?next=/sekrit/')
- User.objects.create_user('testuser', 'test@example.com', 's3krit')
- self.client.login(username='testuser', password='s3krit')
- response = self.client.get('/sekrit/')
- self.assertEqual(response.status_code, 200)
- self.assertContains(response, "<p>Isn't it sekrit!</p>")
- def test_fallback_flatpage_special_chars(self):
- "A flatpage with special chars in the URL can be served by the fallback middleware"
- fp = FlatPage.objects.create(
- url="/some.very_special~chars-here/",
- title="A very special page",
- content="Isn't it special!",
- enable_comments=False,
- registration_required=False,
- )
- fp.sites.add(settings.SITE_ID)
- response = self.client.get('/some.very_special~chars-here/')
- self.assertEqual(response.status_code, 200)
- self.assertContains(response, "<p>Isn't it special!</p>")
- @modify_settings(INSTALLED_APPS={'append': 'django.contrib.flatpages'})
- @override_settings(
- APPEND_SLASH=True,
- LOGIN_URL='/accounts/login/',
- MIDDLEWARE_CLASSES=[
- 'django.middleware.common.CommonMiddleware',
- 'django.contrib.sessions.middleware.SessionMiddleware',
- 'django.middleware.csrf.CsrfViewMiddleware',
- 'django.contrib.auth.middleware.AuthenticationMiddleware',
- 'django.contrib.messages.middleware.MessageMiddleware',
- 'django.contrib.flatpages.middleware.FlatpageFallbackMiddleware',
- ],
- ROOT_URLCONF='flatpages_tests.urls',
- TEMPLATES=FLATPAGES_TEMPLATES,
- SITE_ID=1,
- )
- class FlatpageMiddlewareAppendSlashTests(TestCase):
- fixtures = ['sample_flatpages', 'example_site']
- def test_redirect_view_flatpage(self):
- "A flatpage can be served through a view and should add a slash"
- response = self.client.get('/flatpage_root/flatpage')
- self.assertRedirects(response, '/flatpage_root/flatpage/', status_code=301)
- def test_redirect_view_non_existent_flatpage(self):
- "A non-existent flatpage raises 404 when served through a view and should not add a slash"
- response = self.client.get('/flatpage_root/no_such_flatpage')
- self.assertEqual(response.status_code, 404)
- def test_redirect_fallback_flatpage(self):
- "A flatpage can be served by the fallback middleware and should add a slash"
- response = self.client.get('/flatpage')
- self.assertRedirects(response, '/flatpage/', status_code=301)
- def test_redirect_fallback_non_existent_flatpage(self):
- "A non-existent flatpage raises a 404 when served by the fallback middleware and should not add a slash"
- response = self.client.get('/no_such_flatpage')
- self.assertEqual(response.status_code, 404)
- def test_redirect_fallback_flatpage_special_chars(self):
- "A flatpage with special chars in the URL can be served by the fallback middleware and should add a slash"
- fp = FlatPage.objects.create(
- url="/some.very_special~chars-here/",
- title="A very special page",
- content="Isn't it special!",
- enable_comments=False,
- registration_required=False,
- )
- fp.sites.add(settings.SITE_ID)
- response = self.client.get('/some.very_special~chars-here')
- self.assertRedirects(response, '/some.very_special~chars-here/', status_code=301)
- def test_redirect_fallback_flatpage_root(self):
- "A flatpage at / should not cause a redirect loop when APPEND_SLASH is set"
- fp = FlatPage.objects.create(
- url="/",
- title="Root",
- content="Root",
- enable_comments=False,
- registration_required=False,
- )
- fp.sites.add(settings.SITE_ID)
- response = self.client.get('/')
- self.assertEqual(response.status_code, 200)
- self.assertContains(response, "<p>Root</p>")
|