Fixes #20476: Prohibit changing a token's owner (#20576)

This commit is contained in:
Jeremy Stretch
2025-10-14 14:12:15 -04:00
committed by GitHub
parent 37a9d03348
commit b7cc4c418b
3 changed files with 42 additions and 3 deletions

View File

@@ -212,9 +212,9 @@ class TokenTest(
@classmethod
def setUpTestData(cls):
users = (
create_test_user('User1'),
create_test_user('User2'),
create_test_user('User3'),
create_test_user('User 1'),
create_test_user('User 2'),
create_test_user('User 3'),
)
tokens = (
@@ -238,6 +238,10 @@ class TokenTest(
},
]
cls.update_data = {
'description': 'Token 1',
}
def test_provision_token_valid(self):
"""
Test the provisioning of a new REST API token given a valid username and password.
@@ -300,6 +304,25 @@ class TokenTest(
response = self.client.post(url, data, format='json', **self.header)
self.assertEqual(response.status_code, 201)
def test_reassign_token(self):
"""
Check that a Token cannot be reassigned to another User.
"""
user1 = User.objects.get(username='User 1')
user2 = User.objects.get(username='User 2')
token1 = Token.objects.filter(user=user1).first()
self.add_permissions('users.change_token')
data = {
'user': user2.pk,
}
url = self._get_detail_url(token1)
response = self.client.patch(url, data, format='json', **self.header)
# Response should succeed because the read-only `user` field is ignored
self.assertEqual(response.status_code, 200)
token1.refresh_from_db()
self.assertEqual(token1.user, user1, "Token's user should not have changed")
class ObjectPermissionTest(
# No GraphQL support for ObjectPermission