2015-11-26 15:05:58 +01:00
|
|
|
import unittest
|
|
|
|
|
|
2021-01-31 16:49:12 -05:00
|
|
|
from perfect_numbers import (
|
|
|
|
|
classify,
|
|
|
|
|
)
|
2017-11-14 15:31:34 -05:00
|
|
|
|
2020-10-15 12:46:24 -04:00
|
|
|
# Tests adapted from `problem-specifications//canonical-data.json`
|
2015-11-26 15:05:58 +01:00
|
|
|
|
2019-10-20 04:14:53 -07:00
|
|
|
|
2015-11-26 15:05:58 +01:00
|
|
|
class PerfectNumbersTest(unittest.TestCase):
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_smallest_perfect_number_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(6), "perfect")
|
2015-11-26 15:05:58 +01:00
|
|
|
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_medium_perfect_number_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(28), "perfect")
|
2015-11-26 15:05:58 +01:00
|
|
|
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_large_perfect_number_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(33550336), "perfect")
|
2015-11-26 15:05:58 +01:00
|
|
|
|
2017-11-14 15:31:34 -05:00
|
|
|
|
|
|
|
|
class AbundantNumbersTest(unittest.TestCase):
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_smallest_abundant_number_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(12), "abundant")
|
|
|
|
|
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_medium_abundant_number_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(30), "abundant")
|
|
|
|
|
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_large_abundant_number_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(33550335), "abundant")
|
|
|
|
|
|
2015-11-26 15:05:58 +01:00
|
|
|
|
2017-11-14 15:31:34 -05:00
|
|
|
class DeficientNumbersTest(unittest.TestCase):
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_smallest_prime_deficient_number_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(2), "deficient")
|
2015-11-26 15:05:58 +01:00
|
|
|
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_smallest_non_prime_deficient_number_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(4), "deficient")
|
|
|
|
|
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_medium_deficient_number_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(32), "deficient")
|
|
|
|
|
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_large_deficient_number_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(33550337), "deficient")
|
|
|
|
|
|
2019-10-20 04:14:53 -07:00
|
|
|
def test_edge_case_no_factors_other_than_itself_is_classified_correctly(self):
|
2017-11-14 15:31:34 -05:00
|
|
|
self.assertIs(classify(1), "deficient")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class InvalidInputsTest(unittest.TestCase):
|
2020-10-15 12:48:47 -04:00
|
|
|
def test_zero_is_rejected_as_it_is_not_a_positive_integer(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2017-11-14 15:31:34 -05:00
|
|
|
classify(0)
|
|
|
|
|
|
2020-10-15 12:48:47 -04:00
|
|
|
def test_negative_integer_is_rejected_as_it_is_not_a_positive_integer(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2017-11-14 15:31:34 -05:00
|
|
|
classify(-1)
|
2015-11-26 15:05:58 +01:00
|
|
|
|
2017-12-12 18:11:43 +00:00
|
|
|
# Utility functions
|
|
|
|
|
def assertRaisesWithMessage(self, exception):
|
|
|
|
|
return self.assertRaisesRegex(exception, r".+")
|
|
|
|
|
|
2016-11-29 09:44:47 +01:00
|
|
|
|
2019-10-20 04:14:53 -07:00
|
|
|
if __name__ == "__main__":
|
2015-11-26 15:05:58 +01:00
|
|
|
unittest.main()
|