1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- from datetime import timedelta
- from django.contrib.auth import get_user_model
- from django.test import TestCase
- from misago.users.namechanges import (
- get_next_available_namechange, get_left_namechanges, get_username_options
- )
- User = get_user_model()
- class UsernameChangesTests(TestCase):
- def test_user_without_permission_to_change_name_has_no_changes_left(self):
- user = User.objects.create_user('User', 'test@example.com')
- user_acl = {"name_changes_allowed": 0}
- assert get_left_namechanges(user, user_acl) == 0
- def test_user_without_namechanges_has_all_changes_left(self):
- user = User.objects.create_user('User', 'test@example.com')
- user_acl = {"name_changes_allowed": 3, "name_changes_expire": 0}
- assert get_left_namechanges(user, user_acl) == 3
- def test_user_own_namechanges_are_subtracted_from_changes_left(self):
- user = User.objects.create_user('User', 'test@example.com')
- user_acl = {"name_changes_allowed": 3, "name_changes_expire": 0}
- user.set_username('Changed')
- assert get_left_namechanges(user, user_acl) == 2
- def test_user_own_recent_namechanges_subtract_from_changes_left(self):
- user = User.objects.create_user('User', 'test@example.com')
- user_acl = {"name_changes_allowed": 3, "name_changes_expire": 5}
-
- user.set_username('Changed')
- assert get_left_namechanges(user, user_acl) == 2
- def test_user_own_expired_namechanges_dont_subtract_from_changes_left(self):
- user = User.objects.create_user('User', 'test@example.com')
- user_acl = {"name_changes_allowed": 3, "name_changes_expire": 5}
-
- username_change = user.set_username('Changed')
- username_change.changed_on -= timedelta(days=10)
- username_change.save()
- assert get_left_namechanges(user, user_acl) == 3
- def test_user_namechanges_by_other_users_dont_subtract_from_changes_left(self):
- user = User.objects.create_user('User', 'test@example.com')
- user_acl = {"name_changes_allowed": 3, "name_changes_expire": 0}
- username_change = user.set_username('Changed')
- username_change.changed_by = None
- username_change.save()
- assert get_left_namechanges(user, user_acl) == 3
- def test_user_next_available_namechange_is_none_for_user_with_changes_left(self):
- user = User.objects.create_user('User', 'test@example.com')
- user_acl = {"name_changes_allowed": 3, "name_changes_expire": 0}
- assert get_next_available_namechange(user, user_acl, 3) is None
-
- def test_user_next_available_namechange_is_none_if_own_namechanges_dont_expire(self):
- user = User.objects.create_user('User', 'test@example.com')
- user_acl = {"name_changes_allowed": 1, "name_changes_expire": 0}
- user.set_username('Changed')
- assert get_next_available_namechange(user, user_acl, 0) is None
- def test_user_next_available_namechange_is_calculated_if_own_namechanges_expire(self):
- user = User.objects.create_user('User', 'test@example.com')
- user_acl = {"name_changes_allowed": 1, "name_changes_expire": 1}
- username_change = user.set_username('Changed')
- next_change_on = get_next_available_namechange(user, user_acl, 0)
- assert next_change_on
- assert next_change_on == username_change.changed_on + timedelta(days=1)
|