Merge pull request #60 from mgius/195_auth_views_tests
tests for auth views
This commit is contained in:
@@ -28,6 +28,7 @@ from django_openstack import urls as django_openstack_urls
|
||||
|
||||
|
||||
urlpatterns = patterns('',
|
||||
url(r'^$', 'django_openstack.tests.views.fakeView', name='splash'),
|
||||
url(r'^dash/$', 'django_openstack.dash.views.instances.usage', name='dash_overview'),
|
||||
url(r'^syspanel/$', 'django_openstack.syspanel.views.instances.usage', name='syspanel_overview')
|
||||
)
|
||||
|
||||
148
django-openstack/django_openstack/tests/view_tests/auth_tests.py
Normal file
148
django-openstack/django_openstack/tests/view_tests/auth_tests.py
Normal file
@@ -0,0 +1,148 @@
|
||||
from django import http
|
||||
from django.core.urlresolvers import reverse
|
||||
from django.utils import unittest
|
||||
from django_openstack import api
|
||||
from django_openstack.tests.view_tests import base
|
||||
from openstackx.api import exceptions as api_exceptions
|
||||
from mox import IsA
|
||||
|
||||
|
||||
class AuthViewTests(base.BaseViewTests):
|
||||
def setUp(self):
|
||||
super(AuthViewTests, self).setUp()
|
||||
self.setActiveUser(None, None, None, None, None)
|
||||
self.PASSWORD = 'secret'
|
||||
|
||||
def test_login_index(self):
|
||||
res = self.client.get(reverse('auth_login'))
|
||||
self.assertTemplateUsed(res, 'splash.html')
|
||||
|
||||
def test_login_user_logged_in(self):
|
||||
self.setActiveUser(self.TEST_TOKEN, self.TEST_USER, self.TEST_TENANT,
|
||||
False, self.TEST_SERVICE_CATALOG)
|
||||
|
||||
res = self.client.get(reverse('auth_login'))
|
||||
self.assertRedirectsNoFollow(res, reverse('dash_overview'))
|
||||
|
||||
def test_login_admin_logged_in(self):
|
||||
self.setActiveUser(self.TEST_TOKEN, self.TEST_USER, self.TEST_TENANT,
|
||||
True, self.TEST_SERVICE_CATALOG)
|
||||
|
||||
res = self.client.get(reverse('auth_login'))
|
||||
self.assertRedirectsNoFollow(res, reverse('syspanel_overview'))
|
||||
|
||||
def test_login(self):
|
||||
TOKEN_ID = 1
|
||||
|
||||
form_data = {'method': 'Login',
|
||||
'password': self.PASSWORD,
|
||||
'username': self.TEST_USER}
|
||||
|
||||
self.mox.StubOutWithMock(api, 'token_create')
|
||||
aToken = self.mox.CreateMock(api.Token)
|
||||
aToken.id = TOKEN_ID
|
||||
aToken.serviceCatalog = {}
|
||||
api.token_create(IsA(http.HttpRequest), "", self.TEST_USER,
|
||||
self.PASSWORD).AndReturn(aToken)
|
||||
|
||||
self.mox.StubOutWithMock(api, 'token_info')
|
||||
tokenInfo = {'user': self.TEST_USER,
|
||||
'tenant': self.TEST_TENANT,
|
||||
'admin': False}
|
||||
api.token_info(IsA(http.HttpRequest), aToken).AndReturn(tokenInfo)
|
||||
|
||||
self.mox.ReplayAll()
|
||||
|
||||
res = self.client.post(reverse('auth_login'), form_data)
|
||||
|
||||
self.assertRedirectsNoFollow(res, reverse('dash_overview'))
|
||||
|
||||
self.mox.VerifyAll()
|
||||
|
||||
def test_login_invalid_credentials(self):
|
||||
form_data = {'method': 'Login',
|
||||
'password': self.PASSWORD,
|
||||
'username': self.TEST_USER}
|
||||
|
||||
self.mox.StubOutWithMock(api, 'token_create')
|
||||
unauthorized = api_exceptions.Unauthorized('unauth', message='unauth')
|
||||
api.token_create(IsA(http.HttpRequest), "", self.TEST_USER,
|
||||
self.PASSWORD).AndRaise(unauthorized)
|
||||
|
||||
self.mox.ReplayAll()
|
||||
|
||||
res = self.client.post(reverse('auth_login'), form_data)
|
||||
|
||||
self.assertTemplateUsed(res, 'splash.html')
|
||||
|
||||
self.mox.VerifyAll()
|
||||
|
||||
def test_login_exception(self):
|
||||
form_data = {'method': 'Login',
|
||||
'password': self.PASSWORD,
|
||||
'username': self.TEST_USER}
|
||||
|
||||
self.mox.StubOutWithMock(api, 'token_create')
|
||||
api_exception = api_exceptions.ApiException('apiException',
|
||||
message='apiException')
|
||||
api.token_create(IsA(http.HttpRequest), "", self.TEST_USER,
|
||||
self.PASSWORD).AndRaise(api_exception)
|
||||
|
||||
self.mox.ReplayAll()
|
||||
|
||||
res = self.client.post(reverse('auth_login'), form_data)
|
||||
|
||||
self.assertTemplateUsed(res, 'splash.html')
|
||||
|
||||
self.mox.VerifyAll()
|
||||
|
||||
def test_switch_tenants_index(self):
|
||||
res = self.client.get(reverse('auth_switch', args=[self.TEST_TENANT]))
|
||||
|
||||
self.assertTemplateUsed(res, 'switch_tenants.html')
|
||||
|
||||
def test_switch_tenants(self):
|
||||
NEW_TENANT = 'newTenant'
|
||||
TOKEN_ID = 1
|
||||
|
||||
self.setActiveUser(self.TEST_TOKEN, self.TEST_USER, self.TEST_TENANT,
|
||||
False, self.TEST_SERVICE_CATALOG)
|
||||
|
||||
form_data = {'method': 'LoginWithTenant',
|
||||
'password': self.PASSWORD,
|
||||
'tenant': NEW_TENANT,
|
||||
'username': self.TEST_USER}
|
||||
|
||||
self.mox.StubOutWithMock(api, 'token_create')
|
||||
aToken = self.mox.CreateMock(api.Token)
|
||||
aToken.id = TOKEN_ID
|
||||
aToken.serviceCatalog = {}
|
||||
api.token_create(IsA(http.HttpRequest), NEW_TENANT, self.TEST_USER,
|
||||
self.PASSWORD).AndReturn(aToken)
|
||||
|
||||
self.mox.StubOutWithMock(api, 'token_info')
|
||||
tokenInfo = {'user': self.TEST_USER,
|
||||
'tenant': NEW_TENANT,
|
||||
'admin': False}
|
||||
api.token_info(IsA(http.HttpRequest), aToken).AndReturn(tokenInfo)
|
||||
|
||||
self.mox.ReplayAll()
|
||||
|
||||
res = self.client.post(reverse('auth_switch', args=[NEW_TENANT]),
|
||||
form_data)
|
||||
|
||||
self.assertRedirectsNoFollow(res, reverse('dash_overview'))
|
||||
self.assertEqual(self.client.session['tenant'], NEW_TENANT)
|
||||
|
||||
self.mox.VerifyAll()
|
||||
|
||||
def test_logout(self):
|
||||
KEY = 'arbitraryKeyString'
|
||||
VALUE = 'arbitraryKeyValue'
|
||||
self.assertNotIn(KEY, self.client.session)
|
||||
self.client.session[KEY] = VALUE
|
||||
|
||||
res = self.client.get(reverse('auth_logout'))
|
||||
|
||||
self.assertRedirectsNoFollow(res, reverse('splash'))
|
||||
self.assertNotIn(KEY, self.client.session)
|
||||
11
django-openstack/django_openstack/tests/views.py
Normal file
11
django-openstack/django_openstack/tests/views.py
Normal file
@@ -0,0 +1,11 @@
|
||||
from django import http
|
||||
|
||||
|
||||
def fakeView(request):
|
||||
resp = http.HttpResponse()
|
||||
resp.write('<html><body><p>'
|
||||
'This is a fake httpresponse from a fake view for testing '
|
||||
' purposes only'
|
||||
'</p></body></html>')
|
||||
|
||||
return resp
|
||||
Reference in New Issue
Block a user