diff options
Diffstat (limited to 'tests')
-rw-r--r-- | tests/test_canary.py | 164 | ||||
-rw-r--r-- | tests/test_canarydb.py | 232 |
2 files changed, 198 insertions, 198 deletions
diff --git a/tests/test_canary.py b/tests/test_canary.py index d23f3fe..c0ba262 100644 --- a/tests/test_canary.py +++ b/tests/test_canary.py @@ -17,87 +17,87 @@ SERVER = "mail.example.com" PASSWORD = "secret" class TestCanary(unittest.TestCase): - def setUp(self): - self.db = mock.Mock(canarydb.CanaryDB) - self.smtp = mock.Mock(smtplib.SMTP_SSL) - self.canary = canary.Canary(self.db, self.smtp, FROM_ADDRESS) - canary.emailutils.get_imap = mock.Mock() - canary.emailutils.get_message = mock.Mock() - canary.emailutils.get_mail_uids = mock.Mock() - canary.emailutils.delete_message = mock.Mock() - canary.emailutils.close = mock.Mock() - - def tearDown(self): - pass - - def testChirp(self): - # Setup Mock - self.db.get_recipients_for_list.return_value = [USER_ADDRESS1, USER_ADDRESS2] - - # Test chirp - self.canary.chirp(LIST_ADDRESS) - - # Assert DB updated - self.db.get_recipients_for_list.assert_called_with(LIST_ADDRESS) - self.db.ping.assert_has_calls( \ - [mock.call(LIST_ADDRESS, USER_ADDRESS1, mock.ANY, mock.ANY), \ - mock.call(LIST_ADDRESS, USER_ADDRESS2, mock.ANY, mock.ANY)]) - args = self.db.ping.call_args - expectedSubject = "Canary Email " + args[0][3] - - # Assert emails were sent - self.assertEqual(1, self.smtp.sendmail.call_count) - args = self.smtp.sendmail.call_args[0] - self.assertEqual(FROM_ADDRESS, args[0]) - self.assertEqual(LIST_ADDRESS, args[1]) - msg = email.message_from_string(args[2]) - self.assertEqual(FROM_ADDRESS, msg['From']) - self.assertEqual(LIST_ADDRESS, msg['To']) - self.assertEqual(expectedSubject, msg['Subject']) - - def testCheck(self): - # Setup mocks - expectedUUID = "1234-5678-9012-3456" - self.db.get_accounts.return_value = [ \ - (LIST_ADDRESS, USER_ADDRESS1, SERVER, PASSWORD), \ - (LIST_ADDRESS, USER_ADDRESS2, SERVER, PASSWORD)] - canary.emailutils.get_mail_uids.return_value = [1] - canary.emailutils.get_message.return_value = {'Subject': "Canary Email " + expectedUUID} - - # Test check - self.canary.check(LIST_ADDRESS) - - # Assert DB calls - self.db.get_accounts.assert_called_with(LIST_ADDRESS) - self.db.pong.assert_has_calls([ \ - mock.call(USER_ADDRESS1, mock.ANY, expectedUUID), \ - mock.call(USER_ADDRESS2, mock.ANY, expectedUUID)]) - - # Assert mail calls - canary.emailutils.get_imap.assert_has_calls([ \ - mock.call(SERVER, USER_ADDRESS1, PASSWORD), \ - mock.call(SERVER, USER_ADDRESS2, PASSWORD)]) - canary.emailutils.get_message.assert_called_with(canary.emailutils.get_imap.return_value, 1) - canary.emailutils.delete_message.assert_called_with(canary.emailutils.get_imap.return_value, 1) - canary.emailutils.close.assert_called_with(canary.emailutils.get_imap.return_value) - - def testDontDeleteOtherMail(self): - # Setup mocks - self.db.get_accounts.return_value = [(LIST_ADDRESS, USER_ADDRESS1, SERVER, PASSWORD)] - canary.emailutils.get_mail_uids.return_value = [1] - canary.emailutils.get_message.return_value = {'Subject': "Buy Our New Widget"} - - # Test check - self.canary.check(LIST_ADDRESS) - - # Assert DB calls - self.db.get_accounts.assert_called_with(LIST_ADDRESS) - self.db.pong.assert_not_called() - - # Assert mail calls - canary.emailutils.get_imap.assert_called_with(SERVER, USER_ADDRESS1, PASSWORD) - canary.emailutils.get_message.assert_called_with(canary.emailutils.get_imap.return_value, 1) - canary.emailutils.delete_message.assert_not_called() - canary.emailutils.close.assert_called_with(canary.emailutils.get_imap.return_value) + def setUp(self): + self.db = mock.Mock(canarydb.CanaryDB) + self.smtp = mock.Mock(smtplib.SMTP_SSL) + self.canary = canary.Canary(self.db, self.smtp, FROM_ADDRESS) + canary.emailutils.get_imap = mock.Mock() + canary.emailutils.get_message = mock.Mock() + canary.emailutils.get_mail_uids = mock.Mock() + canary.emailutils.delete_message = mock.Mock() + canary.emailutils.close = mock.Mock() + + def tearDown(self): + pass + + def testChirp(self): + # Setup Mock + self.db.get_recipients_for_list.return_value = [USER_ADDRESS1, USER_ADDRESS2] + + # Test chirp + self.canary.chirp(LIST_ADDRESS) + + # Assert DB updated + self.db.get_recipients_for_list.assert_called_with(LIST_ADDRESS) + self.db.ping.assert_has_calls( \ + [mock.call(LIST_ADDRESS, USER_ADDRESS1, mock.ANY, mock.ANY), \ + mock.call(LIST_ADDRESS, USER_ADDRESS2, mock.ANY, mock.ANY)]) + args = self.db.ping.call_args + expectedSubject = "Canary Email " + args[0][3] + + # Assert emails were sent + self.assertEqual(1, self.smtp.sendmail.call_count) + args = self.smtp.sendmail.call_args[0] + self.assertEqual(FROM_ADDRESS, args[0]) + self.assertEqual(LIST_ADDRESS, args[1]) + msg = email.message_from_string(args[2]) + self.assertEqual(FROM_ADDRESS, msg['From']) + self.assertEqual(LIST_ADDRESS, msg['To']) + self.assertEqual(expectedSubject, msg['Subject']) + + def testCheck(self): + # Setup mocks + expectedUUID = "1234-5678-9012-3456" + self.db.get_accounts.return_value = [ \ + (LIST_ADDRESS, USER_ADDRESS1, SERVER, PASSWORD), \ + (LIST_ADDRESS, USER_ADDRESS2, SERVER, PASSWORD)] + canary.emailutils.get_mail_uids.return_value = [1] + canary.emailutils.get_message.return_value = {'Subject': "Canary Email " + expectedUUID} + + # Test check + self.canary.check(LIST_ADDRESS) + + # Assert DB calls + self.db.get_accounts.assert_called_with(LIST_ADDRESS) + self.db.pong.assert_has_calls([ \ + mock.call(USER_ADDRESS1, mock.ANY, expectedUUID), \ + mock.call(USER_ADDRESS2, mock.ANY, expectedUUID)]) + + # Assert mail calls + canary.emailutils.get_imap.assert_has_calls([ \ + mock.call(SERVER, USER_ADDRESS1, PASSWORD), \ + mock.call(SERVER, USER_ADDRESS2, PASSWORD)]) + canary.emailutils.get_message.assert_called_with(canary.emailutils.get_imap.return_value, 1) + canary.emailutils.delete_message.assert_called_with(canary.emailutils.get_imap.return_value, 1) + canary.emailutils.close.assert_called_with(canary.emailutils.get_imap.return_value) + + def testDontDeleteOtherMail(self): + # Setup mocks + self.db.get_accounts.return_value = [(LIST_ADDRESS, USER_ADDRESS1, SERVER, PASSWORD)] + canary.emailutils.get_mail_uids.return_value = [1] + canary.emailutils.get_message.return_value = {'Subject': "Buy Our New Widget"} + + # Test check + self.canary.check(LIST_ADDRESS) + + # Assert DB calls + self.db.get_accounts.assert_called_with(LIST_ADDRESS) + self.db.pong.assert_not_called() + + # Assert mail calls + canary.emailutils.get_imap.assert_called_with(SERVER, USER_ADDRESS1, PASSWORD) + canary.emailutils.get_message.assert_called_with(canary.emailutils.get_imap.return_value, 1) + canary.emailutils.delete_message.assert_not_called() + canary.emailutils.close.assert_called_with(canary.emailutils.get_imap.return_value) diff --git a/tests/test_canarydb.py b/tests/test_canarydb.py index a51afdc..195387e 100644 --- a/tests/test_canarydb.py +++ b/tests/test_canarydb.py @@ -5,119 +5,119 @@ import datetime from emailcanary import canarydb class TestCanaryDB(unittest.TestCase): - def setUp(self): - self.tempdir = tempfile.mkdtemp() - self.db = canarydb.CanaryDB(self.tempdir + "canary.db") - - def tearDown(self): - self.db.close() - shutil.rmtree(self.tempdir) - - def testPingCheckPong(self): - listAddress = "list@example.com" - address = "test@example.com" - time = datetime.datetime(2015, 10, 24, 9, 00) - uuid = "1234" - expectedDelta = datetime.datetime.now() - time - - # Record a Ping - self.db.ping(listAddress, address, time, uuid) - - # Check for missing pongs - missing = self.db.get_missing_pongs() - - self.assertEqual(1, len(missing)) - firstMissing = missing[0] - self.assertEqual(4, len(firstMissing)) - self.assertEqual(listAddress, firstMissing[0]) - self.assertEqual(uuid, firstMissing[1]) - self.assertEqual(address, firstMissing[2]) - delta = firstMissing[3].total_seconds() - expectedDelta.total_seconds() - self.assertTrue(delta <= 10) - - # Record a pong - pongtime = datetime.datetime(2015, 10, 24, 9, 05) - self.db.pong(address, pongtime, uuid) - - # Check for missing pongs - missing = self.db.get_missing_pongs() - self.assertEqual(0, len(missing)) - - def testCloseReopen(self): - listAddress = "list@example.com" - address = "test@example.com" - time = datetime.datetime(2015, 10, 24, 9, 00) - uuid = "1234" - expectedDelta = datetime.datetime.now() - time - - # Record a Ping - self.db.ping(listAddress, address, time, uuid) - - # Close, Reopen - self.db.close() - self.db = canarydb.CanaryDB(self.tempdir + "canary.db") - - # Check for missing pongs - missing = self.db.get_missing_pongs() - - self.assertEqual(1, len(missing)) - firstMissing = missing[0] - self.assertEqual(4, len(firstMissing)) - self.assertEqual(listAddress, firstMissing[0]) - self.assertEqual(uuid, firstMissing[1]) - self.assertEqual(address, firstMissing[2]) - delta = firstMissing[3].total_seconds() - expectedDelta.total_seconds() - self.assertTrue(delta <= 10) - - def testAccounts(self): - listAddress = "list@example.org" - address = "user@example.net" - imapserver = "imap.example.net" - password = "secretpassword" - - # Verify that no accounts exist - accounts = self.db.get_accounts() - self.assertEqual(0, len(accounts)) - - # Add one account - self.db.add_account(listAddress, address, imapserver, password) - - # Verify that the account exists - accounts = self.db.get_accounts() - self.assertEqual(1, len(accounts)) - self.assertEqual(listAddress, accounts[0][0]) - self.assertEqual(address, accounts[0][1]) - self.assertEqual(imapserver, accounts[0][2]) - self.assertEqual(password, accounts[0][3]) - - # Remove the account - self.db.remove_account(listAddress, address) - accounts = self.db.get_accounts() - self.assertEqual(0, len(accounts)) - - def testGetRecipientsForList(self): - listAddress1 = "list1@example.org" - listAddress2 = "list2@example.org" - imapserver = "imap.example.net" - password = "secretpassword" - address1 = "user1@example.net" - address2 = "user2@example.net" - - # No accounts - self.assertEqual([], self.db.get_recipients_for_list(listAddress1)); - self.assertEqual([], self.db.get_recipients_for_list(listAddress2)); - - # One account - self.db.add_account(listAddress1, address1, imapserver, password) - self.assertEqual([address1], self.db.get_recipients_for_list(listAddress1)); - self.assertEqual([], self.db.get_recipients_for_list(listAddress2)); - - # Two accounts - self.db.add_account(listAddress1, address2, imapserver, password) - self.assertEqual([address1, address2], self.db.get_recipients_for_list(listAddress1)); - self.assertEqual([], self.db.get_recipients_for_list(listAddress2)); - - # Two lists - self.db.add_account(listAddress2, address1, imapserver, password) - self.assertEqual([address1, address2], self.db.get_recipients_for_list(listAddress1)); - self.assertEqual([address1], self.db.get_recipients_for_list(listAddress2)); + def setUp(self): + self.tempdir = tempfile.mkdtemp() + self.db = canarydb.CanaryDB(self.tempdir + "canary.db") + + def tearDown(self): + self.db.close() + shutil.rmtree(self.tempdir) + + def testPingCheckPong(self): + listAddress = "list@example.com" + address = "test@example.com" + time = datetime.datetime(2015, 10, 24, 9, 00) + uuid = "1234" + expectedDelta = datetime.datetime.now() - time + + # Record a Ping + self.db.ping(listAddress, address, time, uuid) + + # Check for missing pongs + missing = self.db.get_missing_pongs() + + self.assertEqual(1, len(missing)) + firstMissing = missing[0] + self.assertEqual(4, len(firstMissing)) + self.assertEqual(listAddress, firstMissing[0]) + self.assertEqual(uuid, firstMissing[1]) + self.assertEqual(address, firstMissing[2]) + delta = firstMissing[3].total_seconds() - expectedDelta.total_seconds() + self.assertTrue(delta <= 10) + + # Record a pong + pongtime = datetime.datetime(2015, 10, 24, 9, 05) + self.db.pong(address, pongtime, uuid) + + # Check for missing pongs + missing = self.db.get_missing_pongs() + self.assertEqual(0, len(missing)) + + def testCloseReopen(self): + listAddress = "list@example.com" + address = "test@example.com" + time = datetime.datetime(2015, 10, 24, 9, 00) + uuid = "1234" + expectedDelta = datetime.datetime.now() - time + + # Record a Ping + self.db.ping(listAddress, address, time, uuid) + + # Close, Reopen + self.db.close() + self.db = canarydb.CanaryDB(self.tempdir + "canary.db") + + # Check for missing pongs + missing = self.db.get_missing_pongs() + + self.assertEqual(1, len(missing)) + firstMissing = missing[0] + self.assertEqual(4, len(firstMissing)) + self.assertEqual(listAddress, firstMissing[0]) + self.assertEqual(uuid, firstMissing[1]) + self.assertEqual(address, firstMissing[2]) + delta = firstMissing[3].total_seconds() - expectedDelta.total_seconds() + self.assertTrue(delta <= 10) + + def testAccounts(self): + listAddress = "list@example.org" + address = "user@example.net" + imapserver = "imap.example.net" + password = "secretpassword" + + # Verify that no accounts exist + accounts = self.db.get_accounts() + self.assertEqual(0, len(accounts)) + + # Add one account + self.db.add_account(listAddress, address, imapserver, password) + + # Verify that the account exists + accounts = self.db.get_accounts() + self.assertEqual(1, len(accounts)) + self.assertEqual(listAddress, accounts[0][0]) + self.assertEqual(address, accounts[0][1]) + self.assertEqual(imapserver, accounts[0][2]) + self.assertEqual(password, accounts[0][3]) + + # Remove the account + self.db.remove_account(listAddress, address) + accounts = self.db.get_accounts() + self.assertEqual(0, len(accounts)) + + def testGetRecipientsForList(self): + listAddress1 = "list1@example.org" + listAddress2 = "list2@example.org" + imapserver = "imap.example.net" + password = "secretpassword" + address1 = "user1@example.net" + address2 = "user2@example.net" + + # No accounts + self.assertEqual([], self.db.get_recipients_for_list(listAddress1)); + self.assertEqual([], self.db.get_recipients_for_list(listAddress2)); + + # One account + self.db.add_account(listAddress1, address1, imapserver, password) + self.assertEqual([address1], self.db.get_recipients_for_list(listAddress1)); + self.assertEqual([], self.db.get_recipients_for_list(listAddress2)); + + # Two accounts + self.db.add_account(listAddress1, address2, imapserver, password) + self.assertEqual([address1, address2], self.db.get_recipients_for_list(listAddress1)); + self.assertEqual([], self.db.get_recipients_for_list(listAddress2)); + + # Two lists + self.db.add_account(listAddress2, address1, imapserver, password) + self.assertEqual([address1, address2], self.db.get_recipients_for_list(listAddress1)); + self.assertEqual([address1], self.db.get_recipients_for_list(listAddress2)); |