Fixed #10460: the logout view can now redirect like the rest of the auth views. Thanks, chronos and steingrd.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@10332 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
35a1f22bc2
commit
3e6f4674e2
|
@ -1,6 +1,6 @@
|
||||||
from django.contrib.auth.tests.basic import BASIC_TESTS
|
from django.contrib.auth.tests.basic import BASIC_TESTS
|
||||||
from django.contrib.auth.tests.views \
|
from django.contrib.auth.tests.views \
|
||||||
import PasswordResetTest, ChangePasswordTest, LoginTest
|
import PasswordResetTest, ChangePasswordTest, LoginTest, LogoutTest
|
||||||
from django.contrib.auth.tests.forms import FORM_TESTS
|
from django.contrib.auth.tests.forms import FORM_TESTS
|
||||||
from django.contrib.auth.tests.remote_user \
|
from django.contrib.auth.tests.remote_user \
|
||||||
import RemoteUserTest, RemoteUserNoCreateTest, RemoteUserCustomTest
|
import RemoteUserTest, RemoteUserNoCreateTest, RemoteUserCustomTest
|
||||||
|
@ -15,4 +15,5 @@ __test__ = {
|
||||||
'TOKEN_GENERATOR_TESTS': TOKEN_GENERATOR_TESTS,
|
'TOKEN_GENERATOR_TESTS': TOKEN_GENERATOR_TESTS,
|
||||||
'CHANGEPASSWORD_TESTS': ChangePasswordTest,
|
'CHANGEPASSWORD_TESTS': ChangePasswordTest,
|
||||||
'LOGIN_TESTS': LoginTest,
|
'LOGIN_TESTS': LoginTest,
|
||||||
|
'LOGOUT_TESTS': LogoutTest,
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
from django.conf.urls.defaults import patterns
|
||||||
|
from django.contrib.auth.urls import urlpatterns
|
||||||
|
|
||||||
|
# special urls for auth test cases
|
||||||
|
urlpatterns += patterns('',
|
||||||
|
(r'^logout/custom_query/$', 'django.contrib.auth.views.logout', dict(redirect_field_name='follow')),
|
||||||
|
(r'^logout/next_page/$', 'django.contrib.auth.views.logout', dict(next_page='/somewhere/')),
|
||||||
|
)
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
from django.contrib.auth import SESSION_KEY
|
||||||
from django.contrib.auth.forms import AuthenticationForm
|
from django.contrib.auth.forms import AuthenticationForm
|
||||||
from django.contrib.sites.models import Site, RequestSite
|
from django.contrib.sites.models import Site, RequestSite
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
|
@ -185,3 +185,51 @@ class LoginTest(TestCase):
|
||||||
self.assert_(isinstance(response.context['form'], AuthenticationForm),
|
self.assert_(isinstance(response.context['form'], AuthenticationForm),
|
||||||
'Login form is not an AuthenticationForm')
|
'Login form is not an AuthenticationForm')
|
||||||
|
|
||||||
|
class LogoutTest(TestCase):
|
||||||
|
fixtures = ['authtestdata.json']
|
||||||
|
urls = 'django.contrib.auth.tests.urls'
|
||||||
|
|
||||||
|
def login(self, password='password'):
|
||||||
|
response = self.client.post('/login/', {
|
||||||
|
'username': 'testclient',
|
||||||
|
'password': password
|
||||||
|
}
|
||||||
|
)
|
||||||
|
self.assertEquals(response.status_code, 302)
|
||||||
|
self.assert_(response['Location'].endswith(settings.LOGIN_REDIRECT_URL))
|
||||||
|
self.assert_(SESSION_KEY in self.client.session)
|
||||||
|
|
||||||
|
def confirm_logged_out(self):
|
||||||
|
self.assert_(SESSION_KEY not in self.client.session)
|
||||||
|
|
||||||
|
def test_logout_default(self):
|
||||||
|
"Logout without next_page option renders the default template"
|
||||||
|
self.login()
|
||||||
|
response = self.client.get('/logout/')
|
||||||
|
self.assertEquals(200, response.status_code)
|
||||||
|
self.assert_('Logged out' in response.content)
|
||||||
|
self.confirm_logged_out()
|
||||||
|
|
||||||
|
def test_logout_with_next_page_specified(self):
|
||||||
|
"Logout with next_page option given redirects to specified resource"
|
||||||
|
self.login()
|
||||||
|
response = self.client.get('/logout/next_page/')
|
||||||
|
self.assertEqual(response.status_code, 302)
|
||||||
|
self.assert_(response['Location'].endswith('/somewhere/'))
|
||||||
|
self.confirm_logged_out()
|
||||||
|
|
||||||
|
def test_logout_with_redirect_argument(self):
|
||||||
|
"Logout with query string redirects to specified resource"
|
||||||
|
self.login()
|
||||||
|
response = self.client.get('/logout/?next=/login/')
|
||||||
|
self.assertEqual(response.status_code, 302)
|
||||||
|
self.assert_(response['Location'].endswith('/login/'))
|
||||||
|
self.confirm_logged_out()
|
||||||
|
|
||||||
|
def test_logout_with_custom_redirect_argument(self):
|
||||||
|
"Logout with custom query string redirects to specified resource"
|
||||||
|
self.login()
|
||||||
|
response = self.client.get('/logout/custom_query/?follow=/somewhere/')
|
||||||
|
self.assertEqual(response.status_code, 302)
|
||||||
|
self.assert_(response['Location'].endswith('/somewhere/'))
|
||||||
|
self.confirm_logged_out()
|
|
@ -43,12 +43,18 @@ def login(request, template_name='registration/login.html', redirect_field_name=
|
||||||
}, context_instance=RequestContext(request))
|
}, context_instance=RequestContext(request))
|
||||||
login = never_cache(login)
|
login = never_cache(login)
|
||||||
|
|
||||||
def logout(request, next_page=None, template_name='registration/logged_out.html'):
|
def logout(request, next_page=None, template_name='registration/logged_out.html', redirect_field_name=REDIRECT_FIELD_NAME):
|
||||||
"Logs out the user and displays 'You are logged out' message."
|
"Logs out the user and displays 'You are logged out' message."
|
||||||
from django.contrib.auth import logout
|
from django.contrib.auth import logout
|
||||||
logout(request)
|
logout(request)
|
||||||
if next_page is None:
|
if next_page is None:
|
||||||
return render_to_response(template_name, {'title': _('Logged out')}, context_instance=RequestContext(request))
|
redirect_to = request.REQUEST.get(redirect_field_name, '')
|
||||||
|
if redirect_to:
|
||||||
|
return HttpResponseRedirect(redirect_to)
|
||||||
|
else:
|
||||||
|
return render_to_response(template_name, {
|
||||||
|
'title': _('Logged out')
|
||||||
|
}, context_instance=RequestContext(request))
|
||||||
else:
|
else:
|
||||||
# Redirect to this page until the session has been cleared.
|
# Redirect to this page until the session has been cleared.
|
||||||
return HttpResponseRedirect(next_page or request.path)
|
return HttpResponseRedirect(next_page or request.path)
|
||||||
|
|
Loading…
Reference in New Issue