- from datetime import datetime, timedelta as td
- from unittest.mock import Mock, patch
-
- from django.core import mail
- from django.utils.timezone import now, utc
- from hc.test import BaseTestCase
- from hc.api.models import Check
-
- CURRENT_TIME = datetime(2020, 1, 15, tzinfo=utc)
- MOCK_NOW = Mock(return_value=CURRENT_TIME)
-
-
- class ProfileModelTestCase(BaseTestCase):
- @patch("hc.lib.date.timezone.now", MOCK_NOW)
- def test_it_sends_report(self):
- check = Check(project=self.project, name="Test Check")
- check.last_ping = now()
- check.save()
-
- sent = self.profile.send_report()
- self.assertTrue(sent)
-
- # And an email should have been sent
- self.assertEqual(len(mail.outbox), 1)
- message = mail.outbox[0]
-
- self.assertEqual(message.subject, "Monthly Report")
- self.assertIn("Test Check", message.body)
-
- html, _ = message.alternatives[0]
- self.assertNotIn("Jan. 2020", html)
- self.assertIn("Dec. 2019", html)
- self.assertIn("Nov. 2019", html)
- self.assertNotIn("Oct. 2019", html)
-
- def test_it_skips_report_if_no_pings(self):
- check = Check(project=self.project, name="Test Check")
- check.save()
-
- sent = self.profile.send_report()
- self.assertFalse(sent)
-
- self.assertEqual(len(mail.outbox), 0)
-
- def test_it_skips_report_if_no_recent_pings(self):
- check = Check(project=self.project, name="Test Check")
- check.last_ping = now() - td(days=365)
- check.save()
-
- sent = self.profile.send_report()
- self.assertFalse(sent)
-
- self.assertEqual(len(mail.outbox), 0)
-
- def test_it_sends_nag(self):
- check = Check(project=self.project, name="Test Check")
- check.status = "down"
- check.last_ping = now()
- check.save()
-
- self.profile.nag_period = td(hours=1)
- self.profile.save()
-
- sent = self.profile.send_report(nag=True)
- self.assertTrue(sent)
-
- # And an email should have been sent
- self.assertEqual(len(mail.outbox), 1)
- message = mail.outbox[0]
-
- self.assertEqual(message.subject, "Reminder: 1 check still down")
- self.assertIn("Test Check", message.body)
-
- def test_it_skips_nag_if_none_down(self):
- check = Check(project=self.project, name="Test Check")
- check.last_ping = now()
- check.save()
-
- self.profile.nag_period = td(hours=1)
- self.profile.save()
-
- sent = self.profile.send_report(nag=True)
- self.assertFalse(sent)
-
- self.assertEqual(len(mail.outbox), 0)
-
- def test_it_sets_next_nag_date(self):
- Check.objects.create(project=self.project, status="down")
-
- self.profile.nag_period = td(hours=1)
- self.profile.update_next_nag_date()
-
- self.assertTrue(self.profile.next_nag_date)
-
- def test_it_does_not_set_next_nag_date_if_no_nag_period(self):
- Check.objects.create(project=self.project, status="down")
- self.profile.update_next_nag_date()
- self.assertIsNone(self.profile.next_nag_date)
-
- def test_it_does_not_update_existing_next_nag_date(self):
- Check.objects.create(project=self.project, status="down")
-
- original_nag_date = now() - td(minutes=30)
-
- self.profile.next_nag_date = original_nag_date
- self.profile.nag_period = td(hours=1)
- self.profile.update_next_nag_date()
-
- self.assertEqual(self.profile.next_nag_date, original_nag_date)
-
- def test_it_clears_next_nag_date(self):
- self.profile.next_nag_date = now()
- self.profile.update_next_nag_date()
- self.assertIsNone(self.profile.next_nag_date)
|