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)