Full coverage auth view
This commit is contained in:
parent
327a47566f
commit
87a877b91c
1 changed files with 29 additions and 3 deletions
|
@ -264,8 +264,8 @@ class LoginTestCase(TestCase):
|
||||||
"""Check we only keep the last 100 Login Ticket for a user"""
|
"""Check we only keep the last 100 Login Ticket for a user"""
|
||||||
client, params = get_login_page_params()
|
client, params = get_login_page_params()
|
||||||
current_lt = params["lt"]
|
current_lt = params["lt"]
|
||||||
i_in_test = random.randint(0, 100)
|
i_in_test = random.randint(0, 99)
|
||||||
i_not_in_test = random.randint(100, 150)
|
i_not_in_test = random.randint(101, 150)
|
||||||
for i in range(150):
|
for i in range(150):
|
||||||
if i == i_in_test:
|
if i == i_in_test:
|
||||||
self.assertTrue(current_lt in client.session['lt'])
|
self.assertTrue(current_lt in client.session['lt'])
|
||||||
|
@ -708,8 +708,12 @@ class LogoutTestCase(TestCase):
|
||||||
|
|
||||||
|
|
||||||
class AuthTestCase(TestCase):
|
class AuthTestCase(TestCase):
|
||||||
|
"""
|
||||||
|
Test for the auth view, used for external services
|
||||||
|
to validate (user, pass, service) tuples.
|
||||||
|
"""
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
|
"""preparing test context"""
|
||||||
settings.CAS_AUTH_CLASS = 'cas_server.auth.TestAuthUser'
|
settings.CAS_AUTH_CLASS = 'cas_server.auth.TestAuthUser'
|
||||||
self.service = 'https://www.example.com'
|
self.service = 'https://www.example.com'
|
||||||
models.ServicePattern.objects.create(
|
models.ServicePattern.objects.create(
|
||||||
|
@ -718,6 +722,7 @@ class AuthTestCase(TestCase):
|
||||||
)
|
)
|
||||||
|
|
||||||
def test_auth_view_goodpass(self):
|
def test_auth_view_goodpass(self):
|
||||||
|
"""successful request are awsered by yes"""
|
||||||
settings.CAS_AUTH_SHARED_SECRET = 'test'
|
settings.CAS_AUTH_SHARED_SECRET = 'test'
|
||||||
client = Client()
|
client = Client()
|
||||||
response = client.post(
|
response = client.post(
|
||||||
|
@ -733,6 +738,7 @@ class AuthTestCase(TestCase):
|
||||||
self.assertEqual(response.content, b'yes\n')
|
self.assertEqual(response.content, b'yes\n')
|
||||||
|
|
||||||
def test_auth_view_badpass(self):
|
def test_auth_view_badpass(self):
|
||||||
|
""" bag user password => no"""
|
||||||
settings.CAS_AUTH_SHARED_SECRET = 'test'
|
settings.CAS_AUTH_SHARED_SECRET = 'test'
|
||||||
client = Client()
|
client = Client()
|
||||||
response = client.post(
|
response = client.post(
|
||||||
|
@ -748,6 +754,7 @@ class AuthTestCase(TestCase):
|
||||||
self.assertEqual(response.content, b'no\n')
|
self.assertEqual(response.content, b'no\n')
|
||||||
|
|
||||||
def test_auth_view_badservice(self):
|
def test_auth_view_badservice(self):
|
||||||
|
"""bad service => no"""
|
||||||
settings.CAS_AUTH_SHARED_SECRET = 'test'
|
settings.CAS_AUTH_SHARED_SECRET = 'test'
|
||||||
client = Client()
|
client = Client()
|
||||||
response = client.post(
|
response = client.post(
|
||||||
|
@ -763,6 +770,7 @@ class AuthTestCase(TestCase):
|
||||||
self.assertEqual(response.content, b'no\n')
|
self.assertEqual(response.content, b'no\n')
|
||||||
|
|
||||||
def test_auth_view_badsecret(self):
|
def test_auth_view_badsecret(self):
|
||||||
|
"""bad api key => no"""
|
||||||
settings.CAS_AUTH_SHARED_SECRET = 'test'
|
settings.CAS_AUTH_SHARED_SECRET = 'test'
|
||||||
client = Client()
|
client = Client()
|
||||||
response = client.post(
|
response = client.post(
|
||||||
|
@ -778,6 +786,7 @@ class AuthTestCase(TestCase):
|
||||||
self.assertEqual(response.content, b'no\n')
|
self.assertEqual(response.content, b'no\n')
|
||||||
|
|
||||||
def test_auth_view_badsettings(self):
|
def test_auth_view_badsettings(self):
|
||||||
|
"""api not set => error"""
|
||||||
settings.CAS_AUTH_SHARED_SECRET = None
|
settings.CAS_AUTH_SHARED_SECRET = None
|
||||||
client = Client()
|
client = Client()
|
||||||
response = client.post(
|
response = client.post(
|
||||||
|
@ -792,6 +801,23 @@ class AuthTestCase(TestCase):
|
||||||
self.assertEqual(response.status_code, 200)
|
self.assertEqual(response.status_code, 200)
|
||||||
self.assertEqual(response.content, b"no\nplease set CAS_AUTH_SHARED_SECRET")
|
self.assertEqual(response.content, b"no\nplease set CAS_AUTH_SHARED_SECRET")
|
||||||
|
|
||||||
|
def test_auth_view_missing_parameter(self):
|
||||||
|
"""missing parameter in request => no"""
|
||||||
|
settings.CAS_AUTH_SHARED_SECRET = 'test'
|
||||||
|
client = Client()
|
||||||
|
params = {
|
||||||
|
'username': settings.CAS_TEST_USER,
|
||||||
|
'password': settings.CAS_TEST_PASSWORD,
|
||||||
|
'service': self.service,
|
||||||
|
'secret': 'test'
|
||||||
|
}
|
||||||
|
for key in ['username', 'password', 'service']:
|
||||||
|
send_params = params.copy()
|
||||||
|
del send_params[key]
|
||||||
|
response = client.post('/auth', send_params)
|
||||||
|
self.assertEqual(response.status_code, 200)
|
||||||
|
self.assertEqual(response.content, b'no\n')
|
||||||
|
|
||||||
|
|
||||||
class ValidateTestCase(TestCase):
|
class ValidateTestCase(TestCase):
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue