test_moderation_views.py 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. from django.contrib.auth import get_user_model
  2. from django.core.urlresolvers import reverse
  3. from misago.acl.testutils import override_acl
  4. from misago.admin.testutils import AdminTestCase
  5. class UserModerationTestCase(AdminTestCase):
  6. def setUp(self):
  7. super(UserModerationTestCase, self).setUp()
  8. self.test_user = get_user_model().objects.create_user(
  9. "Bob", "bob@bob.com", "Pass.123")
  10. self.link_kwargs = {'user_slug': 'bob', 'user_id': self.test_user.pk}
  11. class RenameUserTests(UserModerationTestCase):
  12. def test_no_rename_permission(self):
  13. """user with no permission fails to rename other user"""
  14. override_acl(self.test_admin, {
  15. 'misago.users.permissions.moderation': {
  16. 'can_rename_users': 0,
  17. },
  18. })
  19. response = self.client.get(
  20. reverse('misago:rename_user', kwargs=self.link_kwargs))
  21. self.assertEqual(response.status_code, 403)
  22. self.assertIn("You can't rename users.", response.content)
  23. def test_rename_user(self):
  24. """user with permission renames other user"""
  25. override_acl(self.test_admin, {
  26. 'misago.users.permissions.moderation': {
  27. 'can_rename_users': 1,
  28. }
  29. })
  30. response = self.client.get(
  31. reverse('misago:rename_user', kwargs=self.link_kwargs))
  32. self.assertEqual(response.status_code, 200)
  33. response = self.client.post(
  34. reverse('misago:rename_user', kwargs=self.link_kwargs),
  35. data={'new_username': 'LoremIpsum'})
  36. self.assertEqual(response.status_code, 302)
  37. response = self.client.post(reverse('misago:index'))
  38. self.assertEqual(response.status_code, 200)
  39. self.assertIn('Bob's username has been changed.', response.content)
  40. class DeleteUserTests(UserModerationTestCase):
  41. def test_no_delete_permission(self):
  42. """user with no permission fails to delete other user"""
  43. override_acl(self.test_admin, {
  44. 'misago.users.permissions.delete': {
  45. 'can_delete_users_newer_than': 0,
  46. 'can_delete_users_with_less_posts_than': 0,
  47. },
  48. })
  49. response = self.client.post(
  50. reverse('misago:delete_user', kwargs=self.link_kwargs))
  51. self.assertEqual(response.status_code, 403)
  52. self.assertIn("You can't delete users.", response.content)
  53. def test_delete_user(self):
  54. """user with permission deletes other user"""
  55. override_acl(self.test_admin, {
  56. 'misago.users.permissions.delete': {
  57. 'can_delete_users_newer_than': 5,
  58. 'can_delete_users_with_less_posts_than': 5,
  59. }
  60. })
  61. response = self.client.post(
  62. reverse('misago:delete_user', kwargs=self.link_kwargs))
  63. self.assertEqual(response.status_code, 302)
  64. response = self.client.post(reverse('misago:index'))
  65. self.assertEqual(response.status_code, 200)
  66. self.assertIn('Bob has been deleted', response.content)