35 lines
1.6 KiB
Python
35 lines
1.6 KiB
Python
|
from django.test import TestCase
|
||
|
from django.contrib.auth.models import Permission
|
||
|
|
||
|
from authentication.models import EventPermission, ExtendedUser
|
||
|
from inventory.models import Event
|
||
|
|
||
|
|
||
|
class PermissionsTestCase(TestCase):
|
||
|
def setUp(self):
|
||
|
super().setUp()
|
||
|
self.user = ExtendedUser.objects.create_user('testuser', 'test', 'test')
|
||
|
event1 = Event.objects.create(slug='testevent1', name='testevent1')
|
||
|
event2 = Event.objects.create(slug='testevent2', name='testevent2')
|
||
|
permission1 = Permission.objects.get(codename='view_event')
|
||
|
EventPermission.objects.create(user=self.user, permission=permission1, event=event1)
|
||
|
EventPermission.objects.create(user=self.user, permission=permission1, event=event2)
|
||
|
|
||
|
def test_user_permissions(self):
|
||
|
"""
|
||
|
Test that a user can only access their own data.
|
||
|
"""
|
||
|
self.client.force_login(self.user)
|
||
|
response = self.client.get('/api/2/users/')
|
||
|
self.assertEqual(response.status_code, 200)
|
||
|
self.assertEqual(len(response.json()), 2)
|
||
|
self.assertEqual(response.json()[0]['username'], 'testuser')
|
||
|
self.assertEqual(response.json()[0]['email'], 'test')
|
||
|
self.assertEqual(response.json()[0]['first_name'], '')
|
||
|
self.assertEqual(response.json()[0]['last_name'], '')
|
||
|
self.assertEqual(response.json()[0]['id'], 1)
|
||
|
self.assertEqual(response.json()[1]['username'], 'testuser')
|
||
|
self.assertEqual(response.json()[1]['email'], 'test')
|
||
|
self.assertEqual(response.json()[1]['first_name'], '')
|
||
|
self.assertEqual(response.json()[1]['last_name'], '')
|