forked from GithubBackups/healthchecks
42 lines
1.3 KiB
Python
42 lines
1.3 KiB
Python
from django.contrib.auth.hashers import make_password
|
|
from django.contrib.auth.models import User
|
|
from django.test import TestCase
|
|
|
|
from hc.accounts.models import Profile
|
|
|
|
|
|
class CheckTokenTestCase(TestCase):
|
|
|
|
def setUp(self):
|
|
super(CheckTokenTestCase, self).setUp()
|
|
|
|
self.alice = User(username="alice")
|
|
self.alice.save()
|
|
|
|
self.profile = Profile(user=self.alice)
|
|
self.profile.token = make_password("secret-token")
|
|
self.profile.save()
|
|
|
|
def test_it_redirects(self):
|
|
r = self.client.get("/accounts/check_token/alice/secret-token/")
|
|
self.assertRedirects(r, "/checks/")
|
|
|
|
# After login, password should be unusable
|
|
self.alice.refresh_from_db()
|
|
assert not self.alice.has_usable_password()
|
|
|
|
def test_it_redirects_already_logged_in(self):
|
|
# Login
|
|
self.client.get("/accounts/check_token/alice/secret-token/")
|
|
|
|
# Login again, when already authenticated
|
|
r = self.client.get("/accounts/check_token/alice/secret-token/")
|
|
self.assertRedirects(r, "/checks/")
|
|
|
|
def test_it_redirects_bad_login(self):
|
|
# Login with a bad token
|
|
url = "/accounts/check_token/alice/invalid-token/"
|
|
r = self.client.get(url, follow=True)
|
|
self.assertRedirects(r, "/accounts/login/")
|
|
self.assertContains(r, "incorrect or expired")
|