test_user_username_api.py 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. import json
  2. from django.urls import reverse
  3. from ...acl.test import patch_user_acl
  4. from ...conf.test import override_dynamic_settings
  5. from ..test import AuthenticatedUserTestCase, create_test_user
  6. class UserUsernameTests(AuthenticatedUserTestCase):
  7. """tests for user change name RPC (POST to /api/users/1/username/)"""
  8. def setUp(self):
  9. super().setUp()
  10. self.link = "/api/users/%s/username/" % self.user.pk
  11. @override_dynamic_settings(username_length_min=2, username_length_max=4)
  12. def test_get_change_username_options(self):
  13. """get to API returns options"""
  14. response = self.client.get(self.link)
  15. self.assertEqual(response.status_code, 200)
  16. response_json = response.json()
  17. self.assertIsNotNone(response_json["changes_left"])
  18. self.assertEqual(response_json["length_min"], 2)
  19. self.assertEqual(response_json["length_max"], 4)
  20. self.assertIsNone(response_json["next_on"])
  21. for i in range(response_json["changes_left"]):
  22. self.user.set_username("NewName%s" % i, self.user)
  23. response = self.client.get(self.link)
  24. self.assertEqual(response.status_code, 200)
  25. response_json = response.json()
  26. self.assertEqual(response_json["changes_left"], 0)
  27. self.assertIsNotNone(response_json["next_on"])
  28. def test_change_username_no_changes_left(self):
  29. """api returns error 400 if there are no username changes left"""
  30. response = self.client.get(self.link)
  31. self.assertEqual(response.status_code, 200)
  32. for i in range(response.json()["changes_left"]):
  33. self.user.set_username("NewName%s" % i, self.user)
  34. response = self.client.get(self.link)
  35. self.assertEqual(response.json()["changes_left"], 0)
  36. response = self.client.post(self.link, data={"username": "Pointless"})
  37. self.assertEqual(response.status_code, 400)
  38. self.assertEqual(
  39. response.json()["detail"], "You can't change your username now."
  40. )
  41. self.assertTrue(self.user.username != "Pointless")
  42. def test_change_username_no_input(self):
  43. """api returns error 400 if new username is empty"""
  44. response = self.client.post(self.link, data={})
  45. self.assertEqual(response.status_code, 400)
  46. self.assertEqual(response.json(), {"detail": "Enter new username."})
  47. def test_change_username_invalid_name(self):
  48. """api returns error 400 if new username is wrong"""
  49. response = self.client.post(self.link, data={"username": "####"})
  50. self.assertEqual(response.status_code, 400)
  51. self.assertEqual(
  52. response.json(),
  53. {"detail": "Username can only contain latin alphabet letters and digits."},
  54. )
  55. def test_change_username(self):
  56. """api changes username and records change"""
  57. response = self.client.get(self.link)
  58. changes_left = response.json()["changes_left"]
  59. old_username = self.user.username
  60. new_username = "NewUsernamu"
  61. response = self.client.post(self.link, data={"username": new_username})
  62. self.assertEqual(response.status_code, 200)
  63. options = response.json()["options"]
  64. self.assertEqual(changes_left, options["changes_left"] + 1)
  65. self.reload_user()
  66. self.assertEqual(self.user.username, new_username)
  67. self.assertTrue(self.user.username != old_username)
  68. self.assertEqual(self.user.namechanges.last().new_username, new_username)
  69. @override_dynamic_settings(
  70. enable_oauth2_client=True,
  71. oauth2_provider="Lorem",
  72. )
  73. def test_change_username_api_returns_403_if_oauth_is_enabled(user, user_client):
  74. response = user_client.post(
  75. reverse("misago:api:user-username", kwargs={"pk": user.pk}),
  76. {
  77. "username": "totallyNew",
  78. },
  79. )
  80. assert response.status_code == 403
  81. class UserUsernameModerationTests(AuthenticatedUserTestCase):
  82. """tests for moderate username RPC (/api/users/1/moderate-username/)"""
  83. def setUp(self):
  84. super().setUp()
  85. self.other_user = create_test_user("OtherUser", "otheruser@example.com")
  86. self.link = "/api/users/%s/moderate-username/" % self.other_user.pk
  87. @patch_user_acl({"can_rename_users": 0})
  88. def test_no_permission(self):
  89. """no permission to moderate username"""
  90. response = self.client.get(self.link)
  91. self.assertEqual(response.status_code, 403)
  92. self.assertEqual(response.json(), {"detail": "You can't rename users."})
  93. response = self.client.post(self.link)
  94. self.assertEqual(response.status_code, 403)
  95. self.assertEqual(response.json(), {"detail": "You can't rename users."})
  96. @patch_user_acl({"can_rename_users": 1})
  97. @override_dynamic_settings(username_length_min=3, username_length_max=12)
  98. def test_moderate_username(self):
  99. """moderate username"""
  100. response = self.client.get(self.link)
  101. self.assertEqual(response.status_code, 200)
  102. options = response.json()
  103. self.assertEqual(options["length_min"], 3)
  104. self.assertEqual(options["length_max"], 12)
  105. response = self.client.post(
  106. self.link, json.dumps({"username": ""}), content_type="application/json"
  107. )
  108. self.assertEqual(response.status_code, 400)
  109. self.assertEqual(response.json(), {"detail": "Enter new username."})
  110. response = self.client.post(
  111. self.link, json.dumps({"username": "$$$"}), content_type="application/json"
  112. )
  113. self.assertEqual(response.status_code, 400)
  114. self.assertEqual(
  115. response.json(),
  116. {"detail": "Username can only contain latin alphabet letters and digits."},
  117. )
  118. response = self.client.post(
  119. self.link, json.dumps({"username": "a"}), content_type="application/json"
  120. )
  121. self.assertEqual(response.status_code, 400)
  122. self.assertEqual(
  123. response.json(), {"detail": "Username must be at least 3 characters long."}
  124. )
  125. response = self.client.post(
  126. self.link,
  127. json.dumps({"username": "NewName"}),
  128. content_type="application/json",
  129. )
  130. self.assertEqual(response.status_code, 200)
  131. self.other_user.refresh_from_db()
  132. self.assertEqual("NewName", self.other_user.username)
  133. self.assertEqual("newname", self.other_user.slug)
  134. options = response.json()
  135. self.assertEqual(options["username"], self.other_user.username)
  136. self.assertEqual(options["slug"], self.other_user.slug)
  137. @patch_user_acl({"can_rename_users": 1})
  138. def test_moderate_own_username(self):
  139. """moderate own username"""
  140. response = self.client.get("/api/users/%s/moderate-username/" % self.user.pk)
  141. self.assertEqual(response.status_code, 200)