123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302 |
- from django.contrib.auth import get_user_model
- from django.urls import reverse
- from misago.admin.testutils import AdminTestCase
- UserModel = get_user_model()
- class GenderProfileFieldTests(AdminTestCase):
- def setUp(self):
- super().setUp()
- self.test_link = reverse(
- "misago:admin:users:accounts:edit", kwargs={"pk": self.user.pk}
- )
- def test_field_displays_in_admin(self):
- """field displays in admin"""
- response = self.client.get(self.test_link)
- self.assertContains(response, 'name="gender"')
- def test_admin_clears_field(self):
- """admin form allows admins to clear field"""
- self.user.profile_fields["gender"] = "female"
- self.user.save()
- self.reload_user()
- self.assertEqual(self.user.profile_fields["gender"], "female")
- response = self.client.post(
- self.test_link,
- data={
- "username": "Edited",
- "rank": str(self.user.rank_id),
- "roles": str(self.user.roles.all()[0].pk),
- "email": "reg@stered.com",
- "new_password": "",
- "signature": "",
- "is_signature_locked": "0",
- "is_hiding_presence": "0",
- "limits_private_thread_invites_to": "0",
- "signature_lock_staff_message": "",
- "signature_lock_user_message": "",
- "subscribe_to_started_threads": "2",
- "subscribe_to_replied_threads": "2",
- },
- )
- self.assertEqual(response.status_code, 302)
- self.reload_user()
- self.assertEqual(self.user.profile_fields["gender"], "")
- def test_admin_validates_field(self):
- """admin form allows admins to edit field"""
- response = self.client.post(
- self.test_link,
- data={
- "username": "Edited",
- "rank": str(self.user.rank_id),
- "roles": str(self.user.roles.all()[0].pk),
- "email": "reg@stered.com",
- "gender": "attackcopter",
- "new_password": "",
- "signature": "",
- "is_signature_locked": "0",
- "is_hiding_presence": "0",
- "limits_private_thread_invites_to": "0",
- "signature_lock_staff_message": "",
- "signature_lock_user_message": "",
- "subscribe_to_started_threads": "2",
- "subscribe_to_replied_threads": "2",
- },
- )
- self.assertContains(
- response, "attackcopter is not one of the available choices."
- )
- def test_admin_edits_field(self):
- """admin form allows admins to edit field"""
- response = self.client.post(
- self.test_link,
- data={
- "username": "Edited",
- "rank": str(self.user.rank_id),
- "roles": str(self.user.roles.all()[0].pk),
- "email": "reg@stered.com",
- "gender": "female",
- "new_password": "",
- "signature": "",
- "is_signature_locked": "0",
- "is_hiding_presence": "0",
- "limits_private_thread_invites_to": "0",
- "signature_lock_staff_message": "",
- "signature_lock_user_message": "",
- "subscribe_to_started_threads": "2",
- "subscribe_to_replied_threads": "2",
- },
- )
- self.assertEqual(response.status_code, 302)
- self.reload_user()
- self.assertEqual(self.user.profile_fields["gender"], "female")
- def test_admin_search_field(self):
- """admin users search searches this field"""
- test_link = reverse("misago:admin:users:accounts:index")
- response = self.client.get("%s?redirected=1&profilefields=female" % test_link)
- self.assertContains(
- response, "No users matching search criteria have been found."
- )
- # search by value
- self.user.profile_fields["gender"] = "female"
- self.user.save()
- response = self.client.get("%s?redirected=1&profilefields=female" % test_link)
- self.assertNotContains(
- response, "No users matching search criteria have been found."
- )
- # search by choice name
- self.user.profile_fields["gender"] = "secret"
- self.user.save()
- response = self.client.get("%s?redirected=1&profilefields=telling" % test_link)
- self.assertNotContains(
- response, "No users matching search criteria have been found."
- )
- def test_field_display(self):
- """field displays on user profile when filled in"""
- test_link = reverse(
- "misago:user-details", kwargs={"pk": self.user.pk, "slug": self.user.slug}
- )
- response = self.client.get(test_link)
- self.assertNotContains(response, "Gender")
- self.user.profile_fields["gender"] = "secret"
- self.user.save()
- response = self.client.get(test_link)
- self.assertContains(response, "Gender")
- self.assertContains(response, "Not telling")
- def test_field_outdated_hidden(self):
- """field with outdated value is hidden"""
- test_link = reverse(
- "misago:user-details", kwargs={"pk": self.user.pk, "slug": self.user.slug}
- )
- response = self.client.get(test_link)
- self.assertNotContains(response, "Gender")
- self.user.profile_fields["gender"] = "not valid"
- self.user.save()
- response = self.client.get(test_link)
- self.assertNotContains(response, "Gender")
- def test_field_display_json(self):
- """field is included in display json"""
- test_link = reverse("misago:api:user-details", kwargs={"pk": self.user.pk})
- response = self.client.get(test_link)
- self.assertEqual(
- response.json()["groups"],
- [
- {
- "name": "IP address",
- "fields": [
- {"fieldname": "join_ip", "name": "Join IP", "text": "127.0.0.1"}
- ],
- }
- ],
- )
- self.user.profile_fields["gender"] = "male"
- self.user.save()
- response = self.client.get(test_link)
- self.assertEqual(
- response.json()["groups"],
- [
- {
- "name": "Personal",
- "fields": [
- {"fieldname": "gender", "name": "Gender", "text": "Male"}
- ],
- },
- {
- "name": "IP address",
- "fields": [
- {"fieldname": "join_ip", "name": "Join IP", "text": "127.0.0.1"}
- ],
- },
- ],
- )
- def test_field_outdated_hidden_json(self):
- """field with outdated value is removed in display json"""
- test_link = reverse("misago:api:user-details", kwargs={"pk": self.user.pk})
- response = self.client.get(test_link)
- self.assertEqual(
- response.json()["groups"],
- [
- {
- "name": "IP address",
- "fields": [
- {"fieldname": "join_ip", "name": "Join IP", "text": "127.0.0.1"}
- ],
- }
- ],
- )
- self.user.profile_fields["gender"] = "invalid"
- self.user.save()
- response = self.client.get(test_link)
- self.assertEqual(
- response.json()["groups"],
- [
- {
- "name": "IP address",
- "fields": [
- {"fieldname": "join_ip", "name": "Join IP", "text": "127.0.0.1"}
- ],
- }
- ],
- )
- def test_api_returns_field_json(self):
- """field json is returned from API"""
- test_link = reverse("misago:api:user-edit-details", kwargs={"pk": self.user.pk})
- response = self.client.get(test_link)
- found_field = None
- for group in response.json():
- for field in group["fields"]:
- if field["fieldname"] == "gender":
- found_field = field
- self.assertEqual(
- found_field,
- {
- "fieldname": "gender",
- "label": "Gender",
- "help_text": None,
- "input": {
- "type": "select",
- "choices": [
- {"label": "Not specified", "value": ""},
- {"label": "Not telling", "value": "secret"},
- {"label": "Female", "value": "female"},
- {"label": "Male", "value": "male"},
- ],
- },
- "initial": "",
- },
- )
- def test_api_clears_field(self):
- """field can be cleared via api"""
- test_link = reverse("misago:api:user-edit-details", kwargs={"pk": self.user.pk})
- self.user.profile_fields["gender"] = "secret"
- self.user.save()
- self.reload_user()
- self.assertEqual(self.user.profile_fields["gender"], "secret")
- response = self.client.post(test_link, data={})
- self.assertEqual(response.status_code, 200)
- self.reload_user()
- self.assertEqual(self.user.profile_fields["gender"], "")
- def test_api_validates_field(self):
- """field can be edited via api"""
- test_link = reverse("misago:api:user-edit-details", kwargs={"pk": self.user.pk})
- response = self.client.post(test_link, data={"gender": "attackhelicopter"})
- self.assertContains(
- response,
- "attackhelicopter is not one of the available choices.",
- status_code=400,
- )
- def test_api_edits_field(self):
- """field can be edited via api"""
- test_link = reverse("misago:api:user-edit-details", kwargs={"pk": self.user.pk})
- response = self.client.post(test_link, data={"gender": "female"})
- self.assertEqual(response.status_code, 200)
- self.reload_user()
- self.assertEqual(self.user.profile_fields["gender"], "female")
|