2017-08-19 14:18:08 -07:00
|
|
|
import unittest
|
|
|
|
|
|
2019-05-23 18:29:18 +02:00
|
|
|
from collatz_conjecture import steps
|
2017-08-19 14:18:08 -07:00
|
|
|
|
2018-08-20 09:48:41 -04:00
|
|
|
# Tests adapted from `problem-specifications//canonical-data.json` @ v1.2.1
|
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()
|