2014-11-19 13:11:55 +01:00
|
|
|
"""
|
|
|
|
|
You can make the following assumptions about the inputs to the
|
|
|
|
|
'sum_of_multiples' function:
|
2017-03-23 13:42:35 +01:00
|
|
|
* All input numbers are non-negative 'int's, i.e. natural numbers
|
|
|
|
|
including zero.
|
|
|
|
|
* A list of factors must be given, and its elements are unique
|
|
|
|
|
and sorted in ascending order.
|
2014-11-19 13:11:55 +01:00
|
|
|
"""
|
|
|
|
|
|
2014-03-18 04:30:26 +01:00
|
|
|
import unittest
|
|
|
|
|
|
2014-11-08 14:06:05 -08:00
|
|
|
from sum_of_multiples import sum_of_multiples
|
2014-06-11 15:06:22 +02:00
|
|
|
|
2014-03-18 04:30:26 +01:00
|
|
|
|
2017-10-25 14:23:03 +02:00
|
|
|
# Tests adapted from `problem-specifications//canonical-data.json` @ v1.1.0
|
2017-03-23 13:42:35 +01:00
|
|
|
|
2014-03-18 04:30:26 +01:00
|
|
|
class SumOfMultiplesTest(unittest.TestCase):
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_3_or_5_up_to_1(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(1, [3, 5]), 0)
|
|
|
|
|
|
|
|
|
|
def test_multiples_of_3_or_5_up_to_4(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(4, [3, 5]), 3)
|
2014-03-18 04:30:26 +01:00
|
|
|
|
2017-10-25 14:23:03 +02:00
|
|
|
def test_multiples_of_3_up_to_7(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(7, [3]), 9)
|
|
|
|
|
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_3_or_5_up_to_10(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(10, [3, 5]), 23)
|
2014-03-18 04:30:26 +01:00
|
|
|
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_3_or_5_up_to_100(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(100, [3, 5]), 2318)
|
2014-03-18 04:30:26 +01:00
|
|
|
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_3_or_5_up_to_1000(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(1000, [3, 5]), 233168)
|
2015-11-29 21:20:11 -07:00
|
|
|
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_7_13_or_17_up_to_20(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(20, [7, 13, 17]), 51)
|
2014-03-18 04:30:26 +01:00
|
|
|
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_4_or_6_up_to_15(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(15, [4, 6]), 30)
|
2014-03-18 04:30:26 +01:00
|
|
|
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_5_6_or_8_up_to_150(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(150, [5, 6, 8]), 4419)
|
2015-04-23 10:21:18 -06:00
|
|
|
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_5_or_25_up_to_51(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(51, [5, 25]), 275)
|
2015-04-23 10:21:18 -06:00
|
|
|
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_43_or_47_up_to_10000(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(10000, [43, 47]), 2203160)
|
2014-10-25 23:28:24 +02:00
|
|
|
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_1_up_to_100(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(100, [1]), 4950)
|
2014-10-25 23:28:24 +02:00
|
|
|
|
2017-03-23 13:42:35 +01:00
|
|
|
def test_multiples_of_an_empty_list_up_to_10000(self):
|
|
|
|
|
self.assertEqual(sum_of_multiples(10000, []), 0)
|
2014-10-25 23:28:24 +02:00
|
|
|
|
2014-03-18 04:30:26 +01:00
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
|
unittest.main()
|