|
|
@@ -329,6 +329,53 @@ class TokenTest(
|
|
|
token1.refresh_from_db()
|
|
|
self.assertEqual(token1.user, user1, "Token's user should not have changed")
|
|
|
|
|
|
+ def test_create_token_returns_plaintext(self):
|
|
|
+ """
|
|
|
+ Test that creating a Token via the REST API returns the usable plaintext value
|
|
|
+ in the response. For v2 tokens this value cannot be recovered later because the
|
|
|
+ database stores only an HMAC digest.
|
|
|
+ """
|
|
|
+ self.add_permissions('users.add_token')
|
|
|
+ user = User.objects.create_user(username='token_plaintext_user')
|
|
|
+ url = reverse('users-api:token-list')
|
|
|
+
|
|
|
+ response = self.client.post(url, {'user': user.pk}, format='json', **self.header)
|
|
|
+ self.assertEqual(response.status_code, 201)
|
|
|
+ self.assertIsNotNone(response.data['token'])
|
|
|
+ self.assertEqual(len(response.data['token']), TOKEN_DEFAULT_LENGTH)
|
|
|
+
|
|
|
+ # The returned plaintext must authenticate against the stored token
|
|
|
+ token = Token.objects.get(pk=response.data['id'])
|
|
|
+ self.assertTrue(token.validate(response.data['token']))
|
|
|
+
|
|
|
+ def test_bulk_create_tokens_returns_plaintexts(self):
|
|
|
+ """
|
|
|
+ Test that bulk-creating Tokens via the REST API returns the plaintext value for
|
|
|
+ each created Token in the response.
|
|
|
+ """
|
|
|
+ self.add_permissions('users.add_token')
|
|
|
+ users = [
|
|
|
+ User.objects.create_user(username='token_bulk_user1'),
|
|
|
+ User.objects.create_user(username='token_bulk_user2'),
|
|
|
+ ]
|
|
|
+ data = [{'user': u.pk} for u in users]
|
|
|
+ url = reverse('users-api:token-list')
|
|
|
+
|
|
|
+ response = self.client.post(url, data, format='json', **self.header)
|
|
|
+ self.assertEqual(response.status_code, 201)
|
|
|
+ self.assertEqual(len(response.data), len(data))
|
|
|
+
|
|
|
+ plaintexts = set()
|
|
|
+ for obj in response.data:
|
|
|
+ self.assertIsNotNone(obj['token'])
|
|
|
+ self.assertEqual(len(obj['token']), TOKEN_DEFAULT_LENGTH)
|
|
|
+ plaintexts.add(obj['token'])
|
|
|
+ token = Token.objects.get(pk=obj['id'])
|
|
|
+ self.assertTrue(token.validate(obj['token']))
|
|
|
+
|
|
|
+ # Each token should be unique
|
|
|
+ self.assertEqual(len(plaintexts), len(data))
|
|
|
+
|
|
|
|
|
|
class ObjectPermissionTest(
|
|
|
# No GraphQL support for ObjectPermission
|