Skip to content

Commit

Permalink
Draft first Decrement mutation
Browse files Browse the repository at this point in the history
This one is trying to check if the parameters have changed by mutating
parties.
  • Loading branch information
v0d1ch committed May 7, 2024
1 parent 1478fa8 commit abd6162
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 6 deletions.
34 changes: 29 additions & 5 deletions hydra-node/test/Hydra/Chain/Direct/Contract/Decrement.hs
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,11 @@
module Hydra.Chain.Direct.Contract.Decrement where

import Hydra.Cardano.Api
import Hydra.Chain.Direct.Contract.Mutation (Mutation (..), SomeMutation (..), modifyInlineDatum, replaceParties)
import Hydra.Prelude hiding (label)

import Cardano.Api.UTxO as UTxO
import Data.Maybe (fromJust)
import Hydra.Chain (HeadParameters (..))
import Hydra.Chain.Direct.Fixture (testNetworkId, testPolicyId)
import Hydra.Chain.Direct.ScriptRegistry (genScriptRegistry, registryUTxO)
Expand All @@ -14,9 +16,12 @@ import Hydra.Chain.Direct.Tx (
mkHeadId,
mkHeadOutput,
)
import Hydra.ContestationPeriod (ContestationPeriod)
import Hydra.ContestationPeriod (ContestationPeriod, toChain)
import Hydra.Contract.Error (ToErrorCode (..))
import Hydra.Contract.HeadError (HeadError (..))
import Hydra.Contract.HeadState qualified as Head
import Hydra.Crypto (MultiSignature (..))
import Hydra.Data.Party qualified as OnChain
import Hydra.Ledger (IsTx (hashUTxO, withoutUTxO))
import Hydra.Ledger.Cardano (
adaOnly,
Expand All @@ -28,7 +33,8 @@ import Hydra.Plutus.Orphans ()
import Hydra.Snapshot (Snapshot (..))
import PlutusTx.Builtins (toBuiltin)
import Test.Hydra.Fixture (genForParty)
import Test.QuickCheck (elements)
import Test.QuickCheck (elements, oneof)
import Test.QuickCheck.Gen (suchThat)
import Test.QuickCheck.Instances ()

healthyDecrementTx :: (Tx, UTxO)
Expand Down Expand Up @@ -115,13 +121,31 @@ healthyDatum :: Head.State
healthyDatum =
Head.Open
{ utxoHash = toBuiltin $ hashUTxO @Tx healthyUTxO
, parties =
partyToChain <$> healthyParties
, contestationPeriod = 10
, parties = healthyOnChainParties
, contestationPeriod = toChain healthyContestationPeriod
, headId = toPlutusCurrencySymbol testPolicyId
}

healthyParties :: [Party]
healthyParties =
[ generateWith arbitrary i | i <- [1 .. 3]
]

healthyOnChainParties :: [OnChain.Party]
healthyOnChainParties = partyToChain <$> healthyParties

data DecrementMutation
= -- | Ensures parties do not change between head input datum and head output
-- datum.
MutatePartiesInOutput
deriving stock (Generic, Show, Enum, Bounded)

genDecrementMutation :: (Tx, UTxO) -> Gen SomeMutation
genDecrementMutation (tx, _utxo) =
oneof
[ SomeMutation (Just $ toErrorCode ChangedParameters) MutatePartiesInOutput <$> do
mutatedParties <- arbitrary `suchThat` (/= healthyOnChainParties)
pure $ ChangeOutput 0 $ modifyInlineDatum (replaceParties mutatedParties) headTxOut
]
where
headTxOut = fromJust $ txOuts' tx !!? 0
4 changes: 3 additions & 1 deletion hydra-node/test/Hydra/Chain/Direct/ContractSpec.hs
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ import Hydra.Chain.Direct.Contract.Close (genCloseInitialMutation, genCloseMutat
import Hydra.Chain.Direct.Contract.CollectCom (genCollectComMutation, healthyCollectComTx)
import Hydra.Chain.Direct.Contract.Commit (genCommitMutation, healthyCommitTx)
import Hydra.Chain.Direct.Contract.Contest (genContestMutation, healthyContestTx)
import Hydra.Chain.Direct.Contract.Decrement (healthyDecrementTx)
import Hydra.Chain.Direct.Contract.Decrement (genDecrementMutation, healthyDecrementTx)
import Hydra.Chain.Direct.Contract.FanOut (genFanoutMutation, healthyFanoutTx)
import Hydra.Chain.Direct.Contract.Init (genInitMutation, healthyInitTx)
import Hydra.Chain.Direct.Contract.Mutation (propMutation)
Expand Down Expand Up @@ -117,6 +117,8 @@ spec = parallel $ do
describe "Decrement" $ do
prop "is healthy" $
propTransactionEvaluates healthyDecrementTx
prop "does not survive random adversarial mutations" $
propMutation healthyDecrementTx genDecrementMutation
describe "Close" $ do
prop "is healthy" $
propTransactionEvaluates healthyCloseTx
Expand Down

0 comments on commit abd6162

Please sign in to comment.