| 123456789101112131415161718192021 |
- from src.node import ExpressionNode as N
- from src.rules.utils import nary_node, least_common_multiple
- from tests.rulestestcase import RulesTestCase, tree
- class TestRulesUtils(RulesTestCase):
- def test_nary_node(self):
- a, b, c, d = tree('a,b,c,d')
- self.assertEqualNodes(nary_node('+', [a]), a)
- self.assertEqualNodes(nary_node('+', [a, b]), N('+', a, b))
- self.assertEqualNodes(nary_node('+', [a, b, c]),
- N('+', N('+', a, b), c))
- self.assertEqualNodes(nary_node('+', [a, b, c, d]),
- N('+', N('+', N('+', a, b), c), d))
- def test_least_common_multiple(self):
- self.assertEqual(least_common_multiple(5, 6), 30)
- self.assertEqual(least_common_multiple(5, 6, 15), 30)
- self.assertEqual(least_common_multiple(2, 4), 4)
|