test_joinip_profilefield.py 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  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(response, "No users matching criteria exist.")
  49. def test_field_display(self):
  50. """field displays on user profile"""
  51. test_link = reverse(
  52. "misago:user-details", kwargs={"pk": self.user.pk, "slug": self.user.slug}
  53. )
  54. response = self.client.get(test_link)
  55. self.assertContains(response, "IP address")
  56. self.assertContains(response, "Join IP")
  57. self.assertContains(response, "127.0.0.1")
  58. @patch_user_acl({"can_see_users_ips": 0})
  59. def test_field_hidden_no_permission(self):
  60. """field is hidden on user profile if user has no permission"""
  61. test_link = reverse(
  62. "misago:user-details", kwargs={"pk": self.user.pk, "slug": self.user.slug}
  63. )
  64. response = self.client.get(test_link)
  65. self.assertNotContains(response, "IP address")
  66. self.assertNotContains(response, "Join IP")
  67. self.assertNotContains(response, "127.0.0.1")
  68. def test_field_hidden_ip_removed(self):
  69. """field is hidden on user profile if ip is removed"""
  70. test_link = reverse(
  71. "misago:user-details", kwargs={"pk": self.user.pk, "slug": self.user.slug}
  72. )
  73. self.user.joined_from_ip = None
  74. self.user.save()
  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_display_json(self):
  80. """field is included in display json"""
  81. test_link = reverse("misago:api:user-details", kwargs={"pk": self.user.pk})
  82. response = self.client.get(test_link)
  83. self.assertEqual(
  84. response.json()["groups"],
  85. [
  86. {
  87. "name": "IP address",
  88. "fields": [
  89. {"fieldname": "join_ip", "name": "Join IP", "text": "127.0.0.1"}
  90. ],
  91. }
  92. ],
  93. )
  94. @patch_user_acl({"can_see_users_ips": 0})
  95. def test_field_hidden_no_permission_json(self):
  96. """field is not included in display json if user has no permission"""
  97. test_link = reverse("misago:api:user-details", kwargs={"pk": self.user.pk})
  98. response = self.client.get(test_link)
  99. self.assertEqual(response.json()["groups"], [])
  100. def test_field_hidden_ip_removed_json(self):
  101. """field is not included in display json if user ip is removed"""
  102. test_link = reverse("misago:api:user-details", kwargs={"pk": self.user.pk})
  103. self.user.joined_from_ip = None
  104. self.user.save()
  105. response = self.client.get(test_link)
  106. self.assertEqual(response.json()["groups"], [])
  107. def test_field_not_in_edit_json(self):
  108. """readonly field json is not returned from API"""
  109. test_link = reverse("misago:api:user-edit-details", kwargs={"pk": self.user.pk})
  110. response = self.client.get(test_link)
  111. found_field = None
  112. for group in response.json():
  113. for field in group["fields"]:
  114. if field["fieldname"] == "join_ip":
  115. found_field = field
  116. self.assertIsNone(found_field)
  117. def test_field_is_not_editable_in_api(self):
  118. """readonly field can't be edited via api"""
  119. test_link = reverse("misago:api:user-edit-details", kwargs={"pk": self.user.pk})
  120. response = self.client.post(test_link, data={"join_ip": "88.12.13.14"})
  121. self.assertEqual(response.status_code, 200)
  122. self.reload_user()
  123. self.assertNotIn("join_ip", self.user.profile_fields)