test_user_editdetails_api.py 4.4 KB

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