test_usernamechanges_api.py 2.5 KB

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