From 19a225841fb8b4dba3f2629e59c684a6d501432f Mon Sep 17 00:00:00 2001 From: Christopher Bunn Date: Mon, 10 Mar 2014 20:46:40 -0400 Subject: [PATCH] Redirect unauthenticated users to contrib.auth's login URL if trying to access a page behind the beta wall. Updates also include adjustment to applicable test scenario, plus URL and template support for basic contrib.auth in testing app. --- hunger/middleware.py | 3 ++- tests/templates/registration/login.html | 0 tests/tests.py | 3 ++- tests/urls.py | 1 + 4 files changed, 5 insertions(+), 2 deletions(-) create mode 100644 tests/templates/registration/login.html diff --git a/hunger/middleware.py b/hunger/middleware.py index 7a768b1..d17d9ab 100644 --- a/hunger/middleware.py +++ b/hunger/middleware.py @@ -83,7 +83,8 @@ def process_view(self, request, view_func, view_args, view_kwargs): return if not request.user.is_authenticated(): - return redirect(self.redirect) + # Ask anonymous user to log in if trying to access in-beta view + return redirect(setting('LOGIN_URL')) if request.user.is_staff: return diff --git a/tests/templates/registration/login.html b/tests/templates/registration/login.html new file mode 100644 index 0000000..e69de29 diff --git a/tests/tests.py b/tests/tests.py index 7442b2d..1c9b1e1 100644 --- a/tests/tests.py +++ b/tests/tests.py @@ -54,8 +54,9 @@ def test_always_allow_module(self): self.assertEqual(response.status_code, 200) def test_garden_when_not_invited(self): + """Confirm that an unauthenticated user is redirected to login""" response = self.client.get(reverse('invited_only')) - self.assertRedirects(response, reverse(self.redirect)) + self.assertRedirects(response, setting('LOGIN_URL')) def test_using_invite(self): cary = User.objects.create_user('cary', 'cary@example.com', 'secret') diff --git a/tests/urls.py b/tests/urls.py index 5556afa..5831996 100644 --- a/tests/urls.py +++ b/tests/urls.py @@ -8,4 +8,5 @@ name='always_allow_module'), url(r'^not-allowed/$', 'tests.views.rejection', name='rejection'), url(r'^hunger/', include('hunger.urls')), + url(r'^accounts/', include('django.contrib.auth.urls')) )