@aztec/end-to-end 0.0.0-test.0 → 0.0.1-commit.023c3e5
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 +321 -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 +106 -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 +41 -72
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +26 -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 +114 -102
- 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 +104 -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 +71 -22
- package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
- package/dest/e2e_epochs/epochs_test.js +260 -54
- 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 +162 -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 +37 -41
- 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 +281 -27
- package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
- package/dest/e2e_p2p/p2p_network.js +237 -175
- 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 +153 -0
- package/dest/e2e_p2p/shared.d.ts +44 -8
- package/dest/e2e_p2p/shared.d.ts.map +1 -1
- package/dest/e2e_p2p/shared.js +165 -27
- package/dest/e2e_token_contract/token_contract_test.d.ts +27 -14
- package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
- package/dest/e2e_token_contract/token_contract_test.js +96 -74
- 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 +278 -0
- package/dest/fixtures/fixtures.d.ts +6 -8
- package/dest/fixtures/fixtures.d.ts.map +1 -1
- package/dest/fixtures/fixtures.js +5 -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/index.d.ts +1 -1
- 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 +218 -0
- package/dest/fixtures/setup.d.ts.map +1 -0
- package/dest/fixtures/setup.js +695 -0
- package/dest/fixtures/setup_p2p_test.d.ts +15 -15
- package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
- package/dest/fixtures/setup_p2p_test.js +96 -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 +31 -12
- 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 +105 -51
- 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 +2 -2
- package/dest/shared/index.d.ts.map +1 -1
- package/dest/shared/jest_setup.d.ts +1 -1
- package/dest/shared/jest_setup.js +1 -1
- 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 +176 -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 +16 -13
- package/dest/spartan/setup_test_wallets.d.ts +27 -11
- package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
- package/dest/spartan/setup_test_wallets.js +233 -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 +27 -0
- package/dest/spartan/utils/bot.d.ts.map +1 -0
- package/dest/spartan/utils/bot.js +141 -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 +36 -0
- package/dest/spartan/utils/config.d.ts.map +1 -0
- package/dest/spartan/utils/config.js +20 -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 +9 -0
- package/dest/spartan/utils/index.d.ts.map +1 -0
- package/dest/spartan/utils/index.js +18 -0
- package/dest/spartan/utils/k8s.d.ts +126 -0
- package/dest/spartan/utils/k8s.d.ts.map +1 -0
- package/dest/spartan/utils/k8s.js +375 -0
- package/dest/spartan/utils/nodes.d.ts +41 -0
- package/dest/spartan/utils/nodes.d.ts.map +1 -0
- package/dest/spartan/utils/nodes.js +461 -0
- package/dest/spartan/utils/scripts.d.ts +16 -0
- package/dest/spartan/utils/scripts.d.ts.map +1 -0
- package/dest/spartan/utils/scripts.js +66 -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/package.json +66 -58
- package/src/bench/client_flows/benchmark.ts +363 -0
- package/src/bench/client_flows/client_flows_benchmark.ts +384 -0
- package/src/bench/client_flows/config.ts +61 -0
- package/src/bench/client_flows/data_extractor.ts +89 -0
- package/src/bench/utils.ts +41 -85
- package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +134 -169
- package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +156 -182
- package/src/e2e_deploy_contract/deploy_test.ts +40 -48
- package/src/e2e_epochs/epochs_test.ts +341 -81
- package/src/e2e_fees/bridging_race.notest.ts +74 -0
- package/src/e2e_fees/fees_test.ts +220 -258
- 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 +46 -59
- package/src/e2e_p2p/inactivity_slash_test.ts +179 -0
- package/src/e2e_p2p/p2p_network.ts +341 -234
- package/src/e2e_p2p/reqresp/utils.ts +207 -0
- package/src/e2e_p2p/shared.ts +260 -39
- package/src/e2e_token_contract/token_contract_test.ts +115 -126
- package/src/fixtures/dumps/epoch_proof_result.json +1 -1
- package/src/fixtures/e2e_prover_test.ts +336 -0
- package/src/fixtures/fixtures.ts +5 -7
- package/src/fixtures/get_acvm_config.ts +4 -12
- package/src/fixtures/get_bb_config.ts +18 -13
- package/src/fixtures/l1_to_l2_messaging.ts +56 -24
- package/src/fixtures/setup.ts +1017 -0
- package/src/fixtures/setup_p2p_test.ts +133 -50
- package/src/fixtures/token_utils.ts +33 -15
- 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 +7 -15
- 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 +103 -91
- package/src/shared/gas_portal_test_harness.ts +59 -50
- package/src/shared/index.ts +1 -1
- package/src/shared/jest_setup.ts +1 -1
- package/src/shared/submit-transactions.ts +18 -20
- package/src/shared/uniswap_l1_l2.ts +197 -221
- package/src/simulators/lending_simulator.ts +16 -17
- package/src/simulators/token_simulator.ts +21 -13
- package/src/spartan/DEVELOP.md +128 -0
- package/src/spartan/setup_test_wallets.ts +308 -95
- package/src/spartan/tx_metrics.ts +376 -0
- package/src/spartan/utils/bot.ts +185 -0
- package/src/spartan/utils/chaos.ts +253 -0
- package/src/spartan/utils/clients.ts +100 -0
- package/src/spartan/utils/config.ts +26 -0
- package/src/spartan/utils/health.ts +255 -0
- package/src/spartan/utils/helm.ts +84 -0
- package/src/spartan/utils/index.ts +64 -0
- package/src/spartan/utils/k8s.ts +527 -0
- package/src/spartan/utils/nodes.ts +538 -0
- package/src/spartan/utils/scripts.ts +63 -0
- package/src/spartan/utils.ts +1 -582
- 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,251 +1,273 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
1
|
+
import { EthAddress } from '@aztec/aztec.js/addresses';
|
|
2
|
+
import { Fr } from '@aztec/aztec.js/fields';
|
|
3
|
+
import { getL1ContractsConfigEnvVars } from '@aztec/ethereum/config';
|
|
4
|
+
import { GSEContract, RollupContract } from '@aztec/ethereum/contracts';
|
|
5
|
+
import { deployL1Contract } from '@aztec/ethereum/deploy-l1-contract';
|
|
6
|
+
import { MultiAdderArtifact } from '@aztec/ethereum/l1-artifacts';
|
|
7
|
+
import { createL1TxUtilsFromViemWallet } from '@aztec/ethereum/l1-tx-utils';
|
|
8
|
+
import { ChainMonitor } from '@aztec/ethereum/test';
|
|
9
|
+
import { EpochNumber } from '@aztec/foundation/branded-types';
|
|
10
|
+
import { SecretValue } from '@aztec/foundation/config';
|
|
6
11
|
import { createLogger } from '@aztec/foundation/log';
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
12
|
+
import { retryUntil } from '@aztec/foundation/retry';
|
|
13
|
+
import { RollupAbi, SlasherAbi, TestERC20Abi } from '@aztec/l1-artifacts';
|
|
14
|
+
import { SpamContract } from '@aztec/noir-test-contracts.js/Spam';
|
|
9
15
|
import { createBootstrapNodeFromPrivateKey, getBootstrapNodeEnr } from '@aztec/p2p/test-helpers';
|
|
16
|
+
import { tryStop } from '@aztec/stdlib/interfaces/server';
|
|
17
|
+
import { SlashFactoryContract } from '@aztec/stdlib/l1-contracts';
|
|
18
|
+
import { ZkPassportProofParams } from '@aztec/stdlib/zkpassport';
|
|
10
19
|
import { getGenesisValues } from '@aztec/world-state/testing';
|
|
11
20
|
import getPort from 'get-port';
|
|
12
|
-
import { getContract } from 'viem';
|
|
21
|
+
import { getAddress, getContract } from 'viem';
|
|
13
22
|
import { privateKeyToAccount } from 'viem/accounts';
|
|
14
|
-
import {
|
|
15
|
-
import {
|
|
16
|
-
import { getPrivateKeyFromIndex } from '../fixtures/utils.js';
|
|
23
|
+
import { deployAccounts, getPrivateKeyFromIndex, getSponsoredFPCAddress, setup, teardown } from '../fixtures/setup.js';
|
|
24
|
+
import { ATTESTER_PRIVATE_KEYS_START_INDEX, createValidatorConfig, generatePrivateKeys } from '../fixtures/setup_p2p_test.js';
|
|
17
25
|
import { getEndToEndTestTelemetryClient } from '../fixtures/with_telemetry_utils.js';
|
|
18
26
|
// Use a fixed bootstrap node private key so that we can re-use the same snapshot and the nodes can find each other
|
|
19
27
|
const BOOTSTRAP_NODE_PRIVATE_KEY = '080212208f988fc0899e4a73a5aee4d271a5f20670603a756ad8d84f2c94263a6427c591';
|
|
20
28
|
const l1ContractsConfig = getL1ContractsConfigEnvVars();
|
|
21
29
|
export const WAIT_FOR_TX_TIMEOUT = l1ContractsConfig.aztecSlotDuration * 3;
|
|
22
|
-
export const
|
|
30
|
+
export const SHORTENED_BLOCK_TIME_CONFIG_NO_PRUNES = {
|
|
23
31
|
aztecSlotDuration: 12,
|
|
24
|
-
ethereumSlotDuration: 4
|
|
32
|
+
ethereumSlotDuration: 4,
|
|
33
|
+
aztecProofSubmissionWindow: 640
|
|
25
34
|
};
|
|
26
35
|
export class P2PNetworkTest {
|
|
36
|
+
testName;
|
|
27
37
|
bootstrapNodeEnr;
|
|
28
38
|
bootNodePort;
|
|
39
|
+
numberOfValidators;
|
|
29
40
|
numberOfNodes;
|
|
30
41
|
metricsPort;
|
|
31
|
-
|
|
42
|
+
context;
|
|
43
|
+
baseAccountPrivateKey;
|
|
32
44
|
baseAccount;
|
|
33
45
|
logger;
|
|
34
46
|
monitor;
|
|
35
47
|
ctx;
|
|
36
48
|
attesterPrivateKeys;
|
|
37
49
|
attesterPublicKeys;
|
|
38
|
-
proposerPrivateKeys;
|
|
39
50
|
peerIdPrivateKeys;
|
|
51
|
+
validators;
|
|
40
52
|
deployedAccounts;
|
|
41
53
|
prefilledPublicData;
|
|
42
54
|
// The re-execution test needs a wallet and a spam contract
|
|
43
55
|
wallet;
|
|
56
|
+
defaultAccountAddress;
|
|
44
57
|
spamContract;
|
|
45
58
|
bootstrapNode;
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
59
|
+
// Store setup options for use in setup()
|
|
60
|
+
setupOptions;
|
|
61
|
+
deployL1ContractsArgs;
|
|
62
|
+
constructor(testName, bootstrapNodeEnr, bootNodePort, numberOfValidators, initialValidatorConfig, numberOfNodes = 0, // If set enable metrics collection
|
|
63
|
+
metricsPort, startProverNode){
|
|
64
|
+
this.testName = testName;
|
|
50
65
|
this.bootstrapNodeEnr = bootstrapNodeEnr;
|
|
51
66
|
this.bootNodePort = bootNodePort;
|
|
67
|
+
this.numberOfValidators = numberOfValidators;
|
|
52
68
|
this.numberOfNodes = numberOfNodes;
|
|
53
69
|
this.metricsPort = metricsPort;
|
|
54
70
|
this.attesterPrivateKeys = [];
|
|
55
71
|
this.attesterPublicKeys = [];
|
|
56
|
-
this.proposerPrivateKeys = [];
|
|
57
72
|
this.peerIdPrivateKeys = [];
|
|
73
|
+
this.validators = [];
|
|
58
74
|
this.deployedAccounts = [];
|
|
59
75
|
this.prefilledPublicData = [];
|
|
60
|
-
this.cleanupInterval = undefined;
|
|
61
|
-
this.gasUtils = undefined;
|
|
62
76
|
this.logger = createLogger(`e2e:e2e_p2p:${testName}`);
|
|
63
77
|
// Set up the base account and node private keys for the initial network deployment
|
|
64
|
-
this.
|
|
65
|
-
this.
|
|
66
|
-
this.attesterPrivateKeys = generatePrivateKeys(ATTESTER_PRIVATE_KEYS_START_INDEX,
|
|
78
|
+
this.baseAccountPrivateKey = `0x${getPrivateKeyFromIndex(1).toString('hex')}`;
|
|
79
|
+
this.baseAccount = privateKeyToAccount(this.baseAccountPrivateKey);
|
|
80
|
+
this.attesterPrivateKeys = generatePrivateKeys(ATTESTER_PRIVATE_KEYS_START_INDEX + numberOfNodes, numberOfValidators);
|
|
67
81
|
this.attesterPublicKeys = this.attesterPrivateKeys.map((privateKey)=>privateKeyToAccount(privateKey).address);
|
|
68
|
-
|
|
82
|
+
const zkPassportParams = ZkPassportProofParams.random();
|
|
83
|
+
// Store setup options for later use
|
|
84
|
+
this.setupOptions = {
|
|
69
85
|
...initialValidatorConfig,
|
|
70
86
|
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
71
87
|
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
72
88
|
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
73
|
-
|
|
74
|
-
|
|
89
|
+
aztecProofSubmissionEpochs: initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
|
|
90
|
+
slashingRoundSizeInEpochs: initialValidatorConfig.slashingRoundSizeInEpochs ?? l1ContractsConfig.slashingRoundSizeInEpochs,
|
|
91
|
+
slasherFlavor: initialValidatorConfig.slasherFlavor ?? 'tally',
|
|
92
|
+
aztecTargetCommitteeSize: numberOfValidators,
|
|
75
93
|
metricsPort: metricsPort,
|
|
76
|
-
numberOfInitialFundedAccounts:
|
|
77
|
-
|
|
94
|
+
numberOfInitialFundedAccounts: 2,
|
|
95
|
+
startProverNode,
|
|
96
|
+
walletMinFeePadding: 2.0
|
|
97
|
+
};
|
|
98
|
+
this.deployL1ContractsArgs = {
|
|
99
|
+
...initialValidatorConfig,
|
|
78
100
|
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
101
|
+
slashingRoundSizeInEpochs: initialValidatorConfig.slashingRoundSizeInEpochs ?? l1ContractsConfig.slashingRoundSizeInEpochs,
|
|
102
|
+
slasherFlavor: initialValidatorConfig.slasherFlavor ?? 'tally',
|
|
79
103
|
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
80
104
|
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
105
|
+
aztecProofSubmissionEpochs: initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
|
|
106
|
+
aztecTargetCommitteeSize: numberOfValidators,
|
|
107
|
+
initialValidators: [],
|
|
108
|
+
zkPassportArgs: {
|
|
109
|
+
zkPassportDomain: zkPassportParams.domain,
|
|
110
|
+
zkPassportScope: zkPassportParams.scope
|
|
111
|
+
}
|
|
112
|
+
};
|
|
84
113
|
}
|
|
85
|
-
static async create({ testName, numberOfNodes, basePort, metricsPort, initialConfig }) {
|
|
114
|
+
static async create({ testName, numberOfNodes, numberOfValidators, basePort, metricsPort, initialConfig, startProverNode }) {
|
|
86
115
|
const port = basePort || await getPort();
|
|
87
116
|
const bootstrapNodeENR = await getBootstrapNodeEnr(BOOTSTRAP_NODE_PRIVATE_KEY, port);
|
|
88
117
|
const bootstrapNodeEnr = bootstrapNodeENR.encodeTxt();
|
|
89
118
|
const initialValidatorConfig = await createValidatorConfig(initialConfig ?? {}, bootstrapNodeEnr);
|
|
90
|
-
return new P2PNetworkTest(testName, bootstrapNodeEnr, port,
|
|
119
|
+
return new P2PNetworkTest(testName, bootstrapNodeEnr, port, numberOfValidators, initialValidatorConfig, numberOfNodes, metricsPort, startProverNode);
|
|
91
120
|
}
|
|
92
121
|
get fundedAccount() {
|
|
93
122
|
if (!this.deployedAccounts[0]) {
|
|
94
|
-
throw new Error('Call
|
|
123
|
+
throw new Error('Call setupAccount to create a funded account.');
|
|
95
124
|
}
|
|
96
125
|
return this.deployedAccounts[0];
|
|
97
126
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
this.
|
|
102
|
-
|
|
103
|
-
|
|
127
|
+
async addBootstrapNode() {
|
|
128
|
+
this.logger.info('Adding bootstrap node');
|
|
129
|
+
const telemetry = await getEndToEndTestTelemetryClient(this.metricsPort);
|
|
130
|
+
this.bootstrapNode = await createBootstrapNodeFromPrivateKey(BOOTSTRAP_NODE_PRIVATE_KEY, this.bootNodePort, telemetry, this.context.config);
|
|
131
|
+
// Overwrite enr with updated info
|
|
132
|
+
this.bootstrapNodeEnr = this.bootstrapNode.getENR().encodeTxt();
|
|
104
133
|
}
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
134
|
+
getValidators() {
|
|
135
|
+
const validators = [];
|
|
136
|
+
for(let i = 0; i < this.numberOfValidators; i++){
|
|
137
|
+
const keyIndex = i;
|
|
138
|
+
const attester = privateKeyToAccount(this.attesterPrivateKeys[keyIndex]);
|
|
139
|
+
validators.push({
|
|
140
|
+
attester: EthAddress.fromString(attester.address),
|
|
141
|
+
withdrawer: EthAddress.fromString(attester.address),
|
|
142
|
+
bn254SecretKey: new SecretValue(Fr.random().toBigInt())
|
|
143
|
+
});
|
|
144
|
+
this.logger.info(`Adding attester ${attester.address} as validator`);
|
|
145
|
+
}
|
|
146
|
+
return {
|
|
147
|
+
validators
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
async applyBaseSetup() {
|
|
151
|
+
await this.addBootstrapNode();
|
|
152
|
+
this.logger.info('Adding validators');
|
|
153
|
+
const rollup = getContract({
|
|
154
|
+
address: this.context.deployL1ContractsValues.l1ContractAddresses.rollupAddress.toString(),
|
|
155
|
+
abi: RollupAbi,
|
|
156
|
+
client: this.context.deployL1ContractsValues.l1Client
|
|
115
157
|
});
|
|
116
|
-
|
|
117
|
-
|
|
158
|
+
this.logger.info(`Adding ${this.numberOfValidators} validators`);
|
|
159
|
+
const stakingAsset = getContract({
|
|
160
|
+
address: this.context.deployL1ContractsValues.l1ContractAddresses.stakingAssetAddress.toString(),
|
|
161
|
+
abi: TestERC20Abi,
|
|
162
|
+
client: this.context.deployL1ContractsValues.l1Client
|
|
118
163
|
});
|
|
119
|
-
this.
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
this.bootstrapNodeEnr = this.bootstrapNode.getENR().encodeTxt();
|
|
164
|
+
const { address: multiAdderAddress } = await deployL1Contract(this.context.deployL1ContractsValues.l1Client, MultiAdderArtifact.contractAbi, MultiAdderArtifact.contractBytecode, [
|
|
165
|
+
rollup.address,
|
|
166
|
+
this.context.deployL1ContractsValues.l1Client.account.address
|
|
167
|
+
]);
|
|
168
|
+
const multiAdder = getContract({
|
|
169
|
+
address: multiAdderAddress.toString(),
|
|
170
|
+
abi: MultiAdderArtifact.contractAbi,
|
|
171
|
+
client: this.context.deployL1ContractsValues.l1Client
|
|
128
172
|
});
|
|
129
|
-
await
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
})
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
const forwarder = getExpectedAddress(ForwarderAbi, ForwarderBytecode, [
|
|
159
|
-
proposerEOA.address
|
|
160
|
-
], proposerEOA.address).address;
|
|
161
|
-
validators.push({
|
|
162
|
-
attester: attester.address,
|
|
163
|
-
proposer: forwarder,
|
|
164
|
-
withdrawer: attester.address,
|
|
165
|
-
amount: l1ContractsConfig.minimumStake
|
|
166
|
-
});
|
|
167
|
-
this.logger.verbose(`Adding (attester, proposer) pair: (${attester.address}, ${forwarder}) as validator`);
|
|
168
|
-
}
|
|
169
|
-
await deployL1ContractsValues.publicClient.waitForTransactionReceipt({
|
|
170
|
-
hash: await rollup.write.cheat__InitialiseValidatorSet([
|
|
171
|
-
validators
|
|
172
|
-
])
|
|
173
|
-
});
|
|
174
|
-
const slotsInEpoch = await rollup.read.getEpochDuration();
|
|
175
|
-
const timestamp = await rollup.read.getTimestampForSlot([
|
|
176
|
-
slotsInEpoch
|
|
177
|
-
]);
|
|
178
|
-
const cheatCodes = new EthCheatCodesWithState(aztecNodeConfig.l1RpcUrls);
|
|
179
|
-
try {
|
|
180
|
-
await cheatCodes.warp(Number(timestamp));
|
|
181
|
-
} catch (err) {
|
|
182
|
-
this.logger.debug('Warp failed, time already satisfied');
|
|
183
|
-
}
|
|
184
|
-
// Send and await a tx to make sure we mine a block for the warp to correctly progress.
|
|
185
|
-
await deployL1ContractsValues.publicClient.waitForTransactionReceipt({
|
|
186
|
-
hash: await deployL1ContractsValues.walletClient.sendTransaction({
|
|
187
|
-
to: this.baseAccount.address,
|
|
188
|
-
value: 1n,
|
|
189
|
-
account: this.baseAccount
|
|
190
|
-
})
|
|
191
|
-
});
|
|
192
|
-
// Set the system time in the node, only after we have warped the time and waited for a block
|
|
193
|
-
// Time is only set in the NEXT block
|
|
194
|
-
dateProvider.setTime(Number(timestamp) * 1000);
|
|
173
|
+
const stakeNeeded = await rollup.read.getActivationThreshold() * BigInt(this.numberOfValidators);
|
|
174
|
+
await Promise.all([
|
|
175
|
+
await stakingAsset.write.mint([
|
|
176
|
+
multiAdder.address,
|
|
177
|
+
stakeNeeded
|
|
178
|
+
], {})
|
|
179
|
+
].map((txHash)=>this.context.deployL1ContractsValues.l1Client.waitForTransactionReceipt({
|
|
180
|
+
hash: txHash
|
|
181
|
+
})));
|
|
182
|
+
const { validators } = this.getValidators();
|
|
183
|
+
this.validators = validators;
|
|
184
|
+
const gseAddress = this.context.deployL1ContractsValues.l1ContractAddresses.gseAddress;
|
|
185
|
+
if (!gseAddress) {
|
|
186
|
+
throw new Error('GSE contract not deployed');
|
|
187
|
+
}
|
|
188
|
+
const gseContract = new GSEContract(this.context.deployL1ContractsValues.l1Client, gseAddress.toString());
|
|
189
|
+
const makeValidatorTuples = async (validator)=>{
|
|
190
|
+
const registrationTuple = await gseContract.makeRegistrationTuple(validator.bn254SecretKey.getValue());
|
|
191
|
+
return {
|
|
192
|
+
attester: validator.attester.toString(),
|
|
193
|
+
withdrawer: validator.withdrawer.toString(),
|
|
194
|
+
...registrationTuple
|
|
195
|
+
};
|
|
196
|
+
};
|
|
197
|
+
const validatorTuples = await Promise.all(validators.map(makeValidatorTuples));
|
|
198
|
+
await this.context.deployL1ContractsValues.l1Client.waitForTransactionReceipt({
|
|
199
|
+
hash: await multiAdder.write.addValidators([
|
|
200
|
+
validatorTuples
|
|
201
|
+
])
|
|
195
202
|
});
|
|
203
|
+
await this.context.cheatCodes.rollup.advanceToEpoch(EpochNumber.fromBigInt(BigInt(await this.context.cheatCodes.rollup.getEpoch()) + await rollup.read.getLagInEpochsForValidatorSet() + 1n));
|
|
204
|
+
// Send and await a tx to make sure we mine a block for the warp to correctly progress.
|
|
205
|
+
await this._sendDummyTx(this.context.deployL1ContractsValues.l1Client);
|
|
196
206
|
}
|
|
197
207
|
async setupAccount() {
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
this.
|
|
208
|
+
this.logger.info('Setting up account');
|
|
209
|
+
const { deployedAccounts } = await deployAccounts(1, this.logger)({
|
|
210
|
+
wallet: this.context.wallet,
|
|
211
|
+
initialFundedAccounts: this.context.initialFundedAccounts
|
|
202
212
|
});
|
|
213
|
+
this.deployedAccounts = deployedAccounts;
|
|
214
|
+
[{ address: this.defaultAccountAddress }] = deployedAccounts;
|
|
215
|
+
this.wallet = this.context.wallet;
|
|
203
216
|
}
|
|
204
217
|
async deploySpamContract() {
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
contractAddress: spamContract.address
|
|
212
|
-
};
|
|
213
|
-
}, async ({ contractAddress })=>{
|
|
214
|
-
if (!this.wallet) {
|
|
215
|
-
throw new Error('Call snapshot t.setupAccount before deploying account contract');
|
|
216
|
-
}
|
|
217
|
-
this.spamContract = await SpamContract.at(contractAddress, this.wallet);
|
|
218
|
+
this.logger.info('Deploying spam contract');
|
|
219
|
+
if (!this.wallet) {
|
|
220
|
+
throw new Error('Call setupAccount before deploying spam contract');
|
|
221
|
+
}
|
|
222
|
+
const spamContract = await SpamContract.deploy(this.wallet).send({
|
|
223
|
+
from: this.defaultAccountAddress
|
|
218
224
|
});
|
|
225
|
+
this.spamContract = spamContract;
|
|
219
226
|
}
|
|
220
227
|
async removeInitialNode() {
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
228
|
+
this.logger.info('Removing initial node');
|
|
229
|
+
// Send and await a tx to make sure we mine a block for the warp to correctly progress.
|
|
230
|
+
const { receipt } = await this._sendDummyTx(this.context.deployL1ContractsValues.l1Client);
|
|
231
|
+
const block = await this.context.deployL1ContractsValues.l1Client.getBlock({
|
|
232
|
+
blockNumber: receipt.blockNumber
|
|
233
|
+
});
|
|
234
|
+
this.context.dateProvider.setTime(Number(block.timestamp) * 1000);
|
|
235
|
+
await this.context.aztecNodeService.stop();
|
|
236
|
+
}
|
|
237
|
+
async sendDummyTx() {
|
|
238
|
+
return await this._sendDummyTx(this.ctx.deployL1ContractsValues.l1Client);
|
|
239
|
+
}
|
|
240
|
+
async _sendDummyTx(l1Client) {
|
|
241
|
+
const l1TxUtils = createL1TxUtilsFromViemWallet(l1Client);
|
|
242
|
+
return await l1TxUtils.sendAndMonitorTransaction({
|
|
243
|
+
to: l1Client.account.address,
|
|
244
|
+
value: 1n
|
|
235
245
|
});
|
|
236
246
|
}
|
|
237
247
|
async setup() {
|
|
238
|
-
this.
|
|
239
|
-
this.
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
248
|
+
this.logger.info('Setting up subsystems from fresh');
|
|
249
|
+
this.context = await setup(0, {
|
|
250
|
+
...this.setupOptions,
|
|
251
|
+
fundSponsoredFPC: true,
|
|
252
|
+
skipAccountDeployment: true,
|
|
253
|
+
slasherFlavor: this.setupOptions.slasherFlavor ?? this.deployL1ContractsArgs.slasherFlavor ?? 'none',
|
|
254
|
+
aztecTargetCommitteeSize: 0,
|
|
255
|
+
l1ContractsArgs: this.deployL1ContractsArgs
|
|
256
|
+
}, // Use checkpointed chain tip for PXE to avoid issues with blocks being dropped due to pruned anchor blocks.
|
|
257
|
+
{
|
|
258
|
+
syncChainTip: 'checkpointed'
|
|
247
259
|
});
|
|
248
|
-
this.
|
|
260
|
+
this.ctx = this.context;
|
|
261
|
+
const sponsoredFPCAddress = await getSponsoredFPCAddress();
|
|
262
|
+
const initialFundedAccounts = [
|
|
263
|
+
...this.context.initialFundedAccounts.map((a)=>a.address),
|
|
264
|
+
sponsoredFPCAddress
|
|
265
|
+
];
|
|
266
|
+
const { prefilledPublicData } = await getGenesisValues(initialFundedAccounts);
|
|
267
|
+
this.prefilledPublicData = prefilledPublicData;
|
|
268
|
+
const rollupContract = RollupContract.getFromL1ContractsValues(this.context.deployL1ContractsValues);
|
|
269
|
+
this.monitor = new ChainMonitor(rollupContract, this.context.dateProvider).start();
|
|
270
|
+
this.monitor.on('l1-block', ({ timestamp })=>this.context.dateProvider.setTime(Number(timestamp) * 1000));
|
|
249
271
|
}
|
|
250
272
|
async stopNodes(nodes) {
|
|
251
273
|
this.logger.info('Stopping nodes');
|
|
@@ -256,12 +278,52 @@ export class P2PNetworkTest {
|
|
|
256
278
|
await Promise.all(nodes.map((node)=>node.stop()));
|
|
257
279
|
this.logger.info('Nodes stopped');
|
|
258
280
|
}
|
|
281
|
+
/**
|
|
282
|
+
* Wait for P2P mesh to be fully formed across all nodes.
|
|
283
|
+
* This ensures that all nodes are connected to each other before proceeding,
|
|
284
|
+
* preventing race conditions where validators propose blocks before the network is ready.
|
|
285
|
+
*
|
|
286
|
+
* @param nodes - Array of nodes to check for P2P connectivity
|
|
287
|
+
* @param expectedNodeCount - Expected number of nodes in the network (defaults to nodes.length)
|
|
288
|
+
* @param timeoutSeconds - Maximum time to wait for connections (default: 30 seconds)
|
|
289
|
+
* @param checkIntervalSeconds - How often to check connectivity (default: 0.1 seconds)
|
|
290
|
+
*/ async waitForP2PMeshConnectivity(nodes, expectedNodeCount, timeoutSeconds = 30, checkIntervalSeconds = 0.1) {
|
|
291
|
+
const nodeCount = expectedNodeCount ?? nodes.length;
|
|
292
|
+
const minPeerCount = nodeCount - 1;
|
|
293
|
+
this.logger.warn(`Waiting for all ${nodeCount} nodes to connect to P2P mesh (at least ${minPeerCount} peers each)...`);
|
|
294
|
+
await Promise.all(nodes.map(async (node, index)=>{
|
|
295
|
+
const p2p = node.getP2P();
|
|
296
|
+
await retryUntil(async ()=>{
|
|
297
|
+
const peers = await p2p.getPeers();
|
|
298
|
+
// Each node should be connected to at least N-1 other nodes
|
|
299
|
+
return peers.length >= minPeerCount ? true : undefined;
|
|
300
|
+
}, `Node ${index} to connect to at least ${minPeerCount} peers`, timeoutSeconds, checkIntervalSeconds);
|
|
301
|
+
}));
|
|
302
|
+
this.logger.warn('All nodes connected to P2P mesh');
|
|
303
|
+
}
|
|
259
304
|
async teardown() {
|
|
260
|
-
this.monitor.stop();
|
|
261
|
-
await this.bootstrapNode
|
|
262
|
-
await this.
|
|
263
|
-
|
|
264
|
-
|
|
305
|
+
await this.monitor.stop();
|
|
306
|
+
await tryStop(this.bootstrapNode, this.logger);
|
|
307
|
+
await teardown(this.context);
|
|
308
|
+
}
|
|
309
|
+
async getContracts() {
|
|
310
|
+
if (!this.ctx.deployL1ContractsValues) {
|
|
311
|
+
throw new Error('DeployAztecL1ContractsValues not set');
|
|
265
312
|
}
|
|
313
|
+
const rollup = new RollupContract(this.ctx.deployL1ContractsValues.l1Client, this.ctx.deployL1ContractsValues.l1ContractAddresses.rollupAddress);
|
|
314
|
+
const slasherContract = getContract({
|
|
315
|
+
address: getAddress((await rollup.getSlasherAddress()).toString()),
|
|
316
|
+
abi: SlasherAbi,
|
|
317
|
+
client: this.ctx.deployL1ContractsValues.l1Client
|
|
318
|
+
});
|
|
319
|
+
// Get the actual slashing proposer from rollup (which handles both empire and tally)
|
|
320
|
+
const slashingProposer = await rollup.getSlashingProposer();
|
|
321
|
+
const slashFactory = new SlashFactoryContract(this.ctx.deployL1ContractsValues.l1Client, getAddress(this.ctx.deployL1ContractsValues.l1ContractAddresses.slashFactoryAddress.toString()));
|
|
322
|
+
return {
|
|
323
|
+
rollup,
|
|
324
|
+
slasherContract,
|
|
325
|
+
slashingProposer,
|
|
326
|
+
slashFactory
|
|
327
|
+
};
|
|
266
328
|
}
|
|
267
329
|
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { AztecNodeService } from '@aztec/aztec-node';
|
|
2
|
+
import { P2PNetworkTest } from '../p2p_network.js';
|
|
3
|
+
export declare const NUM_VALIDATORS = 6;
|
|
4
|
+
export declare const NUM_TXS_PER_NODE = 2;
|
|
5
|
+
export declare const BOOT_NODE_UDP_PORT = 4500;
|
|
6
|
+
export declare const createReqrespDataDir: () => string;
|
|
7
|
+
type ReqrespOptions = {
|
|
8
|
+
disableStatusHandshake?: boolean;
|
|
9
|
+
};
|
|
10
|
+
export declare function createReqrespTest(options?: ReqrespOptions): Promise<P2PNetworkTest>;
|
|
11
|
+
export declare function cleanupReqrespTest(params: {
|
|
12
|
+
t: P2PNetworkTest;
|
|
13
|
+
nodes?: AztecNodeService[];
|
|
14
|
+
dataDir: string;
|
|
15
|
+
}): Promise<void>;
|
|
16
|
+
export declare function runReqrespTxTest(params: {
|
|
17
|
+
t: P2PNetworkTest;
|
|
18
|
+
dataDir: string;
|
|
19
|
+
disableStatusHandshake?: boolean;
|
|
20
|
+
}): Promise<AztecNodeService[]>;
|
|
21
|
+
export {};
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9lMmVfcDJwL3JlcXJlc3AvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQWdCMUQsT0FBTyxFQUFFLGNBQWMsRUFBOEQsTUFBTSxtQkFBbUIsQ0FBQztBQUkvRyxlQUFPLE1BQU0sY0FBYyxJQUFJLENBQUM7QUFDaEMsZUFBTyxNQUFNLGdCQUFnQixJQUFJLENBQUM7QUFDbEMsZUFBTyxNQUFNLGtCQUFrQixPQUFPLENBQUM7QUFFdkMsZUFBTyxNQUFNLG9CQUFvQixjQUEyRCxDQUFDO0FBRTdGLEtBQUssY0FBYyxHQUFHO0lBQ3BCLHNCQUFzQixDQUFDLEVBQUUsT0FBTyxDQUFDO0NBQ2xDLENBQUM7QUFFRix3QkFBc0IsaUJBQWlCLENBQUMsT0FBTyxHQUFFLGNBQW1CLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQW9CN0Y7QUFFRCx3QkFBc0Isa0JBQWtCLENBQUMsTUFBTSxFQUFFO0lBQUUsQ0FBQyxFQUFFLGNBQWMsQ0FBQztJQUFDLEtBQUssQ0FBQyxFQUFFLGdCQUFnQixFQUFFLENBQUM7SUFBQyxPQUFPLEVBQUUsTUFBTSxDQUFBO0NBQUUsaUJBU2xIO0FBSUQsd0JBQXNCLGdCQUFnQixDQUFDLE1BQU0sRUFBRTtJQUM3QyxDQUFDLEVBQUUsY0FBYyxDQUFDO0lBQ2xCLE9BQU8sRUFBRSxNQUFNLENBQUM7SUFDaEIsc0JBQXNCLENBQUMsRUFBRSxPQUFPLENBQUM7Q0FDbEMsR0FBRyxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQXdHOUIifQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/e2e_p2p/reqresp/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAgB1D,OAAO,EAAE,cAAc,EAA8D,MAAM,mBAAmB,CAAC;AAI/G,eAAO,MAAM,cAAc,IAAI,CAAC;AAChC,eAAO,MAAM,gBAAgB,IAAI,CAAC;AAClC,eAAO,MAAM,kBAAkB,OAAO,CAAC;AAEvC,eAAO,MAAM,oBAAoB,cAA2D,CAAC;AAE7F,KAAK,cAAc,GAAG;IACpB,sBAAsB,CAAC,EAAE,OAAO,CAAC;CAClC,CAAC;AAEF,wBAAsB,iBAAiB,CAAC,OAAO,GAAE,cAAmB,GAAG,OAAO,CAAC,cAAc,CAAC,CAoB7F;AAED,wBAAsB,kBAAkB,CAAC,MAAM,EAAE;IAAE,CAAC,EAAE,cAAc,CAAC;IAAC,KAAK,CAAC,EAAE,gBAAgB,EAAE,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,iBASlH;AAID,wBAAsB,gBAAgB,CAAC,MAAM,EAAE;IAC7C,CAAC,EAAE,cAAc,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,sBAAsB,CAAC,EAAE,OAAO,CAAC;CAClC,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAwG9B"}
|