Skip to content

Commit

Permalink
Make tests run in Property (ResourceT IO)
Browse files Browse the repository at this point in the history
  • Loading branch information
carbolymer committed Dec 24, 2024
1 parent 20bab42 commit 193e479
Show file tree
Hide file tree
Showing 6 changed files with 31 additions and 18 deletions.
4 changes: 4 additions & 0 deletions cardano-cli/cardano-cli.cabal
Original file line number Diff line number Diff line change
Expand Up @@ -291,9 +291,11 @@ library cardano-cli-test-lib
hedgehog-extras ^>=0.6.1.0,
http-types,
lifted-base,
mmorph,
monad-control,
network,
process,
resourcet,
text,
transformers-base,
utf8-string,
Expand Down Expand Up @@ -323,8 +325,10 @@ test-suite cardano-cli-test
hedgehog,
hedgehog-extras ^>=0.6.1.0,
monad-control,
mmorph,
parsec,
regex-tdfa,
resourcet,
tasty,
tasty-hedgehog,
text,
Expand Down
8 changes: 4 additions & 4 deletions cardano-cli/test/cardano-cli-golden/Test/Golden/Byron/Tx.hs
Original file line number Diff line number Diff line change
Expand Up @@ -9,11 +9,11 @@ import Cardano.CLI.Byron.Tx

import Control.Monad (void)
import Data.ByteString (ByteString)
import GHC.Stack

import Test.Cardano.CLI.Util

import Hedgehog (Property, (===))
import qualified Hedgehog as H
import Hedgehog (MonadTest, Property, (===))
import qualified Hedgehog.Extras.Test.Base as H
import Hedgehog.Internal.Property (failWith)

Expand Down Expand Up @@ -67,14 +67,14 @@ hprop_byronTx = propertyOnce $ H.moduleWorkspace "tmp" $ \tempDir -> do

compareByronTxs createdTx expectedTx

getTxByteString :: FilePath -> H.PropertyT IO (ATxAux ByteString)
getTxByteString :: (MonadTest m, MonadIO m, HasCallStack) => FilePath -> m (ATxAux ByteString)
getTxByteString txFp = do
eATxAuxBS <- liftIO . runExceptT $ readByronTx $ File txFp
case eATxAuxBS of
Left err -> failWith Nothing . docToString $ renderByronTxError err
Right aTxAuxBS -> return aTxAuxBS

compareByronTxs :: FilePath -> FilePath -> H.PropertyT IO ()
compareByronTxs :: (MonadTest m, MonadIO m, HasCallStack) => FilePath -> FilePath -> m ()
compareByronTxs createdTx expectedTx = do
createdATxAuxBS <- getTxByteString createdTx
expectedATxAuxBS <- getTxByteString expectedTx
Expand Down
18 changes: 11 additions & 7 deletions cardano-cli/test/cardano-cli-test-lib/Test/Cardano/CLI/Util.hs
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,9 @@ import Control.Exception.Lifted (bracket_)
import Control.Monad (when)
import Control.Monad.Base
import Control.Monad.Catch hiding (bracket_)
import Control.Monad.Morph (hoist)
import Control.Monad.Trans.Control (MonadBaseControl)
import Control.Monad.Trans.Resource (ResourceT, runResourceT)
import qualified Data.Aeson as Aeson
import qualified Data.Aeson.Encode.Pretty as Aeson
import qualified Data.Aeson.Key as Aeson
Expand All @@ -62,7 +64,7 @@ import qualified Hedgehog as H
import Hedgehog.Extras (ExecConfig)
import qualified Hedgehog.Extras as H
import Hedgehog.Extras.Test (ExecConfig (..))
import Hedgehog.Internal.Property (Diff, MonadTest, PropertyT, liftTest, mkTest)
import Hedgehog.Internal.Property (Diff, MonadTest, liftTest, mkTest)
import qualified Hedgehog.Internal.Property as H
import Hedgehog.Internal.Show (ValueDiff (ValueSame), mkValue, showPretty, valueDiff)
import Hedgehog.Internal.Source (getCaller)
Expand Down Expand Up @@ -161,9 +163,10 @@ execDetailFlex execConfig pkgBin envBin arguments = GHC.withFrozenCallStack $ do
H.evalIO $ IO.readCreateProcessWithExitCode cp ""

tryExecCardanoCLI
:: [String]
:: (MonadCatch m, MonadIO m, HasCallStack)
=> [String]
-- ^ Arguments to the CLI command
-> H.PropertyT IO (Either H.Failure String)
-> H.PropertyT m (Either H.Failure String)
-- ^ Captured stdout, or error in case of failures
tryExecCardanoCLI args =
GHC.withFrozenCallStack (H.execFlex "cardano-cli" "CARDANO_CLI") args
Expand Down Expand Up @@ -278,8 +281,8 @@ withSnd f a = (a, f a)

-- These were lifted from hedgehog and slightly modified

propertyOnce :: H.PropertyT IO () -> H.Property
propertyOnce = H.withTests 1 . H.withShrinks 0 . H.property
propertyOnce :: H.PropertyT (ResourceT IO) () -> H.Property
propertyOnce = H.withTests 1 . H.withShrinks 0 . H.property . hoist runResourceT

-- | Check for equivalence between two types and perform a file cleanup on failure.
equivalence
Expand Down Expand Up @@ -388,9 +391,10 @@ bracketSem (FileSem path semaphore) act =
act path

-- | Invert the behavior of a MonadTest: success becomes failure and vice versa.
expectFailure :: HasCallStack => H.TestT IO m -> PropertyT IO ()
expectFailure
:: (MonadTrans t, MonadTest (t m), MonadCatch (t m), MonadIO m, HasCallStack) => H.TestT m a -> t m ()
expectFailure prop = GHC.withFrozenCallStack $ do
(res, _) <- H.evalIO $ H.runTestT prop
(res, _) <- H.evalM . lift $ H.runTestT prop
case res of
Left _ -> pure () -- Property failed so we succeed
_ -> H.failWith Nothing "Expected the test to fail but it passed" -- Property passed but we expected a failure
3 changes: 2 additions & 1 deletion cardano-cli/test/cardano-cli-test/Test/Cli/Hash.hs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
module Test.Cli.Hash where

import Control.Monad (void)
import Control.Monad.IO.Class
import Data.List (intercalate)
import GHC.IO.Exception (ExitCode (..))
import System.Directory (getCurrentDirectory)
Expand Down Expand Up @@ -77,7 +78,7 @@ hprop_generate_anchor_data_hash_from_file_uri =
]
result === exampleAnchorDataHash
where
toPOSIX :: FilePath -> PropertyT IO [Char]
toPOSIX :: MonadIO m => FilePath -> PropertyT m [Char]
toPOSIX path =
case map dropTrailingPathSeparator (splitDirectories path) of
letter : restOfPath -> do
Expand Down
9 changes: 5 additions & 4 deletions cardano-cli/test/cardano-cli-test/Test/Cli/Pipes.hs
Original file line number Diff line number Diff line change
Expand Up @@ -18,17 +18,18 @@ import System.FilePath ()
#endif

import qualified Hedgehog as H
import Hedgehog (Property)
import Hedgehog (Property, PropertyT)
import System.FilePath ((</>))

#ifdef UNIX
import Cardano.CLI.Read
import Cardano.CLI.OS.Posix
import Test.Cardano.CLI.Util


import Control.Monad.Morph (hoist)
import Control.Monad.Trans.Resource (runResourceT)
import qualified Data.ByteString.Char8 as BSC
import qualified Data.ByteString.Lazy as LBS
import Test.Cardano.CLI.Util

import Hedgehog ((===), forAll)
import qualified Hedgehog.Gen as G
Expand All @@ -38,7 +39,7 @@ import qualified Hedgehog.Extras.Test.Base as H
import qualified Hedgehog.Extras.Test.File as H

hprop_readFromPipe :: Property
hprop_readFromPipe = H.withTests 10 . H.property . H.moduleWorkspace "tmp" $ \ws -> do
hprop_readFromPipe = H.withTests 10 . H.property . hoist runResourceT . H.moduleWorkspace "tmp" $ \ws -> do

s <- forAll $ G.string (R.linear 1 8192) G.ascii

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,13 @@
module Test.Cli.Shelley.Run.Hash where

import Control.Monad (void)
import Control.Monad.Catch (MonadCatch)
import Control.Monad.Trans.Resource (MonadResource)
import GHC.Stack

import Test.Cardano.CLI.Util

import Hedgehog (Property)
import Hedgehog (MonadTest, Property)
import qualified Hedgehog as H
import qualified Hedgehog.Extras as H

Expand All @@ -21,7 +24,7 @@ hprop_hash_trip =
-- Test that @cardano-cli hash --text > file1@ and
-- @cardano-cli --text --out-file file2@ yields
-- similar @file1@ and @file2@ files.
hash_trip_fun :: String -> H.PropertyT IO ()
hash_trip_fun :: (MonadTest m, MonadCatch m, MonadResource m, HasCallStack) => String -> m ()
hash_trip_fun input =
H.moduleWorkspace "tmp" $ \tempDir -> do
hashFile <- noteTempFile tempDir "hash.txt"
Expand Down

0 comments on commit 193e479

Please sign in to comment.