-
Notifications
You must be signed in to change notification settings - Fork 720
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
cardano-testnet: Test treasury donation
- Loading branch information
Showing
4 changed files
with
175 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
160 changes: 160 additions & 0 deletions
160
cardano-testnet/test/cardano-testnet-test/Cardano/Testnet/Test/Gov/TreasuryDonation.hs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,160 @@ | ||
{-# LANGUAGE DataKinds #-} | ||
{-# LANGUAGE GADTs #-} | ||
{-# LANGUAGE NamedFieldPuns #-} | ||
{-# LANGUAGE NumericUnderscores #-} | ||
{-# LANGUAGE OverloadedStrings #-} | ||
{-# LANGUAGE ScopedTypeVariables #-} | ||
|
||
module Cardano.Testnet.Test.Gov.TreasuryDonation | ||
( hprop_ledger_events_treasury_donation | ||
) where | ||
|
||
import Cardano.Api | ||
import Cardano.Api.Ledger | ||
|
||
import qualified Cardano.Ledger.Coin as L | ||
import Cardano.Testnet | ||
|
||
import Prelude | ||
|
||
import Control.Monad.Catch (MonadCatch) | ||
import Control.Monad (void, when) | ||
import qualified Data.Text as Text | ||
import GHC.Stack (HasCallStack) | ||
import System.Exit | ||
import System.FilePath ((</>)) | ||
|
||
import Testnet.Components.Query | ||
import Testnet.Components.TestWatchdog | ||
import Testnet.Process.Run (execCli', execCliAny, mkExecConfig) | ||
import Testnet.Property.Util (integrationWorkspace) | ||
import Testnet.Types | ||
|
||
import Hedgehog | ||
import qualified Hedgehog as H | ||
import qualified Hedgehog.Extras as H | ||
|
||
-- | Test that donating to the treasury indeed increases the treasury | ||
-- Execute me with: | ||
-- @DISABLE_RETRIES=1 cabal test cardano-testnet-test --test-options '-p "/Treasury Donation/"'@ | ||
hprop_ledger_events_treasury_donation :: Property | ||
hprop_ledger_events_treasury_donation = integrationWorkspace "treasury-donation" $ \tempAbsBasePath' -> runWithDefaultWatchdog_ $ do | ||
conf@Conf { tempAbsPath=tempAbsPath@(TmpAbsolutePath work) } | ||
<- mkConf tempAbsBasePath' | ||
let tempBaseAbsPath = makeTmpBaseAbsPath tempAbsPath | ||
|
||
let ceo = ConwayEraOnwardsConway | ||
sbe = conwayEraOnwardsToShelleyBasedEra ceo | ||
era = toCardanoEra sbe | ||
cEra = AnyCardanoEra era | ||
fastTestnetOptions = cardanoDefaultTestnetOptions | ||
{ cardanoEpochLength = 100 | ||
, cardanoSlotLength = 0.1 | ||
, cardanoNodeEra = cEra | ||
} | ||
|
||
TestnetRuntime | ||
{ testnetMagic | ||
, poolNodes | ||
, wallets=wallet0:_ | ||
, configurationFile | ||
} | ||
<- cardanoTestnetDefault fastTestnetOptions conf | ||
|
||
PoolNode{poolRuntime} <- H.headM poolNodes | ||
poolSprocket1 <- H.noteShow $ nodeSprocket poolRuntime | ||
execConfig <- mkExecConfig tempBaseAbsPath poolSprocket1 testnetMagic | ||
let socketPath = nodeSocketPath poolRuntime | ||
|
||
epochStateView <- getEpochStateView configurationFile socketPath | ||
|
||
H.note_ $ "Sprocket: " <> show poolSprocket1 | ||
H.note_ $ "Abs path: " <> tempAbsBasePath' | ||
H.note_ $ "Socketpath: " <> unFile socketPath | ||
H.note_ $ "Foldblocks config file: " <> unFile configurationFile | ||
|
||
L.Coin currentTreasury <- getTreasuryValue epochStateView | ||
H.note_ $ "currentTreasury: " <> show currentTreasury | ||
(currentTreasury H.=== 0) -- Treasury should initially be 0 | ||
|
||
let doOneDonation = doTreasuryDonation sbe execConfig work epochStateView wallet0 | ||
|
||
doOneDonation 0 Nothing 500 | ||
doOneDonation 1 Nothing 500_013 | ||
doOneDonation 2 Nothing (-497) -- Test donation that should fail because donation is negative | ||
doOneDonation 3 (Just 1_234) (-497) -- Test donation that should fail because current treasury value is wrong | ||
|
||
doTreasuryDonation :: () | ||
=> HasCallStack | ||
=> MonadCatch m | ||
=> MonadTest m | ||
=> MonadIO m | ||
=> H.MonadAssertion m | ||
=> ShelleyBasedEra era | ||
-> H.ExecConfig | ||
-> FilePath -- ^ Where temporary files can be stored | ||
-> EpochStateView | ||
-> PaymentKeyInfo | ||
-> Int -- ^ The number of the call, used to create unique temporary file names. Starts at 0. | ||
-> (Maybe Int) -- ^ The current treasury value to use. If unspecified, it will obtained from the node. | ||
-> Int -- ^ The amount to donate | ||
-> m () | ||
doTreasuryDonation sbe execConfig work epochStateView wallet0 idx currentTreasury' treasuryDonation = do | ||
currentTreasury <- | ||
case currentTreasury' of | ||
Nothing -> do | ||
v <- unCoin <$> getTreasuryValue epochStateView | ||
H.note_ $ "currentTreasury: " <> show v | ||
return v | ||
Just x -> pure $ toInteger x | ||
|
||
txBodyFp <- H.note $ work </> "treasury-donation-" <> show idx <> ".body" | ||
signedTxFp <- H.note $ work </> "treasury-donation-" <> show idx <> ".signed" | ||
|
||
txIn0 <- findLargestUtxoForPaymentKey epochStateView sbe wallet0 | ||
|
||
(exitCode, stdout, stderr) <- execCliAny execConfig | ||
[ "conway", "transaction", "build" | ||
, "--tx-in", Text.unpack $ renderTxIn txIn0 | ||
, "--change-address", Text.unpack $ paymentKeyInfoAddr wallet0 | ||
, "--current-treasury-value", show currentTreasury | ||
, "--treasury-donation", show treasuryDonation | ||
, "--out-file", txBodyFp | ||
] | ||
when (not $ null stdout) (H.note_ stdout) | ||
when (not $ null stderr) (H.note_ stderr) | ||
|
||
(exitCode == ExitSuccess) H.=== (currentTreasury >= 0 && treasuryDonation >= 0) | ||
|
||
case exitCode of | ||
ExitFailure _ -> do | ||
H.assert (currentTreasury < 0 || treasuryDonation < 0) | ||
return () | ||
ExitSuccess -> do | ||
H.noteM_ $ execCli' execConfig | ||
[ "conway", "transaction", "view" | ||
, "--tx-file", txBodyFp | ||
] | ||
|
||
H.noteM_ $ execCli' execConfig | ||
[ "conway", "transaction", "sign" | ||
, "--tx-body-file", txBodyFp | ||
, "--signing-key-file", signingKeyFp $ paymentKeyInfoPair wallet0 | ||
, "--out-file", signedTxFp | ||
] | ||
|
||
H.noteM_ $ execCli' execConfig | ||
[ "conway", "transaction", "view" | ||
, "--tx-file", signedTxFp | ||
] | ||
|
||
H.noteM_ $ execCli' execConfig | ||
[ "conway", "transaction", "submit" | ||
, "--tx-file", signedTxFp | ||
] | ||
|
||
void $ waitForEpochs epochStateView (EpochInterval 5) | ||
|
||
L.Coin finalTreasury <- getTreasuryValue epochStateView | ||
H.note_ $ "finalTreasury: " <> show finalTreasury | ||
finalTreasury H.=== (currentTreasury + (toInteger treasuryDonation)) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters