test_csrf.py 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. from django.contrib.auth.models import User
  2. from django.contrib.flatpages.models import FlatPage
  3. from django.contrib.sites.models import Site
  4. from django.test import Client, TestCase, modify_settings, override_settings
  5. from django.test.utils import ignore_warnings
  6. from django.utils.deprecation import RemovedInDjango20Warning
  7. from .settings import FLATPAGES_TEMPLATES
  8. @modify_settings(INSTALLED_APPS={'append': 'django.contrib.flatpages'})
  9. @override_settings(
  10. LOGIN_URL='/accounts/login/',
  11. MIDDLEWARE=[
  12. 'django.middleware.common.CommonMiddleware',
  13. 'django.contrib.sessions.middleware.SessionMiddleware',
  14. 'django.middleware.csrf.CsrfViewMiddleware',
  15. 'django.contrib.auth.middleware.AuthenticationMiddleware',
  16. 'django.contrib.messages.middleware.MessageMiddleware',
  17. 'django.contrib.flatpages.middleware.FlatpageFallbackMiddleware',
  18. ],
  19. ROOT_URLCONF='flatpages_tests.urls',
  20. CSRF_FAILURE_VIEW='django.views.csrf.csrf_failure',
  21. TEMPLATES=FLATPAGES_TEMPLATES,
  22. SITE_ID=1,
  23. )
  24. class FlatpageCSRFTests(TestCase):
  25. @classmethod
  26. def setUpTestData(cls):
  27. # don't use the manager because we want to ensure the site exists
  28. # with pk=1, regardless of whether or not it already exists.
  29. cls.site1 = Site(pk=1, domain='example.com', name='example.com')
  30. cls.site1.save()
  31. cls.fp1 = FlatPage.objects.create(
  32. url='/flatpage/', title='A Flatpage', content="Isn't it flat!",
  33. enable_comments=False, template_name='', registration_required=False
  34. )
  35. cls.fp2 = FlatPage.objects.create(
  36. url='/location/flatpage/', title='A Nested Flatpage', content="Isn't it flat and deep!",
  37. enable_comments=False, template_name='', registration_required=False
  38. )
  39. cls.fp3 = FlatPage.objects.create(
  40. url='/sekrit/', title='Sekrit Flatpage', content="Isn't it sekrit!",
  41. enable_comments=False, template_name='', registration_required=True
  42. )
  43. cls.fp4 = FlatPage.objects.create(
  44. url='/location/sekrit/', title='Sekrit Nested Flatpage', content="Isn't it sekrit and deep!",
  45. enable_comments=False, template_name='', registration_required=True
  46. )
  47. cls.fp1.sites.add(cls.site1)
  48. cls.fp2.sites.add(cls.site1)
  49. cls.fp3.sites.add(cls.site1)
  50. cls.fp4.sites.add(cls.site1)
  51. def setUp(self):
  52. self.client = Client(enforce_csrf_checks=True)
  53. def test_view_flatpage(self):
  54. "A flatpage can be served through a view, even when the middleware is in use"
  55. response = self.client.get('/flatpage_root/flatpage/')
  56. self.assertContains(response, "<p>Isn't it flat!</p>")
  57. def test_view_non_existent_flatpage(self):
  58. "A non-existent flatpage raises 404 when served through a view, even when the middleware is in use"
  59. response = self.client.get('/flatpage_root/no_such_flatpage/')
  60. self.assertEqual(response.status_code, 404)
  61. def test_view_authenticated_flatpage(self):
  62. "A flatpage served through a view can require authentication"
  63. response = self.client.get('/flatpage_root/sekrit/')
  64. self.assertRedirects(response, '/accounts/login/?next=/flatpage_root/sekrit/')
  65. user = User.objects.create_user('testuser', 'test@example.com', 's3krit')
  66. self.client.force_login(user)
  67. response = self.client.get('/flatpage_root/sekrit/')
  68. self.assertContains(response, "<p>Isn't it sekrit!</p>")
  69. def test_fallback_flatpage(self):
  70. "A flatpage can be served by the fallback middleware"
  71. response = self.client.get('/flatpage/')
  72. self.assertContains(response, "<p>Isn't it flat!</p>")
  73. def test_fallback_non_existent_flatpage(self):
  74. "A non-existent flatpage raises a 404 when served by the fallback middleware"
  75. response = self.client.get('/no_such_flatpage/')
  76. self.assertEqual(response.status_code, 404)
  77. def test_post_view_flatpage(self):
  78. "POSTing to a flatpage served through a view will raise a CSRF error if no token is provided (Refs #14156)"
  79. response = self.client.post('/flatpage_root/flatpage/')
  80. self.assertEqual(response.status_code, 403)
  81. def test_post_fallback_flatpage(self):
  82. "POSTing to a flatpage served by the middleware will raise a CSRF error if no token is provided (Refs #14156)"
  83. response = self.client.post('/flatpage/')
  84. self.assertEqual(response.status_code, 403)
  85. def test_post_unknown_page(self):
  86. "POSTing to an unknown page isn't caught as a 403 CSRF error"
  87. response = self.client.post('/no_such_page/')
  88. self.assertEqual(response.status_code, 404)
  89. @ignore_warnings(category=RemovedInDjango20Warning)
  90. @override_settings(
  91. MIDDLEWARE=None,
  92. MIDDLEWARE_CLASSES=[
  93. 'django.middleware.common.CommonMiddleware',
  94. 'django.contrib.sessions.middleware.SessionMiddleware',
  95. 'django.middleware.csrf.CsrfViewMiddleware',
  96. 'django.contrib.auth.middleware.AuthenticationMiddleware',
  97. 'django.contrib.messages.middleware.MessageMiddleware',
  98. 'django.contrib.flatpages.middleware.FlatpageFallbackMiddleware',
  99. ],
  100. )
  101. class FlatpageCSRFMiddlewareClassesTests(FlatpageCSRFTests):
  102. pass