test_joinip_profilefield.py 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. from django.contrib.auth import get_user_model
  2. from django.urls import reverse
  3. from misago.admin.testutils import AdminTestCase
  4. from misago.acl.testutils import override_acl
  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('{}?redirected=1&profilefields=127.0.0.1'.format(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. def test_field_hidden_no_permission(self):
  64. """field is hidden on user profile if user has no permission"""
  65. test_link = reverse(
  66. 'misago:user-details',
  67. kwargs={
  68. 'pk': self.user.pk,
  69. 'slug': self.user.slug,
  70. },
  71. )
  72. override_acl(self.user, {
  73. 'can_see_users_ips': 0
  74. })
  75. response = self.client.get(test_link)
  76. self.assertNotContains(response, "IP address")
  77. self.assertNotContains(response, "Join IP")
  78. self.assertNotContains(response, "127.0.0.1")
  79. def test_field_hidden_ip_removed(self):
  80. """field is hidden on user profile if ip is removed"""
  81. test_link = reverse(
  82. 'misago:user-details',
  83. kwargs={
  84. 'pk': self.user.pk,
  85. 'slug': self.user.slug,
  86. },
  87. )
  88. self.user.joined_from_ip = None
  89. self.user.save()
  90. response = self.client.get(test_link)
  91. self.assertNotContains(response, "IP address")
  92. self.assertNotContains(response, "Join IP")
  93. self.assertNotContains(response, "127.0.0.1")
  94. def test_field_display_json(self):
  95. """field is included in display json"""
  96. test_link = reverse('misago:api:user-details', kwargs={'pk': self.user.pk})
  97. response = self.client.get(test_link)
  98. self.assertEqual(
  99. response.json()['groups'],
  100. [
  101. {
  102. 'name': 'IP address',
  103. 'fields': [
  104. {
  105. 'fieldname': 'join_ip',
  106. 'name': 'Join IP',
  107. 'text': '127.0.0.1',
  108. },
  109. ],
  110. },
  111. ]
  112. )
  113. def test_field_hidden_no_permission_json(self):
  114. """field is not included in display json if user has no permission"""
  115. test_link = reverse('misago:api:user-details', kwargs={'pk': self.user.pk})
  116. override_acl(self.user, {
  117. 'can_see_users_ips': 0
  118. })
  119. response = self.client.get(test_link)
  120. self.assertEqual(response.json()['groups'], [])
  121. def test_field_hidden_ip_removed_json(self):
  122. """field is not included in display json if user ip is removed"""
  123. test_link = reverse('misago:api:user-details', kwargs={'pk': self.user.pk})
  124. self.user.joined_from_ip = None
  125. self.user.save()
  126. response = self.client.get(test_link)
  127. self.assertEqual(response.json()['groups'], [])
  128. def test_field_not_in_edit_json(self):
  129. """readonly field json is not returned from API"""
  130. test_link = reverse('misago:api:user-edit-details', kwargs={'pk': self.user.pk})
  131. response = self.client.get(test_link)
  132. found_field = None
  133. for group in response.json():
  134. for field in group['fields']:
  135. if field['fieldname'] == 'join_ip':
  136. found_field = field
  137. self.assertIsNone(found_field)
  138. def test_field_is_not_editable_in_api(self):
  139. """readonly field can't be edited via api"""
  140. test_link = reverse('misago:api:user-edit-details', kwargs={'pk': self.user.pk})
  141. response = self.client.post(test_link, data={'join_ip': '88.12.13.14'})
  142. self.assertEqual(response.status_code, 200)
  143. self.reload_user()
  144. self.assertNotIn('join_ip', self.user.profile_fields)