74 lines
3.3 KiB
Python
74 lines
3.3 KiB
Python
from django.test import TestCase
|
|
from django.urls import reverse
|
|
from rest_framework.authtoken.models import Token
|
|
|
|
from model_bakery import baker
|
|
|
|
from fellchensammlung.models import AdoptionNotice, User, TrustLevel, Notification
|
|
|
|
|
|
class UserTest(TestCase):
|
|
@classmethod
|
|
def setUpTestData(cls):
|
|
cls.test_user0 = User.objects.create_user(username='testuser0',
|
|
first_name="Admin",
|
|
last_name="BOFH",
|
|
password='12345')
|
|
cls.test_user0.trust_level = TrustLevel.ADMIN
|
|
cls.test_user0.save()
|
|
|
|
cls.test_user1 = User.objects.create_user(username='testuser1',
|
|
first_name="Max",
|
|
last_name="Müller",
|
|
password='12345')
|
|
|
|
cls.test_user2 = User.objects.create_user(username='testuser2',
|
|
first_name="Mira",
|
|
last_name="Müller",
|
|
password='12345')
|
|
|
|
adoption1 = baker.make(AdoptionNotice, name="TestAdoption1", owner=cls.test_user0)
|
|
notification1 = baker.make(Notification,
|
|
title="TestNotification1",
|
|
user_to_notify=cls.test_user0,
|
|
adoption_notice=adoption1)
|
|
notification2 = baker.make(Notification, title="TestNotification1", user_to_notify=cls.test_user1)
|
|
notification3 = baker.make(Notification, title="TestNotification1", user_to_notify=cls.test_user2)
|
|
token = baker.make(Token, user=cls.test_user0)
|
|
|
|
def test_detail_self(self):
|
|
self.client.login(username='testuser1', password='12345')
|
|
|
|
response = self.client.post(reverse('user-me'))
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertContains(response, "Max")
|
|
|
|
def test_detail_self_via_id(self):
|
|
self.client.login(username='testuser1', password='12345')
|
|
|
|
response = self.client.post(reverse('user-detail', args=str(self.test_user1.pk)))
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertContains(response, "Max")
|
|
|
|
def test_detail_admin_with_token(self):
|
|
self.client.login(username='testuser0', password='12345')
|
|
|
|
response = self.client.post(reverse('user-me'))
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertContains(response, Token.objects.get(user=self.test_user0).key)
|
|
|
|
def test_detail_unauthenticated(self):
|
|
response = self.client.get(reverse('user-me'))
|
|
self.assertEqual(response.status_code, 302)
|
|
self.assertEqual(response.url, "/accounts/login/?next=/user/me/")
|
|
|
|
def test_detail_unauthorized(self):
|
|
self.client.login(username='testuser2', password='12345')
|
|
response = self.client.get(reverse('user-detail', args=str(self.test_user1.pk)))
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_detail_authorized(self):
|
|
self.client.login(username='testuser0', password='12345')
|
|
response = self.client.get(reverse('user-detail', args=str(self.test_user1.pk)))
|
|
self.assertEqual(response.status_code, 200)
|