test_user_editdetails_api.py 4.7 KB

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