test_csrf.py 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. import os
  2. from django.contrib.auth.models import User
  3. from django.contrib.auth.tests.utils import skipIfCustomUser
  4. from django.test import TestCase, Client
  5. from django.test import override_settings
  6. @override_settings(
  7. LOGIN_URL='/accounts/login/',
  8. MIDDLEWARE_CLASSES=(
  9. 'django.middleware.common.CommonMiddleware',
  10. 'django.contrib.sessions.middleware.SessionMiddleware',
  11. 'django.middleware.csrf.CsrfViewMiddleware',
  12. 'django.contrib.auth.middleware.AuthenticationMiddleware',
  13. 'django.contrib.messages.middleware.MessageMiddleware',
  14. 'django.contrib.flatpages.middleware.FlatpageFallbackMiddleware',
  15. ),
  16. CSRF_FAILURE_VIEW='django.views.csrf.csrf_failure',
  17. TEMPLATE_DIRS=(
  18. os.path.join(os.path.dirname(__file__), 'templates'),
  19. ),
  20. SITE_ID=1,
  21. )
  22. class FlatpageCSRFTests(TestCase):
  23. fixtures = ['sample_flatpages', 'example_site']
  24. urls = 'django.contrib.flatpages.tests.urls'
  25. def setUp(self):
  26. self.client = Client(enforce_csrf_checks=True)
  27. def test_view_flatpage(self):
  28. "A flatpage can be served through a view, even when the middleware is in use"
  29. response = self.client.get('/flatpage_root/flatpage/')
  30. self.assertEqual(response.status_code, 200)
  31. self.assertContains(response, "<p>Isn't it flat!</p>")
  32. def test_view_non_existent_flatpage(self):
  33. "A non-existent flatpage raises 404 when served through a view, even when the middleware is in use"
  34. response = self.client.get('/flatpage_root/no_such_flatpage/')
  35. self.assertEqual(response.status_code, 404)
  36. @skipIfCustomUser
  37. def test_view_authenticated_flatpage(self):
  38. "A flatpage served through a view can require authentication"
  39. response = self.client.get('/flatpage_root/sekrit/')
  40. self.assertRedirects(response, '/accounts/login/?next=/flatpage_root/sekrit/')
  41. User.objects.create_user('testuser', 'test@example.com', 's3krit')
  42. self.client.login(username='testuser', password='s3krit')
  43. response = self.client.get('/flatpage_root/sekrit/')
  44. self.assertEqual(response.status_code, 200)
  45. self.assertContains(response, "<p>Isn't it sekrit!</p>")
  46. def test_fallback_flatpage(self):
  47. "A flatpage can be served by the fallback middleware"
  48. response = self.client.get('/flatpage/')
  49. self.assertEqual(response.status_code, 200)
  50. self.assertContains(response, "<p>Isn't it flat!</p>")
  51. def test_fallback_non_existent_flatpage(self):
  52. "A non-existent flatpage raises a 404 when served by the fallback middleware"
  53. response = self.client.get('/no_such_flatpage/')
  54. self.assertEqual(response.status_code, 404)
  55. def test_post_view_flatpage(self):
  56. "POSTing to a flatpage served through a view will raise a CSRF error if no token is provided (Refs #14156)"
  57. response = self.client.post('/flatpage_root/flatpage/')
  58. self.assertEqual(response.status_code, 403)
  59. def test_post_fallback_flatpage(self):
  60. "POSTing to a flatpage served by the middleware will raise a CSRF error if no token is provided (Refs #14156)"
  61. response = self.client.post('/flatpage/')
  62. self.assertEqual(response.status_code, 403)
  63. def test_post_unknown_page(self):
  64. "POSTing to an unknown page isn't caught as a 403 CSRF error"
  65. response = self.client.post('/no_such_page/')
  66. self.assertEqual(response.status_code, 404)