From 226edac9ff87fd70f86eb378c2b825f9d87cce2c Mon Sep 17 00:00:00 2001 From: Sebastian Nagel Date: Mon, 6 May 2024 10:20:00 +0200 Subject: [PATCH] Generate blueprints spending from key AND script This was not covered before and seems like we have failing transactions now. --- hydra-node/test/Hydra/Chain/Direct/TxSpec.hs | 12 +++--------- 1 file changed, 3 insertions(+), 9 deletions(-) diff --git a/hydra-node/test/Hydra/Chain/Direct/TxSpec.hs b/hydra-node/test/Hydra/Chain/Direct/TxSpec.hs index ba688eb5b95..934c8e84453 100644 --- a/hydra-node/test/Hydra/Chain/Direct/TxSpec.hs +++ b/hydra-node/test/Hydra/Chain/Direct/TxSpec.hs @@ -94,7 +94,6 @@ import Test.Cardano.Ledger.Shelley.Arbitrary (genMetadata') import Test.Hydra.Fixture (genForParty) import Test.Hydra.Prelude import Test.QuickCheck ( - Positive (..), Property, checkCoverage, choose, @@ -290,11 +289,10 @@ genBlueprintTxWithUTxO = >>= addSomeReferenceInputs >>= addValidityRange >>= addRandomMetadata - >>= removeRandomInputs >>= addCollateralInput where spendingPubKeyOutput (utxo, txbody) = do - utxoToSpend <- (genUTxOAdaOnlyOfSize . getPositive) . Positive =<< choose (0, 50) + utxoToSpend <- genUTxOAdaOnlyOfSize =<< choose (0, 3) pure ( utxo <> utxoToSpend , txbody & addVkInputs (toList $ UTxO.inputSet utxoToSpend) @@ -303,8 +301,7 @@ genBlueprintTxWithUTxO = spendSomeScriptInputs (utxo, txbody) = do let alwaysSucceedingScript = PlutusScriptSerialised $ Plutus.alwaysSucceedingNAryFunction 3 datum <- unsafeHashableScriptData . fromPlutusData <$> arbitrary - redeemer <- - unsafeHashableScriptData . fromPlutusData <$> arbitrary -- . B . BS.pack <$> vector n + redeemer <- unsafeHashableScriptData . fromPlutusData <$> arbitrary let genTxOut = do value <- genValue let scriptAddress = mkScriptAddress testNetworkId alwaysSucceedingScript @@ -340,10 +337,6 @@ genBlueprintTxWithUTxO = mtdt <- genMetadata pure (utxo, txbody{txMetadata = mtdt}) - removeRandomInputs (utxo, txbody) = do - someInput <- elements $ txIns txbody - pure (utxo, txbody{txIns = [someInput]}) - addCollateralInput (utxo, txbody) = do utxoToSpend <- genUTxOAdaOnlyOfSize 1 pure @@ -369,6 +362,7 @@ prop_interestingBlueprintTx = do True & cover 1 (spendsFromScript (utxo, tx)) "blueprint spends script UTxO" & cover 1 (spendsFromPubKey (utxo, tx)) "blueprint spends pub key UTxO" + & cover 1 (spendsFromPubKey (utxo, tx) && spendsFromScript (utxo, tx)) "blueprint spends from script AND pub key" & cover 1 (hasReferenceInputs tx) "blueprint has reference input" where hasReferenceInputs tx =