test_joinip_profilefield.py 5.5 KB

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