test_moderation_views.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  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. from misago.users.models import Ban
  6. class UserModerationTestCase(AdminTestCase):
  7. def setUp(self):
  8. super(UserModerationTestCase, self).setUp()
  9. self.test_user = get_user_model().objects.create_user(
  10. "Bob", "bob@bob.com", "Pass.123")
  11. self.link_kwargs = {'user_slug': 'bob', 'user_id': self.test_user.pk}
  12. class RenameUserTests(UserModerationTestCase):
  13. def test_no_rename_permission(self):
  14. """user with no permission fails to rename other user"""
  15. override_acl(self.test_admin, {
  16. 'misago.users.permissions.moderation': {
  17. 'can_rename_users': 0,
  18. },
  19. })
  20. response = self.client.get(
  21. reverse('misago:rename_user', kwargs=self.link_kwargs))
  22. self.assertEqual(response.status_code, 403)
  23. self.assertIn("You can't rename users.", response.content)
  24. def test_rename_user(self):
  25. """user with permission renames other user"""
  26. override_acl(self.test_admin, {
  27. 'misago.users.permissions.moderation': {
  28. 'can_rename_users': 1,
  29. }
  30. })
  31. response = self.client.get(
  32. reverse('misago:rename_user', kwargs=self.link_kwargs))
  33. self.assertEqual(response.status_code, 200)
  34. response = self.client.post(
  35. reverse('misago:rename_user', kwargs=self.link_kwargs),
  36. data={'new_username': 'LoremIpsum'})
  37. self.assertEqual(response.status_code, 302)
  38. response = self.client.post(reverse('misago:index'))
  39. self.assertEqual(response.status_code, 200)
  40. self.assertIn('Bob's username has been changed.', response.content)
  41. class BanUserTests(UserModerationTestCase):
  42. def test_no_ban_permission(self):
  43. """user with no permission fails to ban other user"""
  44. override_acl(self.test_admin, {
  45. 'misago.users.permissions.moderation': {
  46. 'can_ban_users': 0,
  47. },
  48. })
  49. response = self.client.get(
  50. reverse('misago:ban_user', kwargs=self.link_kwargs))
  51. self.assertEqual(response.status_code, 403)
  52. self.assertIn("You can't ban users.", response.content)
  53. def test_ban_user(self):
  54. """user with permission bans other user"""
  55. override_acl(self.test_admin, {
  56. 'misago.users.permissions.moderation': {
  57. 'can_ban_users': 1,
  58. 'max_ban_length': 0,
  59. }
  60. })
  61. response = self.client.get(
  62. reverse('misago:ban_user', kwargs=self.link_kwargs))
  63. self.assertEqual(response.status_code, 200)
  64. response = self.client.post(
  65. reverse('misago:ban_user', kwargs=self.link_kwargs))
  66. self.assertEqual(response.status_code, 302)
  67. response = self.client.post(reverse('misago:index'))
  68. self.assertEqual(response.status_code, 200)
  69. self.assertIn('Bob has been banned.', response.content)
  70. Ban.objects.get(banned_value=self.test_user.username.lower())
  71. class LiftUserBanTests(UserModerationTestCase):
  72. def test_no_lift_ban_permission(self):
  73. """user with no permission fails to lift user ban"""
  74. override_acl(self.test_admin, {
  75. 'misago.users.permissions.moderation': {
  76. 'can_lift_bans': 0,
  77. 'max_lifted_ban_length': 0,
  78. },
  79. })
  80. Ban.objects.create(banned_value=self.test_user.username)
  81. response = self.client.post(
  82. reverse('misago:lift_user_ban', kwargs=self.link_kwargs))
  83. self.assertEqual(response.status_code, 403)
  84. self.assertIn("You can't lift bans.", response.content)
  85. def test_lift_user_ban(self):
  86. """user with permission lifts other user ban"""
  87. override_acl(self.test_admin, {
  88. 'misago.users.permissions.moderation': {
  89. 'can_lift_bans': 1,
  90. 'max_lifted_ban_length': 0,
  91. }
  92. })
  93. test_ban = Ban.objects.create(banned_value=self.test_user.username)
  94. response = self.client.post(
  95. reverse('misago:lift_user_ban', kwargs=self.link_kwargs))
  96. self.assertEqual(response.status_code, 302)
  97. response = self.client.post(reverse('misago:index'))
  98. self.assertEqual(response.status_code, 200)
  99. self.assertIn('ban has been lifted.', response.content)
  100. test_ban = Ban.objects.get(id=test_ban.pk)
  101. self.assertTrue(test_ban.is_expired)
  102. class DeleteUserTests(UserModerationTestCase):
  103. def test_no_delete_permission(self):
  104. """user with no permission fails to delete other user"""
  105. override_acl(self.test_admin, {
  106. 'misago.users.permissions.delete': {
  107. 'can_delete_users_newer_than': 0,
  108. 'can_delete_users_with_less_posts_than': 0,
  109. },
  110. })
  111. response = self.client.post(
  112. reverse('misago:delete_user', kwargs=self.link_kwargs))
  113. self.assertEqual(response.status_code, 403)
  114. self.assertIn("You can't delete users.", response.content)
  115. def test_delete_user(self):
  116. """user with permission deletes other user"""
  117. override_acl(self.test_admin, {
  118. 'misago.users.permissions.delete': {
  119. 'can_delete_users_newer_than': 5,
  120. 'can_delete_users_with_less_posts_than': 5,
  121. }
  122. })
  123. response = self.client.post(
  124. reverse('misago:delete_user', kwargs=self.link_kwargs))
  125. self.assertEqual(response.status_code, 302)
  126. response = self.client.post(reverse('misago:index'))
  127. self.assertEqual(response.status_code, 200)
  128. self.assertIn('Bob has been deleted', response.content)