2017-02-21 18:02:20 +01:00
|
|
|
import unittest
|
|
|
|
|
|
2021-01-31 16:49:12 -05:00
|
|
|
from all_your_base import (
|
|
|
|
|
rebase,
|
|
|
|
|
)
|
2017-02-21 18:02:20 +01:00
|
|
|
|
2020-10-15 12:46:24 -04:00
|
|
|
# Tests adapted from `problem-specifications//canonical-data.json`
|
2017-03-09 11:03:20 +01:00
|
|
|
|
2017-02-21 18:02:20 +01:00
|
|
|
|
2019-10-25 20:32:15 +02:00
|
|
|
class AllYourBaseTest(unittest.TestCase):
|
|
|
|
|
def test_single_bit_one_to_decimal(self):
|
2017-02-21 18:02:20 +01:00
|
|
|
self.assertEqual(rebase(2, [1], 10), [1])
|
|
|
|
|
|
|
|
|
|
def test_binary_to_single_decimal(self):
|
|
|
|
|
self.assertEqual(rebase(2, [1, 0, 1], 10), [5])
|
|
|
|
|
|
|
|
|
|
def test_single_decimal_to_binary(self):
|
|
|
|
|
self.assertEqual(rebase(10, [5], 2), [1, 0, 1])
|
|
|
|
|
|
|
|
|
|
def test_binary_to_multiple_decimal(self):
|
|
|
|
|
self.assertEqual(rebase(2, [1, 0, 1, 0, 1, 0], 10), [4, 2])
|
|
|
|
|
|
|
|
|
|
def test_decimal_to_binary(self):
|
|
|
|
|
self.assertEqual(rebase(10, [4, 2], 2), [1, 0, 1, 0, 1, 0])
|
|
|
|
|
|
|
|
|
|
def test_trinary_to_hexadecimal(self):
|
|
|
|
|
self.assertEqual(rebase(3, [1, 1, 2, 0], 16), [2, 10])
|
|
|
|
|
|
|
|
|
|
def test_hexadecimal_to_trinary(self):
|
|
|
|
|
self.assertEqual(rebase(16, [2, 10], 3), [1, 1, 2, 0])
|
|
|
|
|
|
|
|
|
|
def test_15_bit_integer(self):
|
|
|
|
|
self.assertEqual(rebase(97, [3, 46, 60], 73), [6, 10, 45])
|
|
|
|
|
|
|
|
|
|
def test_empty_list(self):
|
2019-10-25 20:32:15 +02:00
|
|
|
self.assertEqual(rebase(2, [], 10), [0])
|
2017-02-21 18:02:20 +01:00
|
|
|
|
|
|
|
|
def test_single_zero(self):
|
2019-10-25 20:32:15 +02:00
|
|
|
self.assertEqual(rebase(10, [0], 2), [0])
|
2017-02-21 18:02:20 +01:00
|
|
|
|
2019-10-25 20:32:15 +02:00
|
|
|
def test_multiple_zeros(self):
|
|
|
|
|
self.assertEqual(rebase(10, [0, 0, 0], 2), [0])
|
2017-02-21 18:02:20 +01:00
|
|
|
|
|
|
|
|
def test_leading_zeros(self):
|
|
|
|
|
self.assertEqual(rebase(7, [0, 6, 0], 10), [4, 2])
|
|
|
|
|
|
2018-02-20 22:12:07 +08:00
|
|
|
def test_input_base_is_one(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2018-02-20 22:12:07 +08:00
|
|
|
rebase(1, [0], 10)
|
2017-10-26 14:06:55 +05:30
|
|
|
|
2018-02-20 22:12:07 +08:00
|
|
|
def test_input_base_is_zero(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2017-10-26 14:06:55 +05:30
|
|
|
rebase(0, [], 10)
|
|
|
|
|
|
2018-02-20 22:12:07 +08:00
|
|
|
def test_input_base_is_negative(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2017-10-26 14:06:55 +05:30
|
|
|
rebase(-2, [1], 10)
|
|
|
|
|
|
2017-02-21 18:02:20 +01:00
|
|
|
def test_negative_digit(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2017-02-21 18:02:20 +01:00
|
|
|
rebase(2, [1, -1, 1, 0, 1, 0], 10)
|
|
|
|
|
|
|
|
|
|
def test_invalid_positive_digit(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2017-02-21 18:02:20 +01:00
|
|
|
rebase(2, [1, 2, 1, 0, 1, 0], 10)
|
|
|
|
|
|
2018-02-20 22:12:07 +08:00
|
|
|
def test_output_base_is_one(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2017-02-21 18:02:20 +01:00
|
|
|
rebase(2, [1, 0, 1, 0, 1, 0], 1)
|
|
|
|
|
|
2018-02-20 22:12:07 +08:00
|
|
|
def test_output_base_is_zero(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2017-02-21 18:02:20 +01:00
|
|
|
rebase(10, [7], 0)
|
|
|
|
|
|
2018-02-20 22:12:07 +08:00
|
|
|
def test_output_base_is_negative(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2017-02-21 18:02:20 +01:00
|
|
|
rebase(2, [1], -7)
|
|
|
|
|
|
|
|
|
|
def test_both_bases_are_negative(self):
|
2017-12-12 18:11:43 +00:00
|
|
|
with self.assertRaisesWithMessage(ValueError):
|
2017-02-21 18:02:20 +01:00
|
|
|
rebase(-2, [1], -7)
|
|
|
|
|
|
2017-12-12 18:11:43 +00:00
|
|
|
# Utility functions
|
|
|
|
|
def assertRaisesWithMessage(self, exception):
|
|
|
|
|
return self.assertRaisesRegex(exception, r".+")
|
|
|
|
|
|
2017-02-21 18:02:20 +01:00
|
|
|
|
2019-10-25 20:32:15 +02:00
|
|
|
if __name__ == "__main__":
|
2017-02-21 18:02:20 +01:00
|
|
|
unittest.main()
|