2022-05-05 16:12:17 +03:00
|
|
|
module BackendC.Positive where
|
|
|
|
|
|
|
|
import Base
|
|
|
|
import Data.Text.IO qualified as TIO
|
|
|
|
import MiniJuvix.Pipeline
|
|
|
|
import MiniJuvix.Translation.MonoJuvixToMiniC as MiniC
|
|
|
|
import System.IO.Extra (withTempDir)
|
|
|
|
import System.Process qualified as P
|
|
|
|
|
|
|
|
data PosTest = PosTest
|
|
|
|
{ _name :: String,
|
|
|
|
_relDir :: FilePath
|
|
|
|
}
|
|
|
|
|
|
|
|
makeLenses ''PosTest
|
|
|
|
|
|
|
|
root :: FilePath
|
|
|
|
root = "tests/positive/MiniC"
|
|
|
|
|
|
|
|
mainFile :: FilePath
|
|
|
|
mainFile = "Input.mjuvix"
|
|
|
|
|
2022-05-13 12:44:06 +03:00
|
|
|
expectedFile :: FilePath
|
|
|
|
expectedFile = "expected.golden"
|
|
|
|
|
2022-05-05 16:12:17 +03:00
|
|
|
testDescr :: PosTest -> TestDescr
|
|
|
|
testDescr PosTest {..} =
|
|
|
|
let tRoot = root </> _relDir
|
|
|
|
in TestDescr
|
|
|
|
{ _testName = _name,
|
|
|
|
_testRoot = tRoot,
|
|
|
|
_testAssertion = Steps $ \step -> do
|
|
|
|
step "Check emscripten and wasmer are on path"
|
|
|
|
assertCmdExists "emcc"
|
|
|
|
assertCmdExists "wasmer"
|
|
|
|
|
|
|
|
step "C Generation"
|
2022-05-13 12:44:06 +03:00
|
|
|
let entryPoint = EntryPoint "." (pure mainFile)
|
2022-05-05 16:12:17 +03:00
|
|
|
p :: MiniC.MiniCResult <- runIO (upToMiniC entryPoint)
|
|
|
|
|
|
|
|
actual <-
|
|
|
|
withTempDir
|
|
|
|
( \dirPath -> do
|
|
|
|
let cOutputFile = dirPath </> "out.c"
|
|
|
|
wasmOutputFile = dirPath </> "out.wasm"
|
|
|
|
TIO.writeFile cOutputFile (p ^. MiniC.resultCCode)
|
|
|
|
step "WASM generation"
|
|
|
|
P.callProcess "emcc" ["-o", wasmOutputFile, cOutputFile]
|
|
|
|
step "WASM execution"
|
|
|
|
pack <$> P.readProcess "wasmer" [wasmOutputFile] ""
|
|
|
|
)
|
|
|
|
|
2022-05-13 12:44:06 +03:00
|
|
|
expected <- TIO.readFile expectedFile
|
2022-05-05 16:12:17 +03:00
|
|
|
step "Compare expected and actual program output"
|
2022-05-13 12:44:06 +03:00
|
|
|
assertEqDiff ("check: WASM output = " <> expectedFile) actual expected
|
2022-05-05 16:12:17 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
allTests :: TestTree
|
|
|
|
allTests =
|
|
|
|
testGroup
|
|
|
|
"Backend C positive tests"
|
|
|
|
(map (mkTest . testDescr) tests)
|
|
|
|
|
|
|
|
tests :: [PosTest]
|
|
|
|
tests =
|
|
|
|
[ PosTest "HelloWorld" "HelloWorld",
|
|
|
|
PosTest "Inductive types and pattern matching" "Nat",
|
2022-05-13 12:44:06 +03:00
|
|
|
PosTest "Polymorphic types" "Polymorphism",
|
|
|
|
PosTest "Multiple modules" "MultiModules"
|
2022-05-05 16:12:17 +03:00
|
|
|
]
|