test_joinip_profilefield.py 5.9 KB

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