mirror of
https://github.com/freedombox/FreedomBox.git
synced 2026-05-20 10:34:30 +00:00
middleware: Refactor tests to avoid repetition
This commit is contained in:
parent
dd5ab7612e
commit
3e8caab08a
@ -148,14 +148,6 @@ class TestAdminMiddleware(TestCase):
|
|||||||
"""Setup each test case before execution."""
|
"""Setup each test case before execution."""
|
||||||
super(TestAdminMiddleware, self).setUp()
|
super(TestAdminMiddleware, self).setUp()
|
||||||
|
|
||||||
|
|
||||||
@patch('django.contrib.messages.success')
|
|
||||||
@patch('plinth.module_loader.loaded_modules')
|
|
||||||
@patch('django.urls.resolve')
|
|
||||||
@patch('django.urls.reverse', return_value='users:login')
|
|
||||||
def test_that_admin_view_is_denied_for_usual_user(self, reverse, resolve, loaded_modules, messages_success):
|
|
||||||
"""Test that normal user is denied for an admin view"""
|
|
||||||
|
|
||||||
self.middleware = AdminRequiredMiddleware()
|
self.middleware = AdminRequiredMiddleware()
|
||||||
self.kwargs = {
|
self.kwargs = {
|
||||||
'view_func': HttpResponse,
|
'view_func': HttpResponse,
|
||||||
@ -163,63 +155,28 @@ class TestAdminMiddleware(TestCase):
|
|||||||
'view_kwargs': {},
|
'view_kwargs': {},
|
||||||
}
|
}
|
||||||
|
|
||||||
resolve.return_value.namespaces = ['mockapp']
|
|
||||||
loaded_modules.__getitem__.return_value = Mock()
|
|
||||||
|
|
||||||
request = RequestFactory().get('/plinth/mockapp')
|
request = RequestFactory().get('/plinth/mockapp')
|
||||||
request.user = Mock()
|
request.user = Mock()
|
||||||
exists_fn = Mock()
|
self.request = request
|
||||||
exists_fn.exists = Mock(return_value=False)
|
|
||||||
request.user.groups.filter.return_value = exists_fn
|
|
||||||
|
|
||||||
self.assertRaises(PermissionDenied, self.middleware.process_view, request, **self.kwargs)
|
def test_that_admin_view_is_denied_for_usual_user(self):
|
||||||
|
"""Test that normal user is denied for an admin view"""
|
||||||
|
self.request.user.groups.filter().exists = Mock(return_value=False)
|
||||||
|
|
||||||
@patch('django.contrib.messages.success')
|
self.assertRaises(PermissionDenied, self.middleware.process_view,
|
||||||
@patch('plinth.module_loader.loaded_modules')
|
self.request, **self.kwargs)
|
||||||
@patch('django.urls.resolve')
|
|
||||||
@patch('django.urls.reverse', return_value='users:login')
|
def test_that_admin_view_is_allowed_for_admin_user(self):
|
||||||
def test_that_admin_view_is_allowed_for_admin_user(self, reverse, resolve, loaded_modules, messages_success):
|
|
||||||
"""Test that admin user is allowed for an admin view"""
|
"""Test that admin user is allowed for an admin view"""
|
||||||
|
self.request.user.groups.filter().exists = Mock(return_value=True)
|
||||||
|
|
||||||
self.kwargs = {
|
response = self.middleware.process_view(self.request, **self.kwargs)
|
||||||
'view_func': HttpResponse,
|
|
||||||
'view_args': [],
|
|
||||||
'view_kwargs': {},
|
|
||||||
}
|
|
||||||
|
|
||||||
resolve.return_value.namespaces = ['mockapp']
|
|
||||||
loaded_modules.__getitem__.return_value = Mock()
|
|
||||||
|
|
||||||
request = RequestFactory().get('/plinth/mockapp')
|
|
||||||
request.user = Mock()
|
|
||||||
exists_fn = Mock()
|
|
||||||
exists_fn.exists = Mock(return_value=True)
|
|
||||||
request.user.groups.filter.return_value = exists_fn
|
|
||||||
|
|
||||||
response = self.middleware.process_view(request, **self.kwargs)
|
|
||||||
self.assertIsNone(response)
|
self.assertIsNone(response)
|
||||||
|
|
||||||
@patch('django.contrib.messages.success')
|
def test_that_public_view_is_allowed_for_normal_user(self):
|
||||||
@patch('plinth.module_loader.loaded_modules')
|
|
||||||
@patch('django.urls.resolve')
|
|
||||||
@patch('django.urls.reverse', return_value='users:login')
|
|
||||||
def test_that_public_view_is_allowed_for_normal_user(self, reverse, resolve, loaded_modules, messages_success):
|
|
||||||
"""Test that normal user is allowed for an public view"""
|
"""Test that normal user is allowed for an public view"""
|
||||||
|
kwargs = dict(self.kwargs)
|
||||||
|
kwargs['view_func'] = public(HttpResponse)
|
||||||
|
|
||||||
self.kwargs = {
|
response = self.middleware.process_view(self.request, **kwargs)
|
||||||
'view_func': public(HttpResponse),
|
|
||||||
'view_args': [],
|
|
||||||
'view_kwargs': {},
|
|
||||||
}
|
|
||||||
|
|
||||||
resolve.return_value.namespaces = ['mockapp']
|
|
||||||
loaded_modules.__getitem__.return_value = Mock()
|
|
||||||
|
|
||||||
request = RequestFactory().get('/plinth/mockapp')
|
|
||||||
request.user = Mock()
|
|
||||||
exists_fn = Mock()
|
|
||||||
exists_fn.exists = Mock(return_value=False)
|
|
||||||
request.user.groups.filter.return_value = exists_fn
|
|
||||||
|
|
||||||
response = self.middleware.process_view(request, **self.kwargs)
|
|
||||||
self.assertIsNone(response)
|
self.assertIsNone(response)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user