2017-08-19 09:16:10 -05:00
|
|
|
|
2016-07-25 16:37:06 -07:00
|
|
|
{-# LANGUAGE OverloadedStrings #-}
|
|
|
|
|
|
|
|
module GeneratedTests where
|
|
|
|
|
|
|
|
import Test.Tasty
|
2019-08-20 17:47:32 +02:00
|
|
|
import Test.Tasty.HUnit (assertEqual, testCase, (@?=))
|
2016-07-25 16:37:06 -07:00
|
|
|
|
|
|
|
import Data.String
|
2017-02-27 08:43:37 -08:00
|
|
|
import Proto3.Suite.DotProto.Generate
|
2016-07-25 16:37:06 -07:00
|
|
|
|
2017-03-16 12:42:51 -05:00
|
|
|
import Turtle hiding (err)
|
2016-07-25 16:37:06 -07:00
|
|
|
|
|
|
|
generatedTests :: TestTree
|
|
|
|
generatedTests = testGroup "Code generator tests"
|
2016-08-12 15:48:28 -07:00
|
|
|
[ testServerGeneration
|
|
|
|
, testClientGeneration ]
|
2016-07-25 16:37:06 -07:00
|
|
|
|
|
|
|
testServerGeneration :: TestTree
|
|
|
|
testServerGeneration = testCase "server generation" $ do
|
|
|
|
mktree hsTmpDir
|
|
|
|
mktree pyTmpDir
|
|
|
|
|
2019-06-18 12:51:25 -07:00
|
|
|
let args = CompileArgs
|
|
|
|
{ includeDir = ["tests"]
|
|
|
|
, extraInstanceFiles = []
|
|
|
|
, inputProto = "simple.proto"
|
|
|
|
, outputDir = hsTmpDir
|
|
|
|
}
|
|
|
|
compileDotProtoFileOrDie args
|
2016-07-25 16:37:06 -07:00
|
|
|
|
2017-03-16 12:42:51 -05:00
|
|
|
do exitCode <- proc "tests/simple-server.sh" [hsTmpDir] empty
|
|
|
|
exitCode @?= ExitSuccess
|
2016-07-25 16:37:06 -07:00
|
|
|
|
2017-03-16 12:42:51 -05:00
|
|
|
do exitCode <- proc "tests/protoc.sh" [pyTmpDir] empty
|
|
|
|
exitCode @?= ExitSuccess
|
2016-07-25 16:37:06 -07:00
|
|
|
|
|
|
|
runManaged $ do
|
|
|
|
serverExitCodeA <- fork (shell (hsTmpDir <> "/simple-server") empty)
|
|
|
|
clientExitCodeA <- fork
|
2016-12-12 10:40:23 -08:00
|
|
|
(export "PYTHONPATH" pyTmpDir >> shell "tests/test-client.sh" empty)
|
2016-07-25 16:37:06 -07:00
|
|
|
|
|
|
|
liftIO $ do
|
|
|
|
serverExitCode <- liftIO (wait serverExitCodeA)
|
|
|
|
clientExitCode <- liftIO (wait clientExitCodeA)
|
|
|
|
|
|
|
|
serverExitCode @?= ExitSuccess
|
|
|
|
clientExitCode @?= ExitSuccess
|
|
|
|
|
|
|
|
rmtree hsTmpDir
|
|
|
|
rmtree pyTmpDir
|
|
|
|
|
2016-08-12 15:48:28 -07:00
|
|
|
testClientGeneration :: TestTree
|
|
|
|
testClientGeneration = testCase "client generation" $ do
|
|
|
|
mktree hsTmpDir
|
|
|
|
mktree pyTmpDir
|
|
|
|
|
2019-06-18 12:51:25 -07:00
|
|
|
let args = CompileArgs
|
|
|
|
{ includeDir = ["tests"]
|
|
|
|
, extraInstanceFiles = []
|
|
|
|
, inputProto = "simple.proto"
|
|
|
|
, outputDir = hsTmpDir
|
|
|
|
}
|
|
|
|
compileDotProtoFileOrDie args
|
2016-08-12 15:48:28 -07:00
|
|
|
|
2017-03-16 12:42:51 -05:00
|
|
|
do exitCode <- proc "tests/simple-client.sh" [hsTmpDir] empty
|
|
|
|
exitCode @?= ExitSuccess
|
2016-08-12 15:48:28 -07:00
|
|
|
|
2017-03-16 12:42:51 -05:00
|
|
|
do exitCode <- proc "tests/protoc.sh" [pyTmpDir] empty
|
|
|
|
exitCode @?= ExitSuccess
|
2016-08-12 15:48:28 -07:00
|
|
|
|
|
|
|
runManaged $ do
|
|
|
|
serverExitCodeA <- fork
|
2016-12-12 10:40:23 -08:00
|
|
|
(export "PYTHONPATH" pyTmpDir >> shell "tests/test-server.sh" empty)
|
2016-08-12 15:48:28 -07:00
|
|
|
clientExitCodeA <- fork (shell (hsTmpDir <> "/simple-client") empty)
|
|
|
|
|
|
|
|
liftIO $ do
|
|
|
|
serverExitCode <- liftIO (wait serverExitCodeA)
|
|
|
|
clientExitCode <- liftIO (wait clientExitCodeA)
|
|
|
|
|
2019-08-20 17:47:32 +02:00
|
|
|
assertEqual "Server exit code" serverExitCode ExitSuccess
|
|
|
|
assertEqual "Client exit code" clientExitCode ExitSuccess
|
2016-08-12 15:48:28 -07:00
|
|
|
|
|
|
|
rmtree hsTmpDir
|
|
|
|
rmtree pyTmpDir
|
|
|
|
|
2016-07-25 16:37:06 -07:00
|
|
|
hsTmpDir, pyTmpDir :: IsString a => a
|
|
|
|
hsTmpDir = "tests/tmp"
|
|
|
|
pyTmpDir = "tests/py-tmp"
|