-- Test library import Test -- Functions under test import Test.Speculate.Engine -- Helper functions import Test.Speculate.Reason (emptyThy) import Test.Speculate.Utils main :: IO () main = mainTest tests 10000 tests :: Int -> [Bool] tests n = [ True , equivalencesBetween (===) (i_ -+- i_) (i_ -+- i_) == [ ( xx -+- yy, yy -+- xx ) ] , equivalencesBetween (===) (i_ -+- (i_ -+- i_)) ((i_ -+- i_) -+- i_) == [ ( xx -+- (yy -+- zz), (xx -+- yy) -+- zz ) , ( xx -+- (yy -+- zz), (xx -+- zz) -+- yy ) , ( xx -+- (yy -+- zz), (yy -+- xx) -+- zz ) , ( xx -+- (yy -+- zz), (yy -+- zz) -+- xx ) , ( xx -+- (yy -+- zz), (zz -+- xx) -+- yy ) , ( xx -+- (yy -+- zz), (zz -+- yy) -+- xx ) ] -- TODO: make the following pass (add ValueE and SameTypeValueE to Test) --, holds n $ \(SameTypeE e1 e2) (SameTypeE e3 e4) -- -> subConsequence emptyThy (e1 -==- e2) e3 e4 -- == subConsequence emptyThy (e2 -==- e1) e3 e4 --, holds n $ \(SameTypeE e1 e2) (SameTypeE e3 e4) -- -> subConsequence emptyThy (e1 -==- e2) e3 e4 -- == subConsequence emptyThy (e1 -==- e2) e4 e3 --, holds n $ \... -- -> not $ subConsequence emptyThy (e1 -<=- e2) e3 e4 , subConsequence emptyThy [] (xx -==- yy) (xx -+- yy) (xx -+- xx) , not $ subConsequence emptyThy [] (xx -<=- yy) (xx -+- yy) (xx -+- xx) , subConsequence emptyThy [(xx -<=- yy, [xx -==- yy])] (xx -<=- yy) (xx -+- yy) (xx -+- xx) , subConsequence emptyThy [] (abs' xx -==- abs' yy) (abs' xx) (abs' yy) , not $ subConsequence emptyThy [] (abs' xx -<=- abs' yy) (abs' xx) (abs' yy) , not $ subConsequence emptyThy [] (abs' xx -==- one) (xx -+- abs' xx) zero , holds n $ \e -> length (expansions preludeInstances 1 e) == 1 , expansions preludeInstances 2 (i_ -+- i_) == [ xx -+- xx , xx -+- yy , yy -+- xx , yy -+- yy ] , expansions preludeInstances 2 (i_ -+- i_ -+- ord' c_) == [ xx -+- xx -+- ord' cc , xx -+- xx -+- ord' dd , xx -+- yy -+- ord' cc , xx -+- yy -+- ord' dd , yy -+- xx -+- ord' cc , yy -+- xx -+- ord' dd , yy -+- yy -+- ord' cc , yy -+- yy -+- ord' dd ] , expansionsOfType i_ ["x","y"] (i_ -+- i_ -+- ord' c_) == [ xx -+- xx -+- ord' c_ , xx -+- yy -+- ord' c_ , yy -+- xx -+- ord' c_ , yy -+- yy -+- ord' c_ ] , expansionsOfType i_ [] (i_ -+- i_ -+- ord' c_) == [] , expansionsWith [xx, yy] (i_ -+- i_ -+- ord' c_) == [ xx -+- xx -+- ord' c_ , xx -+- yy -+- ord' c_ , yy -+- xx -+- ord' c_ , yy -+- yy -+- ord' c_ ] , expansionsWith [cc] (i_ -+- i_ -+- ord' c_) == [ i_ -+- i_ -+- ord' cc ] , expansionsWith [xx, yy, cc] (i_ -+- i_ -+- ord' c_) == [ xx -+- xx -+- ord' cc , xx -+- yy -+- ord' cc , yy -+- xx -+- ord' cc , yy -+- yy -+- ord' cc ] ] where x === y = equal preludeInstances 1000 x y