123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- from rest_framework import status
- from desecapi.models import Token
- from desecapi.tests.base import DomainOwnerTestCase
- class TokenTestCase(DomainOwnerTestCase):
- def setUp(self):
- super().setUp()
- self.token2 = self.create_token(self.owner, name='testtoken')
- self.other_token = self.create_token(self.user)
- def test_list_tokens(self):
- response = self.client.get(self.reverse('v1:token-list'))
- self.assertStatus(response, status.HTTP_200_OK)
- self.assertEqual(len(response.data), 2)
- self.assertIn('id', response.data[0])
- self.assertFalse(any(field in response.data[0] for field in ['token', 'key', 'value']))
- self.assertNotContains(response, self.token)
- def test_delete_my_token(self):
- token_id = Token.objects.get(user=self.owner, name='testtoken').id
- url = self.reverse('v1:token-detail', pk=token_id)
- response = self.client.delete(url)
- self.assertStatus(response, status.HTTP_204_NO_CONTENT)
- self.assertFalse(Token.objects.filter(pk=token_id).exists())
- response = self.client.get(url)
- self.assertStatus(response, status.HTTP_404_NOT_FOUND)
- def test_retrieve_my_token(self):
- token_id = Token.objects.get(user=self.owner, name='testtoken').id
- url = self.reverse('v1:token-detail', pk=token_id)
- response = self.client.get(url)
- self.assertStatus(response, status.HTTP_200_OK)
- self.assertFalse(any(field in response.data for field in ['token', 'key', 'value']))
- def test_retrieve_other_token(self):
- token_id = Token.objects.get(user=self.user).id
- url = self.reverse('v1:token-detail', pk=token_id)
- response = self.client.get(url)
- self.assertStatus(response, status.HTTP_404_NOT_FOUND)
- def test_update_my_token(self):
- token_id = Token.objects.get(user=self.user).id
- url = self.reverse('v1:token-detail', pk=token_id)
- for method in [self.client.patch, self.client.put]:
- response = method(url, data={'name': 'foobar'})
- self.assertStatus(response, status.HTTP_405_METHOD_NOT_ALLOWED)
- def test_create_token(self):
- n = len(Token.objects.filter(user=self.owner).all())
- response = self.client.post(self.reverse('v1:token-list'))
- self.assertStatus(response, status.HTTP_201_CREATED)
- self.assertTrue(all(field in response.data for field in ['id', 'created', 'token', 'name']))
- self.assertEqual(response.data['name'], '')
- response = self.client.post(self.reverse('v1:token-list'), data={'name': 'foobar'})
- self.assertStatus(response, status.HTTP_201_CREATED)
- self.assertTrue(all(field in response.data for field in ['id', 'created', 'token', 'name']))
- self.assertEqual(response.data['name'], 'foobar')
- self.assertEqual(len(Token.objects.filter(user=self.owner).all()), n + 2)
|