@aztec/end-to-end 0.0.0-test.1 → 0.0.1-commit.001888fc
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dest/bench/client_flows/benchmark.d.ts +62 -0
- package/dest/bench/client_flows/benchmark.d.ts.map +1 -0
- package/dest/bench/client_flows/benchmark.js +281 -0
- package/dest/bench/client_flows/client_flows_benchmark.d.ts +79 -0
- package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -0
- package/dest/bench/client_flows/client_flows_benchmark.js +329 -0
- package/dest/bench/client_flows/config.d.ts +14 -0
- package/dest/bench/client_flows/config.d.ts.map +1 -0
- package/dest/bench/client_flows/config.js +124 -0
- package/dest/bench/client_flows/data_extractor.d.ts +2 -0
- package/dest/bench/client_flows/data_extractor.d.ts.map +1 -0
- package/dest/bench/client_flows/data_extractor.js +79 -0
- package/dest/bench/utils.d.ts +16 -41
- package/dest/bench/utils.d.ts.map +1 -1
- package/dest/bench/utils.js +44 -72
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +28 -19
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +125 -103
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +32 -32
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +105 -104
- package/dest/e2e_deploy_contract/deploy_test.d.ts +19 -10
- package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
- package/dest/e2e_deploy_contract/deploy_test.js +26 -27
- package/dest/e2e_epochs/epochs_test.d.ts +75 -24
- package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
- package/dest/e2e_epochs/epochs_test.js +290 -58
- package/dest/e2e_fees/bridging_race.notest.d.ts +2 -0
- package/dest/e2e_fees/bridging_race.notest.d.ts.map +1 -0
- package/dest/e2e_fees/bridging_race.notest.js +61 -0
- package/dest/e2e_fees/fees_test.d.ts +38 -23
- package/dest/e2e_fees/fees_test.d.ts.map +1 -1
- package/dest/e2e_fees/fees_test.js +169 -183
- package/dest/e2e_l1_publisher/write_json.d.ts +11 -0
- package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -0
- package/dest/e2e_l1_publisher/write_json.js +56 -0
- package/dest/e2e_multi_validator/utils.d.ts +12 -0
- package/dest/e2e_multi_validator/utils.d.ts.map +1 -0
- package/dest/e2e_multi_validator/utils.js +214 -0
- package/dest/e2e_nested_contract/nested_contract_test.d.ts +15 -15
- package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
- package/dest/e2e_nested_contract/nested_contract_test.js +36 -42
- package/dest/e2e_p2p/inactivity_slash_test.d.ts +31 -0
- package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -0
- package/dest/e2e_p2p/inactivity_slash_test.js +136 -0
- package/dest/e2e_p2p/p2p_network.d.ts +282 -27
- package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
- package/dest/e2e_p2p/p2p_network.js +255 -176
- package/dest/e2e_p2p/reqresp/utils.d.ts +22 -0
- package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -0
- package/dest/e2e_p2p/reqresp/utils.js +190 -0
- package/dest/e2e_p2p/shared.d.ts +64 -8
- package/dest/e2e_p2p/shared.d.ts.map +1 -1
- package/dest/e2e_p2p/shared.js +200 -27
- package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
- package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
- package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
- package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
- package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
- package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
- package/dest/e2e_token_contract/token_contract_test.d.ts +29 -14
- package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
- package/dest/e2e_token_contract/token_contract_test.js +107 -75
- package/dest/fixtures/authwit_proxy.d.ts +15 -0
- package/dest/fixtures/authwit_proxy.d.ts.map +1 -0
- package/dest/fixtures/authwit_proxy.js +30 -0
- package/dest/fixtures/e2e_prover_test.d.ts +55 -0
- package/dest/fixtures/e2e_prover_test.d.ts.map +1 -0
- package/dest/fixtures/e2e_prover_test.js +271 -0
- package/dest/fixtures/elu_monitor.d.ts +21 -0
- package/dest/fixtures/elu_monitor.d.ts.map +1 -0
- package/dest/fixtures/elu_monitor.js +102 -0
- package/dest/fixtures/fixtures.d.ts +10 -8
- package/dest/fixtures/fixtures.d.ts.map +1 -1
- package/dest/fixtures/fixtures.js +11 -5
- package/dest/fixtures/get_acvm_config.d.ts +2 -2
- package/dest/fixtures/get_acvm_config.d.ts.map +1 -1
- package/dest/fixtures/get_acvm_config.js +3 -15
- package/dest/fixtures/get_bb_config.d.ts +2 -2
- package/dest/fixtures/get_bb_config.d.ts.map +1 -1
- package/dest/fixtures/get_bb_config.js +10 -17
- package/dest/fixtures/ha_setup.d.ts +71 -0
- package/dest/fixtures/ha_setup.d.ts.map +1 -0
- package/dest/fixtures/ha_setup.js +116 -0
- package/dest/fixtures/index.d.ts +2 -1
- package/dest/fixtures/index.d.ts.map +1 -1
- package/dest/fixtures/index.js +1 -0
- package/dest/fixtures/l1_to_l2_messaging.d.ts +11 -7
- package/dest/fixtures/l1_to_l2_messaging.d.ts.map +1 -1
- package/dest/fixtures/l1_to_l2_messaging.js +45 -19
- package/dest/fixtures/logging.d.ts +1 -1
- package/dest/fixtures/setup.d.ts +239 -0
- package/dest/fixtures/setup.d.ts.map +1 -0
- package/dest/fixtures/setup.js +606 -0
- package/dest/fixtures/setup_p2p_test.d.ts +23 -15
- package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
- package/dest/fixtures/setup_p2p_test.js +102 -31
- package/dest/fixtures/token_utils.d.ts +10 -4
- package/dest/fixtures/token_utils.d.ts.map +1 -1
- package/dest/fixtures/token_utils.js +33 -13
- package/dest/fixtures/utils.d.ts +5 -153
- package/dest/fixtures/utils.d.ts.map +1 -1
- package/dest/fixtures/utils.js +4 -552
- package/dest/fixtures/web3signer.d.ts +5 -0
- package/dest/fixtures/web3signer.d.ts.map +1 -0
- package/dest/fixtures/web3signer.js +53 -0
- package/dest/fixtures/with_telemetry_utils.d.ts +2 -2
- package/dest/fixtures/with_telemetry_utils.d.ts.map +1 -1
- package/dest/fixtures/with_telemetry_utils.js +2 -2
- package/dest/index.d.ts +1 -1
- package/dest/quality_of_service/grafana_client.d.ts +41 -0
- package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
- package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
- package/dest/quality_of_service/prometheus_client.d.ts +38 -0
- package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
- package/dest/quality_of_service/prometheus_client.js +67 -0
- package/dest/shared/cross_chain_test_harness.d.ts +44 -27
- package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
- package/dest/shared/cross_chain_test_harness.js +107 -53
- package/dest/shared/gas_portal_test_harness.d.ts +33 -25
- package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
- package/dest/shared/gas_portal_test_harness.js +51 -30
- package/dest/shared/index.d.ts +3 -2
- package/dest/shared/index.d.ts.map +1 -1
- package/dest/shared/index.js +1 -0
- package/dest/shared/jest_setup.d.ts +1 -1
- package/dest/shared/jest_setup.js +42 -2
- package/dest/shared/mock_state_view.d.ts +86 -0
- package/dest/shared/mock_state_view.d.ts.map +1 -0
- package/dest/shared/mock_state_view.js +186 -0
- package/dest/shared/submit-transactions.d.ts +6 -4
- package/dest/shared/submit-transactions.d.ts.map +1 -1
- package/dest/shared/submit-transactions.js +15 -16
- package/dest/shared/uniswap_l1_l2.d.ts +3 -25
- package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
- package/dest/shared/uniswap_l1_l2.js +175 -126
- package/dest/simulators/index.d.ts +1 -1
- package/dest/simulators/lending_simulator.d.ts +7 -7
- package/dest/simulators/lending_simulator.d.ts.map +1 -1
- package/dest/simulators/lending_simulator.js +17 -18
- package/dest/simulators/token_simulator.d.ts +6 -3
- package/dest/simulators/token_simulator.d.ts.map +1 -1
- package/dest/simulators/token_simulator.js +12 -30
- package/dest/spartan/setup_test_wallets.d.ts +36 -11
- package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
- package/dest/spartan/setup_test_wallets.js +276 -62
- package/dest/spartan/tx_metrics.d.ts +88 -0
- package/dest/spartan/tx_metrics.d.ts.map +1 -0
- package/dest/spartan/tx_metrics.js +422 -0
- package/dest/spartan/utils/bot.d.ts +28 -0
- package/dest/spartan/utils/bot.d.ts.map +1 -0
- package/dest/spartan/utils/bot.js +142 -0
- package/dest/spartan/utils/chaos.d.ts +79 -0
- package/dest/spartan/utils/chaos.d.ts.map +1 -0
- package/dest/spartan/utils/chaos.js +142 -0
- package/dest/spartan/utils/clients.d.ts +39 -0
- package/dest/spartan/utils/clients.d.ts.map +1 -0
- package/dest/spartan/utils/clients.js +90 -0
- package/dest/spartan/utils/config.d.ts +45 -0
- package/dest/spartan/utils/config.d.ts.map +1 -0
- package/dest/spartan/utils/config.js +23 -0
- package/dest/spartan/utils/health.d.ts +63 -0
- package/dest/spartan/utils/health.d.ts.map +1 -0
- package/dest/spartan/utils/health.js +202 -0
- package/dest/spartan/utils/helm.d.ts +15 -0
- package/dest/spartan/utils/helm.d.ts.map +1 -0
- package/dest/spartan/utils/helm.js +47 -0
- package/dest/spartan/utils/index.d.ts +11 -0
- package/dest/spartan/utils/index.d.ts.map +1 -0
- package/dest/spartan/utils/index.js +22 -0
- package/dest/spartan/utils/k8s.d.ts +128 -0
- package/dest/spartan/utils/k8s.d.ts.map +1 -0
- package/dest/spartan/utils/k8s.js +381 -0
- package/dest/spartan/utils/nodes.d.ts +40 -0
- package/dest/spartan/utils/nodes.d.ts.map +1 -0
- package/dest/spartan/utils/nodes.js +461 -0
- package/dest/spartan/utils/pod_logs.d.ts +25 -0
- package/dest/spartan/utils/pod_logs.d.ts.map +1 -0
- package/dest/spartan/utils/pod_logs.js +74 -0
- package/dest/spartan/utils/scripts.d.ts +30 -0
- package/dest/spartan/utils/scripts.d.ts.map +1 -0
- package/dest/spartan/utils/scripts.js +81 -0
- package/dest/spartan/utils.d.ts +2 -415
- package/dest/spartan/utils.d.ts.map +1 -1
- package/dest/spartan/utils.js +1 -445
- package/dest/test-wallet/test_wallet.d.ts +83 -0
- package/dest/test-wallet/test_wallet.d.ts.map +1 -0
- package/dest/test-wallet/test_wallet.js +214 -0
- package/dest/test-wallet/utils.d.ts +41 -0
- package/dest/test-wallet/utils.d.ts.map +1 -0
- package/dest/test-wallet/utils.js +71 -0
- package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
- package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
- package/dest/test-wallet/wallet_worker_script.js +48 -0
- package/dest/test-wallet/worker_wallet.d.ts +52 -0
- package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
- package/dest/test-wallet/worker_wallet.js +151 -0
- package/dest/test-wallet/worker_wallet_schema.d.ts +274 -0
- package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
- package/dest/test-wallet/worker_wallet_schema.js +10 -0
- package/package.json +72 -62
- package/src/bench/client_flows/benchmark.ts +363 -0
- package/src/bench/client_flows/client_flows_benchmark.ts +388 -0
- package/src/bench/client_flows/config.ts +69 -0
- package/src/bench/client_flows/data_extractor.ts +89 -0
- package/src/bench/utils.ts +47 -86
- package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +149 -171
- package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +155 -182
- package/src/e2e_deploy_contract/deploy_test.ts +40 -48
- package/src/e2e_epochs/epochs_test.ts +364 -93
- package/src/e2e_fees/bridging_race.notest.ts +74 -0
- package/src/e2e_fees/fees_test.ts +213 -259
- package/src/e2e_l1_publisher/write_json.ts +77 -0
- package/src/e2e_multi_validator/utils.ts +258 -0
- package/src/e2e_nested_contract/nested_contract_test.ts +48 -59
- package/src/e2e_p2p/inactivity_slash_test.ts +179 -0
- package/src/e2e_p2p/p2p_network.ts +367 -234
- package/src/e2e_p2p/reqresp/utils.ts +256 -0
- package/src/e2e_p2p/shared.ts +315 -39
- package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
- package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
- package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
- package/src/e2e_token_contract/token_contract_test.ts +132 -126
- package/src/fixtures/authwit_proxy.ts +50 -0
- package/src/fixtures/dumps/epoch_proof_result.json +1 -1
- package/src/fixtures/e2e_prover_test.ts +332 -0
- package/src/fixtures/elu_monitor.ts +126 -0
- package/src/fixtures/fixtures.ts +15 -7
- package/src/fixtures/get_acvm_config.ts +4 -12
- package/src/fixtures/get_bb_config.ts +18 -13
- package/src/fixtures/ha_setup.ts +186 -0
- package/src/fixtures/index.ts +1 -0
- package/src/fixtures/l1_to_l2_messaging.ts +56 -24
- package/src/fixtures/setup.ts +903 -0
- package/src/fixtures/setup_p2p_test.ts +134 -50
- package/src/fixtures/token_utils.ts +37 -16
- package/src/fixtures/utils.ts +27 -820
- package/src/fixtures/web3signer.ts +63 -0
- package/src/fixtures/with_telemetry_utils.ts +2 -2
- package/src/guides/up_quick_start.sh +9 -17
- package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +2 -2
- package/src/quality_of_service/prometheus_client.ts +113 -0
- package/src/shared/cross_chain_test_harness.ts +110 -94
- package/src/shared/gas_portal_test_harness.ts +59 -50
- package/src/shared/index.ts +2 -1
- package/src/shared/jest_setup.ts +52 -2
- package/src/shared/mock_state_view.ts +188 -0
- package/src/shared/submit-transactions.ts +19 -20
- package/src/shared/uniswap_l1_l2.ts +207 -226
- package/src/simulators/lending_simulator.ts +18 -17
- package/src/simulators/token_simulator.ts +18 -34
- package/src/spartan/DEVELOP.md +128 -0
- package/src/spartan/setup_test_wallets.ts +393 -95
- package/src/spartan/tx_metrics.ts +376 -0
- package/src/spartan/utils/bot.ts +188 -0
- package/src/spartan/utils/chaos.ts +253 -0
- package/src/spartan/utils/clients.ts +100 -0
- package/src/spartan/utils/config.ts +29 -0
- package/src/spartan/utils/health.ts +255 -0
- package/src/spartan/utils/helm.ts +84 -0
- package/src/spartan/utils/index.ts +71 -0
- package/src/spartan/utils/k8s.ts +535 -0
- package/src/spartan/utils/nodes.ts +543 -0
- package/src/spartan/utils/pod_logs.ts +99 -0
- package/src/spartan/utils/scripts.ts +99 -0
- package/src/spartan/utils.ts +1 -582
- package/src/test-wallet/test_wallet.ts +306 -0
- package/src/test-wallet/utils.ts +112 -0
- package/src/test-wallet/wallet_worker_script.ts +60 -0
- package/src/test-wallet/worker_wallet.ts +213 -0
- package/src/test-wallet/worker_wallet_schema.ts +13 -0
- package/dest/e2e_prover/e2e_prover_test.d.ts +0 -56
- package/dest/e2e_prover/e2e_prover_test.d.ts.map +0 -1
- package/dest/e2e_prover/e2e_prover_test.js +0 -291
- package/dest/fixtures/setup_l1_contracts.d.ts +0 -6
- package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
- package/dest/fixtures/setup_l1_contracts.js +0 -17
- package/dest/fixtures/snapshot_manager.d.ts +0 -87
- package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
- package/dest/fixtures/snapshot_manager.js +0 -479
- package/dest/quality_of_service/alert_checker.d.ts +0 -41
- package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
- package/dest/sample-dapp/connect.js +0 -12
- package/dest/sample-dapp/contracts.js +0 -10
- package/dest/sample-dapp/deploy.js +0 -35
- package/dest/sample-dapp/index.js +0 -98
- package/src/e2e_prover/e2e_prover_test.ts +0 -418
- package/src/fixtures/setup_l1_contracts.ts +0 -27
- package/src/fixtures/snapshot_manager.ts +0 -617
- package/src/sample-dapp/connect.mjs +0 -16
- package/src/sample-dapp/contracts.mjs +0 -14
- package/src/sample-dapp/deploy.mjs +0 -40
- package/src/sample-dapp/index.mjs +0 -128
|
@@ -1,127 +1,173 @@
|
|
|
1
|
-
import { getSchnorrWalletWithSecretKey } from '@aztec/accounts/schnorr';
|
|
2
1
|
import type { InitialAccountData } from '@aztec/accounts/testing';
|
|
3
2
|
import type { AztecNodeConfig, AztecNodeService } from '@aztec/aztec-node';
|
|
4
|
-
import
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
|
|
3
|
+
import { AztecAddress, EthAddress } from '@aztec/aztec.js/addresses';
|
|
4
|
+
import { Fr } from '@aztec/aztec.js/fields';
|
|
5
|
+
import { getL1ContractsConfigEnvVars } from '@aztec/ethereum/config';
|
|
6
|
+
import {
|
|
7
|
+
type EmpireSlashingProposerContract,
|
|
8
|
+
GSEContract,
|
|
9
|
+
RollupContract,
|
|
10
|
+
type TallySlashingProposerContract,
|
|
11
|
+
} from '@aztec/ethereum/contracts';
|
|
12
|
+
import type { Operator } from '@aztec/ethereum/deploy-aztec-l1-contracts';
|
|
13
|
+
import { deployL1Contract } from '@aztec/ethereum/deploy-l1-contract';
|
|
14
|
+
import { MultiAdderArtifact } from '@aztec/ethereum/l1-artifacts';
|
|
15
|
+
import { createL1TxUtils } from '@aztec/ethereum/l1-tx-utils';
|
|
16
|
+
import { ChainMonitor } from '@aztec/ethereum/test';
|
|
17
|
+
import type { ExtendedViemWalletClient, ViemClient } from '@aztec/ethereum/types';
|
|
18
|
+
import { EpochNumber } from '@aztec/foundation/branded-types';
|
|
19
|
+
import { SecretValue } from '@aztec/foundation/config';
|
|
9
20
|
import { type Logger, createLogger } from '@aztec/foundation/log';
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
21
|
+
import { retryUntil } from '@aztec/foundation/retry';
|
|
22
|
+
import { RollupAbi, SlasherAbi, TestERC20Abi } from '@aztec/l1-artifacts';
|
|
23
|
+
import { SpamContract } from '@aztec/noir-test-contracts.js/Spam';
|
|
12
24
|
import type { BootstrapNode } from '@aztec/p2p/bootstrap';
|
|
13
25
|
import { createBootstrapNodeFromPrivateKey, getBootstrapNodeEnr } from '@aztec/p2p/test-helpers';
|
|
26
|
+
import { tryStop } from '@aztec/stdlib/interfaces/server';
|
|
27
|
+
import { SlashFactoryContract } from '@aztec/stdlib/l1-contracts';
|
|
28
|
+
import { TopicType } from '@aztec/stdlib/p2p';
|
|
14
29
|
import type { PublicDataTreeLeaf } from '@aztec/stdlib/trees';
|
|
30
|
+
import { ZkPassportProofParams } from '@aztec/stdlib/zkpassport';
|
|
15
31
|
import { getGenesisValues } from '@aztec/world-state/testing';
|
|
16
32
|
|
|
17
33
|
import getPort from 'get-port';
|
|
18
|
-
import { getContract } from 'viem';
|
|
34
|
+
import { type GetContractReturnType, getAddress, getContract } from 'viem';
|
|
19
35
|
import { privateKeyToAccount } from 'viem/accounts';
|
|
20
36
|
|
|
37
|
+
import {
|
|
38
|
+
type EndToEndContext,
|
|
39
|
+
type SetupOptions,
|
|
40
|
+
deployAccounts,
|
|
41
|
+
getPrivateKeyFromIndex,
|
|
42
|
+
getSponsoredFPCAddress,
|
|
43
|
+
setup,
|
|
44
|
+
teardown,
|
|
45
|
+
} from '../fixtures/setup.js';
|
|
21
46
|
import {
|
|
22
47
|
ATTESTER_PRIVATE_KEYS_START_INDEX,
|
|
23
|
-
PROPOSER_PRIVATE_KEYS_START_INDEX,
|
|
24
48
|
createValidatorConfig,
|
|
25
49
|
generatePrivateKeys,
|
|
26
50
|
} from '../fixtures/setup_p2p_test.js';
|
|
27
|
-
import {
|
|
28
|
-
type ISnapshotManager,
|
|
29
|
-
type SubsystemsContext,
|
|
30
|
-
createSnapshotManager,
|
|
31
|
-
deployAccounts,
|
|
32
|
-
} from '../fixtures/snapshot_manager.js';
|
|
33
|
-
import { getPrivateKeyFromIndex } from '../fixtures/utils.js';
|
|
34
51
|
import { getEndToEndTestTelemetryClient } from '../fixtures/with_telemetry_utils.js';
|
|
52
|
+
import type { TestWallet } from '../test-wallet/test_wallet.js';
|
|
35
53
|
|
|
36
54
|
// Use a fixed bootstrap node private key so that we can re-use the same snapshot and the nodes can find each other
|
|
37
55
|
const BOOTSTRAP_NODE_PRIVATE_KEY = '080212208f988fc0899e4a73a5aee4d271a5f20670603a756ad8d84f2c94263a6427c591';
|
|
38
56
|
const l1ContractsConfig = getL1ContractsConfigEnvVars();
|
|
39
57
|
export const WAIT_FOR_TX_TIMEOUT = l1ContractsConfig.aztecSlotDuration * 3;
|
|
40
58
|
|
|
41
|
-
export const
|
|
59
|
+
export const SHORTENED_BLOCK_TIME_CONFIG_NO_PRUNES = {
|
|
42
60
|
aztecSlotDuration: 12,
|
|
43
61
|
ethereumSlotDuration: 4,
|
|
62
|
+
aztecProofSubmissionEpochs: 640,
|
|
44
63
|
};
|
|
45
64
|
|
|
46
65
|
export class P2PNetworkTest {
|
|
47
|
-
|
|
48
|
-
|
|
66
|
+
public context!: EndToEndContext;
|
|
67
|
+
public baseAccountPrivateKey: `0x${string}`;
|
|
68
|
+
public baseAccount;
|
|
49
69
|
|
|
50
70
|
public logger: Logger;
|
|
51
71
|
public monitor!: ChainMonitor;
|
|
52
72
|
|
|
53
|
-
public ctx!:
|
|
73
|
+
public ctx!: EndToEndContext;
|
|
54
74
|
public attesterPrivateKeys: `0x${string}`[] = [];
|
|
55
75
|
public attesterPublicKeys: string[] = [];
|
|
56
|
-
public proposerPrivateKeys: `0x${string}`[] = [];
|
|
57
76
|
public peerIdPrivateKeys: string[] = [];
|
|
77
|
+
public validators: Operator[] = [];
|
|
58
78
|
|
|
59
79
|
public deployedAccounts: InitialAccountData[] = [];
|
|
60
80
|
public prefilledPublicData: PublicDataTreeLeaf[] = [];
|
|
81
|
+
|
|
61
82
|
// The re-execution test needs a wallet and a spam contract
|
|
62
|
-
public wallet?:
|
|
83
|
+
public wallet?: TestWallet;
|
|
84
|
+
public defaultAccountAddress?: AztecAddress;
|
|
63
85
|
public spamContract?: SpamContract;
|
|
64
86
|
|
|
65
87
|
public bootstrapNode?: BootstrapNode;
|
|
66
88
|
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
private
|
|
89
|
+
// Store setup options for use in setup()
|
|
90
|
+
private setupOptions: SetupOptions;
|
|
91
|
+
private deployL1ContractsArgs: any;
|
|
70
92
|
|
|
71
93
|
constructor(
|
|
72
|
-
testName: string,
|
|
94
|
+
public readonly testName: string,
|
|
73
95
|
public bootstrapNodeEnr: string,
|
|
74
96
|
public bootNodePort: number,
|
|
75
|
-
|
|
76
|
-
initialValidatorConfig:
|
|
97
|
+
public numberOfValidators: number,
|
|
98
|
+
initialValidatorConfig: SetupOptions,
|
|
99
|
+
public numberOfNodes = 0,
|
|
77
100
|
// If set enable metrics collection
|
|
78
101
|
private metricsPort?: number,
|
|
102
|
+
startProverNode?: boolean,
|
|
79
103
|
) {
|
|
80
104
|
this.logger = createLogger(`e2e:e2e_p2p:${testName}`);
|
|
81
105
|
|
|
82
106
|
// Set up the base account and node private keys for the initial network deployment
|
|
83
|
-
this.
|
|
84
|
-
this.
|
|
85
|
-
this.attesterPrivateKeys = generatePrivateKeys(
|
|
107
|
+
this.baseAccountPrivateKey = `0x${getPrivateKeyFromIndex(1)!.toString('hex')}`;
|
|
108
|
+
this.baseAccount = privateKeyToAccount(this.baseAccountPrivateKey);
|
|
109
|
+
this.attesterPrivateKeys = generatePrivateKeys(
|
|
110
|
+
ATTESTER_PRIVATE_KEYS_START_INDEX + numberOfNodes,
|
|
111
|
+
numberOfValidators,
|
|
112
|
+
);
|
|
86
113
|
this.attesterPublicKeys = this.attesterPrivateKeys.map(privateKey => privateKeyToAccount(privateKey).address);
|
|
87
114
|
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
115
|
+
const zkPassportParams = ZkPassportProofParams.random();
|
|
116
|
+
|
|
117
|
+
// Store setup options for later use
|
|
118
|
+
this.setupOptions = {
|
|
119
|
+
...initialValidatorConfig,
|
|
120
|
+
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
121
|
+
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
122
|
+
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
123
|
+
aztecProofSubmissionEpochs:
|
|
124
|
+
initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
|
|
125
|
+
slashingRoundSizeInEpochs:
|
|
126
|
+
initialValidatorConfig.slashingRoundSizeInEpochs ?? l1ContractsConfig.slashingRoundSizeInEpochs,
|
|
127
|
+
slasherFlavor: initialValidatorConfig.slasherFlavor ?? 'tally',
|
|
128
|
+
aztecTargetCommitteeSize: numberOfValidators,
|
|
129
|
+
metricsPort: metricsPort,
|
|
130
|
+
numberOfInitialFundedAccounts: 2,
|
|
131
|
+
startProverNode,
|
|
132
|
+
walletMinFeePadding: 2.0,
|
|
133
|
+
};
|
|
134
|
+
|
|
135
|
+
this.deployL1ContractsArgs = {
|
|
136
|
+
...initialValidatorConfig,
|
|
137
|
+
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
138
|
+
slashingRoundSizeInEpochs:
|
|
139
|
+
initialValidatorConfig.slashingRoundSizeInEpochs ?? l1ContractsConfig.slashingRoundSizeInEpochs,
|
|
140
|
+
slasherFlavor: initialValidatorConfig.slasherFlavor ?? 'tally',
|
|
141
|
+
|
|
142
|
+
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
143
|
+
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
144
|
+
aztecProofSubmissionEpochs:
|
|
145
|
+
initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
|
|
146
|
+
aztecTargetCommitteeSize: numberOfValidators,
|
|
147
|
+
initialValidators: [],
|
|
148
|
+
zkPassportArgs: {
|
|
149
|
+
zkPassportDomain: zkPassportParams.domain,
|
|
150
|
+
zkPassportScope: zkPassportParams.scope,
|
|
101
151
|
},
|
|
102
|
-
|
|
103
|
-
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
104
|
-
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
105
|
-
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
106
|
-
aztecProofSubmissionWindow:
|
|
107
|
-
initialValidatorConfig.aztecProofSubmissionWindow ?? l1ContractsConfig.aztecProofSubmissionWindow,
|
|
108
|
-
initialValidators: [],
|
|
109
|
-
},
|
|
110
|
-
);
|
|
152
|
+
};
|
|
111
153
|
}
|
|
112
154
|
|
|
113
155
|
static async create({
|
|
114
156
|
testName,
|
|
115
157
|
numberOfNodes,
|
|
158
|
+
numberOfValidators,
|
|
116
159
|
basePort,
|
|
117
160
|
metricsPort,
|
|
118
161
|
initialConfig,
|
|
162
|
+
startProverNode,
|
|
119
163
|
}: {
|
|
120
164
|
testName: string;
|
|
121
165
|
numberOfNodes: number;
|
|
166
|
+
numberOfValidators: number;
|
|
122
167
|
basePort?: number;
|
|
123
168
|
metricsPort?: number;
|
|
124
|
-
initialConfig?:
|
|
169
|
+
initialConfig?: SetupOptions;
|
|
170
|
+
startProverNode?: boolean;
|
|
125
171
|
}) {
|
|
126
172
|
const port = basePort || (await getPort());
|
|
127
173
|
|
|
@@ -133,213 +179,205 @@ export class P2PNetworkTest {
|
|
|
133
179
|
bootstrapNodeEnr,
|
|
134
180
|
);
|
|
135
181
|
|
|
136
|
-
return new P2PNetworkTest(
|
|
182
|
+
return new P2PNetworkTest(
|
|
183
|
+
testName,
|
|
184
|
+
bootstrapNodeEnr,
|
|
185
|
+
port,
|
|
186
|
+
numberOfValidators,
|
|
187
|
+
initialValidatorConfig,
|
|
188
|
+
numberOfNodes,
|
|
189
|
+
metricsPort,
|
|
190
|
+
startProverNode,
|
|
191
|
+
);
|
|
137
192
|
}
|
|
138
193
|
|
|
139
194
|
get fundedAccount() {
|
|
140
195
|
if (!this.deployedAccounts[0]) {
|
|
141
|
-
throw new Error('Call
|
|
196
|
+
throw new Error('Call setupAccount to create a funded account.');
|
|
142
197
|
}
|
|
143
198
|
return this.deployedAccounts[0];
|
|
144
199
|
}
|
|
145
200
|
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
201
|
+
async addBootstrapNode() {
|
|
202
|
+
this.logger.info('Adding bootstrap node');
|
|
203
|
+
const telemetry = await getEndToEndTestTelemetryClient(this.metricsPort);
|
|
204
|
+
this.bootstrapNode = await createBootstrapNodeFromPrivateKey(
|
|
205
|
+
BOOTSTRAP_NODE_PRIVATE_KEY,
|
|
206
|
+
this.bootNodePort,
|
|
207
|
+
telemetry,
|
|
208
|
+
this.context.config,
|
|
209
|
+
);
|
|
210
|
+
// Overwrite enr with updated info
|
|
211
|
+
this.bootstrapNodeEnr = this.bootstrapNode.getENR().encodeTxt();
|
|
153
212
|
}
|
|
154
213
|
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
214
|
+
getValidators() {
|
|
215
|
+
const validators: Operator[] = [];
|
|
216
|
+
|
|
217
|
+
for (let i = 0; i < this.numberOfValidators; i++) {
|
|
218
|
+
const keyIndex = i;
|
|
219
|
+
const attester = privateKeyToAccount(this.attesterPrivateKeys[keyIndex]!);
|
|
220
|
+
|
|
221
|
+
validators.push({
|
|
222
|
+
attester: EthAddress.fromString(attester.address),
|
|
223
|
+
withdrawer: EthAddress.fromString(attester.address),
|
|
224
|
+
bn254SecretKey: new SecretValue(Fr.random().toBigInt()),
|
|
225
|
+
});
|
|
226
|
+
|
|
227
|
+
this.logger.info(`Adding attester ${attester.address} as validator`);
|
|
228
|
+
}
|
|
229
|
+
return { validators };
|
|
170
230
|
}
|
|
171
231
|
|
|
172
|
-
async
|
|
173
|
-
await this.
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
);
|
|
181
|
-
// Overwrite enr with updated info
|
|
182
|
-
this.bootstrapNodeEnr = this.bootstrapNode.getENR().encodeTxt();
|
|
232
|
+
async applyBaseSetup() {
|
|
233
|
+
await this.addBootstrapNode();
|
|
234
|
+
|
|
235
|
+
this.logger.info('Adding validators');
|
|
236
|
+
const rollup = getContract({
|
|
237
|
+
address: this.context.deployL1ContractsValues.l1ContractAddresses.rollupAddress.toString(),
|
|
238
|
+
abi: RollupAbi,
|
|
239
|
+
client: this.context.deployL1ContractsValues.l1Client,
|
|
183
240
|
});
|
|
184
241
|
|
|
185
|
-
|
|
186
|
-
'add-validators',
|
|
187
|
-
async ({ deployL1ContractsValues, aztecNodeConfig, dateProvider }) => {
|
|
188
|
-
const rollup = getContract({
|
|
189
|
-
address: deployL1ContractsValues.l1ContractAddresses.rollupAddress.toString(),
|
|
190
|
-
abi: RollupAbi,
|
|
191
|
-
client: deployL1ContractsValues.walletClient,
|
|
192
|
-
});
|
|
193
|
-
|
|
194
|
-
this.logger.verbose(`Adding ${this.numberOfNodes} validators`);
|
|
195
|
-
|
|
196
|
-
const stakingAsset = getContract({
|
|
197
|
-
address: deployL1ContractsValues.l1ContractAddresses.stakingAssetAddress.toString(),
|
|
198
|
-
abi: TestERC20Abi,
|
|
199
|
-
client: deployL1ContractsValues.walletClient,
|
|
200
|
-
});
|
|
201
|
-
|
|
202
|
-
const stakeNeeded = l1ContractsConfig.minimumStake * BigInt(this.numberOfNodes);
|
|
203
|
-
await Promise.all(
|
|
204
|
-
[
|
|
205
|
-
await stakingAsset.write.mint(
|
|
206
|
-
[deployL1ContractsValues.walletClient.account.address, stakeNeeded],
|
|
207
|
-
{} as any,
|
|
208
|
-
),
|
|
209
|
-
await stakingAsset.write.approve(
|
|
210
|
-
[deployL1ContractsValues.l1ContractAddresses.rollupAddress.toString(), stakeNeeded],
|
|
211
|
-
{} as any,
|
|
212
|
-
),
|
|
213
|
-
].map(txHash => deployL1ContractsValues.publicClient.waitForTransactionReceipt({ hash: txHash })),
|
|
214
|
-
);
|
|
242
|
+
this.logger.info(`Adding ${this.numberOfValidators} validators`);
|
|
215
243
|
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
const slotsInEpoch = await rollup.read.getEpochDuration();
|
|
242
|
-
const timestamp = await rollup.read.getTimestampForSlot([slotsInEpoch]);
|
|
243
|
-
const cheatCodes = new EthCheatCodesWithState(aztecNodeConfig.l1RpcUrls);
|
|
244
|
-
try {
|
|
245
|
-
await cheatCodes.warp(Number(timestamp));
|
|
246
|
-
} catch (err) {
|
|
247
|
-
this.logger.debug('Warp failed, time already satisfied');
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
// Send and await a tx to make sure we mine a block for the warp to correctly progress.
|
|
251
|
-
await deployL1ContractsValues.publicClient.waitForTransactionReceipt({
|
|
252
|
-
hash: await deployL1ContractsValues.walletClient.sendTransaction({
|
|
253
|
-
to: this.baseAccount.address,
|
|
254
|
-
value: 1n,
|
|
255
|
-
account: this.baseAccount,
|
|
256
|
-
}),
|
|
257
|
-
});
|
|
258
|
-
|
|
259
|
-
// Set the system time in the node, only after we have warped the time and waited for a block
|
|
260
|
-
// Time is only set in the NEXT block
|
|
261
|
-
dateProvider.setTime(Number(timestamp) * 1000);
|
|
262
|
-
},
|
|
244
|
+
const stakingAsset = getContract({
|
|
245
|
+
address: this.context.deployL1ContractsValues.l1ContractAddresses.stakingAssetAddress.toString(),
|
|
246
|
+
abi: TestERC20Abi,
|
|
247
|
+
client: this.context.deployL1ContractsValues.l1Client,
|
|
248
|
+
});
|
|
249
|
+
|
|
250
|
+
const { address: multiAdderAddress } = await deployL1Contract(
|
|
251
|
+
this.context.deployL1ContractsValues.l1Client,
|
|
252
|
+
MultiAdderArtifact.contractAbi,
|
|
253
|
+
MultiAdderArtifact.contractBytecode,
|
|
254
|
+
[rollup.address, this.context.deployL1ContractsValues.l1Client.account.address],
|
|
255
|
+
);
|
|
256
|
+
|
|
257
|
+
const multiAdder = getContract({
|
|
258
|
+
address: multiAdderAddress.toString(),
|
|
259
|
+
abi: MultiAdderArtifact.contractAbi,
|
|
260
|
+
client: this.context.deployL1ContractsValues.l1Client,
|
|
261
|
+
});
|
|
262
|
+
|
|
263
|
+
const stakeNeeded = (await rollup.read.getActivationThreshold()) * BigInt(this.numberOfValidators);
|
|
264
|
+
await Promise.all(
|
|
265
|
+
[await stakingAsset.write.mint([multiAdder.address, stakeNeeded], {} as any)].map(txHash =>
|
|
266
|
+
this.context.deployL1ContractsValues.l1Client.waitForTransactionReceipt({ hash: txHash }),
|
|
267
|
+
),
|
|
263
268
|
);
|
|
269
|
+
|
|
270
|
+
const { validators } = this.getValidators();
|
|
271
|
+
this.validators = validators;
|
|
272
|
+
|
|
273
|
+
const gseAddress = this.context.deployL1ContractsValues.l1ContractAddresses.gseAddress!;
|
|
274
|
+
if (!gseAddress) {
|
|
275
|
+
throw new Error('GSE contract not deployed');
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
const gseContract = new GSEContract(this.context.deployL1ContractsValues.l1Client, gseAddress.toString());
|
|
279
|
+
|
|
280
|
+
const makeValidatorTuples = async (validator: Operator) => {
|
|
281
|
+
const registrationTuple = await gseContract.makeRegistrationTuple(validator.bn254SecretKey.getValue());
|
|
282
|
+
return {
|
|
283
|
+
attester: validator.attester.toString() as `0x${string}`,
|
|
284
|
+
withdrawer: validator.withdrawer.toString() as `0x${string}`,
|
|
285
|
+
...registrationTuple,
|
|
286
|
+
};
|
|
287
|
+
};
|
|
288
|
+
const validatorTuples = await Promise.all(validators.map(makeValidatorTuples));
|
|
289
|
+
|
|
290
|
+
await this.context.deployL1ContractsValues.l1Client.waitForTransactionReceipt({
|
|
291
|
+
hash: await multiAdder.write.addValidators([validatorTuples]),
|
|
292
|
+
});
|
|
293
|
+
|
|
294
|
+
await this.context.cheatCodes.rollup.advanceToEpoch(
|
|
295
|
+
EpochNumber.fromBigInt(
|
|
296
|
+
BigInt(await this.context.cheatCodes.rollup.getEpoch()) +
|
|
297
|
+
(await rollup.read.getLagInEpochsForValidatorSet()) +
|
|
298
|
+
1n,
|
|
299
|
+
),
|
|
300
|
+
);
|
|
301
|
+
|
|
302
|
+
// Send and await a tx to make sure we mine a block for the warp to correctly progress.
|
|
303
|
+
await this._sendDummyTx(this.context.deployL1ContractsValues.l1Client);
|
|
264
304
|
}
|
|
265
305
|
|
|
266
306
|
async setupAccount() {
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
307
|
+
this.logger.info('Setting up account');
|
|
308
|
+
const { deployedAccounts } = await deployAccounts(
|
|
309
|
+
1,
|
|
310
|
+
this.logger,
|
|
311
|
+
)({
|
|
312
|
+
wallet: this.context.wallet,
|
|
313
|
+
initialFundedAccounts: this.context.initialFundedAccounts,
|
|
314
|
+
});
|
|
315
|
+
this.deployedAccounts = deployedAccounts;
|
|
316
|
+
[{ address: this.defaultAccountAddress }] = deployedAccounts;
|
|
317
|
+
this.wallet = this.context.wallet;
|
|
276
318
|
}
|
|
277
319
|
|
|
278
320
|
async deploySpamContract() {
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
return { contractAddress: spamContract.address };
|
|
288
|
-
},
|
|
289
|
-
async ({ contractAddress }) => {
|
|
290
|
-
if (!this.wallet) {
|
|
291
|
-
throw new Error('Call snapshot t.setupAccount before deploying account contract');
|
|
292
|
-
}
|
|
293
|
-
this.spamContract = await SpamContract.at(contractAddress, this.wallet);
|
|
294
|
-
},
|
|
295
|
-
);
|
|
321
|
+
this.logger.info('Deploying spam contract');
|
|
322
|
+
if (!this.wallet) {
|
|
323
|
+
throw new Error('Call setupAccount before deploying spam contract');
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
({ contract: this.spamContract } = await SpamContract.deploy(this.wallet).send({
|
|
327
|
+
from: this.defaultAccountAddress!,
|
|
328
|
+
}));
|
|
296
329
|
}
|
|
297
330
|
|
|
298
331
|
async removeInitialNode() {
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
value: 1n,
|
|
307
|
-
account: this.baseAccount,
|
|
308
|
-
}),
|
|
309
|
-
});
|
|
310
|
-
const block = await deployL1ContractsValues.publicClient.getBlock({
|
|
311
|
-
blockNumber: receipt.blockNumber,
|
|
312
|
-
});
|
|
313
|
-
dateProvider.setTime(Number(block.timestamp) * 1000);
|
|
314
|
-
|
|
315
|
-
await aztecNode.stop();
|
|
316
|
-
},
|
|
317
|
-
);
|
|
318
|
-
}
|
|
332
|
+
this.logger.info('Removing initial node');
|
|
333
|
+
// Send and await a tx to make sure we mine a block for the warp to correctly progress.
|
|
334
|
+
const { receipt } = await this._sendDummyTx(this.context.deployL1ContractsValues.l1Client);
|
|
335
|
+
const block = await this.context.deployL1ContractsValues.l1Client.getBlock({
|
|
336
|
+
blockNumber: receipt.blockNumber,
|
|
337
|
+
});
|
|
338
|
+
this.context.dateProvider.setTime(Number(block.timestamp) * 1000);
|
|
319
339
|
|
|
320
|
-
|
|
321
|
-
|
|
340
|
+
await this.context.aztecNodeService.stop();
|
|
341
|
+
}
|
|
322
342
|
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
343
|
+
async sendDummyTx() {
|
|
344
|
+
return await this._sendDummyTx(this.ctx.deployL1ContractsValues.l1Client);
|
|
345
|
+
}
|
|
326
346
|
|
|
327
|
-
|
|
347
|
+
private async _sendDummyTx(l1Client: ExtendedViemWalletClient) {
|
|
348
|
+
const l1TxUtils = createL1TxUtils(l1Client);
|
|
349
|
+
return await l1TxUtils.sendAndMonitorTransaction({
|
|
350
|
+
to: l1Client.account!.address,
|
|
351
|
+
value: 1n,
|
|
352
|
+
});
|
|
353
|
+
}
|
|
328
354
|
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
355
|
+
async setup() {
|
|
356
|
+
this.logger.info('Setting up subsystems from fresh');
|
|
357
|
+
this.context = await setup(
|
|
358
|
+
0,
|
|
333
359
|
{
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
360
|
+
...this.setupOptions,
|
|
361
|
+
fundSponsoredFPC: true,
|
|
362
|
+
skipAccountDeployment: true,
|
|
363
|
+
slasherFlavor: this.setupOptions.slasherFlavor ?? this.deployL1ContractsArgs.slasherFlavor ?? 'none',
|
|
364
|
+
aztecTargetCommitteeSize: 0,
|
|
365
|
+
l1ContractsArgs: this.deployL1ContractsArgs,
|
|
339
366
|
},
|
|
367
|
+
// Use checkpointed chain tip for PXE to avoid issues with blocks being dropped due to pruned anchor blocks.
|
|
368
|
+
{ syncChainTip: 'checkpointed' },
|
|
340
369
|
);
|
|
370
|
+
this.ctx = this.context;
|
|
371
|
+
|
|
372
|
+
const sponsoredFPCAddress = await getSponsoredFPCAddress();
|
|
373
|
+
const initialFundedAccounts = [...this.context.initialFundedAccounts.map(a => a.address), sponsoredFPCAddress];
|
|
341
374
|
|
|
342
|
-
|
|
375
|
+
const { prefilledPublicData } = await getGenesisValues(initialFundedAccounts);
|
|
376
|
+
this.prefilledPublicData = prefilledPublicData;
|
|
377
|
+
|
|
378
|
+
const rollupContract = RollupContract.getFromL1ContractsValues(this.context.deployL1ContractsValues);
|
|
379
|
+
this.monitor = new ChainMonitor(rollupContract, this.context.dateProvider).start();
|
|
380
|
+
this.monitor.on('l1-block', ({ timestamp }) => this.context.dateProvider.setTime(Number(timestamp) * 1000));
|
|
343
381
|
}
|
|
344
382
|
|
|
345
383
|
async stopNodes(nodes: AztecNodeService[]) {
|
|
@@ -355,12 +393,107 @@ export class P2PNetworkTest {
|
|
|
355
393
|
this.logger.info('Nodes stopped');
|
|
356
394
|
}
|
|
357
395
|
|
|
396
|
+
/**
|
|
397
|
+
* Wait for P2P mesh to be fully formed across all nodes.
|
|
398
|
+
* This ensures that all nodes are connected to each other before proceeding,
|
|
399
|
+
* preventing race conditions where validators propose blocks before the network is ready.
|
|
400
|
+
*
|
|
401
|
+
* @param nodes - Array of nodes to check for P2P connectivity
|
|
402
|
+
* @param expectedNodeCount - Expected number of nodes in the network (defaults to nodes.length)
|
|
403
|
+
* @param timeoutSeconds - Maximum time to wait for connections (default: 30 seconds)
|
|
404
|
+
* @param checkIntervalSeconds - How often to check connectivity (default: 0.1 seconds)
|
|
405
|
+
*/
|
|
406
|
+
async waitForP2PMeshConnectivity(
|
|
407
|
+
nodes: AztecNodeService[],
|
|
408
|
+
expectedNodeCount?: number,
|
|
409
|
+
timeoutSeconds = 30,
|
|
410
|
+
checkIntervalSeconds = 0.1,
|
|
411
|
+
topics: TopicType[] = [TopicType.tx],
|
|
412
|
+
) {
|
|
413
|
+
const nodeCount = expectedNodeCount ?? nodes.length;
|
|
414
|
+
const minPeerCount = nodeCount - 1;
|
|
415
|
+
|
|
416
|
+
this.logger.warn(
|
|
417
|
+
`Waiting for all ${nodeCount} nodes to connect to P2P mesh (at least ${minPeerCount} peers each)...`,
|
|
418
|
+
);
|
|
419
|
+
|
|
420
|
+
await Promise.all(
|
|
421
|
+
nodes.map(async (node, index) => {
|
|
422
|
+
const p2p = node.getP2P();
|
|
423
|
+
await retryUntil(
|
|
424
|
+
async () => {
|
|
425
|
+
const peers = await p2p.getPeers();
|
|
426
|
+
// Each node should be connected to at least N-1 other nodes
|
|
427
|
+
return peers.length >= minPeerCount ? true : undefined;
|
|
428
|
+
},
|
|
429
|
+
`Node ${index} to connect to at least ${minPeerCount} peers`,
|
|
430
|
+
timeoutSeconds,
|
|
431
|
+
checkIntervalSeconds,
|
|
432
|
+
);
|
|
433
|
+
}),
|
|
434
|
+
);
|
|
435
|
+
|
|
436
|
+
this.logger.warn('All nodes connected to P2P mesh');
|
|
437
|
+
|
|
438
|
+
// Wait for GossipSub mesh to form for all specified topics.
|
|
439
|
+
// We only require at least 1 mesh peer per node because GossipSub
|
|
440
|
+
// stops grafting once it reaches Dlo peers and won't fill the mesh to all available peers.
|
|
441
|
+
for (const topic of topics) {
|
|
442
|
+
this.logger.warn(`Waiting for GossipSub mesh to form for ${topic} topic...`);
|
|
443
|
+
await Promise.all(
|
|
444
|
+
nodes.map(async (node, index) => {
|
|
445
|
+
const p2p = node.getP2P();
|
|
446
|
+
await retryUntil(
|
|
447
|
+
async () => {
|
|
448
|
+
const meshPeers = await p2p.getGossipMeshPeerCount(topic);
|
|
449
|
+
this.logger.debug(`Node ${index} has ${meshPeers} gossip mesh peers for ${topic} topic`);
|
|
450
|
+
return meshPeers >= 1 ? true : undefined;
|
|
451
|
+
},
|
|
452
|
+
`Node ${index} to have gossip mesh peers for ${topic} topic`,
|
|
453
|
+
timeoutSeconds,
|
|
454
|
+
checkIntervalSeconds,
|
|
455
|
+
);
|
|
456
|
+
}),
|
|
457
|
+
);
|
|
458
|
+
this.logger.warn(`All nodes have gossip mesh peers for ${topic} topic`);
|
|
459
|
+
}
|
|
460
|
+
}
|
|
461
|
+
|
|
358
462
|
async teardown() {
|
|
359
|
-
this.monitor.stop();
|
|
360
|
-
await this.bootstrapNode
|
|
361
|
-
await this.
|
|
362
|
-
|
|
363
|
-
|
|
463
|
+
await this.monitor.stop();
|
|
464
|
+
await tryStop(this.bootstrapNode, this.logger);
|
|
465
|
+
await teardown(this.context);
|
|
466
|
+
}
|
|
467
|
+
|
|
468
|
+
async getContracts(): Promise<{
|
|
469
|
+
rollup: RollupContract;
|
|
470
|
+
slasherContract: GetContractReturnType<typeof SlasherAbi, ViemClient>;
|
|
471
|
+
slashingProposer: EmpireSlashingProposerContract | TallySlashingProposerContract | undefined;
|
|
472
|
+
slashFactory: SlashFactoryContract;
|
|
473
|
+
}> {
|
|
474
|
+
if (!this.ctx.deployL1ContractsValues) {
|
|
475
|
+
throw new Error('DeployAztecL1ContractsValues not set');
|
|
364
476
|
}
|
|
477
|
+
|
|
478
|
+
const rollup = new RollupContract(
|
|
479
|
+
this.ctx.deployL1ContractsValues!.l1Client,
|
|
480
|
+
this.ctx.deployL1ContractsValues!.l1ContractAddresses.rollupAddress,
|
|
481
|
+
);
|
|
482
|
+
|
|
483
|
+
const slasherContract = getContract({
|
|
484
|
+
address: getAddress((await rollup.getSlasherAddress()).toString()),
|
|
485
|
+
abi: SlasherAbi,
|
|
486
|
+
client: this.ctx.deployL1ContractsValues.l1Client,
|
|
487
|
+
});
|
|
488
|
+
|
|
489
|
+
// Get the actual slashing proposer from rollup (which handles both empire and tally)
|
|
490
|
+
const slashingProposer = await rollup.getSlashingProposer();
|
|
491
|
+
|
|
492
|
+
const slashFactory = new SlashFactoryContract(
|
|
493
|
+
this.ctx.deployL1ContractsValues.l1Client,
|
|
494
|
+
getAddress(this.ctx.deployL1ContractsValues.l1ContractAddresses.slashFactoryAddress!.toString()),
|
|
495
|
+
);
|
|
496
|
+
|
|
497
|
+
return { rollup, slasherContract, slashingProposer, slashFactory };
|
|
365
498
|
}
|
|
366
499
|
}
|