Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CIP-0138 array #6749

Open
wants to merge 7 commits into
base: yura/cip-0138-builtin-array
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
42 changes: 34 additions & 8 deletions plutus-core/testlib/Test/Tasty/Extras.hs
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
{-# LANGUAGE BlockArguments #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE TupleSections #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE TypeSynonymInstances #-}

module Test.Tasty.Extras
( Layer (..)
Expand All @@ -24,6 +24,7 @@ module Test.Tasty.Extras
, goldenVsDoc
, goldenVsDocM
, nestedGoldenVsText
, nestedGoldenVsTextPredM
, nestedGoldenVsTextM
, nestedGoldenVsDoc
, nestedGoldenVsDocM
Expand All @@ -33,16 +34,18 @@ module Test.Tasty.Extras
import PlutusPrelude hiding (toList)

import Control.Monad.Free.Church (F (runF), MonadFree, liftF)
import Control.Monad.Reader
import Control.Monad.Reader (MonadReader (ask, local), ReaderT (..), asks, mapReaderT)
import Data.ByteString.Lazy qualified as BSL
import Data.Text (Text)
import Data.Text.Encoding (encodeUtf8)
import Data.Version
import GHC.Exts
import Data.Text.IO qualified as TIO
import Data.Version (showVersion)
import GHC.Exts (IsList (Item, fromList, toList))
import System.FilePath (joinPath, (</>))
import System.Info
import Test.Tasty
import Test.Tasty.Golden
import System.Info (compilerVersion)
import Test.Tasty (TestName, TestTree, testGroup)
import Test.Tasty.Golden (createDirectoriesAndWriteFile, goldenVsStringDiff)
import Test.Tasty.Golden.Advanced (goldenTest)

-- | We use the GHC version number to create directories with names like `9.2`
-- and `9.6` containing golden files whose contents depend on the GHC version.
Expand Down Expand Up @@ -206,6 +209,28 @@ goldenVsDocM name ref val = goldenVsTextM name ref $ render <$> val
nestedGoldenVsText :: TestName -> FilePath -> Text -> TestNested
nestedGoldenVsText name ext = nestedGoldenVsTextM name ext . pure

{-| Compare the contents of a file under a name prefix against a 'Text'
using a predicate.
-}
nestedGoldenVsTextPredM
:: TestName
-- ^ The name of the test
-> FilePath
-- ^ The file extension
-> IO Text
-- ^ The text-producing action to execute
-> (Text -> Text -> Bool)
-- ^ How to compare golden file contents with the produced text
-> TestNested
nestedGoldenVsTextPredM name ext action predicate = do
filePath <- asks $ foldr (</>) (name ++ ext ++ ".golden")
embed $ goldenTest name (TIO.readFile filePath) action
do \golden actual -> pure
if predicate golden actual
then Nothing
else Just "Predicate failed on golden file"
do createDirectoriesAndWriteFile filePath . BSL.fromStrict . encodeUtf8

-- | Check the contents of a file under a name prefix against a 'Text'.
nestedGoldenVsTextM :: TestName -> FilePath -> IO Text -> TestNested
nestedGoldenVsTextM name ext text = do
Expand All @@ -219,3 +244,4 @@ nestedGoldenVsDoc name ext = nestedGoldenVsDocM name ext . pure
-- | Check the contents of a file under a name prefix against a 'Text'.
nestedGoldenVsDocM :: TestName -> FilePath -> IO (Doc ann) -> TestNested
nestedGoldenVsDocM name ext val = nestedGoldenVsTextM name ext $ render <$> val

Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ test_IntegerDistribution =
\(AsArbitraryBuiltin (i :: Integer)) ->
let magnitudes = magnitudesPositive nextInterestingBound highInterestingBound
(low, high) =
maybe (error $ "Panic: unknown integer") (bimap (* signum i) (* signum i)) $
maybe (error "Panic: unknown integer") (bimap (* signum i) (* signum i)) $
find ((>= abs i) . snd) magnitudes
bounds = map snd magnitudes
isInteresting = i `elem` concat
Expand Down Expand Up @@ -390,7 +390,7 @@ test_BuiltinArray =
let arrayOfInts = mkConstant @(Vector Integer) @DefaultUni () (Vector.fromList [1..10])
let index = mkConstant @Integer @DefaultUni () 5
expectedValue = mkConstant @Integer @DefaultUni () 6
term = mkIterAppNoAnn (tyInst () (builtin () IndexArray) integer) [index, arrayOfInts]
term = mkIterAppNoAnn (tyInst () (builtin () IndexArray) integer) [arrayOfInts, index]
typecheckEvaluateCekNoEmit def defaultBuiltinCostModelForTesting term @?=
Right (EvaluationSuccess expectedValue)
]
Expand Down
Loading
Loading