-
Notifications
You must be signed in to change notification settings - Fork 123
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
This adds a dedicated `cryptol-api-tests` test suite which exercises properties of the Cryptol API that are inconvenient to check with the Cryptol executable itself (e.g., properties of the REPL's tab completion). I have also rejigged the CI so that `cryptol-api-tests` is run on each CI run.
- Loading branch information
1 parent
fd811de
commit 0e8ddd1
Showing
6 changed files
with
136 additions
and
17 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
module Main (main) where | ||
|
||
import System.Console.Haskeline.Completion (Completion(..)) | ||
import Test.Tasty | ||
import Test.Tasty.HUnit | ||
|
||
import qualified Cryptol.REPL.Command as REPL | ||
import qualified Cryptol.REPL.Monad as REPL | ||
import Cryptol.REPL.Monad (REPL) | ||
import Cryptol.Utils.Logger (quietLogger) | ||
import Cryptol.Utils.PP (pp) | ||
|
||
import REPL.Haskeline (cryptolCommand) | ||
|
||
main :: IO () | ||
main = defaultMain $ | ||
testGroup "Cryptol API tests" | ||
[ testGroup "Tab completion tests" $ | ||
map (uncurry replTabCompletionTestCase) | ||
[ (":check rev", ":check reverse") | ||
, (":t rev", ":t reverse") | ||
, (":type rev", ":type reverse") | ||
] | ||
] | ||
|
||
-- | Assert a property in the 'REPL' monad and turn it into a test case. | ||
replTestCase :: TestName -> REPL () -> TestTree | ||
replTestCase name replAssertion = | ||
testCase name $ | ||
REPL.runREPL | ||
False -- Don't use batch mode | ||
False -- Disable call stacks | ||
quietLogger -- Ignore all log messages | ||
replAssertion | ||
|
||
-- | Assert that the REPL will tab-complete the given input in a particular way. | ||
replTabCompletionTestCase :: | ||
-- | The input before the cursor just prior to hitting the tab key. | ||
String -> | ||
-- | The expected terminal input after hitting the tab key. | ||
String -> | ||
TestTree | ||
replTabCompletionTestCase beforeTab afterTabExpected = | ||
replTestCase (show beforeTab ++ " --> " ++ show afterTabExpected) $ | ||
do -- Load the prelude so that the REPL knows how to tab-complete prelude | ||
-- definitions. | ||
REPL.loadPrelude | ||
-- Perform the actual tab completion. (Oddly, Haskeline requires that the | ||
-- input to the left of the cursor should be reversed.) | ||
(_input, completions) <- cryptolCommand (reverse beforeTab, "") | ||
-- Check that the results match what is expected. | ||
REPL.io $ | ||
case completions of | ||
[completion] -> | ||
do assertBool "Tab completion finished" (isFinished completion) | ||
let afterTabActual = beforeTab ++ replacement completion | ||
afterTabExpected @=? afterTabActual | ||
[] -> assertFailure "Expected one tab completion, but received none" | ||
_ -> assertFailure $ "Expected one tab completion, but received " ++ | ||
show (length completions) | ||
`REPL.catch` | ||
-- If something goes wrong run running the REPL, report it as a test | ||
-- failure. | ||
\x -> REPL.io $ assertFailure $ show $ pp x |
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters