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