2017-08-19 14:18:08 -07:00
|
|
|
import unittest
|
|
|
|
|
|
2021-01-31 16:49:12 -05:00
|
|
|
from collatz_conjecture import (
|
|
|
|
|
steps,
|
|
|
|
|
)
|
2017-08-19 14:18:08 -07:00
|
|
|
|
2020-10-15 12:46:24 -04:00
|
|
|
# Tests adapted from `problem-specifications//canonical-data.json`
|
2017-08-19 14:18:08 -07:00
|
|
|
|
|
|
|
|
|
2019-05-23 18:29:18 +02:00
|
|
|
class CollatzConjectureTest(unittest.TestCase):
|
2017-08-19 14:18:08 -07:00
|
|
|
def test_zero_steps_for_one(self):
|
2019-05-23 18:29:18 +02:00
|
|
|
self.assertEqual(steps(1), 0)
|
2017-08-19 14:18:08 -07:00
|
|
|
|
|
|
|
|
def test_divide_if_even(self):
|
2019-05-23 18:29:18 +02:00
|
|
|
self.assertEqual(steps(16), 4)
|
2017-08-19 14:18:08 -07:00
|
|
|
|
|
|
|
|
def test_even_and_odd_steps(self):
|
2019-05-23 18:29:18 +02:00
|
|
|
self.assertEqual(steps(12), 9)
|
2017-08-19 14:18:08 -07:00
|
|
|
|
|
|
|
|
def test_large_number_of_even_and_odd_steps(self):
|
2019-05-23 18:29:18 +02:00
|
|
|
self.assertEqual(steps(1000000), 152)
|
2017-08-19 14:18:08 -07:00
|
|
|
|
2019-05-23 18:29:18 +02:00
|
|
|
def test_zero_is_an_error(self):
|
2018-02-20 05:56:45 +08:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2019-05-23 18:29:18 +02:00
|
|
|
steps(0)
|
2017-08-19 14:18:08 -07:00
|
|
|
|
2019-05-23 18:29:18 +02:00
|
|
|
def test_negative_value_is_an_error(self):
|
2018-02-20 05:56:45 +08:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2019-05-23 18:29:18 +02:00
|
|
|
steps(-15)
|
2018-02-20 05:56:45 +08:00
|
|
|
|
|
|
|
|
# Utility functions
|
|
|
|
|
def assertRaisesWithMessage(self, exception):
|
|
|
|
|
return self.assertRaisesRegex(exception, r".+")
|
2017-08-19 14:18:08 -07:00
|
|
|
|
|
|
|
|
|
2019-05-23 18:29:18 +02:00
|
|
|
if __name__ == "__main__":
|
2017-08-19 14:18:08 -07:00
|
|
|
unittest.main()
|