Browse Source

Tests for hc.accounts

pull/7/head
Pēteris Caune 9 years ago
parent
commit
364e7ebec9
4 changed files with 49 additions and 3 deletions
  1. +0
    -3
      hc/accounts/tests.py
  2. +0
    -0
      hc/accounts/tests/__init__.py
  3. +17
    -0
      hc/accounts/tests/test_check_token.py
  4. +32
    -0
      hc/accounts/tests/test_login.py

+ 0
- 3
hc/accounts/tests.py View File

@ -1,3 +0,0 @@
from django.test import TestCase
# Create your tests here.

+ 0
- 0
hc/accounts/tests/__init__.py View File


+ 17
- 0
hc/accounts/tests/test_check_token.py View File

@ -0,0 +1,17 @@
from django.contrib.auth.models import User
from django.test import TestCase
class CheckTokenTestCase(TestCase):
def test_it_redirects(self):
alice = User(username="alice")
alice.set_password("secret-token")
alice.save()
r = self.client.get("/accounts/check_token/alice/secret-token/")
assert r.status_code == 302
# After login, password should be unusable
alice_again = User.objects.get(username="alice")
assert not alice_again.has_usable_password()

+ 32
- 0
hc/accounts/tests/test_login.py View File

@ -0,0 +1,32 @@
from django.contrib.auth.models import User
from django.core import mail
from django.test import TestCase
from hc.api.models import Check
class LoginTestCase(TestCase):
def test_it_sends_link(self):
check = Check()
check.save()
session = self.client.session
session["welcome_code"] = str(check.code)
session.save()
form = {"email": "[email protected]"}
r = self.client.post("/accounts/login/", form)
assert r.status_code == 302
# An user should have been created
self.assertEqual(User.objects.count(), 1)
# And email sent
self.assertEqual(len(mail.outbox), 1)
self.assertEqual(mail.outbox[0].subject, 'Log in to healthchecks.io')
# And check should be associated with the new user
check_again = Check.objects.get(code=check.code)
assert check_again.user

Loading…
Cancel
Save