2017-10-22 03:00:28 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
2023-02-06 14:59:57 +00:00
|
|
|
from django.contrib.auth import get_user_model
|
2017-10-22 03:00:28 +00:00
|
|
|
from django.core.management import call_command
|
2017-10-28 17:27:33 +00:00
|
|
|
from django.test import TestCase
|
|
|
|
from django.test import Client as HttpClient
|
|
|
|
from django.utils import timezone
|
2023-02-12 04:21:09 +00:00
|
|
|
from django.utils.formats import get_format, reset_format_cache
|
2017-10-22 03:00:28 +00:00
|
|
|
|
2022-05-28 02:56:38 +00:00
|
|
|
from faker import Faker
|
2017-10-22 03:00:28 +00:00
|
|
|
|
|
|
|
from core import models
|
|
|
|
|
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
class FormsTestCaseBase(TestCase):
|
2020-01-30 18:39:29 +00:00
|
|
|
c = None
|
2020-01-29 22:42:59 +00:00
|
|
|
child = None
|
2020-01-30 18:39:29 +00:00
|
|
|
user = None
|
2020-01-29 22:42:59 +00:00
|
|
|
|
2017-10-22 03:00:28 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2020-01-29 22:04:19 +00:00
|
|
|
super(FormsTestCaseBase, cls).setUpClass()
|
2022-05-28 02:56:38 +00:00
|
|
|
fake = Faker()
|
2022-02-10 00:00:30 +00:00
|
|
|
call_command("migrate", verbosity=0)
|
2017-10-22 03:00:28 +00:00
|
|
|
|
|
|
|
cls.c = HttpClient()
|
|
|
|
|
|
|
|
fake_user = fake.simple_profile()
|
2022-02-10 00:00:30 +00:00
|
|
|
credentials = {"username": fake_user["username"], "password": fake.password()}
|
2023-02-08 04:29:15 +00:00
|
|
|
cls.user = get_user_model().objects.create_user(
|
|
|
|
is_superuser=True, **credentials
|
|
|
|
)
|
2020-01-30 18:39:29 +00:00
|
|
|
cls.c.login(**credentials)
|
2017-10-22 03:00:28 +00:00
|
|
|
|
2020-01-29 22:42:59 +00:00
|
|
|
cls.child = models.Child.objects.create(
|
2022-02-10 00:00:30 +00:00
|
|
|
first_name="Child", last_name="One", birth_date=timezone.localdate()
|
2020-01-29 22:42:59 +00:00
|
|
|
)
|
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
@staticmethod
|
|
|
|
def localdate_string(datetime=None):
|
2022-02-10 00:00:30 +00:00
|
|
|
"""Converts an object to a local date string for form input."""
|
2023-02-12 04:21:09 +00:00
|
|
|
reset_format_cache()
|
2022-02-10 00:00:30 +00:00
|
|
|
date_format = get_format("DATE_INPUT_FORMATS")[0]
|
2020-01-29 22:04:19 +00:00
|
|
|
return timezone.localdate(datetime).strftime(date_format)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def localtime_string(datetime=None):
|
2022-02-10 00:00:30 +00:00
|
|
|
"""Converts an object to a local time string for form input."""
|
2023-02-12 04:21:09 +00:00
|
|
|
reset_format_cache()
|
2022-02-10 00:00:30 +00:00
|
|
|
datetime_format = get_format("DATETIME_INPUT_FORMATS")[0]
|
2020-01-29 22:04:19 +00:00
|
|
|
return timezone.localtime(datetime).strftime(datetime_format)
|
|
|
|
|
|
|
|
|
2020-01-30 18:39:29 +00:00
|
|
|
class InitialValuesTestCase(FormsTestCaseBase):
|
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
|
|
|
super(InitialValuesTestCase, cls).setUpClass()
|
|
|
|
cls.timer = models.Timer.objects.create(
|
2022-02-10 00:00:30 +00:00
|
|
|
user=cls.user, start=timezone.localtime() - timezone.timedelta(minutes=30)
|
2020-01-30 18:39:29 +00:00
|
|
|
)
|
2020-01-29 22:04:19 +00:00
|
|
|
|
2020-01-30 18:39:29 +00:00
|
|
|
def test_child_with_one_child(self):
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.get("/sleep/add/")
|
|
|
|
self.assertEqual(page.context["form"].initial["child"], self.child)
|
2020-01-29 22:04:19 +00:00
|
|
|
|
2020-01-30 18:39:29 +00:00
|
|
|
def test_child_with_parameter(self):
|
2020-01-30 19:35:43 +00:00
|
|
|
child_two = models.Child.objects.create(
|
2022-02-10 00:00:30 +00:00
|
|
|
first_name="Child", last_name="Two", birth_date=timezone.localdate()
|
2020-01-30 19:35:43 +00:00
|
|
|
)
|
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.get("/sleep/add/")
|
|
|
|
self.assertTrue("child" not in page.context["form"].initial)
|
2020-01-29 22:04:19 +00:00
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.get("/sleep/add/?child={}".format(self.child.slug))
|
|
|
|
self.assertEqual(page.context["form"].initial["child"], self.child)
|
2020-01-29 22:04:19 +00:00
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.get("/sleep/add/?child={}".format(child_two.slug))
|
|
|
|
self.assertEqual(page.context["form"].initial["child"], child_two)
|
2020-01-29 22:04:19 +00:00
|
|
|
|
2020-01-30 18:39:29 +00:00
|
|
|
def test_feeding_type(self):
|
2020-01-30 19:35:43 +00:00
|
|
|
child_two = models.Child.objects.create(
|
2022-02-10 00:00:30 +00:00
|
|
|
first_name="Child", last_name="Two", birth_date=timezone.localdate()
|
2020-01-30 19:35:43 +00:00
|
|
|
)
|
2020-03-28 10:54:07 +00:00
|
|
|
child_three = models.Child.objects.create(
|
2022-02-10 00:00:30 +00:00
|
|
|
first_name="Child", last_name="Three", birth_date=timezone.localdate()
|
2020-03-28 10:54:07 +00:00
|
|
|
)
|
|
|
|
start_time = timezone.localtime() - timezone.timedelta(hours=4)
|
2022-02-10 00:00:30 +00:00
|
|
|
end_time = timezone.localtime() - timezone.timedelta(hours=3, minutes=30)
|
2020-01-30 18:39:29 +00:00
|
|
|
f_one = models.Feeding.objects.create(
|
2020-01-29 22:42:59 +00:00
|
|
|
child=self.child,
|
2020-03-28 10:54:07 +00:00
|
|
|
start=start_time,
|
|
|
|
end=end_time,
|
2022-02-10 00:00:30 +00:00
|
|
|
type="breast milk",
|
|
|
|
method="left breast",
|
2020-01-30 18:39:29 +00:00
|
|
|
)
|
|
|
|
f_two = models.Feeding.objects.create(
|
2020-01-30 19:35:43 +00:00
|
|
|
child=child_two,
|
2020-03-28 10:54:07 +00:00
|
|
|
start=start_time,
|
|
|
|
end=end_time,
|
2022-02-10 00:00:30 +00:00
|
|
|
type="formula",
|
|
|
|
method="bottle",
|
2020-01-29 22:42:59 +00:00
|
|
|
)
|
2020-03-28 10:54:07 +00:00
|
|
|
f_three = models.Feeding.objects.create(
|
|
|
|
child=child_three,
|
|
|
|
start=start_time,
|
|
|
|
end=end_time,
|
2022-02-10 00:00:30 +00:00
|
|
|
type="fortified breast milk",
|
|
|
|
method="bottle",
|
2020-03-28 10:54:07 +00:00
|
|
|
)
|
2020-01-29 22:42:59 +00:00
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.get("/feedings/add/")
|
|
|
|
self.assertTrue("type" not in page.context["form"].initial)
|
2020-01-30 18:39:29 +00:00
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.get("/feedings/add/?child={}".format(self.child.slug))
|
|
|
|
self.assertEqual(page.context["form"].initial["type"], f_one.type)
|
|
|
|
self.assertFalse("method" in page.context["form"].initial)
|
2020-01-30 18:39:29 +00:00
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.get("/feedings/add/?child={}".format(child_two.slug))
|
|
|
|
self.assertEqual(page.context["form"].initial["type"], f_two.type)
|
|
|
|
self.assertEqual(page.context["form"].initial["method"], f_two.method)
|
2020-03-28 10:54:07 +00:00
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.get("/feedings/add/?child={}".format(child_three.slug))
|
|
|
|
self.assertEqual(page.context["form"].initial["type"], f_three.type)
|
|
|
|
self.assertEqual(page.context["form"].initial["method"], f_three.method)
|
2020-01-30 18:39:29 +00:00
|
|
|
|
|
|
|
def test_timer_set(self):
|
|
|
|
self.timer.stop()
|
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.get("/sleep/add/")
|
|
|
|
self.assertTrue("start" not in page.context["form"].initial)
|
|
|
|
self.assertTrue("end" not in page.context["form"].initial)
|
2020-01-30 18:39:29 +00:00
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.get("/sleep/add/?timer={}".format(self.timer.id))
|
|
|
|
self.assertEqual(page.context["form"].initial["start"], self.timer.start)
|
|
|
|
self.assertEqual(page.context["form"].initial["end"], self.timer.end)
|
2020-01-30 18:39:29 +00:00
|
|
|
|
|
|
|
def test_timer_stop_on_save(self):
|
|
|
|
end = timezone.localtime()
|
2020-01-29 22:04:19 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.child.id,
|
|
|
|
"start": self.localtime_string(self.timer.start),
|
|
|
|
"end": self.localtime_string(end),
|
2020-01-29 22:04:19 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post(
|
|
|
|
"/sleep/add/?timer={}".format(self.timer.id), params, follow=True
|
|
|
|
)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2020-01-30 18:39:29 +00:00
|
|
|
self.timer.refresh_from_db()
|
|
|
|
self.assertFalse(self.timer.active)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertEqual(self.localtime_string(self.timer.end), params["end"])
|
2020-01-29 22:04:19 +00:00
|
|
|
|
|
|
|
|
2022-06-14 21:05:03 +00:00
|
|
|
class BMIFormsTestCase(FormsTestCaseBase):
|
2022-05-28 04:50:25 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2022-06-14 21:05:03 +00:00
|
|
|
super(BMIFormsTestCase, cls).setUpClass()
|
2022-05-28 04:50:25 +00:00
|
|
|
cls.bmi = models.BMI.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
bmi=30,
|
|
|
|
date=timezone.localdate() - timezone.timedelta(days=2),
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_add(self):
|
|
|
|
params = {
|
|
|
|
"child": self.child.id,
|
|
|
|
"bmi": 35,
|
|
|
|
"date": self.localdate_string(),
|
|
|
|
}
|
|
|
|
|
|
|
|
page = self.c.post("/bmi/add/", params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "Bmi entry for {} added".format(str(self.child)))
|
|
|
|
|
|
|
|
def test_edit(self):
|
|
|
|
params = {
|
|
|
|
"child": self.bmi.child.id,
|
|
|
|
"bmi": self.bmi.bmi + 1,
|
|
|
|
"date": self.bmi.date,
|
|
|
|
}
|
|
|
|
page = self.c.post("/bmi/{}/".format(self.bmi.id), params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.bmi.refresh_from_db()
|
|
|
|
self.assertEqual(self.bmi.bmi, params["bmi"])
|
|
|
|
self.assertContains(
|
|
|
|
page, "Bmi entry for {} updated".format(str(self.bmi.child))
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_delete(self):
|
|
|
|
page = self.c.post("/bmi/{}/delete/".format(self.bmi.id), follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "Bmi entry deleted")
|
|
|
|
|
|
|
|
|
2020-01-30 19:35:43 +00:00
|
|
|
class ChildFormsTestCase(FormsTestCaseBase):
|
2020-01-29 22:04:19 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2020-01-30 19:35:43 +00:00
|
|
|
super(ChildFormsTestCase, cls).setUpClass()
|
2020-01-29 22:04:19 +00:00
|
|
|
cls.child = models.Child.objects.first()
|
|
|
|
|
|
|
|
def test_add(self):
|
2017-11-01 20:14:42 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"first_name": "Child",
|
|
|
|
"last_name": "Two",
|
|
|
|
"birth_date": timezone.localdate(),
|
2017-11-01 20:14:42 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/children/add/", params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Child entry added")
|
2017-11-01 20:14:42 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_edit(self):
|
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"first_name": "Name",
|
|
|
|
"last_name": "Changed",
|
|
|
|
"birth_date": self.child.birth_date,
|
2020-01-29 22:04:19 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post(
|
|
|
|
"/children/{}/edit/".format(self.child.slug), params, follow=True
|
|
|
|
)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.child.refresh_from_db()
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertEqual(self.child.last_name, params["last_name"])
|
|
|
|
self.assertContains(page, "Child entry updated")
|
2017-11-01 20:14:42 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_delete(self):
|
2022-02-10 00:00:30 +00:00
|
|
|
params = {"confirm_name": "Incorrect"}
|
|
|
|
page = self.c.post(
|
|
|
|
"/children/{}/delete/".format(self.child.slug), params, follow=True
|
|
|
|
)
|
2017-11-01 20:14:42 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertFormError(
|
|
|
|
page, "form", "confirm_name", "Name does not match child name."
|
|
|
|
)
|
2017-11-01 20:14:42 +00:00
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
params["confirm_name"] = str(self.child)
|
|
|
|
page = self.c.post(
|
|
|
|
"/children/{}/delete/".format(self.child.slug), params, follow=True
|
|
|
|
)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Child entry deleted")
|
2020-01-29 22:04:19 +00:00
|
|
|
|
|
|
|
|
2020-01-30 19:35:43 +00:00
|
|
|
class DiaperChangeFormsTestCase(FormsTestCaseBase):
|
2020-01-29 22:04:19 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2020-01-30 19:35:43 +00:00
|
|
|
super(DiaperChangeFormsTestCase, cls).setUpClass()
|
2020-01-29 22:42:59 +00:00
|
|
|
cls.change = models.DiaperChange.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
time=timezone.localtime(),
|
|
|
|
wet=True,
|
|
|
|
solid=True,
|
2022-02-10 00:00:30 +00:00
|
|
|
color="black",
|
|
|
|
amount=0.45,
|
2020-01-29 22:42:59 +00:00
|
|
|
)
|
2017-10-22 03:00:28 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_add(self):
|
|
|
|
child = models.Child.objects.first()
|
2017-11-01 20:14:42 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": child.id,
|
|
|
|
"time": self.localtime_string(),
|
|
|
|
"color": "black",
|
|
|
|
"amount": 0.45,
|
2017-11-01 20:14:42 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/changes/add/", params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Diaper Change entry for {} added".format(str(child)))
|
2020-01-29 22:04:19 +00:00
|
|
|
|
|
|
|
def test_edit(self):
|
2017-10-22 03:00:28 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.change.child.id,
|
|
|
|
"time": self.localtime_string(),
|
|
|
|
"wet": self.change.wet,
|
|
|
|
"solid": self.change.solid,
|
|
|
|
"color": self.change.color,
|
|
|
|
"amount": 1.23,
|
2020-01-29 22:04:19 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/changes/{}/".format(self.change.id), params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.change.refresh_from_db()
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertEqual(self.change.amount, params["amount"])
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertContains(
|
2022-02-10 00:00:30 +00:00
|
|
|
page, "Diaper Change entry for {} updated".format(str(self.change.child))
|
2020-01-29 22:04:19 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
def test_delete(self):
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/changes/{}/delete/".format(self.change.id), follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Diaper Change entry deleted")
|
2020-01-29 22:04:19 +00:00
|
|
|
|
|
|
|
|
2020-01-30 19:35:43 +00:00
|
|
|
class FeedingFormsTestCase(FormsTestCaseBase):
|
2020-01-29 22:04:19 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2020-01-30 19:35:43 +00:00
|
|
|
super(FeedingFormsTestCase, cls).setUpClass()
|
2020-01-29 22:42:59 +00:00
|
|
|
cls.feeding = models.Feeding.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
start=timezone.localtime() - timezone.timedelta(hours=2),
|
|
|
|
end=timezone.localtime() - timezone.timedelta(hours=1, minutes=30),
|
2022-02-10 00:00:30 +00:00
|
|
|
type="breast milk",
|
|
|
|
method="left breast",
|
|
|
|
amount=2.5,
|
2020-01-29 22:42:59 +00:00
|
|
|
)
|
2020-01-29 22:04:19 +00:00
|
|
|
|
|
|
|
def test_add(self):
|
|
|
|
end = timezone.localtime()
|
|
|
|
start = end - timezone.timedelta(minutes=30)
|
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.child.id,
|
|
|
|
"start": self.localtime_string(start),
|
|
|
|
"end": self.localtime_string(end),
|
|
|
|
"type": "formula",
|
|
|
|
"method": "bottle",
|
|
|
|
"amount": 0,
|
2017-10-22 03:00:28 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/feedings/add/", params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Feeding entry for {} added".format(str(self.child)))
|
2017-10-22 03:00:28 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_edit(self):
|
|
|
|
end = timezone.localtime()
|
|
|
|
start = end - timezone.timedelta(minutes=30)
|
2019-05-17 04:33:26 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.feeding.child.id,
|
|
|
|
"start": self.localtime_string(start),
|
|
|
|
"end": self.localtime_string(end),
|
|
|
|
"type": self.feeding.type,
|
|
|
|
"method": self.feeding.method,
|
|
|
|
"amount": 100,
|
2019-05-17 04:33:26 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/feedings/{}/".format(self.feeding.id), params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.feeding.refresh_from_db()
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertEqual(self.feeding.amount, params["amount"])
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertContains(
|
2022-02-10 00:00:30 +00:00
|
|
|
page, "Feeding entry for {} updated".format(str(self.feeding.child))
|
2020-01-29 22:04:19 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
def test_delete(self):
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/feedings/{}/delete/".format(self.feeding.id), follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Feeding entry deleted")
|
2019-05-17 04:33:26 +00:00
|
|
|
|
|
|
|
|
2022-06-14 21:05:03 +00:00
|
|
|
class HeadCircumferenceFormsTestCase(FormsTestCaseBase):
|
2022-05-27 23:23:38 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2022-06-14 21:05:03 +00:00
|
|
|
super(HeadCircumferenceFormsTestCase, cls).setUpClass()
|
2022-05-28 04:50:25 +00:00
|
|
|
cls.head_circumference = models.HeadCircumference.objects.create(
|
2022-05-27 23:23:38 +00:00
|
|
|
child=cls.child,
|
2022-05-28 04:50:25 +00:00
|
|
|
head_circumference=15,
|
|
|
|
date=timezone.localdate() - timezone.timedelta(days=2),
|
2022-05-27 23:23:38 +00:00
|
|
|
)
|
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
def test_add(self):
|
2022-05-27 23:23:38 +00:00
|
|
|
params = {
|
|
|
|
"child": self.child.id,
|
2022-05-28 04:50:25 +00:00
|
|
|
"head_circumference": 20,
|
|
|
|
"date": self.localdate_string(),
|
2022-05-27 23:23:38 +00:00
|
|
|
}
|
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
page = self.c.post("/head-circumference/add/", params, follow=True)
|
2022-05-27 23:23:38 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-05-28 04:50:25 +00:00
|
|
|
self.assertContains(
|
|
|
|
page, "Head Circumference entry for {} added".format(str(self.child))
|
|
|
|
)
|
2022-05-27 23:23:38 +00:00
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
def test_edit(self):
|
2022-05-27 23:23:38 +00:00
|
|
|
params = {
|
2022-05-28 04:50:25 +00:00
|
|
|
"child": self.head_circumference.child.id,
|
|
|
|
"head_circumference": self.head_circumference.head_circumference + 1,
|
|
|
|
"date": self.head_circumference.date,
|
2022-05-27 23:23:38 +00:00
|
|
|
}
|
2022-05-28 04:50:25 +00:00
|
|
|
page = self.c.post(
|
|
|
|
"/head-circumference/{}/".format(self.head_circumference.id),
|
|
|
|
params,
|
|
|
|
follow=True,
|
|
|
|
)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.head_circumference.refresh_from_db()
|
|
|
|
self.assertEqual(
|
|
|
|
self.head_circumference.head_circumference, params["head_circumference"]
|
|
|
|
)
|
|
|
|
self.assertContains(
|
|
|
|
page,
|
|
|
|
"Head Circumference entry for {} updated".format(
|
|
|
|
str(self.head_circumference.child)
|
|
|
|
),
|
|
|
|
)
|
2022-05-27 23:23:38 +00:00
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
def test_delete(self):
|
|
|
|
page = self.c.post(
|
|
|
|
"/head-circumference/{}/delete/".format(self.head_circumference.id),
|
|
|
|
follow=True,
|
|
|
|
)
|
2022-05-27 23:23:38 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-05-28 04:50:25 +00:00
|
|
|
self.assertContains(page, "Head Circumference entry deleted")
|
2022-05-27 23:23:38 +00:00
|
|
|
|
|
|
|
|
2022-06-14 21:05:03 +00:00
|
|
|
class HeightFormsTestCase(FormsTestCaseBase):
|
2022-05-28 04:50:25 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2022-06-14 21:05:03 +00:00
|
|
|
super(HeightFormsTestCase, cls).setUpClass()
|
2022-05-28 04:50:25 +00:00
|
|
|
cls.height = models.Height.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
height=12.5,
|
|
|
|
date=timezone.localdate() - timezone.timedelta(days=2),
|
|
|
|
)
|
2022-05-27 23:23:38 +00:00
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
def test_add(self):
|
|
|
|
params = {
|
|
|
|
"child": self.child.id,
|
|
|
|
"height": 13.5,
|
|
|
|
"date": self.localdate_string(),
|
|
|
|
}
|
2022-05-27 23:23:38 +00:00
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
page = self.c.post("/height/add/", params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "Height entry for {} added".format(str(self.child)))
|
2022-05-27 23:23:38 +00:00
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
def test_edit(self):
|
2022-05-27 23:23:38 +00:00
|
|
|
params = {
|
2022-05-28 04:50:25 +00:00
|
|
|
"child": self.height.child.id,
|
|
|
|
"height": self.height.height + 1,
|
|
|
|
"date": self.height.date,
|
2022-05-27 23:23:38 +00:00
|
|
|
}
|
2022-05-28 04:50:25 +00:00
|
|
|
page = self.c.post("/height/{}/".format(self.height.id), params, follow=True)
|
2022-05-27 23:23:38 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-05-28 04:50:25 +00:00
|
|
|
self.height.refresh_from_db()
|
|
|
|
self.assertEqual(self.height.height, params["height"])
|
2022-05-27 23:23:38 +00:00
|
|
|
self.assertContains(
|
2022-05-28 04:50:25 +00:00
|
|
|
page, "Height entry for {} updated".format(str(self.height.child))
|
2022-05-27 23:23:38 +00:00
|
|
|
)
|
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
def test_delete(self):
|
|
|
|
page = self.c.post("/height/{}/delete/".format(self.height.id), follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "Height entry deleted")
|
|
|
|
|
|
|
|
|
2022-06-14 21:05:03 +00:00
|
|
|
class NoteFormsTestCase(FormsTestCaseBase):
|
2022-05-28 04:50:25 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2022-06-14 21:05:03 +00:00
|
|
|
super(NoteFormsTestCase, cls).setUpClass()
|
2022-05-28 04:50:25 +00:00
|
|
|
cls.note = models.Note.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
note="Test note!",
|
|
|
|
time=timezone.localtime() - timezone.timedelta(days=2),
|
2022-05-27 23:23:38 +00:00
|
|
|
)
|
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
def test_add(self):
|
|
|
|
params = {
|
|
|
|
"child": self.child.id,
|
|
|
|
"note": "New note",
|
|
|
|
"time": self.localtime_string(),
|
|
|
|
}
|
2022-05-27 23:23:38 +00:00
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
page = self.c.post("/notes/add/", params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "Note entry for {} added".format(str(self.child)))
|
2022-05-27 23:23:38 +00:00
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
def test_edit(self):
|
2022-05-27 23:23:38 +00:00
|
|
|
params = {
|
|
|
|
"child": self.note.child.id,
|
2022-05-28 04:50:25 +00:00
|
|
|
"note": "changed note",
|
|
|
|
"time": self.note.time,
|
2022-05-27 23:23:38 +00:00
|
|
|
}
|
|
|
|
page = self.c.post("/notes/{}/".format(self.note.id), params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.note.refresh_from_db()
|
2022-05-28 04:50:25 +00:00
|
|
|
self.assertEqual(self.note.note, params["note"])
|
|
|
|
self.assertContains(
|
|
|
|
page, "Note entry for {} updated".format(str(self.note.child))
|
|
|
|
)
|
2022-05-27 23:23:38 +00:00
|
|
|
|
|
|
|
def test_delete(self):
|
|
|
|
page = self.c.post("/notes/{}/delete/".format(self.note.id), follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "Note entry deleted")
|
|
|
|
|
|
|
|
|
|
|
|
class PumpingFormsTestCase(FormsTestCaseBase):
|
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
|
|
|
super(PumpingFormsTestCase, cls).setUpClass()
|
|
|
|
cls.bp = models.Pumping.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
amount=50.0,
|
|
|
|
time=timezone.localtime() - timezone.timedelta(days=1),
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_add(self):
|
|
|
|
params = {
|
|
|
|
"child": self.child.id,
|
|
|
|
"amount": "50.0",
|
|
|
|
"time": self.localtime_string(),
|
|
|
|
}
|
|
|
|
|
|
|
|
page = self.c.post("/pumping/add/", params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "Pumping entry for {} added".format(str(self.child)))
|
|
|
|
|
|
|
|
def test_edit(self):
|
|
|
|
params = {
|
|
|
|
"child": self.bp.child.id,
|
|
|
|
"amount": self.bp.amount + 2,
|
|
|
|
"time": self.localtime_string(),
|
|
|
|
}
|
|
|
|
page = self.c.post("/pumping/{}/".format(self.bp.id), params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.bp.refresh_from_db()
|
|
|
|
self.assertEqual(self.bp.amount, params["amount"])
|
|
|
|
self.assertContains(
|
|
|
|
page, "Pumping entry for {} updated".format(str(self.bp.child))
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_delete(self):
|
|
|
|
page = self.c.post("/pumping/{}/delete/".format(self.bp.id), follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "Pumping entry deleted")
|
|
|
|
|
|
|
|
|
2020-01-30 19:35:43 +00:00
|
|
|
class SleepFormsTestCase(FormsTestCaseBase):
|
2020-01-29 22:04:19 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2020-01-30 19:35:43 +00:00
|
|
|
super(SleepFormsTestCase, cls).setUpClass()
|
2020-01-29 22:42:59 +00:00
|
|
|
cls.sleep = models.Sleep.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
start=timezone.localtime() - timezone.timedelta(hours=6),
|
2022-02-10 00:00:30 +00:00
|
|
|
end=timezone.localtime() - timezone.timedelta(hours=4),
|
2020-01-29 22:42:59 +00:00
|
|
|
)
|
2017-10-28 17:27:33 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_add(self):
|
2021-10-27 02:43:26 +00:00
|
|
|
# Prevent potential sleep entry intersection errors.
|
|
|
|
models.Sleep.objects.all().delete()
|
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
end = timezone.localtime()
|
|
|
|
start = end - timezone.timedelta(minutes=2)
|
2017-10-28 17:27:33 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.child.id,
|
|
|
|
"start": self.localtime_string(start),
|
|
|
|
"end": self.localtime_string(end),
|
2017-10-28 17:27:33 +00:00
|
|
|
}
|
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/sleep/add/", params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Sleep entry for {} added".format(str(self.child)))
|
2017-11-04 03:29:55 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_edit(self):
|
|
|
|
end = timezone.localtime()
|
|
|
|
start = end - timezone.timedelta(minutes=2)
|
2017-10-22 03:00:28 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.sleep.child.id,
|
|
|
|
"start": self.localtime_string(start),
|
|
|
|
"end": self.localtime_string(end),
|
2017-10-22 03:00:28 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/sleep/{}/".format(self.sleep.id), params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.sleep.refresh_from_db()
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertEqual(self.localtime_string(self.sleep.end), params["end"])
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertContains(
|
2022-02-10 00:00:30 +00:00
|
|
|
page, "Sleep entry for {} updated".format(str(self.sleep.child))
|
2020-01-29 22:04:19 +00:00
|
|
|
)
|
2017-10-22 03:00:28 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_delete(self):
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/sleep/{}/delete/".format(self.sleep.id), follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Sleep entry deleted")
|
2017-11-01 16:44:07 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
|
2022-05-28 04:50:25 +00:00
|
|
|
class TaggedFormsTestCase(FormsTestCaseBase):
|
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
|
|
|
super(TaggedFormsTestCase, cls).setUpClass()
|
|
|
|
|
|
|
|
cls.note = models.Note.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
note="Setup note",
|
|
|
|
time=timezone.now() - timezone.timedelta(days=2),
|
|
|
|
)
|
|
|
|
cls.note.tags.add("oldtag")
|
|
|
|
cls.oldtag = models.Tag.objects.filter(slug="oldtag").first()
|
|
|
|
|
|
|
|
def test_add_no_tags(self):
|
|
|
|
params = {
|
|
|
|
"child": self.child.id,
|
|
|
|
"note": "note with no tags",
|
|
|
|
"time": (timezone.now() - timezone.timedelta(minutes=1)).isoformat(),
|
|
|
|
}
|
|
|
|
|
|
|
|
page = self.c.post("/notes/add/", params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "note with no tags")
|
|
|
|
|
|
|
|
def test_add_with_tags(self):
|
|
|
|
params = {
|
|
|
|
"child": self.child.id,
|
|
|
|
"note": "this note has tags",
|
|
|
|
"time": (timezone.now() - timezone.timedelta(minutes=1)).isoformat(),
|
|
|
|
"tags": 'A,B,"setup tag"',
|
|
|
|
}
|
|
|
|
|
|
|
|
old_notes = list(models.Note.objects.all())
|
|
|
|
|
|
|
|
page = self.c.post("/notes/add/", params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "this note has tags")
|
|
|
|
|
|
|
|
new_notes = list(models.Note.objects.all())
|
|
|
|
|
|
|
|
# Find the new tag and extract its tags
|
|
|
|
old_pks = [n.pk for n in old_notes]
|
|
|
|
new_note = [n for n in new_notes if n.pk not in old_pks][0]
|
|
|
|
new_note_tag_names = [t.name for t in new_note.tags.all()]
|
|
|
|
|
|
|
|
self.assertSetEqual(set(new_note_tag_names), {"A", "B", "setup tag"})
|
|
|
|
|
|
|
|
def test_edit(self):
|
|
|
|
old_tag_last_used = self.oldtag.last_used
|
|
|
|
|
|
|
|
params = {
|
|
|
|
"child": self.note.child.id,
|
|
|
|
"note": "Edited note",
|
|
|
|
"time": self.localdate_string(),
|
|
|
|
"tags": "oldtag,newtag",
|
|
|
|
}
|
|
|
|
page = self.c.post("/notes/{}/".format(self.note.id), params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
|
|
|
|
self.note.refresh_from_db()
|
|
|
|
self.oldtag.refresh_from_db()
|
|
|
|
self.assertEqual(self.note.note, params["note"])
|
|
|
|
self.assertContains(
|
|
|
|
page, "Note entry for {} updated".format(str(self.note.child))
|
|
|
|
)
|
|
|
|
|
|
|
|
self.assertSetEqual(
|
|
|
|
set(t.name for t in self.note.tags.all()), {"oldtag", "newtag"}
|
|
|
|
)
|
|
|
|
|
|
|
|
# Old tag remains old, because it was not added
|
|
|
|
self.assertEqual(old_tag_last_used, self.oldtag.last_used)
|
|
|
|
|
|
|
|
# Second phase: Remove all tags then add "oldtag" through posting
|
|
|
|
# which should update the last_used tag
|
|
|
|
self.note.tags.clear()
|
|
|
|
self.note.save()
|
|
|
|
|
|
|
|
params = {
|
|
|
|
"child": self.note.child.id,
|
|
|
|
"note": "Edited note (2)",
|
|
|
|
"time": self.localdate_string(),
|
|
|
|
"tags": "oldtag",
|
|
|
|
}
|
|
|
|
page = self.c.post("/notes/{}/".format(self.note.id), params, follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
|
|
|
|
self.note.refresh_from_db()
|
|
|
|
self.oldtag.refresh_from_db()
|
|
|
|
|
|
|
|
self.assertLess(old_tag_last_used, self.oldtag.last_used)
|
|
|
|
|
|
|
|
def test_delete(self):
|
|
|
|
page = self.c.post("/notes/{}/delete/".format(self.note.id), follow=True)
|
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(page, "Note entry deleted")
|
|
|
|
|
|
|
|
|
2020-01-30 19:35:43 +00:00
|
|
|
class TemperatureFormsTestCase(FormsTestCaseBase):
|
2020-01-29 22:04:19 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2020-01-30 19:35:43 +00:00
|
|
|
super(TemperatureFormsTestCase, cls).setUpClass()
|
2020-01-29 22:42:59 +00:00
|
|
|
cls.temp = models.Temperature.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
temperature=98.6,
|
2022-02-10 00:00:30 +00:00
|
|
|
time=timezone.localtime() - timezone.timedelta(days=1),
|
2020-01-29 22:42:59 +00:00
|
|
|
)
|
2020-01-29 22:04:19 +00:00
|
|
|
|
|
|
|
def test_add(self):
|
2017-11-10 02:15:09 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.child.id,
|
|
|
|
"temperature": "98.6",
|
|
|
|
"time": self.localtime_string(),
|
2017-11-10 02:15:09 +00:00
|
|
|
}
|
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/temperature/add/", params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertContains(
|
2022-02-10 00:00:30 +00:00
|
|
|
page, "Temperature entry for {} added".format(str(self.child))
|
2020-01-29 22:04:19 +00:00
|
|
|
)
|
2017-11-10 02:15:09 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_edit(self):
|
2017-11-10 02:15:09 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.temp.child.id,
|
|
|
|
"temperature": self.temp.temperature + 2,
|
|
|
|
"time": self.localtime_string(),
|
2017-11-10 02:15:09 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/temperature/{}/".format(self.temp.id), params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.temp.refresh_from_db()
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertEqual(self.temp.temperature, params["temperature"])
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertContains(
|
2022-02-10 00:00:30 +00:00
|
|
|
page, "Temperature entry for {} updated".format(str(self.temp.child))
|
2020-01-29 22:04:19 +00:00
|
|
|
)
|
2017-11-10 02:15:09 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_delete(self):
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/temperature/{}/delete/".format(self.temp.id), follow=True)
|
2017-11-10 02:15:09 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Temperature entry deleted")
|
2017-11-10 02:15:09 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
|
2020-01-30 19:35:43 +00:00
|
|
|
class TummyTimeFormsTestCase(FormsTestCaseBase):
|
2020-01-29 22:04:19 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2020-01-30 19:35:43 +00:00
|
|
|
super(TummyTimeFormsTestCase, cls).setUpClass()
|
2020-01-29 22:42:59 +00:00
|
|
|
cls.tt = models.TummyTime.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
start=timezone.localtime() - timezone.timedelta(hours=2),
|
2022-02-10 00:00:30 +00:00
|
|
|
end=timezone.localtime() - timezone.timedelta(hours=1, minutes=50),
|
2020-01-29 22:42:59 +00:00
|
|
|
)
|
2020-01-29 22:04:19 +00:00
|
|
|
|
|
|
|
def test_add(self):
|
|
|
|
end = timezone.localtime()
|
|
|
|
start = end - timezone.timedelta(minutes=2)
|
2017-11-04 03:29:55 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.child.id,
|
|
|
|
"start": self.localtime_string(start),
|
|
|
|
"end": self.localtime_string(end),
|
|
|
|
"milestone": "",
|
2017-11-04 03:29:55 +00:00
|
|
|
}
|
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/tummy-time/add/", params, follow=True)
|
2017-11-01 16:44:07 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertContains(
|
2022-02-10 00:00:30 +00:00
|
|
|
page, "Tummy Time entry for {} added".format(str(self.child))
|
2020-01-29 22:04:19 +00:00
|
|
|
)
|
2017-11-04 03:29:55 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_edit(self):
|
|
|
|
end = timezone.localtime()
|
|
|
|
start = end - timezone.timedelta(minutes=1, seconds=32)
|
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.tt.child.id,
|
|
|
|
"start": self.localtime_string(start),
|
|
|
|
"end": self.localtime_string(end),
|
|
|
|
"milestone": "Moved head!",
|
2020-01-29 22:04:19 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/tummy-time/{}/".format(self.tt.id), params, follow=True)
|
2017-11-04 03:29:55 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.tt.refresh_from_db()
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertEqual(self.tt.milestone, params["milestone"])
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertContains(
|
2022-02-10 00:00:30 +00:00
|
|
|
page, "Tummy Time entry for {} updated".format(str(self.tt.child))
|
2020-01-29 22:04:19 +00:00
|
|
|
)
|
2017-11-04 03:29:55 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_delete(self):
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/tummy-time/{}/delete/".format(self.tt.id), follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Tummy Time entry deleted")
|
2020-01-29 22:04:19 +00:00
|
|
|
|
|
|
|
|
2020-01-30 19:35:43 +00:00
|
|
|
class TimerFormsTestCase(FormsTestCaseBase):
|
2020-01-30 21:32:01 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
|
|
|
super(TimerFormsTestCase, cls).setUpClass()
|
|
|
|
cls.timer = models.Timer.objects.create(user=cls.user)
|
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_add(self):
|
2017-11-05 19:18:30 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.child.id,
|
|
|
|
"name": "Test Timer",
|
|
|
|
"start": self.localtime_string(),
|
2017-11-05 19:18:30 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/timers/add/", params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, params["name"])
|
|
|
|
self.assertContains(page, params["child"])
|
2017-11-05 19:18:30 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_edit(self):
|
2020-01-30 21:32:01 +00:00
|
|
|
start_time = self.timer.start - timezone.timedelta(hours=1)
|
2022-02-10 00:00:30 +00:00
|
|
|
params = {"name": "New Timer Name", "start": self.localtime_string(start_time)}
|
|
|
|
page = self.c.post(
|
|
|
|
"/timers/{}/edit/".format(self.timer.id), params, follow=True
|
|
|
|
)
|
2017-11-04 03:29:55 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, params["name"])
|
2020-01-30 21:32:01 +00:00
|
|
|
self.timer.refresh_from_db()
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertEqual(self.localtime_string(self.timer.start), params["start"])
|
2020-01-30 21:32:01 +00:00
|
|
|
|
|
|
|
def test_edit_stopped(self):
|
|
|
|
self.timer.stop()
|
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"name": "Edit stopped timer",
|
|
|
|
"start": self.localtime_string(self.timer.start),
|
|
|
|
"end": self.localtime_string(self.timer.end),
|
2020-01-30 21:32:01 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post(
|
|
|
|
"/timers/{}/edit/".format(self.timer.id), params, follow=True
|
|
|
|
)
|
2020-01-30 21:32:01 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2017-11-05 19:18:30 +00:00
|
|
|
|
2020-02-07 05:50:22 +00:00
|
|
|
def test_delete_inactive(self):
|
|
|
|
models.Timer.objects.create(user=self.user)
|
|
|
|
self.assertEqual(models.Timer.objects.count(), 2)
|
|
|
|
self.timer.stop()
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/timers/delete-inactive/", follow=True)
|
2020-02-07 05:50:22 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
messages = list(page.context["messages"])
|
2020-02-07 05:50:22 +00:00
|
|
|
self.assertEqual(len(messages), 1)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertEqual(str(messages[0]), "All inactive timers deleted.")
|
2020-02-07 05:50:22 +00:00
|
|
|
self.assertEqual(models.Timer.objects.count(), 1)
|
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
|
2020-01-30 18:39:29 +00:00
|
|
|
class ValidationsTestCase(FormsTestCaseBase):
|
|
|
|
def test_validate_date(self):
|
|
|
|
future = timezone.localtime() + timezone.timedelta(days=1)
|
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.child,
|
|
|
|
"weight": "8.5",
|
|
|
|
"date": self.localdate_string(future),
|
2020-01-30 18:39:29 +00:00
|
|
|
}
|
|
|
|
entry = models.Weight.objects.create(**params)
|
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/weight/{}/".format(entry.id), params, follow=True)
|
2020-01-30 18:39:29 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertFormError(page, "form", "date", "Date can not be in the future.")
|
2020-01-30 18:39:29 +00:00
|
|
|
|
|
|
|
def test_validate_duration(self):
|
|
|
|
end = timezone.localtime() - timezone.timedelta(minutes=10)
|
|
|
|
start = end + timezone.timedelta(minutes=5)
|
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.child,
|
|
|
|
"start": self.localtime_string(start),
|
|
|
|
"end": self.localtime_string(end),
|
|
|
|
"milestone": "",
|
2020-01-30 18:39:29 +00:00
|
|
|
}
|
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/tummy-time/add/", params, follow=True)
|
2020-01-30 18:39:29 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertFormError(
|
|
|
|
page, "form", None, "Start time must come before end time."
|
|
|
|
)
|
2020-01-30 18:39:29 +00:00
|
|
|
|
|
|
|
start = end - timezone.timedelta(weeks=53)
|
2022-02-10 00:00:30 +00:00
|
|
|
params["start"] = self.localtime_string(start)
|
|
|
|
page = self.c.post("/tummy-time/add/", params, follow=True)
|
2020-01-30 18:39:29 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertFormError(page, "form", None, "Duration too long.")
|
2020-01-30 18:39:29 +00:00
|
|
|
|
|
|
|
def test_validate_time(self):
|
|
|
|
future = timezone.localtime() + timezone.timedelta(hours=1)
|
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.child,
|
|
|
|
"start": self.localtime_string(),
|
|
|
|
"end": self.localtime_string(future),
|
|
|
|
"milestone": "",
|
2020-01-30 18:39:29 +00:00
|
|
|
}
|
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/tummy-time/add/", params, follow=True)
|
2020-01-30 18:39:29 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertFormError(page, "form", "end", "Date/time can not be in the future.")
|
2020-01-30 18:39:29 +00:00
|
|
|
|
|
|
|
def test_validate_unique_period(self):
|
|
|
|
entry = models.TummyTime.objects.create(
|
|
|
|
child=self.child,
|
|
|
|
start=timezone.localtime() - timezone.timedelta(minutes=10),
|
|
|
|
end=timezone.localtime() - timezone.timedelta(minutes=5),
|
|
|
|
)
|
|
|
|
|
|
|
|
start = entry.start - timezone.timedelta(minutes=2)
|
|
|
|
end = entry.end + timezone.timedelta(minutes=2)
|
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": entry.child.id,
|
|
|
|
"start": self.localtime_string(start),
|
|
|
|
"end": self.localtime_string(end),
|
|
|
|
"milestone": "",
|
2020-01-30 18:39:29 +00:00
|
|
|
}
|
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/tummy-time/add/", params, follow=True)
|
2020-01-30 18:39:29 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
|
|
|
self.assertFormError(
|
2022-02-10 00:00:30 +00:00
|
|
|
page, "form", None, "Another entry intersects the specified time period."
|
|
|
|
)
|
2020-01-30 18:39:29 +00:00
|
|
|
|
|
|
|
|
2022-06-14 21:05:03 +00:00
|
|
|
class WeightFormsTestCase(FormsTestCaseBase):
|
2020-01-29 22:04:19 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls):
|
2022-06-14 21:05:03 +00:00
|
|
|
super(WeightFormsTestCase, cls).setUpClass()
|
2020-01-29 22:42:59 +00:00
|
|
|
cls.weight = models.Weight.objects.create(
|
|
|
|
child=cls.child,
|
|
|
|
weight=8,
|
2022-02-10 00:00:30 +00:00
|
|
|
date=timezone.localdate() - timezone.timedelta(days=2),
|
2020-01-29 22:42:59 +00:00
|
|
|
)
|
2020-01-29 22:04:19 +00:00
|
|
|
|
|
|
|
def test_add(self):
|
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.child.id,
|
|
|
|
"weight": 8.5,
|
|
|
|
"date": self.localdate_string(),
|
2020-01-29 22:04:19 +00:00
|
|
|
}
|
|
|
|
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/weight/add/", params, follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Weight entry for {} added".format(str(self.child)))
|
2017-11-05 19:18:30 +00:00
|
|
|
|
2020-01-29 22:04:19 +00:00
|
|
|
def test_edit(self):
|
2017-11-05 19:18:30 +00:00
|
|
|
params = {
|
2022-02-10 00:00:30 +00:00
|
|
|
"child": self.weight.child.id,
|
|
|
|
"weight": self.weight.weight + 1,
|
|
|
|
"date": self.localdate_string(),
|
2017-11-05 19:18:30 +00:00
|
|
|
}
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/weight/{}/".format(self.weight.id), params, follow=True)
|
2017-11-05 19:18:30 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.weight.refresh_from_db()
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertEqual(self.weight.weight, params["weight"])
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertContains(
|
2022-02-10 00:00:30 +00:00
|
|
|
page, "Weight entry for {} updated".format(str(self.weight.child))
|
2020-01-29 22:04:19 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
def test_delete(self):
|
2022-02-10 00:00:30 +00:00
|
|
|
page = self.c.post("/weight/{}/delete/".format(self.weight.id), follow=True)
|
2020-01-29 22:04:19 +00:00
|
|
|
self.assertEqual(page.status_code, 200)
|
2022-02-10 00:00:30 +00:00
|
|
|
self.assertContains(page, "Weight entry deleted")
|