-
Notifications
You must be signed in to change notification settings - Fork 45
/
Copy pathPartialOrder.hs
77 lines (70 loc) · 1.94 KB
/
PartialOrder.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
module Test.Booster.Pattern.PartialOrder (
test_transitiveClosure,
) where
import Data.Set qualified as Set
import Test.Tasty
import Test.Tasty.HUnit
import Booster.Pattern.Base
import Booster.Pattern.Bool
import Booster.Pattern.PartialOrder
test_transitiveClosure :: TestTree
test_transitiveClosure =
testGroup
"<Int --- strict partial order"
[ test
"No new items"
ltIntSymbol
( [ LtInt (var "A") (var "B")
, LtInt (var "C") (var "D")
]
)
( []
)
, test
"One new item"
ltIntSymbol
( [ LtInt (var "A") (var "B")
, LtInt (var "B") (var "C")
]
)
( [ LtInt (var "A") (var "C")
]
)
, test
"Two new items"
ltIntSymbol
( [ LtInt (var "A") (var "B")
, LtInt (var "B") (var "C")
, LtInt (var "B") (var "D")
]
)
( [ LtInt (var "A") (var "C")
, LtInt (var "A") (var "D")
]
)
, test
"Cycle, no new items"
ltIntSymbol
( [ LtInt (var "A") (var "B")
, LtInt (var "B") (var "A")
]
)
( []
)
]
----------------------------------------
-- Test fixture
test :: String -> Symbol -> [Term] -> [Term] -> TestTree
test name sym input expected =
testCase name $
transitiveClosure sym (Set.fromList $ map Predicate input)
@?= (Set.fromList $ map Predicate expected)
ltIntSymbol :: Symbol
ltIntSymbol =
case LtInt (var "DUMMY") (var "DUMMY") of
SymbolApplication ltInt _ _ -> ltInt
_ -> error "Impossible"
someSort :: Sort
someSort = SortApp "SomeSort" []
var :: VarName -> Term
var variableName = Var $ Variable{variableSort = someSort, variableName}