diff --git a/cabal.project b/cabal.project index fbdb1810247..1f17b09e04f 100644 --- a/cabal.project +++ b/cabal.project @@ -32,8 +32,8 @@ packages: trace-resources trace-forward -program-options - ghc-options: -Werror +-- program-options +-- ghc-options: -Werror test-show-details: direct diff --git a/cardano-testnet/cardano-testnet.cabal b/cardano-testnet/cardano-testnet.cabal index 62d43a59c39..84f074afada 100644 --- a/cardano-testnet/cardano-testnet.cabal +++ b/cardano-testnet/cardano-testnet.cabal @@ -198,6 +198,7 @@ test-suite cardano-testnet-test , cardano-api:{cardano-api, internal} , cardano-cli , cardano-crypto-class + , cardano-ledger-core , cardano-ledger-conway , cardano-ledger-core , cardano-ledger-shelley diff --git a/cardano-testnet/src/Testnet/Defaults.hs b/cardano-testnet/src/Testnet/Defaults.hs index 3d923d6b502..a502817f42a 100644 --- a/cardano-testnet/src/Testnet/Defaults.hs +++ b/cardano-testnet/src/Testnet/Defaults.hs @@ -16,6 +16,7 @@ module Testnet.Defaults , defaultConwayGenesis , defaultShelleyGenesis , defaultShelleyGenesisFp + , defaultV3CostModel , defaultYamlHardforkViaConfig , defaultMainnetTopology , plutusV3NonSpendingScript @@ -100,8 +101,8 @@ defaultAlonzoGenesis = do } where - priceExecStepsRat = promoteRatio $ 721 % (10000000 :: Word64) - priceMemStepsRat = promoteRatio $ 577 % (10000 :: Word64) + priceExecStepsRat = promoteRatio $ 721 % (100000000000 :: Word64) + priceMemStepsRat = promoteRatio $ 577 % (1000000000 :: Word64) checkBoundedRational r = case boundRational r of @@ -110,8 +111,8 @@ defaultAlonzoGenesis = do maxTxExUnits = Api.toAlonzoExUnits $ Api.ExecutionUnits - { Api.executionSteps = 10000000000 - , Api.executionMemory = 140000000 + { Api.executionSteps = 100000000000 + , Api.executionMemory = 1400000000 } maxBlockExUnits = Api.toAlonzoExUnits $ Api.ExecutionUnits @@ -127,7 +128,7 @@ defaultAlonzoGenesis = do , Map.singleton pv3 defaultV3CostModel ] defaultV1CostModel = Api.CostModel - [ 205665, 812, 1, 1, 1000, 571, 0, 1, 1000, 24177, 4, 1, 1000, 32, 117366, 10475, 4 + [ 205665, 812, 1, 1, 1000, 571, 0, 1, 1000, 24177, 4, 1, 1000, 32, 117366, 102, 4 , 23000, 100, 23000, 100, 23000, 100, 23000, 100, 23000, 100, 23000, 100, 100, 100 , 23000, 100, 19537, 32, 175354, 32, 46417, 4, 221973, 511, 0, 1, 89141, 32, 497525 , 14068, 4, 2, 196500, 453240, 220, 0, 1, 1, 1000, 28662, 4, 2, 245000, 216773, 62 @@ -153,20 +154,30 @@ defaultAlonzoGenesis = do , 32, 32696, 32, 43357, 32, 32247, 32, 38314, 32, 35892428, 10, 9462713, 1021, 10, 38887044 , 32947, 10 ] - defaultV3CostModel = Api.CostModel - [ 205665, 812, 1, 1, 1000, 571, 0, 1, 1000, 24177, 4, 1, 1000, 32, 117366, 10475, 4, 117366, 10475, 4, 832808, 18 - , 3209094, 6, 331451, 1, 65990684, 23097, 18, 114242, 18, 94393407 - , 87060, 18, 16420089, 18, 2145798, 36, 3795345, 12, 889023, 1, 204237282, 23271, 36, 129165, 36, 189977790 - , 85902, 36, 33012864, 36, 388443360, 1, 401885761, 72, 2331379, 72, 23000, 100, 23000, 100, 23000, 100, 23000, 100, 23000 - , 100, 23000, 100, 23000, 100, 23000, 100, 100, 100, 23000, 100 - , 19537, 32, 175354, 32, 46417, 4, 221973, 511, 0, 1, 89141, 32, 497525, 14068, 4, 2, 196500, 453240, 220, 0, 1, 1, 1000, 28662 - , 4, 2, 245000, 216773, 62, 1, 1060367, 12586, 1, 208512, 421, 1, 187000, 1000, 52998, 1, 80436, 32 - , 43249, 1000, 32, 32, 80556, 1, 57667, 4, 1927926, 82523, 4, 1000, 10, 197145, 156, 1, 197145, 156, 1, 204924, 473, 1, 208896 - , 511, 1, 52467, 32, 64832, 32, 65493, 32, 22558, 32, 16563, 32, 76511, 32, 196500, 453240, 220, 0 - , 1, 1, 69522, 11687, 0, 1, 60091, 32, 196500, 453240, 220, 0, 1, 1, 196500, 453240, 220, 0, 1, 1, 1159724, 392670, 0, 2, 806990 - , 30482, 4, 1927926, 82523, 4, 265318, 0, 4, 0, 85931, 32, 205665, 812, 1, 1, 41182 - , 32, 212342, 32, 31220, 32, 32696, 32, 43357, 32, 32247, 32, 38314, 32, 35190005, 10, 57996947, 18975, 10, 39121781, 32260, 10 - ] + + +-- | Proposing script (protocol parameter update) fails to execute unless this is set to 0 +cekStartupCost_exBudgetCPU :: Integer +cekStartupCost_exBudgetCPU = 1 + +cekLamCost_exBudgetMemory :: Integer +cekLamCost_exBudgetMemory = 1 + +defaultV3CostModel :: Api.CostModel +defaultV3CostModel = Api.CostModel + [ 205665, 812, 1, 1, 1000, 571, 0, 1, 1000, 24177, 4, 1, 1000, 32, 100, 10475, 4, 117366, 10475, 4, 103, 18 + , 3209094, 6, 331451, 1, 65990684, 23097, 19, cekStartupCost_exBudgetCPU, cekLamCost_exBudgetMemory, 107 + , 87060, 21, 16420089, 22, 2145798, 36, 3795345, 12, 889023, 1, 204237282, 23271, 36, 129165, 36, 189977790 + , 85902, 36, 33012864, 36, 388443360, 1, 401885761, 72, 2331379, 72, 23000, 100, 23000, 100, 23000, 100, 23000, 100, 23000 + , 100, 23000, 100, 23000, 100, 23000, 100, 100, 100, 23000, 100 + , 19537, 32, 175354, 32, 46417, 4, 221973, 511, 0, 1, 89141, 32, 497525, 14068, 4, 2, 196500, 453240, 220, 0, 1, 1, 1000, 28662 + , 4, 2, 245000, 216773, 62, 1, 1060367, 12586, 1, 208512, 421, 1, 187000, 1000, 52998, 1, 80436, 32 + , 43249, 1000, 32, 32, 80556, 1, 57667, 4, 1927926, 82523, 4, 1000, 10, 197145, 156, 1, 197145, 156, 1, 204924, 473, 1, 208896 + , 511, 1, 52467, 32, 64832, 32, 65493, 32, 22558, 32, 16563, 32, 76511, 32, 196500, 453240, 220, 0 + , 1, 1, 69522, 11687, 0, 1, 60091, 32, 196500, 453240, 220, 0, 1, 1, 196500, 453240, 220, 0, 1, 1, 1159724, 392670, 0, 2, 806990 + , 30482, 4, 1927926, 82523, 4, 265318, 0, 4, 0, 85931, 32, 205665, 812, 1, 1, 41182 + , 32, 212342, 32, 31220, 32, 32696, 32, 43357, 32, 32247, 32, 38314, 32, 35190005, 10, 57996947, 18975, 10, 39121781, 32260, 10 + ] defaultConwayGenesis :: ConwayGenesis StandardCrypto defaultConwayGenesis = diff --git a/cardano-testnet/test/cardano-testnet-test/Cardano/Testnet/Test/LedgerEvents/Gov/ProposeNewConstitution.hs b/cardano-testnet/test/cardano-testnet-test/Cardano/Testnet/Test/LedgerEvents/Gov/ProposeNewConstitution.hs index 5ddb42a829e..ab0fc01eccd 100644 --- a/cardano-testnet/test/cardano-testnet-test/Cardano/Testnet/Test/LedgerEvents/Gov/ProposeNewConstitution.hs +++ b/cardano-testnet/test/cardano-testnet-test/Cardano/Testnet/Test/LedgerEvents/Gov/ProposeNewConstitution.hs @@ -181,22 +181,21 @@ hprop_ledger_events_propose_new_constitution = H.integrationWorkspace "propose-n ] -- Create constitution proposal - - guardRailScriptFp <- H.note $ work "guard-rail-script.plutusV3" - H.writeFile guardRailScriptFp $ Text.unpack plutusV3NonSpendingScript + guardRailScript <- H.note $ work "guard-rail-script.plutusV3" + H.writeFile guardRailScript $ Text.unpack plutusV3NonSpendingScript -- TODO: Update help text for policyid. The script hash is not -- only useful for minting scripts constitutionScriptHash <- filter (/= '\n') <$> H.execCli' execConfig [ convertToEraString cEra, "transaction" , "policyid" - , "--script-file", guardRailScriptFp + , "--script-file", guardRailScript ] void $ H.execCli' execConfig [ "conway", "governance", "action", "create-constitution" , "--testnet" - , "--governance-action-deposit", show @Int 1_000_000 -- TODO: Get this from the node - , "--deposit-return-stake-verification-key-file", stakeVkeyFp + , "--governance-action-deposit", show @Int 1_000_000 -- TODO: retrieve this from conway genesis. + , "--deposit-return-stake-script-file", guardRailScript , "--anchor-url", "https://tinyurl.com/3wrwb2as" , "--anchor-data-hash", proposalAnchorDataHash , "--constitution-url", "https://tinyurl.com/2pahcy6z" @@ -216,6 +215,7 @@ hprop_ledger_events_propose_new_constitution = H.integrationWorkspace "propose-n , "--tx-in", Text.unpack $ renderTxIn txin2 , "--tx-out", Text.unpack (paymentKeyInfoAddr (wallets !! 0)) <> "+" <> show @Int 5_000_000 , "--proposal-file", constitutionActionFp + -- TODO: Left off here. You need to witness the action with the proposal script , "--out-file", txbodyFp ] @@ -281,7 +281,7 @@ hprop_ledger_events_propose_new_constitution = H.integrationWorkspace "propose-n [ "conway", "transaction", "build" , "--change-address", Text.unpack $ paymentKeyInfoAddr $ wallets !! 0 , "--tx-in", Text.unpack $ renderTxIn txin3 - , "--tx-out", Text.unpack (paymentKeyInfoAddr (wallets !! 1)) <> "+" <> show @Int 3_000_000 + , "--tx-out", Text.unpack (paymentKeyInfoAddr (wallets !! 0)) <> "+" <> show @Int 3_000_000 , "--vote-file", voteFp 1 , "--vote-file", voteFp 2 , "--vote-file", voteFp 3 @@ -304,7 +304,7 @@ hprop_ledger_events_propose_new_constitution = H.integrationWorkspace "propose-n [ "conway", "transaction", "submit" , "--tx-file", voteTxFp ] - + H.threadDelay 10_000_000 -- We check that constitution was succcessfully ratified !eConstitutionAdopted @@ -318,6 +318,56 @@ hprop_ledger_events_propose_new_constitution = H.integrationWorkspace "propose-n void $ evalEither eConstitutionAdopted + -- TODO: Attempt a protocol parameters update (witnessed with guard rail script) + pparamsUpdateFp <- H.note $ work "protocol-parameters-upate.action" + void $ H.execCli' execConfig + [ convertToEraString cEra, "governance", "action", "create-protocol-parameters-update" + , "--testnet" + , "--governance-action-deposit", show @Int 1_000_000 -- TODO: retrieve this from conway genesis. + , "--deposit-return-stake-script-file", guardRailScript + , "--anchor-url", "https://tinyurl.com/3wrwb2as" + , "--anchor-data-hash", proposalAnchorDataHash + , "--constitution-script-hash", constitutionScriptHash + , "--committee-term-length", show @Int 1000 + , "--out-file", pparamsUpdateFp + ] + updateProposalTxBody <- H.note $ work "update-proposal.txbody" + txin4 <- findLargestUtxoForPaymentKey epochStateView sbe $ wallets !! 0 + txin5 <- findLargestUtxoForPaymentKey epochStateView sbe $ wallets !! 1 + txinColl <- findLargestUtxoForPaymentKey epochStateView sbe $ wallets !! 2 + + void $ H.execCli' execConfig + [ convertToEraString cEra, "transaction", "build" + , "--change-address", Text.unpack $ paymentKeyInfoAddr $ head wallets + , "--tx-in", Text.unpack $ renderTxIn txin4 + , "--tx-in", Text.unpack $ renderTxIn txin5 + , "--tx-in-collateral", Text.unpack $ renderTxIn txinColl + , "--tx-out", Text.unpack (paymentKeyInfoAddr (wallets !! 1)) <> "+" <> show @Int 5_000_000 + , "--proposal-file", pparamsUpdateFp + , "--proposal-script-file", guardRailScript + , "--proposal-redeemer-value", "0" + , "--witness-override", show @Int 12 + , "--out-file", updateProposalTxBody + ] + + updateProposalTx <- H.note $ work "update-proposal.tx" + void $ H.execCli' execConfig + [ "conway", "transaction", "sign" + , "--tx-body-file", updateProposalTxBody + , "--signing-key-file", paymentSKey $ paymentKeyInfoPair $ wallets !! 0 + , "--signing-key-file", paymentSKey $ paymentKeyInfoPair $ wallets !! 1 + , "--signing-key-file", paymentSKey $ paymentKeyInfoPair $ wallets !! 2 + , "--signing-key-file", drepSKeyFp 1 + , "--signing-key-file", drepSKeyFp 2 + , "--signing-key-file", drepSKeyFp 3 + , "--out-file", updateProposalTx + ] + + void $ H.execCli' execConfig + [ "conway", "transaction", "submit" + , "--tx-file", updateProposalTx + ] + foldBlocksCheckProposalWasSubmitted :: TxId -- TxId of submitted tx -> Env diff --git a/cardano-testnet/test/cardano-testnet-test/cardano-testnet-test.hs b/cardano-testnet/test/cardano-testnet-test/cardano-testnet-test.hs index eaff169901e..857f8ed5a4d 100644 --- a/cardano-testnet/test/cardano-testnet-test/cardano-testnet-test.hs +++ b/cardano-testnet/test/cardano-testnet-test/cardano-testnet-test.hs @@ -37,10 +37,10 @@ tests = do pure $ testGroup "test/Spec.hs" [ testGroup "Spec" [ testGroup "Ledger Events" - [ H.ignoreOnWindows "Sanity Check" LedgerEvents.hprop_ledger_events_sanity_check - , H.ignoreOnWindows "Treasury Growth" LedgerEvents.prop_check_if_treasury_is_growing + [ --H.ignoreOnWindows "Sanity Check" LedgerEvents.hprop_ledger_events_sanity_check + -- , H.ignoreOnWindows "Treasury Growth" LedgerEvents.prop_check_if_treasury_is_growing -- TODO: Replace foldBlocks with checkLedgerStateCondition - , testGroup "Governance" + testGroup "Governance" [ H.ignoreOnMacAndWindows "ProposeAndRatifyNewConstitution" Cardano.Testnet.Test.LedgerEvents.Gov.ProposeNewConstitution.hprop_ledger_events_propose_new_constitution -- FIXME Those tests are flaky -- , H.ignoreOnWindows "InfoAction" LedgerEvents.hprop_ledger_events_info_action