Skip to content

Commit

Permalink
Update hprop_ledger_events_treasury_withdrawal to work with the new…
Browse files Browse the repository at this point in the history
… checks
  • Loading branch information
palas committed Oct 28, 2024
1 parent a62a0d9 commit e83b0c0
Showing 1 changed file with 41 additions and 28 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -35,12 +35,14 @@ import qualified Data.Map.Strict as M
import qualified Data.Text as Text
import GHC.Stack
import Lens.Micro
import System.Directory (makeAbsolute)
import System.FilePath ((</>))

import Test.Cardano.CLI.Hash (serveFilesWhile)
import Testnet.Components.Query
import Testnet.Defaults
import Testnet.Process.Cli.Keys (cliStakeAddressKeyGen)
import Testnet.Process.Run (execCli', mkExecConfig)
import Testnet.Process.Run (addEnvVarsToConfig, execCli', mkExecConfig)
import Testnet.Property.Util (integrationRetryWorkspace)
import Testnet.Start.Types
import Testnet.Types
Expand Down Expand Up @@ -87,13 +89,14 @@ hprop_ledger_events_treasury_withdrawal = integrationRetryWorkspace 2 "treasury
H.note_ $ "Foldblocks config file: " <> unFile configurationFile

gov <- H.createDirectoryIfMissing $ work </> "governance"
proposalAnchorFile <- H.note $ work </> gov </> "sample-proposal-anchor"
treasuryWithdrawalActionFp <- H.note $ work </> gov </> "treasury-withdrawal.action"

H.writeFile proposalAnchorFile "dummy anchor data"
let proposalAnchorDataIpfsHash = "QmexFJuEn5RtnHEqpxDcqrazdHPzAwe7zs2RxHLfMH5gBz"
proposalAnchorFile <- H.noteM $ liftIO $ makeAbsolute $ "test" </> "cardano-testnet-test" </> "files" </> "sample-proposal-anchor"

treasuryWithdrawalActionFp <- H.note $ work </> gov </> "treasury-withdrawal.action"

proposalAnchorDataHash <- execCli' execConfig
[ "hash", "anchor-data", "--file-text", proposalAnchorFile
[ "hash", "anchor-data", "--file-binary", proposalAnchorFile
]

txin2 <- findLargestUtxoForPaymentKey epochStateView sbe wallet1
Expand Down Expand Up @@ -145,35 +148,45 @@ hprop_ledger_events_treasury_withdrawal = integrationRetryWorkspace 2 "treasury
-- {{{ Create treasury withdrawal
let withdrawalAmount = 3_300_777 :: Integer
govActionDeposit <- getMinDRepDeposit epochStateView ceo
void $ execCli' execConfig
[ eraName, "governance", "action", "create-treasury-withdrawal"
, "--testnet"
, "--anchor-url", "https://tinyurl.com/3wrwb2as"
, "--anchor-data-hash", proposalAnchorDataHash
, "--governance-action-deposit", show govActionDeposit
, "--deposit-return-stake-verification-key-file", stakeVkeyFp
, "--transfer", show withdrawalAmount
, "--funds-receiving-stake-verification-key-file", stakeVkeyFp
, "--out-file", treasuryWithdrawalActionFp
]

let relativeUrl = ["ipfs", proposalAnchorDataIpfsHash]

txbodyFp <- H.note $ work </> "tx.body"
txbodySignedFp <- H.note $ work </> "tx.body.signed"

-- wait for one block before using wallet0 again
_ <- waitForBlocks epochStateView 1

txin3 <- findLargestUtxoForPaymentKey epochStateView sbe wallet0

void $ execCli' execConfig
[ eraName, "transaction", "build"
, "--change-address", Text.unpack $ paymentKeyInfoAddr wallet0
, "--tx-in", Text.unpack $ renderTxIn txin3
, "--tx-out", Text.unpack (paymentKeyInfoAddr wallet1) <> "+" <> show @Int 5_000_000
, "--proposal-file", treasuryWithdrawalActionFp
, "--out-file", txbodyFp
]
-- Create temporary HTTP server with files required by the call to `cardano-cli`
-- In this case, the server emulates an IPFS gateway
serveFilesWhile
[(relativeUrl, proposalAnchorFile)]
( \port -> do
let execConfig' = addEnvVarsToConfig execConfig [("IPFS_GATEWAY_URI", "http://localhost:" ++ show port ++ "/")]
void $ execCli' execConfig'
[ eraName, "governance", "action", "create-treasury-withdrawal"
, "--testnet"
, "--anchor-url", "ipfs://" ++ proposalAnchorDataIpfsHash
, "--anchor-data-hash", proposalAnchorDataHash
, "--governance-action-deposit", show govActionDeposit
, "--deposit-return-stake-verification-key-file", stakeVkeyFp
, "--transfer", show withdrawalAmount
, "--funds-receiving-stake-verification-key-file", stakeVkeyFp
, "--out-file", treasuryWithdrawalActionFp
]

-- wait for one block before using wallet0 again
_ <- waitForBlocks epochStateView 1

txin3 <- findLargestUtxoForPaymentKey epochStateView sbe wallet0

void $ execCli' execConfig'
[ eraName, "transaction", "build"
, "--change-address", Text.unpack $ paymentKeyInfoAddr wallet0
, "--tx-in", Text.unpack $ renderTxIn txin3
, "--tx-out", Text.unpack (paymentKeyInfoAddr wallet1) <> "+" <> show @Int 5_000_000
, "--proposal-file", treasuryWithdrawalActionFp
, "--out-file", txbodyFp
]
)

void $ execCli' execConfig
[ eraName, "transaction", "sign"
Expand Down

0 comments on commit e83b0c0

Please sign in to comment.