test_rules_utils.py 1.2 KB

1234567891011121314151617181920212223242526272829303132
  1. from src.node import ExpressionNode as N
  2. from src.rules.utils import nary_node, is_prime, least_common_multiple
  3. from tests.rulestestcase import RulesTestCase, tree
  4. class TestRulesUtils(RulesTestCase):
  5. def test_nary_node(self):
  6. a, b, c, d = tree('a,b,c,d')
  7. self.assertEqualNodes(nary_node('+', [a]), a)
  8. self.assertEqualNodes(nary_node('+', [a, b]), N('+', a, b))
  9. self.assertEqualNodes(nary_node('+', [a, b, c]),
  10. N('+', N('+', a, b), c))
  11. self.assertEqualNodes(nary_node('+', [a, b, c, d]),
  12. N('+', N('+', N('+', a, b), c), d))
  13. def test_is_prime(self):
  14. self.assertTrue(is_prime(2))
  15. self.assertTrue(is_prime(3))
  16. self.assertTrue(is_prime(647))
  17. self.assertFalse(is_prime(0))
  18. self.assertFalse(is_prime(1))
  19. self.assertFalse(is_prime(4))
  20. self.assertFalse(is_prime(9))
  21. self.assertFalse(is_prime(100))
  22. def test_least_common_multiple(self):
  23. self.assertEqual(least_common_multiple(5, 6), 30)
  24. self.assertEqual(least_common_multiple(5, 6, 15), 30)
  25. self.assertEqual(least_common_multiple(2, 4), 4)