{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeOperators #-}
module Test.Cardano.Ledger.Constrained.Preds.Universes
where
import qualified Cardano.Chain.Common as Byron
import qualified Cardano.Crypto.Signing as Byron
import Cardano.Ledger.Address (Addr (..), BootstrapAddress (..), bootstrapKeyHash)
import Cardano.Ledger.Allegra.Scripts (ValidityInterval (..))
import Cardano.Ledger.Alonzo.TxOut (AlonzoTxOut (..))
import Cardano.Ledger.Babbage.TxOut (BabbageTxOut (..))
import Cardano.Ledger.BaseTypes (
Network (..),
SlotNo (..),
StrictMaybe (..),
TxIx (..),
inject,
mkCertIxPartial,
)
import qualified Cardano.Ledger.BaseTypes as Utils (Globals (..))
import Cardano.Ledger.Coin (Coin (..))
import Cardano.Ledger.Core
import Cardano.Ledger.Credential (Credential (..), Ptr (..), SlotNo32 (..), StakeReference (..))
import Cardano.Ledger.DRep (DRep (..))
import Cardano.Ledger.Keys (coerceKeyRole)
import Cardano.Ledger.Keys.Bootstrap (BootstrapWitness, makeBootstrapWitness)
import Cardano.Ledger.Mary.Value (
AssetName (..),
MaryValue (..),
MultiAsset (..),
PolicyID (..),
multiAssetFromList,
)
import Cardano.Ledger.Plutus.Data (Data (..), Datum (..), dataToBinaryData, hashData)
import Cardano.Ledger.Shelley.TxOut (ShelleyTxOut (..))
import Data.Default (Default (def))
import qualified Data.List as List
import Data.Map (Map)
import qualified Data.Map.Strict as Map
import Data.Set (Set)
import qualified Data.Set as Set
import Data.String (IsString (..))
import Test.Cardano.Ledger.Constrained.Ast
import Test.Cardano.Ledger.Constrained.Classes hiding (genTxOut)
import Test.Cardano.Ledger.Constrained.Combinators (genFromMap, itemFromSet, setSized)
import Test.Cardano.Ledger.Constrained.Env
import Test.Cardano.Ledger.Constrained.Monad (monadTyped)
import Test.Cardano.Ledger.Constrained.Preds.Repl (ReplMode (..), modeRepl)
import Test.Cardano.Ledger.Constrained.Rewrite (standardOrderInfo)
import Test.Cardano.Ledger.Constrained.Scripts (allPlutusScripts, genCoreScript, spendPlutusScripts)
import Test.Cardano.Ledger.Constrained.Solver
import Test.Cardano.Ledger.Constrained.TypeRep
import Test.Cardano.Ledger.Constrained.Utils (testIO)
import Test.Cardano.Ledger.Constrained.Vars
import Test.Cardano.Ledger.Core.KeyPair (KeyPair (..))
import Test.Cardano.Ledger.Generic.Functions (protocolVersion)
import Test.Cardano.Ledger.Generic.GenState (PlutusPurposeTag (..))
import Test.Cardano.Ledger.Generic.Proof
import Test.Cardano.Ledger.Shelley.Utils (epochFromSlotNo)
import qualified Test.Cardano.Ledger.Shelley.Utils as Utils
import Test.Tasty (TestTree, defaultMain)
import Test.Tasty.QuickCheck
import Cardano.Ledger.Conway.Governance (GovActionId (..), GovActionIx (..))
import Cardano.Ledger.TxIn (TxIn (..))
data UnivSize = UnivSize
{ UnivSize -> Int
usNumTxOuts :: Int
, UnivSize -> Int
usMaxAssets :: Int
, UnivSize -> Int
usMaxPolicyID :: Int
, UnivSize -> Int
usNumMultiAsset :: Int
, UnivSize -> Int
usNumPtr :: Int
, UnivSize -> Int
usNumAddr :: Int
, UnivSize -> Int
usNumKeys :: Int
, UnivSize -> Int
usNumPools :: Int
, UnivSize -> Int
usNumStakeKeys :: Int
, UnivSize -> Int
usNumGenesisKeys :: Int
, UnivSize -> Int
usNumVoteKeys :: Int
, UnivSize -> Int
usNumCredentials :: Int
, UnivSize -> Int
usNumDatums :: Int
, UnivSize -> Int
usNumTxIn :: Int
, UnivSize -> Int
usNumPreUtxo :: Int
, UnivSize -> Int
usNumColUtxo :: Int
, UnivSize -> Int
usNumDReps :: Int
, UnivSize -> Int
usMinCerts :: Int
, UnivSize -> Int
usMaxCerts :: Int
, UnivSize -> Int
usDatumFreq :: Int
, UnivSize -> Bool
usGenerateWithdrawals :: Bool
, UnivSize -> Int
usMinInputs :: Int
, UnivSize -> Int
usMaxInputs :: Int
, UnivSize -> Int
usMinCollaterals :: Int
, UnivSize -> Int
usMaxCollaterals :: Int
, UnivSize -> Int
usRegKeyFreq :: Int
, UnivSize -> Int
usUnRegKeyFreq :: Int
, UnivSize -> Bool
usAllowReRegisterPool :: Bool
, UnivSize -> Int
usSpendScriptFreq :: Int
, UnivSize -> Int
usCredScriptFreq :: Int
}
instance Default UnivSize where
def :: UnivSize
def =
UnivSize
{ usNumTxOuts :: Int
usNumTxOuts = Int
100
, usMaxAssets :: Int
usMaxAssets = Int
9
, usMaxPolicyID :: Int
usMaxPolicyID = Int
2
, usNumMultiAsset :: Int
usNumMultiAsset = Int
10
, usNumPtr :: Int
usNumPtr = Int
30
, usNumAddr :: Int
usNumAddr = Int
200
, usNumKeys :: Int
usNumKeys = Int
50
, usNumPools :: Int
usNumPools = Int
40
, usNumStakeKeys :: Int
usNumStakeKeys = Int
10
, usNumGenesisKeys :: Int
usNumGenesisKeys = Int
20
, usNumVoteKeys :: Int
usNumVoteKeys = Int
40
, usNumCredentials :: Int
usNumCredentials = Int
40
, usNumDatums :: Int
usNumDatums = Int
30
, usNumTxIn :: Int
usNumTxIn = Int
120
, usNumPreUtxo :: Int
usNumPreUtxo = Int
100
, usNumColUtxo :: Int
usNumColUtxo = Int
20
, usNumDReps :: Int
usNumDReps = Int
20
, usMaxCerts :: Int
usMaxCerts = Int
6
, usMinCerts :: Int
usMinCerts = Int
4
, usDatumFreq :: Int
usDatumFreq = Int
1
, usGenerateWithdrawals :: Bool
usGenerateWithdrawals = Bool
True
, usMinInputs :: Int
usMinInputs = Int
2
, usMaxInputs :: Int
usMaxInputs = Int
10
, usMinCollaterals :: Int
usMinCollaterals = Int
2
, usMaxCollaterals :: Int
usMaxCollaterals = Int
2
, usAllowReRegisterPool :: Bool
usAllowReRegisterPool = Bool
True
, usRegKeyFreq :: Int
usRegKeyFreq = Int
1
, usUnRegKeyFreq :: Int
usUnRegKeyFreq = Int
1
, usSpendScriptFreq :: Int
usSpendScriptFreq = Int
3
, usCredScriptFreq :: Int
usCredScriptFreq = Int
1
}
variedCoin :: Gen Coin
variedCoin :: Gen Coin
variedCoin =
Integer -> Coin
Coin
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall a. HasCallStack => [(Int, Gen a)] -> Gen a
frequency
[ (Int
2, forall (f :: * -> *) a. Applicative f => a -> f a
pure Integer
0)
, (Int
2, forall a. Random a => (a, a) -> Gen a
choose (Integer
1, Integer
10))
, (Int
2, forall a. Random a => (a, a) -> Gen a
choose (Integer
11, Integer
100))
, (Int
2, forall a. Random a => (a, a) -> Gen a
choose (Integer
101, Integer
1000))
, (Int
2, forall a. Random a => (a, a) -> Gen a
choose (Integer
1001, Integer
10000))
, (Int
8, forall a. Random a => (a, a) -> Gen a
choose (Integer
10001, Integer
100000))
, (Int
12, forall a. Random a => (a, a) -> Gen a
choose (Integer
100001, Integer
1000000))
]
noZeroCoin :: Gen Coin
noZeroCoin :: Gen Coin
noZeroCoin =
Integer -> Coin
Coin
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall a. HasCallStack => [(Int, Gen a)] -> Gen a
frequency
[ (Int
1, forall a. Random a => (a, a) -> Gen a
choose (Integer
1, Integer
10))
, (Int
1, forall a. Random a => (a, a) -> Gen a
choose (Integer
11, Integer
1000))
, (Int
1, forall a. Random a => (a, a) -> Gen a
choose (Integer
1001, Integer
100000))
, (Int
6, forall a. Random a => (a, a) -> Gen a
choose (Integer
100001, Integer
600000))
, (Int
6, forall a. Random a => (a, a) -> Gen a
choose (Integer
600001, Integer
2000000))
, (Int
6, forall a. Random a => (a, a) -> Gen a
choose (Integer
2000001, Integer
4000000))
]
genAddrPair :: Network -> Gen (BootstrapAddress, Byron.SigningKey)
genAddrPair :: Network -> Gen (BootstrapAddress, SigningKey)
genAddrPair Network
netwrk = do
SigningKey
signkey <- Gen SigningKey
genSigningKey
let verificationKey :: VerificationKey
verificationKey = SigningKey -> VerificationKey
Byron.toVerification SigningKey
signkey
asd :: AddrSpendingData
asd = VerificationKey -> AddrSpendingData
Byron.VerKeyASD VerificationKey
verificationKey
byronNetwork :: NetworkMagic
byronNetwork = case Network
netwrk of
Network
Mainnet -> NetworkMagic
Byron.NetworkMainOrStage
Network
Testnet -> Word32 -> NetworkMagic
Byron.NetworkTestnet Word32
0
attrs :: AddrAttributes
attrs =
Maybe HDAddressPayload -> NetworkMagic -> AddrAttributes
Byron.AddrAttributes
(forall a. a -> Maybe a
Just (ByteString -> HDAddressPayload
Byron.HDAddressPayload ByteString
"a compressed lenna.png"))
NetworkMagic
byronNetwork
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Address -> BootstrapAddress
BootstrapAddress (AddrSpendingData -> AddrAttributes -> Address
Byron.makeAddress AddrSpendingData
asd AddrAttributes
attrs), SigningKey
signkey)
genByronUniv :: Network -> Gen (Map (KeyHash 'Payment) (Addr, Byron.SigningKey))
genByronUniv :: Network -> Gen (Map (KeyHash 'Payment) (Addr, SigningKey))
genByronUniv Network
netwrk = do
[(BootstrapAddress, SigningKey)]
list <- forall a. Int -> Gen a -> Gen [a]
vectorOf Int
50 (Network -> Gen (BootstrapAddress, SigningKey)
genAddrPair Network
netwrk)
forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$
forall k a. Ord k => [(k, a)] -> Map k a
Map.fromList
(forall a b. (a -> b) -> [a] -> [b]
List.map (\(BootstrapAddress
addr, SigningKey
signkey) -> (BootstrapAddress -> KeyHash 'Payment
bootstrapKeyHash BootstrapAddress
addr, (BootstrapAddress -> Addr
AddrBootstrap BootstrapAddress
addr, SigningKey
signkey))) [(BootstrapAddress, SigningKey)]
list)
bootWitness ::
Hash HASH EraIndependentTxBody ->
[BootstrapAddress] ->
Map (KeyHash 'Payment) (Addr, Byron.SigningKey) ->
Set BootstrapWitness
bootWitness :: Hash HASH EraIndependentTxBody
-> [BootstrapAddress]
-> Map (KeyHash 'Payment) (Addr, SigningKey)
-> Set BootstrapWitness
bootWitness Hash HASH EraIndependentTxBody
hash [BootstrapAddress]
bootaddrs Map (KeyHash 'Payment) (Addr, SigningKey)
byronuniv = forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
List.foldl' Set BootstrapWitness -> BootstrapAddress -> Set BootstrapWitness
accum forall a. Set a
Set.empty [BootstrapAddress]
bootaddrs
where
accum :: Set BootstrapWitness -> BootstrapAddress -> Set BootstrapWitness
accum Set BootstrapWitness
ans bootaddr :: BootstrapAddress
bootaddr@(BootstrapAddress Address
a) = case forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup (BootstrapAddress -> KeyHash 'Payment
bootstrapKeyHash BootstrapAddress
bootaddr) Map (KeyHash 'Payment) (Addr, SigningKey)
byronuniv of
Just (AddrBootstrap BootstrapAddress
_, SigningKey
signkey) ->
forall a. Ord a => a -> Set a -> Set a
Set.insert (Hash HASH EraIndependentTxBody
-> SigningKey -> Attributes AddrAttributes -> BootstrapWitness
makeBootstrapWitness Hash HASH EraIndependentTxBody
hash SigningKey
signkey (Address -> Attributes AddrAttributes
Byron.addrAttributes Address
a)) Set BootstrapWitness
ans
Maybe (Addr, SigningKey)
_ -> Set BootstrapWitness
ans
genDatums ::
Era era => UnivSize -> Int -> Map DataHash (Data era) -> Gen [Datum era]
genDatums :: forall era.
Era era =>
UnivSize -> Int -> Map DataHash (Data era) -> Gen [Datum era]
genDatums UnivSize
sizes Int
n Map DataHash (Data era)
datauniv = forall a. Int -> Gen a -> Gen [a]
vectorOf Int
n (forall era.
Era era =>
UnivSize -> Map DataHash (Data era) -> Gen (Datum era)
genDatum UnivSize
sizes Map DataHash (Data era)
datauniv)
genDatum :: Era era => UnivSize -> Map DataHash (Data era) -> Gen (Datum era)
genDatum :: forall era.
Era era =>
UnivSize -> Map DataHash (Data era) -> Gen (Datum era)
genDatum UnivSize {Int
usDatumFreq :: Int
usDatumFreq :: UnivSize -> Int
usDatumFreq} Map DataHash (Data era)
datauniv =
forall a. HasCallStack => [(Int, Gen a)] -> Gen a
frequency
[ (Int
1, forall era. DataHash -> Datum era
DatumHash forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a, b) -> a
fst forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall k a. [String] -> Map k a -> Gen (k, a)
genFromMap [String
"from genDatums DatumHash case"] Map DataHash (Data era)
datauniv)
,
( Int
usDatumFreq
, forall era. BinaryData era -> Datum era
Datum forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall era. Era era => Data era -> BinaryData era
dataToBinaryData forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a, b) -> b
snd
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall k a. [String] -> Map k a -> Gen (k, a)
genFromMap [String
"from genDatums Datum case"] Map DataHash (Data era)
datauniv
)
]
genTxOut ::
Reflect era =>
UnivSize ->
(Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era)) ->
Proof era ->
Coin ->
Set Addr ->
Map ScriptHash (ScriptF era) ->
Map ScriptHash (ScriptF era) ->
Map DataHash (Data era) ->
Gen (TxOut era)
genTxOut :: forall era.
Reflect era =>
UnivSize
-> (Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era))
-> Proof era
-> Coin
-> Set Addr
-> Map ScriptHash (ScriptF era)
-> Map ScriptHash (ScriptF era)
-> Map DataHash (Data era)
-> Gen (TxOut era)
genTxOut UnivSize
sizes Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era)
genvalue Proof era
p Coin
c Set Addr
addruniv Map ScriptHash (ScriptF era)
scriptuniv Map ScriptHash (ScriptF era)
spendscriptuniv Map DataHash (Data era)
datauniv =
case forall era. Proof era -> TxOutWit era
whichTxOut Proof era
p of
TxOutWit era
TxOutShelleyToMary ->
forall era.
(HasCallStack, Era era, Val (Value era)) =>
Addr -> Value era -> ShelleyTxOut era
ShelleyTxOut forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall t. [String] -> Set t -> Gen t
pick1 [String
"genTxOut ShelleyToMary Addr"] Set Addr
addruniv forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era)
genvalue Coin
c Map ScriptHash (ScriptF era)
scriptuniv
TxOutWit era
TxOutAlonzoToAlonzo -> do
Addr
addr <- forall t. [String] -> Set t -> Gen t
pick1 [String
"genTxOut AlonzoToAlonzo Addr"] Set Addr
addruniv
Value era
v <- Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era)
genvalue Coin
c Map ScriptHash (ScriptF era)
scriptuniv
case Addr
addr of
AddrBootstrap BootstrapAddress
_ -> forall (f :: * -> *) a. Applicative f => a -> f a
pure (forall era.
(Era era, Val (Value era), HasCallStack) =>
Addr -> Value era -> StrictMaybe DataHash -> AlonzoTxOut era
AlonzoTxOut Addr
addr Value era
v forall a. StrictMaybe a
SNothing)
Addr Network
_ PaymentCredential
paycred StakeReference
_ ->
if forall era.
EraScript era =>
PaymentCredential -> Map ScriptHash (ScriptF era) -> Bool
needsDatum PaymentCredential
paycred Map ScriptHash (ScriptF era)
spendscriptuniv
then
forall era.
(Era era, Val (Value era), HasCallStack) =>
Addr -> Value era -> StrictMaybe DataHash -> AlonzoTxOut era
AlonzoTxOut Addr
addr Value era
v forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. a -> StrictMaybe a
SJust forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a, b) -> a
fst
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall k a. [String] -> Map k a -> Gen (k, a)
genFromMap [String
"from genTxOut, AlonzoToAlonzo, needsDatum case"] Map DataHash (Data era)
datauniv
else forall (f :: * -> *) a. Applicative f => a -> f a
pure (forall era.
(Era era, Val (Value era), HasCallStack) =>
Addr -> Value era -> StrictMaybe DataHash -> AlonzoTxOut era
AlonzoTxOut Addr
addr Value era
v forall a. StrictMaybe a
SNothing)
TxOutWit era
TxOutBabbageToConway -> do
Addr
addr <- forall t. [String] -> Set t -> Gen t
pick1 [String
"genTxOut BabbageToConway Addr"] Set Addr
addruniv
Value era
v <- Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era)
genvalue Coin
c Map ScriptHash (ScriptF era)
scriptuniv
(ScriptF Proof era
_ Script era
refscript) <- forall a b. (a, b) -> b
snd forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall k a. [String] -> Map k a -> Gen (k, a)
genFromMap [String
"genTxOut, BabbageToConway, refscript case"] Map ScriptHash (ScriptF era)
scriptuniv
StrictMaybe (Script era)
maybescript <- forall a. HasCallStack => [a] -> Gen a
elements [forall a. StrictMaybe a
SNothing, forall a. a -> StrictMaybe a
SJust Script era
refscript]
case Addr
addr of
AddrBootstrap BootstrapAddress
_ -> forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ forall era.
(Era era, Val (Value era), HasCallStack) =>
Addr
-> Value era
-> Datum era
-> StrictMaybe (Script era)
-> BabbageTxOut era
BabbageTxOut Addr
addr Value era
v forall era. Datum era
NoDatum StrictMaybe (Script era)
maybescript
Addr Network
_ PaymentCredential
paycred StakeReference
_ ->
if forall era.
EraScript era =>
PaymentCredential -> Map ScriptHash (ScriptF era) -> Bool
needsDatum PaymentCredential
paycred Map ScriptHash (ScriptF era)
spendscriptuniv
then forall era.
(Era era, Val (Value era), HasCallStack) =>
Addr
-> Value era
-> Datum era
-> StrictMaybe (Script era)
-> BabbageTxOut era
BabbageTxOut Addr
addr Value era
v forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall era.
Era era =>
UnivSize -> Map DataHash (Data era) -> Gen (Datum era)
genDatum UnivSize
sizes Map DataHash (Data era)
datauniv forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall (f :: * -> *) a. Applicative f => a -> f a
pure StrictMaybe (Script era)
maybescript
else forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ forall era.
(Era era, Val (Value era), HasCallStack) =>
Addr
-> Value era
-> Datum era
-> StrictMaybe (Script era)
-> BabbageTxOut era
BabbageTxOut Addr
addr Value era
v forall era. Datum era
NoDatum StrictMaybe (Script era)
maybescript
needsDatum ::
EraScript era =>
Credential 'Payment ->
Map ScriptHash (ScriptF era) ->
Bool
needsDatum :: forall era.
EraScript era =>
PaymentCredential -> Map ScriptHash (ScriptF era) -> Bool
needsDatum (ScriptHashObj ScriptHash
hash) Map ScriptHash (ScriptF era)
spendScriptUniv = case forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup ScriptHash
hash Map ScriptHash (ScriptF era)
spendScriptUniv of
Maybe (ScriptF era)
Nothing -> Bool
False
Just (ScriptF Proof era
_ Script era
script) -> Bool -> Bool
not (forall era. EraScript era => Script era -> Bool
isNativeScript Script era
script)
needsDatum PaymentCredential
_ Map ScriptHash (ScriptF era)
_ = Bool
False
genTxOuts ::
Reflect era =>
UnivSize ->
(Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era)) ->
Proof era ->
Int ->
Set Addr ->
Map ScriptHash (ScriptF era) ->
Map ScriptHash (ScriptF era) ->
Map DataHash (Data era) ->
Gen [TxOutF era]
genTxOuts :: forall era.
Reflect era =>
UnivSize
-> (Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era))
-> Proof era
-> Int
-> Set Addr
-> Map ScriptHash (ScriptF era)
-> Map ScriptHash (ScriptF era)
-> Map DataHash (Data era)
-> Gen [TxOutF era]
genTxOuts UnivSize
sizes Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era)
genvalue Proof era
p Int
ntxouts Set Addr
addruniv Map ScriptHash (ScriptF era)
scriptuniv Map ScriptHash (ScriptF era)
spendscriptuniv Map DataHash (Data era)
datauniv = do
let genOne :: Gen (TxOut era)
genOne = do
Coin
c <- Gen Coin
noZeroCoin
forall era.
Reflect era =>
UnivSize
-> (Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era))
-> Proof era
-> Coin
-> Set Addr
-> Map ScriptHash (ScriptF era)
-> Map ScriptHash (ScriptF era)
-> Map DataHash (Data era)
-> Gen (TxOut era)
genTxOut UnivSize
sizes Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era)
genvalue Proof era
p Coin
c Set Addr
addruniv Map ScriptHash (ScriptF era)
scriptuniv Map ScriptHash (ScriptF era)
spendscriptuniv Map DataHash (Data era)
datauniv
forall a. Int -> Gen a -> Gen [a]
vectorOf Int
ntxouts (forall era. Proof era -> TxOut era -> TxOutF era
TxOutF Proof era
p forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Gen (TxOut era)
genOne)
genMultiAssetTriple ::
Map.Map ScriptHash (ScriptF era) ->
Set AssetName ->
Gen Integer ->
Gen (PolicyID, AssetName, Integer)
genMultiAssetTriple :: forall era.
Map ScriptHash (ScriptF era)
-> Set AssetName
-> Gen Integer
-> Gen (PolicyID, AssetName, Integer)
genMultiAssetTriple Map ScriptHash (ScriptF era)
scriptMap Set AssetName
assetSet Gen Integer
genAmount =
(,,)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (ScriptHash -> PolicyID
PolicyID forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a, b) -> a
fst forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (forall k a. [String] -> Map k a -> Gen (k, a)
genFromMap [] Map ScriptHash (ScriptF era)
scriptMap))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> (forall a b. (a, b) -> a
fst forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (forall a. [String] -> Set a -> Gen (a, Set a)
itemFromSet [] Set AssetName
assetSet))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Gen Integer
genAmount
pick1 :: [String] -> Set t -> Gen t
pick1 :: forall t. [String] -> Set t -> Gen t
pick1 [String]
msgs Set t
s = forall a b. (a, b) -> a
fst forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall a. [String] -> Set a -> Gen (a, Set a)
itemFromSet (String
"from pick1" forall a. a -> [a] -> [a]
: [String]
msgs) Set t
s
makeHashScriptMap ::
Reflect era =>
Proof era ->
Int ->
PlutusPurposeTag ->
Map (KeyHash 'Witness) (KeyPair 'Witness) ->
ValidityInterval ->
Gen (Map ScriptHash (ScriptF era))
makeHashScriptMap :: forall era.
Reflect era =>
Proof era
-> Int
-> PlutusPurposeTag
-> Map (KeyHash 'Witness) (KeyPair 'Witness)
-> ValidityInterval
-> Gen (Map ScriptHash (ScriptF era))
makeHashScriptMap Proof era
p Int
size PlutusPurposeTag
tag Map (KeyHash 'Witness) (KeyPair 'Witness)
m ValidityInterval
vi = do
let genOne :: PlutusPurposeTag -> Gen (Script era)
genOne PlutusPurposeTag
Spending =
case forall era. Proof era -> ScriptWit era
whichScript Proof era
p of
ScriptWit era
ScriptShelleyToShelley -> forall era.
Proof era
-> PlutusPurposeTag
-> Map (KeyHash 'Witness) (KeyPair 'Witness)
-> ValidityInterval
-> Gen (Script era)
genCoreScript Proof era
p PlutusPurposeTag
Spending Map (KeyHash 'Witness) (KeyPair 'Witness)
m ValidityInterval
vi
ScriptWit era
ScriptAllegraToMary -> forall era.
Proof era
-> PlutusPurposeTag
-> Map (KeyHash 'Witness) (KeyPair 'Witness)
-> ValidityInterval
-> Gen (Script era)
genCoreScript Proof era
p PlutusPurposeTag
Spending Map (KeyHash 'Witness) (KeyPair 'Witness)
m ValidityInterval
vi
ScriptWit era
ScriptAlonzoToConway ->
forall a. HasCallStack => [Gen a] -> Gen a
oneof
[ forall a b. (a, b) -> b
snd forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a, b) -> b
snd forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall k a. [String] -> Map k a -> Gen (k, a)
genFromMap [] (forall era.
Reflect era =>
Proof era -> Map ScriptHash (IsValid, Script era)
spendPlutusScripts Proof era
p)
, forall era.
Proof era
-> PlutusPurposeTag
-> Map (KeyHash 'Witness) (KeyPair 'Witness)
-> ValidityInterval
-> Gen (Script era)
genCoreScript Proof era
p PlutusPurposeTag
Spending Map (KeyHash 'Witness) (KeyPair 'Witness)
m ValidityInterval
vi
]
genOne PlutusPurposeTag
t = forall era.
Proof era
-> PlutusPurposeTag
-> Map (KeyHash 'Witness) (KeyPair 'Witness)
-> ValidityInterval
-> Gen (Script era)
genCoreScript Proof era
p PlutusPurposeTag
t Map (KeyHash 'Witness) (KeyPair 'Witness)
m ValidityInterval
vi
[Script era]
scs <- forall a. Int -> Gen a -> Gen [a]
vectorOf Int
size (PlutusPurposeTag -> Gen (Script era)
genOne PlutusPurposeTag
tag)
forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ forall k a. Ord k => [(k, a)] -> Map k a
Map.fromList forall a b. (a -> b) -> a -> b
$ forall a b. (a -> b) -> [a] -> [b]
map (\Script era
x -> (forall era. EraScript era => Script era -> ScriptHash
hashScript Script era
x, forall era. Proof era -> Script era -> ScriptF era
ScriptF Proof era
p Script era
x)) [Script era]
scs
genDataWits ::
Era era =>
Proof era ->
Int ->
Gen (Map DataHash (Data era))
genDataWits :: forall era.
Era era =>
Proof era -> Int -> Gen (Map DataHash (Data era))
genDataWits Proof era
_p Int
size = do
[Data era]
scs <- forall a. Int -> Gen a -> Gen [a]
vectorOf Int
size forall a. Arbitrary a => Gen a
arbitrary
forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ forall k a. Ord k => [(k, a)] -> Map k a
Map.fromList forall a b. (a -> b) -> a -> b
$ forall a b. (a -> b) -> [a] -> [b]
map (\Data era
x -> (forall era. Data era -> DataHash
hashData Data era
x, Data era
x)) [Data era]
scs
genAddrWith ::
Proof era ->
Network ->
Set (Credential 'Payment) ->
Set Ptr ->
Set (Credential 'Staking) ->
Map (KeyHash 'Payment) (Addr, Byron.SigningKey) ->
Gen Addr
genAddrWith :: forall era.
Proof era
-> Network
-> Set PaymentCredential
-> Set Ptr
-> Set (Credential 'Staking)
-> Map (KeyHash 'Payment) (Addr, SigningKey)
-> Gen Addr
genAddrWith Proof era
proof Network
net Set PaymentCredential
ps Set Ptr
ptrss Set (Credential 'Staking)
cs Map (KeyHash 'Payment) (Addr, SigningKey)
byronMap =
case forall era. Proof era -> TxOutWit era
whichTxOut Proof era
proof of
TxOutWit era
TxOutBabbageToConway -> Network -> PaymentCredential -> StakeReference -> Addr
Addr Network
net forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall t. [String] -> Set t -> Gen t
pick1 [String
"from genPayCred ScriptHashObj"] Set PaymentCredential
ps forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall era.
Proof era
-> Set Ptr -> Set (Credential 'Staking) -> Gen StakeReference
genStakeRefWith Proof era
proof Set Ptr
ptrss Set (Credential 'Staking)
cs
TxOutWit era
_ ->
forall a. HasCallStack => [(Int, Gen a)] -> Gen a
frequency
[ (Int
8, Network -> PaymentCredential -> StakeReference -> Addr
Addr Network
net forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall t. [String] -> Set t -> Gen t
pick1 [String
"from genPayCred ScriptHashObj"] Set PaymentCredential
ps forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall era.
Proof era
-> Set Ptr -> Set (Credential 'Staking) -> Gen StakeReference
genStakeRefWith Proof era
proof Set Ptr
ptrss Set (Credential 'Staking)
cs)
, (Int
2, forall a b. (a, b) -> a
fst forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a, b) -> b
snd forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall k a. [String] -> Map k a -> Gen (k, a)
genFromMap [String
"from byronAddrUniv"] Map (KeyHash 'Payment) (Addr, SigningKey)
byronMap)
]
genPtr :: SlotNo -> Gen Ptr
genPtr :: SlotNo -> Gen Ptr
genPtr (SlotNo Word64
n) =
SlotNo32 -> TxIx -> CertIx -> Ptr
Ptr
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (Word32 -> SlotNo32
SlotNo32 forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall a. Random a => (a, a) -> Gen a
choose (Word32
0, forall a b. (Integral a, Num b) => a -> b
fromIntegral Word64
n))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> (Word16 -> TxIx
TxIx forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall a. Random a => (a, a) -> Gen a
choose (Word16
0, Word16
10))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> (HasCallStack => Integer -> CertIx
mkCertIxPartial forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall a. Random a => (a, a) -> Gen a
choose (Integer
1, Integer
20))
genStakeRefWith ::
forall era.
Proof era ->
Set Ptr ->
Set (Credential 'Staking) ->
Gen StakeReference
genStakeRefWith :: forall era.
Proof era
-> Set Ptr -> Set (Credential 'Staking) -> Gen StakeReference
genStakeRefWith Proof era
proof Set Ptr
ps Set (Credential 'Staking)
cs =
forall a. HasCallStack => [(Int, Gen a)] -> Gen a
frequency
[ (Int
80, Credential 'Staking -> StakeReference
StakeRefBase forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall t. [String] -> Set t -> Gen t
pick1 [String
"from genStakeRefWith StakeRefBase"] Set (Credential 'Staking)
cs)
,
( if forall era. Proof era -> ProtVer
protocolVersion Proof era
proof forall a. Ord a => a -> a -> Bool
>= forall era. Proof era -> ProtVer
protocolVersion Proof ConwayEra
Conway then Int
0 else Int
5
, Ptr -> StakeReference
StakeRefPtr forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall t. [String] -> Set t -> Gen t
pick1 [String
"from genStakeRefWith StakeRefPtr"] Set Ptr
ps
)
, (Int
15, forall (f :: * -> *) a. Applicative f => a -> f a
pure StakeReference
StakeRefNull)
]
noScripts :: Proof era -> Addr -> Bool
noScripts :: forall era. Proof era -> Addr -> Bool
noScripts Proof era
_ (Addr Network
_ (ScriptHashObj ScriptHash
_) StakeReference
_) = Bool
False
noScripts Proof era
_ (Addr Network
_ PaymentCredential
_ (StakeRefBase (ScriptHashObj ScriptHash
_))) = Bool
False
noScripts Proof era
_ (AddrBootstrap BootstrapAddress
_) = Bool
False
noScripts Proof era
_ Addr
_ = Bool
True
genDReps :: Set (Credential 'Staking) -> Gen [DRep]
genDReps :: Set (Credential 'Staking) -> Gen [DRep]
genDReps Set (Credential 'Staking)
creds =
forall a. [a] -> Gen [a]
shuffle
( forall a b. (a -> b) -> [a] -> [b]
map (Credential 'DRepRole -> DRep
DRepCredential forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (a :: KeyRole -> *) (r :: KeyRole) (r' :: KeyRole).
HasKeyRole a =>
a r -> a r'
coerceKeyRole) (forall a. Set a -> [a]
Set.toList Set (Credential 'Staking)
creds)
forall a. [a] -> [a] -> [a]
++ [DRep
DRepAlwaysAbstain, DRep
DRepAlwaysNoConfidence]
)
genDRepsT ::
UnivSize ->
Term era (Set (Credential 'Staking)) ->
Target era (Gen (Set DRep))
genDRepsT :: forall era.
UnivSize
-> Term era (Set (Credential 'Staking))
-> Target era (Gen (Set DRep))
genDRepsT UnivSize
sizes Term era (Set (Credential 'Staking))
creds = forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"listToSet" (\Set (Credential 'Staking)
cs -> (forall a. Ord a => [a] -> Set a
Set.fromList forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. Int -> [a] -> [a]
take (UnivSize -> Int
usNumDReps UnivSize
sizes)) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Set (Credential 'Staking) -> Gen [DRep]
genDReps Set (Credential 'Staking)
cs) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Set (Credential 'Staking))
creds
txOutT :: Reflect era => Proof era -> Addr -> Coin -> TxOutF era
txOutT :: forall era. Reflect era => Proof era -> Addr -> Coin -> TxOutF era
txOutT Proof era
p Addr
x Coin
c = forall era. Proof era -> TxOut era -> TxOutF era
TxOutF Proof era
p (forall era.
(EraTxOut era, HasCallStack) =>
Addr -> Value era -> TxOut era
mkBasicTxOut Addr
x (forall t s. Inject t s => t -> s
inject Coin
c))
colTxOutT :: EraTxOut era => Proof era -> Set Addr -> Gen (TxOutF era)
colTxOutT :: forall era.
EraTxOut era =>
Proof era -> Set Addr -> Gen (TxOutF era)
colTxOutT Proof era
p Set Addr
noScriptAddr =
forall era. Proof era -> TxOut era -> TxOutF era
TxOutF Proof era
p
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (forall era.
(EraTxOut era, HasCallStack) =>
Addr -> Value era -> TxOut era
mkBasicTxOut forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall t. [String] -> Set t -> Gen t
pick1 [String
"from colTxOutT noScriptAddr"] Set Addr
noScriptAddr forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> (forall t s. Inject t s => t -> s
inject forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Gen Coin
noZeroCoin))
colTxOutSetT :: EraTxOut era => Proof era -> Set Addr -> Gen (Set (TxOutF era))
colTxOutSetT :: forall era.
EraTxOut era =>
Proof era -> Set Addr -> Gen (Set (TxOutF era))
colTxOutSetT Proof era
p Set Addr
noScriptAddr = forall a b. (a -> b -> a) -> a -> Set b -> a
Set.foldl' Gen (Set (TxOutF era)) -> Addr -> Gen (Set (TxOutF era))
accum (forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a. Set a
Set.empty) Set Addr
noScriptAddr
where
accum :: Gen (Set (TxOutF era)) -> Addr -> Gen (Set (TxOutF era))
accum Gen (Set (TxOutF era))
ansM Addr
addr = do
Coin
c <- Gen Coin
noZeroCoin
forall a. Ord a => a -> Set a -> Set a
Set.insert (forall era. Proof era -> TxOut era -> TxOutF era
TxOutF Proof era
p (forall era.
(EraTxOut era, HasCallStack) =>
Addr -> Value era -> TxOut era
mkBasicTxOut Addr
addr (forall t s. Inject t s => t -> s
inject Coin
c))) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Gen (Set (TxOutF era))
ansM
scriptHashObjT :: Term era ScriptHash -> Target era (Credential k)
scriptHashObjT :: forall era (k :: KeyRole).
Term era ScriptHash -> Target era (Credential k)
scriptHashObjT Term era ScriptHash
x = forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"ScriptHashObj" forall (kr :: KeyRole). ScriptHash -> Credential kr
ScriptHashObj forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era ScriptHash
x
keyHashObjT ::
Term era (KeyHash 'Witness) -> Target era (Credential k)
keyHashObjT :: forall era (k :: KeyRole).
Term era (KeyHash 'Witness) -> Target era (Credential k)
keyHashObjT Term era (KeyHash 'Witness)
x = forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"KeyHashObj" (forall (kr :: KeyRole). KeyHash kr -> Credential kr
KeyHashObj forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (a :: KeyRole -> *) (r :: KeyRole) (r' :: KeyRole).
HasKeyRole a =>
a r -> a r'
coerceKeyRole) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (KeyHash 'Witness)
x
makeValidityT ::
Term era SlotNo -> Term era SlotNo -> Term era SlotNo -> Target era ValidityInterval
makeValidityT :: forall era.
Term era SlotNo
-> Term era SlotNo
-> Term era SlotNo
-> Target era ValidityInterval
makeValidityT Term era SlotNo
begin Term era SlotNo
current Term era SlotNo
end =
forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr
String
"(-i)x(+j)"
(\SlotNo
beginD SlotNo
x SlotNo
endD -> StrictMaybe SlotNo -> StrictMaybe SlotNo -> ValidityInterval
ValidityInterval (forall a. a -> StrictMaybe a
SJust (SlotNo
x forall a. Num a => a -> a -> a
- SlotNo
beginD)) (forall a. a -> StrictMaybe a
SJust (SlotNo
x forall a. Num a => a -> a -> a
+ SlotNo
endD)))
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era SlotNo
begin
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era SlotNo
current
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era SlotNo
end
ptrUnivT :: Int -> Term era SlotNo -> Target era (Gen (Set Ptr))
ptrUnivT :: forall era. Int -> Term era SlotNo -> Target era (Gen (Set Ptr))
ptrUnivT Int
nptrs Term era SlotNo
x = forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"" (forall a. Ord a => [String] -> Int -> Gen a -> Gen (Set a)
setSized [String
"From init ptruniv"] Int
nptrs) forall era root a t.
RootTarget era root (a -> t)
-> RootTarget era root a -> RootTarget era root t
:$ (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"" SlotNo -> Gen Ptr
genPtr forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era SlotNo
x)
addrUnivT ::
Proof era ->
Int ->
Term era Network ->
Term era (Set (Credential 'Payment)) ->
Term era (Set Ptr) ->
Term era (Set (Credential 'Staking)) ->
Term era (Map (KeyHash 'Payment) (Addr, Byron.SigningKey)) ->
Target era (Gen (Set Addr))
addrUnivT :: forall era.
Proof era
-> Int
-> Term era Network
-> Term era (Set PaymentCredential)
-> Term era (Set Ptr)
-> Term era (Set (Credential 'Staking))
-> Term era (Map (KeyHash 'Payment) (Addr, SigningKey))
-> Target era (Gen (Set Addr))
addrUnivT Proof era
p Int
naddr Term era Network
net Term era (Set PaymentCredential)
ps Term era (Set Ptr)
pts Term era (Set (Credential 'Staking))
cs Term era (Map (KeyHash 'Payment) (Addr, SigningKey))
byronAddrUnivT =
forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"" (forall a. Ord a => [String] -> Int -> Gen a -> Gen (Set a)
setSized [String
"From addrUnivT"] Int
naddr)
forall era root a t.
RootTarget era root (a -> t)
-> RootTarget era root a -> RootTarget era root t
:$ (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"genAddrWith" (forall era.
Proof era
-> Network
-> Set PaymentCredential
-> Set Ptr
-> Set (Credential 'Staking)
-> Map (KeyHash 'Payment) (Addr, SigningKey)
-> Gen Addr
genAddrWith Proof era
p) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era Network
net forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Set PaymentCredential)
ps forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Set Ptr)
pts forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Set (Credential 'Staking))
cs forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Map (KeyHash 'Payment) (Addr, SigningKey))
byronAddrUnivT)
makeHashScriptMapT ::
Proof era ->
Int ->
PlutusPurposeTag ->
Term era (Map (KeyHash 'Witness) (KeyPair 'Witness)) ->
Term era ValidityInterval ->
Target era (Gen (Map ScriptHash (ScriptF era)))
makeHashScriptMapT :: forall era.
Proof era
-> Int
-> PlutusPurposeTag
-> Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
-> Term era ValidityInterval
-> Target era (Gen (Map ScriptHash (ScriptF era)))
makeHashScriptMapT Proof era
p Int
size PlutusPurposeTag
tag Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
m Term era ValidityInterval
vi =
forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr
String
"makeHashScriptMap"
(forall era a. (Reflect era => Proof era -> a) -> Proof era -> a
unReflect forall era.
Reflect era =>
Proof era
-> Int
-> PlutusPurposeTag
-> Map (KeyHash 'Witness) (KeyPair 'Witness)
-> ValidityInterval
-> Gen (Map ScriptHash (ScriptF era))
makeHashScriptMap Proof era
p Int
size PlutusPurposeTag
tag)
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
m
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era ValidityInterval
vi
cast :: forall k. Set (KeyHash 'Witness) -> Set (KeyHash k)
cast :: forall (k :: KeyRole). Set (KeyHash 'Witness) -> Set (KeyHash k)
cast Set (KeyHash 'Witness)
x = forall b a. Ord b => (a -> b) -> Set a -> Set b
Set.map (\KeyHash 'Witness
kh -> forall (a :: KeyRole -> *) (r :: KeyRole) (r' :: KeyRole).
HasKeyRole a =>
a r -> a r'
coerceKeyRole @KeyHash @'Witness KeyHash 'Witness
kh) Set (KeyHash 'Witness)
x
castCredCold :: Set (KeyHash 'Witness) -> Set (Credential 'ColdCommitteeRole)
castCredCold :: Set (KeyHash 'Witness) -> Set (Credential 'ColdCommitteeRole)
castCredCold = forall b a. Ord b => (a -> b) -> Set a -> Set b
Set.map (forall (a :: KeyRole -> *) (r :: KeyRole) (r' :: KeyRole).
HasKeyRole a =>
a r -> a r'
coerceKeyRole forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (kr :: KeyRole). KeyHash kr -> Credential kr
KeyHashObj)
castCredHot :: Set (KeyHash 'Witness) -> Set (Credential 'HotCommitteeRole)
castCredHot :: Set (KeyHash 'Witness) -> Set (Credential 'HotCommitteeRole)
castCredHot = forall b a. Ord b => (a -> b) -> Set a -> Set b
Set.map (forall (a :: KeyRole -> *) (r :: KeyRole) (r' :: KeyRole).
HasKeyRole a =>
a r -> a r'
coerceKeyRole forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (kr :: KeyRole). KeyHash kr -> Credential kr
KeyHashObj)
txinToGovactionId :: TxIn -> GovActionId
txinToGovactionId :: TxIn -> GovActionId
txinToGovactionId (TxIn TxId
idx (TxIx Word16
n)) = TxId -> GovActionIx -> GovActionId
GovActionId TxId
idx (Word16 -> GovActionIx
GovActionIx (forall a b. (Integral a, Num b) => a -> b
fromIntegral Word16
n))
universePreds :: Reflect era => UnivSize -> Proof era -> [Pred era]
universePreds :: forall era. Reflect era => UnivSize -> Proof era -> [Pred era]
universePreds UnivSize
size Proof era
p =
[ forall t era. Sizeable t => Term era Size -> Term era t -> Pred era
Sized (forall era. Era era => Int -> Int -> Term era Size
Range Int
100 Int
500) forall era. Era era => Term era SlotNo
currentSlot
, forall t era. Sizeable t => Term era Size -> Term era t -> Pred era
Sized (forall era. Era era => Int -> Int -> Term era Size
Range Int
0 Int
30) forall era. Era era => Term era SlotNo
beginSlotDelta
, forall t era. Sizeable t => Term era Size -> Term era t -> Pred era
Sized (forall era. Era era => Int -> Int -> Term era Size
Range Int
900 Int
1000) forall era. Era era => Term era SlotNo
endSlotDelta
, forall t era. Sizeable t => Term era Size -> Term era t -> Pred era
Sized (forall era. Era era => Int -> Term era Size
ExactSize (UnivSize -> Int
usNumKeys UnivSize
size)) Term era [KeyPair 'Witness]
keypairs
, forall era.
Era era =>
Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
keymapUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"xx" (\[KeyPair 'Witness]
s -> forall k a. Ord k => [(k, a)] -> Map k a
Map.fromList (forall a b. (a -> b) -> [a] -> [b]
map (\KeyPair 'Witness
x -> (forall (kd :: KeyRole). VKey kd -> KeyHash kd
hashKey (forall (kd :: KeyRole). KeyPair kd -> VKey kd
vKey KeyPair 'Witness
x), KeyPair 'Witness
x)) [KeyPair 'Witness]
s)) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era [KeyPair 'Witness]
keypairs)
, forall t era. Sizeable t => Term era Size -> Term era t -> Pred era
Sized (forall era. Era era => Int -> Term era Size
ExactSize (UnivSize -> Int
usNumPools UnivSize
size)) Term era (Set (KeyHash 'Witness))
prePoolUniv
, forall a era.
Ord a =>
Term era (Set a) -> Term era (Set a) -> Pred era
Subset Term era (Set (KeyHash 'Witness))
prePoolUniv (forall a era b. Ord a => Term era (Map a b) -> Term era (Set a)
Dom forall era.
Era era =>
Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
keymapUniv)
, forall era. Era era => Term era (Set (KeyHash 'StakePool))
poolHashUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"WitnessToStakePool" forall (k :: KeyRole). Set (KeyHash 'Witness) -> Set (KeyHash k)
cast forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Set (KeyHash 'Witness))
prePoolUniv)
, forall t era. Sizeable t => Term era Size -> Term era t -> Pred era
Sized (forall era. Era era => Int -> Term era Size
ExactSize (UnivSize -> Int
usNumStakeKeys UnivSize
size)) Term era (Set (KeyHash 'Witness))
preStakeUniv
, forall a era.
Ord a =>
Term era (Set a) -> Term era (Set a) -> Pred era
Subset Term era (Set (KeyHash 'Witness))
preStakeUniv (forall a era b. Ord a => Term era (Map a b) -> Term era (Set a)
Dom forall era.
Era era =>
Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
keymapUniv)
, forall era. Era era => Term era (Set (KeyHash 'Staking))
stakeHashUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"WitnessToStaking" forall (k :: KeyRole). Set (KeyHash 'Witness) -> Set (KeyHash k)
cast forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Set (KeyHash 'Witness))
preStakeUniv)
, forall era. Era era => Term era (Set (KeyHash 'DRepRole))
drepHashUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"WitnessToDRepRole" forall (k :: KeyRole). Set (KeyHash 'Witness) -> Set (KeyHash k)
cast forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Set (KeyHash 'Witness))
preStakeUniv)
, forall t era. Sizeable t => Term era Size -> Term era t -> Pred era
Sized (forall era. Era era => Int -> Term era Size
ExactSize (UnivSize -> Int
usNumGenesisKeys UnivSize
size)) Term era (Set (KeyHash 'Witness))
preGenesisUniv
, forall a era.
Ord a =>
Term era (Set a) -> Term era (Set a) -> Pred era
Subset Term era (Set (KeyHash 'Witness))
preGenesisUniv (forall a era b. Ord a => Term era (Map a b) -> Term era (Set a)
Dom forall era.
Era era =>
Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
keymapUniv)
, Term era (Set (KeyHash 'Genesis))
preGenesisDom forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"WitnessToGenesis" forall (k :: KeyRole). Set (KeyHash 'Witness) -> Set (KeyHash k)
cast forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Set (KeyHash 'Witness))
preGenesisUniv)
, Term era (Set (KeyHash 'Genesis))
preGenesisDom forall a era. Eq a => Term era a -> Term era a -> Pred era
:=: (forall a era b. Ord a => Term era (Map a b) -> Term era (Set a)
Dom forall era.
Era era =>
Term era (Map (KeyHash 'Genesis) GenDelegPair)
genesisHashUniv)
, forall t era. Sizeable t => Term era Size -> Term era t -> Pred era
Sized (forall era. Era era => Int -> Term era Size
ExactSize (UnivSize -> Int
usNumVoteKeys UnivSize
size)) Term era (Set (KeyHash 'Witness))
preVoteUniv
, forall a era.
Ord a =>
Term era (Set a) -> Term era (Set a) -> Pred era
Subset Term era (Set (KeyHash 'Witness))
preVoteUniv (forall a era b. Ord a => Term era (Map a b) -> Term era (Set a)
Dom forall era.
Era era =>
Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
keymapUniv)
, forall era.
Era era =>
Term era (Set (Credential 'ColdCommitteeRole))
voteCredUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"WitnessToStakePool" Set (KeyHash 'Witness) -> Set (Credential 'ColdCommitteeRole)
castCredCold forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era (Set (KeyHash 'Witness))
preVoteUniv)
, forall t era. Sizeable t => Term era Size -> Term era t -> Pred era
Sized (forall era. Era era => Int -> Term era Size
ExactSize (UnivSize -> Int
usNumTxIn UnivSize
size)) forall era. Era era => Term era (Set TxIn)
txinUniv
, forall a era.
Ord a =>
Direct (Term era a) -> Term era (Set a) -> Pred era
Member (forall a b. b -> Either a b
Right forall era. Era era => Term era TxIn
feeTxIn) forall era. Era era => Term era (Set TxIn)
txinUniv
, forall era. Era era => Term era (Set GovActionId)
govActionIdUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"TxIn-to-GovActionId" (forall b a. Ord b => (a -> b) -> Set a -> Set b
Set.map TxIn -> GovActionId
txinToGovactionId) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era (Set TxIn)
txinUniv)
, forall era. Era era => Term era ValidityInterval
validityInterval forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: forall era.
Term era SlotNo
-> Term era SlotNo
-> Term era SlotNo
-> Target era ValidityInterval
makeValidityT forall era. Era era => Term era SlotNo
beginSlotDelta forall era. Era era => Term era SlotNo
currentSlot forall era. Era era => Term era SlotNo
endSlotDelta
, forall era t.
(Era era, Eq t) =>
Term era Size
-> Term era [t] -> [(Int, Target era t, [Pred era])] -> Pred era
Choose
(forall era. Era era => Int -> Term era Size
ExactSize (UnivSize -> Int
usNumCredentials UnivSize
size))
Term era [Credential 'Staking]
credList
[
( UnivSize -> Int
usCredScriptFreq UnivSize
size
, forall era (k :: KeyRole).
Term era ScriptHash -> Target era (Credential k)
scriptHashObjT Term era ScriptHash
scripthash
, [forall a era.
Ord a =>
Direct (Term era a) -> Term era (Set a) -> Pred era
Member (forall a b. a -> Either a b
Left Term era ScriptHash
scripthash) (forall a era b. Ord a => Term era (Map a b) -> Term era (Set a)
Dom (forall era.
Era era =>
Proof era -> Term era (Map ScriptHash (ScriptF era))
nonSpendScriptUniv Proof era
p))]
)
, (Int
1, forall era (k :: KeyRole).
Term era (KeyHash 'Witness) -> Target era (Credential k)
keyHashObjT Term era (KeyHash 'Witness)
keyhash, [forall a era.
Ord a =>
Direct (Term era a) -> Term era (Set a) -> Pred era
Member (forall a b. a -> Either a b
Left Term era (KeyHash 'Witness)
keyhash) (forall a era b. Ord a => Term era (Map a b) -> Term era (Set a)
Dom forall era.
Era era =>
Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
keymapUniv)])
]
, forall era. Era era => Term era (Set (Credential 'Staking))
credsUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: forall x era. Ord x => Term era [x] -> Target era (Set x)
listToSetTarget Term era [Credential 'Staking]
credList
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom (forall era.
Era era =>
Proof era -> Term era (Map ScriptHash (ScriptF era))
spendscriptUniv Proof era
p) (forall era.
Proof era
-> Int
-> PlutusPurposeTag
-> Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
-> Term era ValidityInterval
-> Target era (Gen (Map ScriptHash (ScriptF era)))
makeHashScriptMapT Proof era
p Int
25 PlutusPurposeTag
Spending forall era.
Era era =>
Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
keymapUniv forall era. Era era => Term era ValidityInterval
validityInterval)
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom (forall era.
Era era =>
Proof era -> Term era (Map ScriptHash (ScriptF era))
nonSpendScriptUniv Proof era
p) (forall era.
Proof era
-> Int
-> PlutusPurposeTag
-> Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
-> Term era ValidityInterval
-> Target era (Gen (Map ScriptHash (ScriptF era)))
makeHashScriptMapT Proof era
p Int
25 PlutusPurposeTag
Certifying forall era.
Era era =>
Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
keymapUniv forall era. Era era => Term era ValidityInterval
validityInterval)
, forall era.
Era era =>
Proof era -> Term era (Map ScriptHash (ScriptF era))
allScriptUniv Proof era
p forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"union" forall k a. Ord k => Map k a -> Map k a -> Map k a
Map.union forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ (forall era.
Era era =>
Proof era -> Term era (Map ScriptHash (ScriptF era))
spendscriptUniv Proof era
p) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ (forall era.
Era era =>
Proof era -> Term era (Map ScriptHash (ScriptF era))
nonSpendScriptUniv Proof era
p))
, forall era t.
(Era era, Eq t) =>
Term era Size
-> Term era [t] -> [(Int, Target era t, [Pred era])] -> Pred era
Choose
(forall era. Era era => Int -> Term era Size
ExactSize Int
70)
Term era [PaymentCredential]
spendcredList
[
( UnivSize -> Int
usSpendScriptFreq UnivSize
size
, forall era (k :: KeyRole).
Term era ScriptHash -> Target era (Credential k)
scriptHashObjT Term era ScriptHash
scripthash
, [forall a era.
Ord a =>
Direct (Term era a) -> Term era (Set a) -> Pred era
Member (forall a b. a -> Either a b
Left Term era ScriptHash
scripthash) (forall a era b. Ord a => Term era (Map a b) -> Term era (Set a)
Dom (forall era.
Era era =>
Proof era -> Term era (Map ScriptHash (ScriptF era))
spendscriptUniv Proof era
p))]
)
, (Int
2, forall era (k :: KeyRole).
Term era (KeyHash 'Witness) -> Target era (Credential k)
keyHashObjT Term era (KeyHash 'Witness)
keyhash, [forall a era.
Ord a =>
Direct (Term era a) -> Term era (Set a) -> Pred era
Member (forall a b. a -> Either a b
Left Term era (KeyHash 'Witness)
keyhash) (forall a era b. Ord a => Term era (Map a b) -> Term era (Set a)
Dom forall era.
Era era =>
Term era (Map (KeyHash 'Witness) (KeyPair 'Witness))
keymapUniv)])
]
, forall era. Era era => Term era (Set PaymentCredential)
spendCredsUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: forall x era. Ord x => Term era [x] -> Target era (Set x)
listToSetTarget Term era [PaymentCredential]
spendcredList
, forall era. Era era => Term era EpochNo
currentEpoch forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"epochFromSlotNo" SlotNo -> EpochNo
epochFromSlotNo forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era SlotNo
currentSlot)
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom forall era. Era era => Term era (Map DataHash (Data era))
dataUniv (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"dataWits" (forall era.
Era era =>
Proof era -> Int -> Gen (Map DataHash (Data era))
genDataWits Proof era
p) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ (forall era t. Rep era t -> t -> Term era t
Lit forall era. Rep era Int
IntR Int
30))
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom forall era. Era era => Term era [Datum era]
datumsUniv (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"genDatums" (forall era.
Era era =>
UnivSize -> Int -> Map DataHash (Data era) -> Gen [Datum era]
genDatums UnivSize
size (UnivSize -> Int
usNumDatums UnivSize
size)) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era (Map DataHash (Data era))
dataUniv)
,
forall era. Era era => Term era Network
network forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: forall t era. t -> Target era t
constTarget (Globals -> Network
Utils.networkId Globals
Utils.testGlobals)
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom forall era. Era era => Term era (Set Ptr)
ptrUniv (forall era. Int -> Term era SlotNo -> Target era (Gen (Set Ptr))
ptrUnivT (UnivSize -> Int
usNumPtr UnivSize
size) forall era. Era era => Term era SlotNo
currentSlot)
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom forall era.
Era era =>
Term era (Map (KeyHash 'Payment) (Addr, SigningKey))
byronAddrUniv (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"byronUniv" Network -> Gen (Map (KeyHash 'Payment) (Addr, SigningKey))
genByronUniv forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era Network
network)
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom
forall era. Era era => Term era (Set Addr)
addrUniv
(forall era.
Proof era
-> Int
-> Term era Network
-> Term era (Set PaymentCredential)
-> Term era (Set Ptr)
-> Term era (Set (Credential 'Staking))
-> Term era (Map (KeyHash 'Payment) (Addr, SigningKey))
-> Target era (Gen (Set Addr))
addrUnivT Proof era
p (UnivSize -> Int
usNumAddr UnivSize
size) forall era. Era era => Term era Network
network forall era. Era era => Term era (Set PaymentCredential)
spendCredsUniv forall era. Era era => Term era (Set Ptr)
ptrUniv forall era. Era era => Term era (Set (Credential 'Staking))
credsUniv forall era.
Era era =>
Term era (Map (KeyHash 'Payment) (Addr, SigningKey))
byronAddrUniv)
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom
forall era. Era era => Term era [MultiAsset]
multiAssetUniv
(forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"multiAsset" (forall a. Int -> Gen a -> Gen [a]
vectorOf (UnivSize -> Int
usNumMultiAsset UnivSize
size) forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall era.
UnivSize -> Map ScriptHash (ScriptF era) -> Gen MultiAsset
multiAsset UnivSize
size) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ (forall era.
Era era =>
Proof era -> Term era (Map ScriptHash (ScriptF era))
nonSpendScriptUniv Proof era
p))
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom
Term era [TxOutF era]
preTxoutUniv
( forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"genTxOuts" (forall era.
Reflect era =>
UnivSize
-> (Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era))
-> Proof era
-> Int
-> Set Addr
-> Map ScriptHash (ScriptF era)
-> Map ScriptHash (ScriptF era)
-> Map DataHash (Data era)
-> Gen [TxOutF era]
genTxOuts UnivSize
size (forall era.
UnivSize
-> Proof era
-> Coin
-> Map ScriptHash (ScriptF era)
-> Gen (Value era)
genValueF UnivSize
size Proof era
p) Proof era
p (UnivSize -> Int
usNumTxOuts UnivSize
size))
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era (Set Addr)
addrUniv
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ (forall era.
Era era =>
Proof era -> Term era (Map ScriptHash (ScriptF era))
nonSpendScriptUniv Proof era
p)
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ (forall era.
Era era =>
Proof era -> Term era (Map ScriptHash (ScriptF era))
spendscriptUniv Proof era
p)
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era (Map DataHash (Data era))
dataUniv
)
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom
(forall era. Era era => Proof era -> Term era (Set (TxOutF era))
colTxoutUniv Proof era
p)
( forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr
String
"colTxOutUniv"
(\Set Addr
x -> forall era.
EraTxOut era =>
Proof era -> Set Addr -> Gen (Set (TxOutF era))
colTxOutSetT Proof era
p (forall a. (a -> Bool) -> Set a -> Set a
Set.filter (forall era. Proof era -> Addr -> Bool
noScripts Proof era
p) Set Addr
x))
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era (Set Addr)
addrUniv
)
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom forall era. Era era => Term era (Set DRep)
drepUniv (forall era.
UnivSize
-> Term era (Set (Credential 'Staking))
-> Target era (Gen (Set DRep))
genDRepsT UnivSize
size forall era. Era era => Term era (Set (Credential 'Staking))
credsUniv)
, forall era. Era era => Term era (Set PaymentCredential)
payUniv forall a era. Eq a => Term era a -> Term era a -> Pred era
:=: forall era. Era era => Term era (Set PaymentCredential)
spendCredsUniv
, forall era. Era era => Term era (Set (Credential 'DRepRole))
voteUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"coerce" (forall b a. Ord b => (a -> b) -> Set a -> Set b
Set.map Credential 'Staking -> Credential 'DRepRole
stakeToDRepRole) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era (Set (Credential 'Staking))
credsUniv)
, forall era.
Era era =>
Term era (Set (Credential 'HotCommitteeRole))
hotCommitteeCredsUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"coerce" (forall b a. Ord b => (a -> b) -> Set a -> Set b
Set.map Credential 'Staking -> Credential 'HotCommitteeRole
stakeToHotCommittee) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era (Set (Credential 'Staking))
credsUniv)
, forall era.
Era era =>
Term era (Set (Credential 'ColdCommitteeRole))
coldCommitteeCredsUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: (forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr String
"coerce" (forall b a. Ord b => (a -> b) -> Set a -> Set b
Set.map Credential 'Staking -> Credential 'ColdCommitteeRole
stakeToColdCommittee) forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era (Set (Credential 'Staking))
credsUniv)
, forall era. Era era => Term era Coin
bigCoin forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: forall t era. t -> Target era t
constTarget (Integer -> Coin
Coin Integer
2000000)
, forall era t r. Term era t -> RootTarget era r (Gen t) -> Pred era
GenFrom
forall era. Reflect era => Term era (TxOutF era)
feeTxOut
( forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr
String
"txout"
( \Set Addr
a Coin
c ->
forall era. Reflect era => Proof era -> Addr -> Coin -> TxOutF era
txOutT Proof era
p
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall t. [String] -> Set t -> Gen t
pick1 [String
"from feeTxOut on (filter nocripts addrUniv)"] (forall a. (a -> Bool) -> Set a -> Set a
Set.filter (forall era. Proof era -> Addr -> Bool
noScripts Proof era
p) Set Addr
a)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall (f :: * -> *) a. Applicative f => a -> f a
pure Coin
c
)
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era (Set Addr)
addrUniv
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Era era => Term era Coin
bigCoin
)
, forall era. Era era => Proof era -> Term era (Set (TxOutF era))
txoutUniv Proof era
p
forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: ( forall a b era. String -> (a -> b) -> RootTarget era Void (a -> b)
Constr
String
"insert"
(\TxOutF era
x [TxOutF era]
y Set (TxOutF era)
_z -> forall a. Ord a => a -> Set a -> Set a
Set.insert TxOutF era
x (forall a. Ord a => [a] -> Set a
Set.fromList [TxOutF era]
y))
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ forall era. Reflect era => Term era (TxOutF era)
feeTxOut
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ Term era [TxOutF era]
preTxoutUniv
forall era a t. Target era (a -> t) -> Term era a -> Target era t
^$ (forall era. Era era => Proof era -> Term era (Set (TxOutF era))
colTxoutUniv Proof era
p)
)
, forall era.
Reflect era =>
Term era (Map ScriptHash (IsValid, ScriptF era))
plutusUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: forall t era. t -> Target era t
constTarget (forall a b k. (a -> b) -> Map k a -> Map k b
Map.map (\(IsValid
x, Script era
y) -> (IsValid
x, forall era. Proof era -> Script era -> ScriptF era
ScriptF Proof era
p Script era
y)) (forall era.
Reflect era =>
Proof era -> Map ScriptHash (IsValid, Script era)
allPlutusScripts Proof era
p))
, forall era.
Reflect era =>
Term era (Map ScriptHash (IsValid, ScriptF era))
spendPlutusUniv forall era t r. Term era t -> RootTarget era r t -> Pred era
:<-: forall t era. t -> Target era t
constTarget (forall a b k. (a -> b) -> Map k a -> Map k b
Map.map (\(IsValid
x, Script era
y) -> (IsValid
x, forall era. Proof era -> Script era -> ScriptF era
ScriptF Proof era
p Script era
y)) (forall era.
Reflect era =>
Proof era -> Map ScriptHash (IsValid, Script era)
spendPlutusScripts Proof era
p))
]
where
credList :: Term era [Credential 'Staking]
credList = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"credList" (forall era a. Rep era a -> Rep era [a]
ListR forall era. Era era => Rep era (Credential 'Staking)
CredR) forall era s t. Access era s t
No)
spendcredList :: Term era [PaymentCredential]
spendcredList = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"spendcred.list" (forall era a. Rep era a -> Rep era [a]
ListR forall era. Era era => Rep era PaymentCredential
PCredR) forall era s t. Access era s t
No)
keyhash :: Term era (KeyHash 'Witness)
keyhash = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"keyhash" forall era. Era era => Rep era (KeyHash 'Witness)
WitHashR forall era s t. Access era s t
No)
scripthash :: Term era ScriptHash
scripthash = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"scripthash" forall era. Era era => Rep era ScriptHash
ScriptHashR forall era s t. Access era s t
No)
preTxoutUniv :: Term era [TxOutF era]
preTxoutUniv = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"preTxoutUniv" (forall era a. Rep era a -> Rep era [a]
ListR (forall era. Era era => Proof era -> Rep era (TxOutF era)
TxOutR Proof era
p)) forall era s t. Access era s t
No)
keypairs :: Term era [KeyPair 'Witness]
keypairs = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"keypairs" (forall era a. Rep era a -> Rep era [a]
ListR forall era. Era era => Rep era (KeyPair 'Witness)
KeyPairR) forall era s t. Access era s t
No)
prePoolUniv :: Term era (Set (KeyHash 'Witness))
prePoolUniv = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"prePoolUniv" (forall a era. Ord a => Rep era a -> Rep era (Set a)
SetR forall era. Era era => Rep era (KeyHash 'Witness)
WitHashR) forall era s t. Access era s t
No)
preStakeUniv :: Term era (Set (KeyHash 'Witness))
preStakeUniv = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"preStakeUniv" (forall a era. Ord a => Rep era a -> Rep era (Set a)
SetR forall era. Era era => Rep era (KeyHash 'Witness)
WitHashR) forall era s t. Access era s t
No)
preGenesisUniv :: Term era (Set (KeyHash 'Witness))
preGenesisUniv = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"preGenesisUniv" (forall a era. Ord a => Rep era a -> Rep era (Set a)
SetR forall era. Era era => Rep era (KeyHash 'Witness)
WitHashR) forall era s t. Access era s t
No)
preGenesisDom :: Term era (Set (KeyHash 'Genesis))
preGenesisDom = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"preGenesisDom" (forall a era. Ord a => Rep era a -> Rep era (Set a)
SetR forall era. Era era => Rep era (KeyHash 'Genesis)
GenHashR) forall era s t. Access era s t
No)
preVoteUniv :: Term era (Set (KeyHash 'Witness))
preVoteUniv = forall era t. V era t -> Term era t
Var (forall era t s.
Era era =>
String -> Rep era t -> Access era s t -> V era t
V String
"preVoteUniv" (forall a era. Ord a => Rep era a -> Rep era (Set a)
SetR forall era. Era era => Rep era (KeyHash 'Witness)
WitHashR) forall era s t. Access era s t
No)
multiAsset :: UnivSize -> Map.Map ScriptHash (ScriptF era) -> Gen MultiAsset
multiAsset :: forall era.
UnivSize -> Map ScriptHash (ScriptF era) -> Gen MultiAsset
multiAsset UnivSize
size Map ScriptHash (ScriptF era)
scripts = do
let assets :: Set AssetName
assets =
forall a. Ord a => [a] -> Set a
Set.fromList [ShortByteString -> AssetName
AssetName (forall a. IsString a => String -> a
fromString (forall a. Show a => a -> String
show (Int
n :: Int) forall a. [a] -> [a] -> [a]
++ String
"Asset")) | Int
n <- [Int
0 .. (UnivSize -> Int
usMaxAssets UnivSize
size)]]
Int
n <- forall a. HasCallStack => [a] -> Gen a
elements [Int
0 .. (UnivSize -> Int
usMaxPolicyID UnivSize
size)]
if Int
n forall a. Eq a => a -> a -> Bool
== Int
0
then forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a. Monoid a => a
mempty
else do
[(PolicyID, AssetName, Integer)]
xs <- forall a. Int -> Gen a -> Gen [a]
vectorOf Int
n (forall era.
Map ScriptHash (ScriptF era)
-> Set AssetName
-> Gen Integer
-> Gen (PolicyID, AssetName, Integer)
genMultiAssetTriple Map ScriptHash (ScriptF era)
scripts Set AssetName
assets (forall a. Random a => (a, a) -> Gen a
choose (Integer
1, Integer
100)))
forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ [(PolicyID, AssetName, Integer)] -> MultiAsset
multiAssetFromList [(PolicyID, AssetName, Integer)]
xs
genValueF :: UnivSize -> Proof era -> Coin -> Map ScriptHash (ScriptF era) -> Gen (Value era)
genValueF :: forall era.
UnivSize
-> Proof era
-> Coin
-> Map ScriptHash (ScriptF era)
-> Gen (Value era)
genValueF UnivSize
size Proof era
proof Coin
c Map ScriptHash (ScriptF era)
scripts = case forall era. Proof era -> ValueWit era
whichValue Proof era
proof of
ValueWit era
ValueShelleyToAllegra -> forall (f :: * -> *) a. Applicative f => a -> f a
pure Coin
c
ValueWit era
ValueMaryToConway -> Coin -> MultiAsset -> MaryValue
MaryValue Coin
c forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall era.
UnivSize -> Map ScriptHash (ScriptF era) -> Gen MultiAsset
multiAsset UnivSize
size Map ScriptHash (ScriptF era)
scripts
stakeToDRepRole :: Credential 'Staking -> Credential 'DRepRole
stakeToDRepRole :: Credential 'Staking -> Credential 'DRepRole
stakeToDRepRole = forall (a :: KeyRole -> *) (r :: KeyRole) (r' :: KeyRole).
HasKeyRole a =>
a r -> a r'
coerceKeyRole
stakeToHotCommittee :: Credential 'Staking -> Credential 'HotCommitteeRole
stakeToHotCommittee :: Credential 'Staking -> Credential 'HotCommitteeRole
stakeToHotCommittee = forall (a :: KeyRole -> *) (r :: KeyRole) (r' :: KeyRole).
HasKeyRole a =>
a r -> a r'
coerceKeyRole
stakeToColdCommittee :: Credential 'Staking -> Credential 'ColdCommitteeRole
stakeToColdCommittee :: Credential 'Staking -> Credential 'ColdCommitteeRole
stakeToColdCommittee = forall (a :: KeyRole -> *) (r :: KeyRole) (r' :: KeyRole).
HasKeyRole a =>
a r -> a r'
coerceKeyRole
solveUniv :: Reflect era => UnivSize -> Proof era -> Gen (Subst era)
solveUniv :: forall era. Reflect era => UnivSize -> Proof era -> Gen (Subst era)
solveUniv UnivSize
size Proof era
proof = do
forall era.
Era era =>
Proof era
-> OrderInfo -> [Pred era] -> Subst era -> Gen (Subst era)
toolChainSub Proof era
proof OrderInfo
standardOrderInfo (forall era. Reflect era => UnivSize -> Proof era -> [Pred era]
universePreds UnivSize
size Proof era
proof) forall era. Subst era
emptySubst
universeStage ::
Reflect era =>
UnivSize ->
Proof era ->
Subst era ->
Gen (Subst era)
universeStage :: forall era.
Reflect era =>
UnivSize -> Proof era -> Subst era -> Gen (Subst era)
universeStage UnivSize
size Proof era
proof = forall era.
Era era =>
Proof era
-> OrderInfo -> [Pred era] -> Subst era -> Gen (Subst era)
toolChainSub Proof era
proof OrderInfo
standardOrderInfo (forall era. Reflect era => UnivSize -> Proof era -> [Pred era]
universePreds UnivSize
size Proof era
proof)
demo :: ReplMode -> IO ()
demo :: ReplMode -> IO ()
demo ReplMode
mode = do
let proof :: Proof ShelleyEra
proof = Proof ShelleyEra
Shelley
Subst ShelleyEra
subst <- forall a. Gen a -> IO a
generate (forall era.
Reflect era =>
UnivSize -> Proof era -> Subst era -> Gen (Subst era)
universeStage forall a. Default a => a
def Proof ShelleyEra
proof forall era. Subst era
emptySubst)
if ReplMode
mode forall a. Eq a => a -> a -> Bool
== ReplMode
Interactive
then String -> IO ()
putStrLn String
"\n" forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> String -> IO ()
putStrLn (forall a. Show a => a -> String
show Subst ShelleyEra
subst)
else forall (f :: * -> *) a. Applicative f => a -> f a
pure ()
Env ShelleyEra
env <- forall (m :: * -> *) t. (HasCallStack, Monad m) => Typed t -> m t
monadTyped (forall era. Subst era -> Env era -> Typed (Env era)
substToEnv Subst ShelleyEra
subst forall era. Env era
emptyEnv)
forall era. ReplMode -> Proof era -> Env era -> String -> IO ()
modeRepl ReplMode
mode Proof ShelleyEra
proof Env ShelleyEra
env String
""
demoTest :: TestTree
demoTest :: TestTree
demoTest = forall a. String -> IO a -> TestTree
testIO String
"Testing Universe Stage" (ReplMode -> IO ()
demo ReplMode
CI)
main :: IO ()
main :: IO ()
main = TestTree -> IO ()
defaultMain forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> TestTree
testIO String
"Testing Universe Stage" (ReplMode -> IO ()
demo ReplMode
Interactive)