test_usernamechanges_api.py 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. from misago.acl.testutils import override_acl
  2. from misago.users.testutils import AuthenticatedUserTestCase
  3. class UsernameChangesApiTests(AuthenticatedUserTestCase):
  4. def setUp(self):
  5. super().setUp()
  6. self.link = '/api/username-changes/'
  7. def test_user_can_always_see_his_name_changes(self):
  8. """list returns own username changes"""
  9. self.user.set_username('NewUsername', self.user)
  10. override_acl(self.user, {'can_see_users_name_history': False})
  11. response = self.client.get('%s?user=%s' % (self.link, self.user.pk))
  12. self.assertEqual(response.status_code, 200)
  13. self.assertContains(response, self.user.username)
  14. def test_list_handles_invalid_filter(self):
  15. """list raises 404 for invalid filter"""
  16. self.user.set_username('NewUsername', self.user)
  17. override_acl(self.user, {'can_see_users_name_history': True})
  18. response = self.client.get('%s?user=abcd' % self.link)
  19. self.assertEqual(response.status_code, 404)
  20. def test_list_handles_nonexisting_user(self):
  21. """list raises 404 for invalid user id"""
  22. self.user.set_username('NewUsername', self.user)
  23. override_acl(self.user, {'can_see_users_name_history': True})
  24. response = self.client.get('%s?user=142141' % self.link)
  25. self.assertEqual(response.status_code, 404)
  26. def test_list_handles_search(self):
  27. """list returns found username changes"""
  28. self.user.set_username('NewUsername', self.user)
  29. override_acl(self.user, {'can_see_users_name_history': False})
  30. response = self.client.get('%s?user=%s&search=new' % (self.link, self.user.pk))
  31. self.assertEqual(response.status_code, 200)
  32. self.assertContains(response, self.user.username)
  33. response = self.client.get('%s?user=%s&search=usernew' % (self.link, self.user.pk))
  34. self.assertEqual(response.status_code, 200)
  35. self.assertContains(response, '[]')
  36. def test_list_denies_permission(self):
  37. """list denies permission for other user (or all) if no access"""
  38. override_acl(self.user, {'can_see_users_name_history': False})
  39. response = self.client.get('%s?user=%s' % (self.link, self.user.pk + 1))
  40. self.assertContains(response, "don't have permission to", status_code=403)
  41. response = self.client.get(self.link)
  42. self.assertContains(response, "don't have permission to", status_code=403)