2016-10-19 07:17:43 -07:00
|
|
|
import unittest
|
|
|
|
|
|
2021-01-31 16:49:12 -05:00
|
|
|
from flatten_array import (
|
|
|
|
|
flatten,
|
|
|
|
|
)
|
2016-10-19 07:17:43 -07:00
|
|
|
|
2023-07-14 15:52:15 -07:00
|
|
|
# These tests are auto-generated with test data from:
|
|
|
|
|
# https://github.com/exercism/problem-specifications/tree/main/exercises/flatten-array/canonical-data.json
|
|
|
|
|
# File last updated on 2023-07-14
|
2017-10-30 20:27:22 +11:00
|
|
|
|
2016-10-19 07:17:43 -07:00
|
|
|
|
2019-10-25 10:07:25 -04:00
|
|
|
class FlattenArrayTest(unittest.TestCase):
|
2022-02-09 15:33:38 -08:00
|
|
|
def test_empty(self):
|
|
|
|
|
inputs = []
|
|
|
|
|
expected = []
|
|
|
|
|
self.assertEqual(flatten(inputs), expected)
|
|
|
|
|
|
2016-10-19 07:17:43 -07:00
|
|
|
def test_no_nesting(self):
|
2019-10-25 10:07:25 -04:00
|
|
|
inputs = [0, 1, 2]
|
|
|
|
|
expected = [0, 1, 2]
|
|
|
|
|
self.assertEqual(flatten(inputs), expected)
|
2016-10-19 07:17:43 -07:00
|
|
|
|
2022-02-09 15:33:38 -08:00
|
|
|
def test_flattens_a_nested_array(self):
|
|
|
|
|
inputs = [[[]]]
|
|
|
|
|
expected = []
|
|
|
|
|
self.assertEqual(flatten(inputs), expected)
|
|
|
|
|
|
2019-10-25 10:07:25 -04:00
|
|
|
def test_flattens_array_with_just_integers_present(self):
|
2017-10-30 20:27:22 +11:00
|
|
|
inputs = [1, [2, 3, 4, 5, 6, 7], 8]
|
|
|
|
|
expected = [1, 2, 3, 4, 5, 6, 7, 8]
|
|
|
|
|
self.assertEqual(flatten(inputs), expected)
|
2016-10-19 07:17:43 -07:00
|
|
|
|
2019-10-25 10:07:25 -04:00
|
|
|
def test_5_level_nesting(self):
|
2017-10-30 20:27:22 +11:00
|
|
|
inputs = [0, 2, [[2, 3], 8, 100, 4, [[[50]]]], -2]
|
|
|
|
|
expected = [0, 2, 2, 3, 8, 100, 4, 50, -2]
|
2016-10-19 07:17:43 -07:00
|
|
|
self.assertEqual(flatten(inputs), expected)
|
|
|
|
|
|
2019-10-25 10:07:25 -04:00
|
|
|
def test_6_level_nesting(self):
|
2016-10-19 07:17:43 -07:00
|
|
|
inputs = [1, [2, [[3]], [4, [[5]]], 6, 7], 8]
|
|
|
|
|
expected = [1, 2, 3, 4, 5, 6, 7, 8]
|
|
|
|
|
self.assertEqual(flatten(inputs), expected)
|
|
|
|
|
|
2022-02-09 15:33:38 -08:00
|
|
|
def test_null_values_are_omitted_from_the_final_result(self):
|
|
|
|
|
inputs = [1, 2, None]
|
|
|
|
|
expected = [1, 2]
|
|
|
|
|
self.assertEqual(flatten(inputs), expected)
|
|
|
|
|
|
|
|
|
|
def test_consecutive_null_values_at_the_front_of_the_list_are_omitted_from_the_final_result(
|
|
|
|
|
self,
|
|
|
|
|
):
|
|
|
|
|
inputs = [None, None, 3]
|
|
|
|
|
expected = [3]
|
|
|
|
|
self.assertEqual(flatten(inputs), expected)
|
|
|
|
|
|
|
|
|
|
def test_consecutive_null_values_in_the_middle_of_the_list_are_omitted_from_the_final_result(
|
|
|
|
|
self,
|
|
|
|
|
):
|
|
|
|
|
inputs = [1, None, None, 4]
|
|
|
|
|
expected = [1, 4]
|
|
|
|
|
self.assertEqual(flatten(inputs), expected)
|
|
|
|
|
|
2019-10-25 10:07:25 -04:00
|
|
|
def test_6_level_nest_list_with_null_values(self):
|
2017-10-30 20:27:22 +11:00
|
|
|
inputs = [0, 2, [[2, 3], 8, [[100]], None, [[None]]], -2]
|
|
|
|
|
expected = [0, 2, 2, 3, 8, 100, -2]
|
|
|
|
|
self.assertEqual(flatten(inputs), expected)
|
|
|
|
|
|
2019-10-25 10:07:25 -04:00
|
|
|
def test_all_values_in_nested_list_are_null(self):
|
2016-10-19 07:17:43 -07:00
|
|
|
inputs = [None, [[[None]]], None, None, [[None, None], None], None]
|
|
|
|
|
expected = []
|
|
|
|
|
self.assertEqual(flatten(inputs), expected)
|