test_joinip_profilefield.py 5.5 KB

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