# -*- coding: utf-8 -*- import re import time from django.test import TestCase, override_settings, tag from django.test import Client as HttpClient from django.contrib.auth import get_user_model from django.core import mail from django.core.management import call_command from faker import Faker from babybuddy.views import UserUnlock class ViewsTestCase(TestCase): @classmethod def setUpClass(cls): super(ViewsTestCase, cls).setUpClass() fake = Faker() call_command("migrate", verbosity=0) cls.c = HttpClient() fake_user = fake.simple_profile() cls.credentials = { "username": fake_user["username"], "password": fake.password(), } cls.user = get_user_model().objects.create_user( is_superuser=True, email="admin@admin.admin", **cls.credentials ) cls.c.login(**cls.credentials) def test_root_router(self): page = self.c.get("/") self.assertEqual(page.url, "/dashboard/") @override_settings(ROLLING_SESSION_REFRESH=1) def test_rolling_sessions(self): self.c.get("/") session1 = str(self.c.cookies["sessionid"]) # Sleep longer than ROLLING_SESSION_REFRESH. time.sleep(2) self.c.get("/") session2 = str(self.c.cookies["sessionid"]) self.c.get("/") session3 = str(self.c.cookies["sessionid"]) self.assertNotEqual(session1, session2) self.assertEqual(session2, session3) def test_user_settings(self): page = self.c.get("/user/settings/") self.assertEqual(page.status_code, 200) def test_add_device_page(self): page = self.c.get("/user/add-device/") self.assertRegex( page.content.decode(), r""".*
]* data-qr-code-content="[^"]+"[^>]*>.*""", ) def test_user_views(self): # Staff setting is required to access user management. page = self.c.get("/users/") self.assertEqual(page.status_code, 403) self.user.is_staff = True self.user.save() page = self.c.get("/users/") self.assertEqual(page.status_code, 200) page = self.c.get("/users/add/") self.assertEqual(page.status_code, 200) entry = get_user_model().objects.first() page = self.c.get("/users/{}/edit/".format(entry.id)) self.assertEqual(page.status_code, 200) page = self.c.get("/users/{}/delete/".format(entry.id)) self.assertEqual(page.status_code, 200) def test_user_unlock(self): # Staff setting is required to unlock users. self.user.is_staff = True self.user.save() entry = get_user_model().objects.first() url = "/users/{}/unlock/".format(entry.id) page = self.c.get(url) self.assertEqual(page.status_code, 200) page = self.c.post(url, follow=True) self.assertEqual(page.status_code, 200) self.assertContains(page, UserUnlock.success_message) def test_welcome(self): page = self.c.get("/welcome/") self.assertEqual(page.status_code, 200) def test_logout_get_fails(self): page = self.c.get("/logout/") self.assertEqual(page.status_code, 405) @tag("isolate") def test_password_reset(self): """ Testing this class primarily ensures Baby Buddy's custom templates are correctly configured for Django's password reset flow. """ self.c.logout() page = self.c.get("/reset/") self.assertEqual(page.status_code, 200) page = self.c.post("/reset/", data={"email": self.user.email}, follow=True) self.assertEqual(page.status_code, 200) self.assertEqual(len(mail.outbox), 1) path = re.search( "http://testserver(?P[^\\s]+)", mail.outbox[0].body ).group("path") page = self.c.get(path, follow=True) self.assertEqual(page.status_code, 200) new_password = "xZZVN6z4TvhFg6S" data = { "new_password1": new_password, "new_password2": new_password, } page = self.c.post(page.request["PATH_INFO"], data=data, follow=True) self.assertEqual(page.status_code, 200)