test_joinip_profilefield.py 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. from django.contrib.auth import get_user_model
  2. from django.urls import reverse
  3. from misago.acl.test import patch_user_acl
  4. from misago.admin.testutils import AdminTestCase
  5. UserModel = get_user_model()
  6. class JoinIpProfileFieldTests(AdminTestCase):
  7. def setUp(self):
  8. super().setUp()
  9. self.test_link = reverse(
  10. 'misago:admin:users:accounts:edit',
  11. kwargs={
  12. 'pk': self.user.pk,
  13. },
  14. )
  15. def test_field_hidden_in_admin(self):
  16. """readonly field doesn't display in the admin"""
  17. response = self.client.get(self.test_link)
  18. self.assertNotContains(response, 'name="join_ip"')
  19. self.assertNotContains(response, "IP address")
  20. self.assertNotContains(response, "Join IP")
  21. def test_admin_edits_field(self):
  22. """admin form allows admins to edit field"""
  23. response = self.client.post(
  24. self.test_link,
  25. data={
  26. 'username': 'Edited',
  27. 'rank': str(self.user.rank_id),
  28. 'roles': str(self.user.roles.all()[0].pk),
  29. 'email': 'reg@stered.com',
  30. 'join_ip': '127.0.0.1',
  31. 'new_password': '',
  32. 'signature': '',
  33. 'is_signature_locked': '0',
  34. 'is_hiding_presence': '0',
  35. 'limits_private_thread_invites_to': '0',
  36. 'signature_lock_staff_message': '',
  37. 'signature_lock_user_message': '',
  38. 'subscribe_to_started_threads': '2',
  39. 'subscribe_to_replied_threads': '2',
  40. }
  41. )
  42. self.assertEqual(response.status_code, 302)
  43. self.reload_user()
  44. self.assertNotIn('join_ip', self.user.profile_fields)
  45. def test_admin_search_field(self):
  46. """admin users search searches this field"""
  47. test_link = reverse('misago:admin:users:accounts:index')
  48. response = self.client.get('%s?redirected=1&profilefields=127.0.0.1' % test_link)
  49. self.assertContains(response, "No users matching search criteria have been found.")
  50. def test_field_display(self):
  51. """field displays on user profile"""
  52. test_link = reverse(
  53. 'misago:user-details',
  54. kwargs={
  55. 'pk': self.user.pk,
  56. 'slug': self.user.slug,
  57. },
  58. )
  59. response = self.client.get(test_link)
  60. self.assertContains(response, "IP address")
  61. self.assertContains(response, "Join IP")
  62. self.assertContains(response, "127.0.0.1")
  63. @patch_user_acl
  64. def test_field_hidden_no_permission(self, patch_user_acl):
  65. """field is hidden on user profile if user has no permission"""
  66. test_link = reverse(
  67. 'misago:user-details',
  68. kwargs={
  69. 'pk': self.user.pk,
  70. 'slug': self.user.slug,
  71. },
  72. )
  73. patch_user_acl(self.user, {
  74. 'can_see_users_ips': 0
  75. })
  76. response = self.client.get(test_link)
  77. self.assertNotContains(response, "IP address")
  78. self.assertNotContains(response, "Join IP")
  79. self.assertNotContains(response, "127.0.0.1")
  80. def test_field_hidden_ip_removed(self):
  81. """field is hidden on user profile if ip is removed"""
  82. test_link = reverse(
  83. 'misago:user-details',
  84. kwargs={
  85. 'pk': self.user.pk,
  86. 'slug': self.user.slug,
  87. },
  88. )
  89. self.user.joined_from_ip = None
  90. self.user.save()
  91. response = self.client.get(test_link)
  92. self.assertNotContains(response, "IP address")
  93. self.assertNotContains(response, "Join IP")
  94. self.assertNotContains(response, "127.0.0.1")
  95. def test_field_display_json(self):
  96. """field is included in display json"""
  97. test_link = reverse('misago:api:user-details', kwargs={'pk': self.user.pk})
  98. response = self.client.get(test_link)
  99. self.assertEqual(
  100. response.json()['groups'],
  101. [
  102. {
  103. 'name': 'IP address',
  104. 'fields': [
  105. {
  106. 'fieldname': 'join_ip',
  107. 'name': 'Join IP',
  108. 'text': '127.0.0.1',
  109. },
  110. ],
  111. },
  112. ]
  113. )
  114. @patch_user_acl
  115. def test_field_hidden_no_permission_json(self, patch_user_acl):
  116. """field is not included in display json if user has no permission"""
  117. test_link = reverse('misago:api:user-details', kwargs={'pk': self.user.pk})
  118. patch_user_acl(self.user, {
  119. 'can_see_users_ips': 0
  120. })
  121. response = self.client.get(test_link)
  122. self.assertEqual(response.json()['groups'], [])
  123. def test_field_hidden_ip_removed_json(self):
  124. """field is not included in display json if user ip is removed"""
  125. test_link = reverse('misago:api:user-details', kwargs={'pk': self.user.pk})
  126. self.user.joined_from_ip = None
  127. self.user.save()
  128. response = self.client.get(test_link)
  129. self.assertEqual(response.json()['groups'], [])
  130. def test_field_not_in_edit_json(self):
  131. """readonly field json is not returned from API"""
  132. test_link = reverse('misago:api:user-edit-details', kwargs={'pk': self.user.pk})
  133. response = self.client.get(test_link)
  134. found_field = None
  135. for group in response.json():
  136. for field in group['fields']:
  137. if field['fieldname'] == 'join_ip':
  138. found_field = field
  139. self.assertIsNone(found_field)
  140. def test_field_is_not_editable_in_api(self):
  141. """readonly field can't be edited via api"""
  142. test_link = reverse('misago:api:user-edit-details', kwargs={'pk': self.user.pk})
  143. response = self.client.post(test_link, data={'join_ip': '88.12.13.14'})
  144. self.assertEqual(response.status_code, 200)
  145. self.reload_user()
  146. self.assertNotIn('join_ip', self.user.profile_fields)