2022-05-30 14:40:52 +03:00
|
|
|
module Termination.Positive where
|
|
|
|
|
|
|
|
import Base
|
2022-08-03 14:20:40 +03:00
|
|
|
import Juvix.Compiler.Pipeline
|
2022-05-30 14:40:52 +03:00
|
|
|
import Termination.Negative qualified as N
|
|
|
|
|
|
|
|
data PosTest = PosTest
|
|
|
|
{ _name :: String,
|
|
|
|
_relDir :: FilePath,
|
|
|
|
_file :: FilePath
|
|
|
|
}
|
|
|
|
|
|
|
|
root :: FilePath
|
|
|
|
root = "tests/positive/Termination"
|
|
|
|
|
|
|
|
testDescr :: PosTest -> TestDescr
|
|
|
|
testDescr PosTest {..} =
|
|
|
|
let tRoot = root </> _relDir
|
|
|
|
in TestDescr
|
|
|
|
{ _testName = _name,
|
|
|
|
_testRoot = tRoot,
|
|
|
|
_testAssertion = Single $ do
|
2022-07-05 16:54:01 +03:00
|
|
|
let entryPoint = (defaultEntryPoint _file) {_entryPointNoStdlib = True}
|
2022-09-14 17:16:15 +03:00
|
|
|
(void . runIO' entryPoint) upToInternal
|
2022-05-30 14:40:52 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
-- Testing --no-termination flag with all termination negative tests
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
rootNegTests :: FilePath
|
|
|
|
rootNegTests = "tests/negative/Termination"
|
|
|
|
|
|
|
|
testDescrFlag :: N.NegTest -> TestDescr
|
|
|
|
testDescrFlag N.NegTest {..} =
|
|
|
|
let tRoot = rootNegTests </> _relDir
|
|
|
|
in TestDescr
|
|
|
|
{ _testName = _name,
|
|
|
|
_testRoot = tRoot,
|
|
|
|
_testAssertion = Single $ do
|
2022-07-23 10:27:12 +03:00
|
|
|
let entryPoint =
|
2022-08-19 17:57:07 +03:00
|
|
|
(defaultEntryPoint _file)
|
2022-07-23 10:27:12 +03:00
|
|
|
{ _entryPointRoot = ".",
|
|
|
|
_entryPointNoTermination = True,
|
2022-08-19 17:57:07 +03:00
|
|
|
_entryPointNoStdlib = True
|
2022-07-23 10:27:12 +03:00
|
|
|
}
|
|
|
|
|
2022-09-14 17:16:15 +03:00
|
|
|
(void . runIO' entryPoint) upToInternal
|
2022-05-30 14:40:52 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
tests :: [PosTest]
|
|
|
|
tests =
|
2022-07-08 14:59:45 +03:00
|
|
|
[ PosTest "Ackerman nice def. is terminating" "." "Ack.juvix",
|
2022-09-12 12:21:39 +03:00
|
|
|
PosTest "Fibonacci with nested pattern" "." "Fib.juvix",
|
2022-07-08 14:59:45 +03:00
|
|
|
PosTest "Recursive functions on Lists" "." "Data/List.juvix"
|
2022-05-30 14:40:52 +03:00
|
|
|
]
|
|
|
|
|
|
|
|
testsWithKeyword :: [PosTest]
|
|
|
|
testsWithKeyword =
|
2022-07-08 14:59:45 +03:00
|
|
|
[ PosTest "terminating added to fx:=fx" "." "ToEmpty.juvix",
|
|
|
|
PosTest "terminating for all functions in the mutual block" "." "Mutual.juvix",
|
|
|
|
PosTest "Undefined is terminating by assumption" "." "Undefined.juvix"
|
2022-05-30 14:40:52 +03:00
|
|
|
]
|
|
|
|
|
|
|
|
negTests :: [N.NegTest]
|
|
|
|
negTests = N.tests
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
allTests :: TestTree
|
|
|
|
allTests =
|
|
|
|
testGroup
|
|
|
|
"Positive tests"
|
|
|
|
[ testGroup
|
|
|
|
"Well-known terminating functions"
|
|
|
|
(map (mkTest . testDescr) tests),
|
|
|
|
testGroup
|
2022-07-23 10:27:12 +03:00
|
|
|
"Bypass termination checking using --non-termination flag on negative tests"
|
2022-05-30 14:40:52 +03:00
|
|
|
(map (mkTest . testDescrFlag) negTests),
|
|
|
|
testGroup
|
|
|
|
"Terminating keyword"
|
|
|
|
(map (mkTest . testDescr) testsWithKeyword)
|
|
|
|
]
|