test_user_editdetails_api.py 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. from django.urls import reverse
  2. from misago.acl.test import patch_user_acl
  3. from misago.users.testutils import AuthenticatedUserTestCase, create_test_user
  4. class UserEditDetailsApiTests(AuthenticatedUserTestCase):
  5. def setUp(self):
  6. super().setUp()
  7. self.api_link = reverse(
  8. "misago:api:user-edit-details", kwargs={"pk": self.user.pk}
  9. )
  10. def get_profile_fields(self):
  11. self.user.refresh_from_db()
  12. return self.user.profile_fields
  13. def test_api_has_no_showstoppers(self):
  14. """api outputs response for freshly created user"""
  15. response = self.client.get(self.api_link)
  16. self.assertEqual(response.status_code, 200)
  17. def test_api_has_no_showstoppers_old_user(self):
  18. """api outputs response for freshly created user"""
  19. response = self.client.get(self.api_link)
  20. self.assertEqual(response.status_code, 200)
  21. def test_other_user(self):
  22. """api handles scenario when its other user looking at profile"""
  23. test_user = create_test_user("OtherUser", "otheruser@example.com")
  24. api_link = reverse("misago:api:user-edit-details", kwargs={"pk": test_user.pk})
  25. # moderator has permission to edit details
  26. with patch_user_acl({"can_moderate_profile_details": True}):
  27. response = self.client.get(api_link)
  28. self.assertEqual(response.status_code, 200)
  29. # non-moderator has no permission to edit details
  30. with patch_user_acl({"can_moderate_profile_details": False}):
  31. response = self.client.get(api_link)
  32. self.assertEqual(response.status_code, 403)
  33. def test_nonexistant_user(self):
  34. """api handles nonexistant users"""
  35. api_link = reverse(
  36. "misago:api:user-edit-details", kwargs={"pk": self.user.pk + 123}
  37. )
  38. response = self.client.get(api_link)
  39. self.assertEqual(response.status_code, 404)
  40. def test_api_updates_text_field(self):
  41. """api updates text field"""
  42. response = self.client.post(
  43. self.api_link, data={"bio": "I have some, as is tradition."}
  44. )
  45. self.assertEqual(response.status_code, 200)
  46. profile_fields = self.get_profile_fields()
  47. self.assertEqual(profile_fields["bio"], "I have some, as is tradition.")
  48. response_json = response.json()
  49. self.assertEqual(response_json["id"], self.user.id)
  50. self.assertTrue(response_json["edit"])
  51. self.assertTrue(response_json["groups"])
  52. def test_api_updates_select_field(self):
  53. """api updates select field"""
  54. response = self.client.post(self.api_link, data={"gender": "female"})
  55. self.assertEqual(response.status_code, 200)
  56. profile_fields = self.get_profile_fields()
  57. self.assertEqual(profile_fields["gender"], "female")
  58. response_json = response.json()
  59. self.assertEqual(response_json["id"], self.user.id)
  60. self.assertTrue(response_json["edit"])
  61. self.assertTrue(response_json["groups"])
  62. def test_api_validates_url_field(self):
  63. """api runs basic validation against url fields"""
  64. response = self.client.post(self.api_link, data={"website": "noturl"})
  65. self.assertEqual(response.status_code, 400)
  66. self.assertEqual(response.json(), {"website": ["Enter a valid URL."]})
  67. def test_api_cleans_url_field(self):
  68. """api cleans url fields"""
  69. response = self.client.post(self.api_link, data={"website": "onet.pl"})
  70. self.assertEqual(response.status_code, 200)
  71. profile_fields = self.get_profile_fields()
  72. self.assertEqual(profile_fields["website"], "http://onet.pl")
  73. response_json = response.json()
  74. self.assertEqual(response_json["id"], self.user.id)
  75. self.assertTrue(response_json["edit"])
  76. self.assertTrue(response_json["groups"])
  77. def test_api_custom_cleans_url_field(self):
  78. """api calls fields clean method"""
  79. response = self.client.post(self.api_link, data={"twitter": "@Weebl"})
  80. self.assertEqual(response.status_code, 200)
  81. profile_fields = self.get_profile_fields()
  82. self.assertEqual(profile_fields["twitter"], "Weebl")
  83. response_json = response.json()
  84. self.assertEqual(response_json["id"], self.user.id)
  85. self.assertTrue(response_json["edit"])
  86. self.assertTrue(response_json["groups"])