Skip to content

Commit

Permalink
Fix genDecrementTx to use correct snapshots
Browse files Browse the repository at this point in the history
  • Loading branch information
ch1bo committed Mar 13, 2024
1 parent 795b0d3 commit 3fd0f4d
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 3 deletions.
15 changes: 12 additions & 3 deletions hydra-node/src/Hydra/Chain/Direct/State.hs
Original file line number Diff line number Diff line change
Expand Up @@ -125,7 +125,7 @@ import Hydra.Snapshot (
genConfirmedSnapshot,
getSnapshot,
)
import Test.QuickCheck (choose, frequency, oneof, suchThat, vector)
import Test.QuickCheck (choose, frequency, getPositive, oneof, vector)
import Test.QuickCheck.Gen (elements)
import Test.QuickCheck.Modifiers (Positive (Positive))

Expand Down Expand Up @@ -1045,13 +1045,22 @@ genCollectComTx = do
genDecrementTx :: Int -> Gen (ChainContext, OpenState, Tx)
genDecrementTx numParties = do
ctx <- genHydraContextFor numParties
(_, stOpen@OpenState{headId}) <- genStOpen ctx
(u0, stOpen@OpenState{headId}) <- genStOpen ctx
cctx <- pickChainContext ctx
snapshot <- arbitrary `suchThat` (\Snapshot{utxoToDecommit} -> isJust utxoToDecommit)
snapshot <- do
number <- getPositive <$> arbitrary
(utxo, toDecommit) <- splitUTxO u0
pure Snapshot{headId, number, confirmed = [], utxo, utxoToDecommit = Just toDecommit}
signatures <- arbitrary
let openUTxO = getKnownUTxO stOpen
pure (cctx, stOpen, unsafeDecrement cctx headId (ctxHeadParameters ctx) openUTxO snapshot signatures)

splitUTxO :: UTxO -> Gen (UTxO, UTxO)
splitUTxO utxo = do
ix <- choose (0, length utxo)
let (p1, p2) = splitAt ix (UTxO.pairs utxo)
pure (UTxO.fromPairs p1, UTxO.fromPairs p2)

genCloseTx :: Int -> Gen (ChainContext, OpenState, Tx, ConfirmedSnapshot Tx)
genCloseTx numParties = do
ctx <- genHydraContextFor numParties
Expand Down
1 change: 1 addition & 0 deletions hydra-node/src/Hydra/Snapshot.hs
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ data Snapshot tx = Snapshot
-- ^ The set of transactions that lead to 'utxo'
, utxoToDecommit :: Maybe (UTxOType tx)
-- ^ UTxO to be decommitted. Spec: Ûω
-- TODO: what is the difference between Noting and (Just mempty) here?
}
deriving stock (Generic)

Expand Down

0 comments on commit 3fd0f4d

Please sign in to comment.