12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- from django.test import TestCase
- from misago.users import credentialchange
- from misago.users.test import create_test_user
- class MockRequest(object):
- def __init__(self, user):
- self.session = {}
- self.user = user
- class CredentialChangeTests(TestCase):
- def setUp(self):
- self.user = create_test_user("User", "user@example.com")
- def test_valid_token_generation(self):
- """credentialchange module allows for store and read of change token"""
- request = MockRequest(self.user)
- token = credentialchange.store_new_credential(
- request, "email", "newmail@example.com"
- )
- email = credentialchange.read_new_credential(request, "email", token)
- self.assertEqual(email, "newmail@example.com")
- def test_email_change_invalidated_token(self):
- """token is invalidated by email change"""
- request = MockRequest(self.user)
- token = credentialchange.store_new_credential(
- request, "email", "newmail@example.com"
- )
- self.user.set_email("otheremail@example.com")
- self.user.save()
- email = credentialchange.read_new_credential(request, "email", token)
- self.assertIsNone(email)
- def test_password_change_invalidated_token(self):
- """token is invalidated by password change"""
- request = MockRequest(self.user)
- token = credentialchange.store_new_credential(
- request, "email", "newmail@example.com"
- )
- self.user.set_password("Egebeg!123")
- self.user.save()
- email = credentialchange.read_new_credential(request, "email", token)
- self.assertIsNone(email)
- def test_invalid_token_is_handled(self):
- """there are no explosions in invalid tokens handling"""
- request = MockRequest(self.user)
- token = credentialchange.store_new_credential(
- request, "email", "newmail@example.com"
- )
- email = credentialchange.read_new_credential(request, "em4il", token)
- self.assertIsNone(email)
|