Пример #1
0
 def test_collapse(self):
     c1, c2 = Dummy(True), Dummy(True)
     n2, n3 = ConditionNode(), ConditionNode(connector=OR)
     n4, n5 = ConditionNode([c1]), ConditionNode([c2], OR)
     n6, n7 = ConditionNode([c1, c1]), ConditionNode([c2, c2], OR)
     n1 = ConditionNode([n2, n3, n4, n5, n6, n7], OR)
     n1.collapse()
     self.assertEqual(n1.connector, OR)
     self.assertEqual(n1.children, [n6, c1, c2, c2, c2])
     # Now test the recursion of the last part
     n8 = ConditionNode([c1, c2, c1], OR)
     n9 = ConditionNode([ConditionNode([ConditionNode([n8])], OR)])
     self.assertEqual(n9.connector, AND)
     n9.collapse()
     self.assertEqual(n9.connector, OR)
     self.assertEqual(n9.children, [c1, c2, c1])
Пример #2
0
 def test_negate(self):
     c1, c2 = Dummy(True), Dummy(False)
     n = ConditionNode([c1, c2])
     result = n.evaluate()
     n.negate()
     self.assertEqual(len(n), 1)
     self.assertEqual(n.connector, AND)
     self.assertEqual(n.children[0].children, [c1, c2])
     self.assertEqual(n.children[0].connector, OR)
     # We went from (c1 AND c2) to (!c1 or !c2)
     self.assertEqual(n.evaluate(), not result)
     self.assertIs(c1.v, False)
     self.assertIs(c2.v, True)
     n.negate()
     self.assertIs(c1.v, True)
     self.assertIs(c2.v, False)
     self.assertEqual(len(n), 1)
     self.assertEqual(n.connector, AND)
     self.assertEqual(len(n.children[0]), 1)
     # collapsing at this point should give us back the original node structure
     n.collapse()
     self.assertEqual(n.evaluate(), result)
     self.assertEqual(n.children, [c1, c2])
     self.assertEqual(n.connector, AND)