@aztec/end-to-end 0.0.0-test.0 → 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.
Files changed (293) 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 +329 -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 +124 -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 +44 -72
  16. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +28 -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 +125 -103
  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 +105 -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 +75 -24
  26. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  27. package/dest/e2e_epochs/epochs_test.js +290 -58
  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 +169 -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 +36 -42
  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 +282 -27
  47. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  48. package/dest/e2e_p2p/p2p_network.js +255 -176
  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 +190 -0
  52. package/dest/e2e_p2p/shared.d.ts +64 -8
  53. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  54. package/dest/e2e_p2p/shared.js +200 -27
  55. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
  56. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
  57. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
  58. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
  59. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
  60. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
  61. package/dest/e2e_token_contract/token_contract_test.d.ts +29 -14
  62. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  63. package/dest/e2e_token_contract/token_contract_test.js +107 -75
  64. package/dest/fixtures/authwit_proxy.d.ts +15 -0
  65. package/dest/fixtures/authwit_proxy.d.ts.map +1 -0
  66. package/dest/fixtures/authwit_proxy.js +30 -0
  67. package/dest/fixtures/e2e_prover_test.d.ts +55 -0
  68. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -0
  69. package/dest/fixtures/e2e_prover_test.js +271 -0
  70. package/dest/fixtures/elu_monitor.d.ts +21 -0
  71. package/dest/fixtures/elu_monitor.d.ts.map +1 -0
  72. package/dest/fixtures/elu_monitor.js +102 -0
  73. package/dest/fixtures/fixtures.d.ts +10 -8
  74. package/dest/fixtures/fixtures.d.ts.map +1 -1
  75. package/dest/fixtures/fixtures.js +11 -5
  76. package/dest/fixtures/get_acvm_config.d.ts +2 -2
  77. package/dest/fixtures/get_acvm_config.d.ts.map +1 -1
  78. package/dest/fixtures/get_acvm_config.js +3 -15
  79. package/dest/fixtures/get_bb_config.d.ts +2 -2
  80. package/dest/fixtures/get_bb_config.d.ts.map +1 -1
  81. package/dest/fixtures/get_bb_config.js +10 -17
  82. package/dest/fixtures/ha_setup.d.ts +71 -0
  83. package/dest/fixtures/ha_setup.d.ts.map +1 -0
  84. package/dest/fixtures/ha_setup.js +116 -0
  85. package/dest/fixtures/index.d.ts +2 -1
  86. package/dest/fixtures/index.d.ts.map +1 -1
  87. package/dest/fixtures/index.js +1 -0
  88. package/dest/fixtures/l1_to_l2_messaging.d.ts +11 -7
  89. package/dest/fixtures/l1_to_l2_messaging.d.ts.map +1 -1
  90. package/dest/fixtures/l1_to_l2_messaging.js +45 -19
  91. package/dest/fixtures/logging.d.ts +1 -1
  92. package/dest/fixtures/setup.d.ts +239 -0
  93. package/dest/fixtures/setup.d.ts.map +1 -0
  94. package/dest/fixtures/setup.js +606 -0
  95. package/dest/fixtures/setup_p2p_test.d.ts +23 -15
  96. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  97. package/dest/fixtures/setup_p2p_test.js +102 -31
  98. package/dest/fixtures/token_utils.d.ts +10 -4
  99. package/dest/fixtures/token_utils.d.ts.map +1 -1
  100. package/dest/fixtures/token_utils.js +33 -13
  101. package/dest/fixtures/utils.d.ts +5 -153
  102. package/dest/fixtures/utils.d.ts.map +1 -1
  103. package/dest/fixtures/utils.js +4 -552
  104. package/dest/fixtures/web3signer.d.ts +5 -0
  105. package/dest/fixtures/web3signer.d.ts.map +1 -0
  106. package/dest/fixtures/web3signer.js +53 -0
  107. package/dest/fixtures/with_telemetry_utils.d.ts +2 -2
  108. package/dest/fixtures/with_telemetry_utils.d.ts.map +1 -1
  109. package/dest/fixtures/with_telemetry_utils.js +2 -2
  110. package/dest/index.d.ts +1 -1
  111. package/dest/quality_of_service/grafana_client.d.ts +41 -0
  112. package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
  113. package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
  114. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  115. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  116. package/dest/quality_of_service/prometheus_client.js +67 -0
  117. package/dest/shared/cross_chain_test_harness.d.ts +44 -27
  118. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  119. package/dest/shared/cross_chain_test_harness.js +107 -53
  120. package/dest/shared/gas_portal_test_harness.d.ts +33 -25
  121. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  122. package/dest/shared/gas_portal_test_harness.js +51 -30
  123. package/dest/shared/index.d.ts +3 -2
  124. package/dest/shared/index.d.ts.map +1 -1
  125. package/dest/shared/index.js +1 -0
  126. package/dest/shared/jest_setup.d.ts +1 -1
  127. package/dest/shared/jest_setup.js +42 -2
  128. package/dest/shared/mock_state_view.d.ts +86 -0
  129. package/dest/shared/mock_state_view.d.ts.map +1 -0
  130. package/dest/shared/mock_state_view.js +186 -0
  131. package/dest/shared/submit-transactions.d.ts +6 -4
  132. package/dest/shared/submit-transactions.d.ts.map +1 -1
  133. package/dest/shared/submit-transactions.js +15 -16
  134. package/dest/shared/uniswap_l1_l2.d.ts +3 -25
  135. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  136. package/dest/shared/uniswap_l1_l2.js +175 -126
  137. package/dest/simulators/index.d.ts +1 -1
  138. package/dest/simulators/lending_simulator.d.ts +7 -7
  139. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  140. package/dest/simulators/lending_simulator.js +17 -18
  141. package/dest/simulators/token_simulator.d.ts +6 -3
  142. package/dest/simulators/token_simulator.d.ts.map +1 -1
  143. package/dest/simulators/token_simulator.js +12 -30
  144. package/dest/spartan/setup_test_wallets.d.ts +36 -11
  145. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  146. package/dest/spartan/setup_test_wallets.js +276 -62
  147. package/dest/spartan/tx_metrics.d.ts +88 -0
  148. package/dest/spartan/tx_metrics.d.ts.map +1 -0
  149. package/dest/spartan/tx_metrics.js +422 -0
  150. package/dest/spartan/utils/bot.d.ts +28 -0
  151. package/dest/spartan/utils/bot.d.ts.map +1 -0
  152. package/dest/spartan/utils/bot.js +142 -0
  153. package/dest/spartan/utils/chaos.d.ts +79 -0
  154. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  155. package/dest/spartan/utils/chaos.js +142 -0
  156. package/dest/spartan/utils/clients.d.ts +39 -0
  157. package/dest/spartan/utils/clients.d.ts.map +1 -0
  158. package/dest/spartan/utils/clients.js +90 -0
  159. package/dest/spartan/utils/config.d.ts +45 -0
  160. package/dest/spartan/utils/config.d.ts.map +1 -0
  161. package/dest/spartan/utils/config.js +23 -0
  162. package/dest/spartan/utils/health.d.ts +63 -0
  163. package/dest/spartan/utils/health.d.ts.map +1 -0
  164. package/dest/spartan/utils/health.js +202 -0
  165. package/dest/spartan/utils/helm.d.ts +15 -0
  166. package/dest/spartan/utils/helm.d.ts.map +1 -0
  167. package/dest/spartan/utils/helm.js +47 -0
  168. package/dest/spartan/utils/index.d.ts +11 -0
  169. package/dest/spartan/utils/index.d.ts.map +1 -0
  170. package/dest/spartan/utils/index.js +22 -0
  171. package/dest/spartan/utils/k8s.d.ts +128 -0
  172. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  173. package/dest/spartan/utils/k8s.js +381 -0
  174. package/dest/spartan/utils/nodes.d.ts +40 -0
  175. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  176. package/dest/spartan/utils/nodes.js +461 -0
  177. package/dest/spartan/utils/pod_logs.d.ts +25 -0
  178. package/dest/spartan/utils/pod_logs.d.ts.map +1 -0
  179. package/dest/spartan/utils/pod_logs.js +74 -0
  180. package/dest/spartan/utils/scripts.d.ts +30 -0
  181. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  182. package/dest/spartan/utils/scripts.js +81 -0
  183. package/dest/spartan/utils.d.ts +2 -415
  184. package/dest/spartan/utils.d.ts.map +1 -1
  185. package/dest/spartan/utils.js +1 -445
  186. package/dest/test-wallet/test_wallet.d.ts +83 -0
  187. package/dest/test-wallet/test_wallet.d.ts.map +1 -0
  188. package/dest/test-wallet/test_wallet.js +214 -0
  189. package/dest/test-wallet/utils.d.ts +41 -0
  190. package/dest/test-wallet/utils.d.ts.map +1 -0
  191. package/dest/test-wallet/utils.js +71 -0
  192. package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
  193. package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
  194. package/dest/test-wallet/wallet_worker_script.js +48 -0
  195. package/dest/test-wallet/worker_wallet.d.ts +52 -0
  196. package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
  197. package/dest/test-wallet/worker_wallet.js +151 -0
  198. package/dest/test-wallet/worker_wallet_schema.d.ts +274 -0
  199. package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
  200. package/dest/test-wallet/worker_wallet_schema.js +10 -0
  201. package/package.json +72 -62
  202. package/src/bench/client_flows/benchmark.ts +363 -0
  203. package/src/bench/client_flows/client_flows_benchmark.ts +388 -0
  204. package/src/bench/client_flows/config.ts +69 -0
  205. package/src/bench/client_flows/data_extractor.ts +89 -0
  206. package/src/bench/utils.ts +47 -86
  207. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +149 -171
  208. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +155 -182
  209. package/src/e2e_deploy_contract/deploy_test.ts +40 -48
  210. package/src/e2e_epochs/epochs_test.ts +364 -93
  211. package/src/e2e_fees/bridging_race.notest.ts +74 -0
  212. package/src/e2e_fees/fees_test.ts +213 -259
  213. package/src/e2e_l1_publisher/write_json.ts +77 -0
  214. package/src/e2e_multi_validator/utils.ts +258 -0
  215. package/src/e2e_nested_contract/nested_contract_test.ts +48 -59
  216. package/src/e2e_p2p/inactivity_slash_test.ts +179 -0
  217. package/src/e2e_p2p/p2p_network.ts +367 -234
  218. package/src/e2e_p2p/reqresp/utils.ts +256 -0
  219. package/src/e2e_p2p/shared.ts +315 -39
  220. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  221. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  222. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  223. package/src/e2e_token_contract/token_contract_test.ts +132 -126
  224. package/src/fixtures/authwit_proxy.ts +50 -0
  225. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  226. package/src/fixtures/e2e_prover_test.ts +332 -0
  227. package/src/fixtures/elu_monitor.ts +126 -0
  228. package/src/fixtures/fixtures.ts +15 -7
  229. package/src/fixtures/get_acvm_config.ts +4 -12
  230. package/src/fixtures/get_bb_config.ts +18 -13
  231. package/src/fixtures/ha_setup.ts +186 -0
  232. package/src/fixtures/index.ts +1 -0
  233. package/src/fixtures/l1_to_l2_messaging.ts +56 -24
  234. package/src/fixtures/setup.ts +903 -0
  235. package/src/fixtures/setup_p2p_test.ts +134 -50
  236. package/src/fixtures/token_utils.ts +37 -16
  237. package/src/fixtures/utils.ts +27 -820
  238. package/src/fixtures/web3signer.ts +63 -0
  239. package/src/fixtures/with_telemetry_utils.ts +2 -2
  240. package/src/guides/up_quick_start.sh +9 -17
  241. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +2 -2
  242. package/src/quality_of_service/prometheus_client.ts +113 -0
  243. package/src/shared/cross_chain_test_harness.ts +110 -94
  244. package/src/shared/gas_portal_test_harness.ts +59 -50
  245. package/src/shared/index.ts +2 -1
  246. package/src/shared/jest_setup.ts +52 -2
  247. package/src/shared/mock_state_view.ts +188 -0
  248. package/src/shared/submit-transactions.ts +19 -20
  249. package/src/shared/uniswap_l1_l2.ts +207 -226
  250. package/src/simulators/lending_simulator.ts +18 -17
  251. package/src/simulators/token_simulator.ts +18 -34
  252. package/src/spartan/DEVELOP.md +128 -0
  253. package/src/spartan/setup_test_wallets.ts +393 -95
  254. package/src/spartan/tx_metrics.ts +376 -0
  255. package/src/spartan/utils/bot.ts +188 -0
  256. package/src/spartan/utils/chaos.ts +253 -0
  257. package/src/spartan/utils/clients.ts +100 -0
  258. package/src/spartan/utils/config.ts +29 -0
  259. package/src/spartan/utils/health.ts +255 -0
  260. package/src/spartan/utils/helm.ts +84 -0
  261. package/src/spartan/utils/index.ts +71 -0
  262. package/src/spartan/utils/k8s.ts +535 -0
  263. package/src/spartan/utils/nodes.ts +543 -0
  264. package/src/spartan/utils/pod_logs.ts +99 -0
  265. package/src/spartan/utils/scripts.ts +99 -0
  266. package/src/spartan/utils.ts +1 -582
  267. package/src/test-wallet/test_wallet.ts +306 -0
  268. package/src/test-wallet/utils.ts +112 -0
  269. package/src/test-wallet/wallet_worker_script.ts +60 -0
  270. package/src/test-wallet/worker_wallet.ts +213 -0
  271. package/src/test-wallet/worker_wallet_schema.ts +13 -0
  272. package/dest/e2e_prover/e2e_prover_test.d.ts +0 -56
  273. package/dest/e2e_prover/e2e_prover_test.d.ts.map +0 -1
  274. package/dest/e2e_prover/e2e_prover_test.js +0 -291
  275. package/dest/fixtures/setup_l1_contracts.d.ts +0 -6
  276. package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
  277. package/dest/fixtures/setup_l1_contracts.js +0 -17
  278. package/dest/fixtures/snapshot_manager.d.ts +0 -87
  279. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  280. package/dest/fixtures/snapshot_manager.js +0 -479
  281. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  282. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  283. package/dest/sample-dapp/connect.js +0 -12
  284. package/dest/sample-dapp/contracts.js +0 -10
  285. package/dest/sample-dapp/deploy.js +0 -35
  286. package/dest/sample-dapp/index.js +0 -98
  287. package/src/e2e_prover/e2e_prover_test.ts +0 -418
  288. package/src/fixtures/setup_l1_contracts.ts +0 -27
  289. package/src/fixtures/snapshot_manager.ts +0 -617
  290. package/src/sample-dapp/connect.mjs +0 -16
  291. package/src/sample-dapp/contracts.mjs +0 -14
  292. package/src/sample-dapp/deploy.mjs +0 -40
  293. package/src/sample-dapp/index.mjs +0 -128
@@ -1,251 +1,273 @@
1
- import { getSchnorrWalletWithSecretKey } from '@aztec/accounts/schnorr';
2
- import { ChainMonitor } from '@aztec/aztec.js/ethereum';
3
- import { RollupContract, getExpectedAddress, getL1ContractsConfigEnvVars } from '@aztec/ethereum';
4
- import { L1TxUtilsWithBlobs } from '@aztec/ethereum/l1-tx-utils-with-blobs';
5
- import { EthCheatCodesWithState } from '@aztec/ethereum/test';
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 { createL1TxUtils } 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 { ForwarderAbi, ForwarderBytecode, RollupAbi, TestERC20Abi } from '@aztec/l1-artifacts';
8
- import { SpamContract } from '@aztec/noir-contracts.js/Spam';
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 { TopicType } from '@aztec/stdlib/p2p';
19
+ import { ZkPassportProofParams } from '@aztec/stdlib/zkpassport';
10
20
  import { getGenesisValues } from '@aztec/world-state/testing';
11
21
  import getPort from 'get-port';
12
- import { getContract } from 'viem';
22
+ import { getAddress, getContract } from 'viem';
13
23
  import { privateKeyToAccount } from 'viem/accounts';
14
- import { ATTESTER_PRIVATE_KEYS_START_INDEX, PROPOSER_PRIVATE_KEYS_START_INDEX, createValidatorConfig, generatePrivateKeys } from '../fixtures/setup_p2p_test.js';
15
- import { createSnapshotManager, deployAccounts } from '../fixtures/snapshot_manager.js';
16
- import { getPrivateKeyFromIndex } from '../fixtures/utils.js';
24
+ import { deployAccounts, getPrivateKeyFromIndex, getSponsoredFPCAddress, setup, teardown } from '../fixtures/setup.js';
25
+ import { ATTESTER_PRIVATE_KEYS_START_INDEX, createValidatorConfig, generatePrivateKeys } from '../fixtures/setup_p2p_test.js';
17
26
  import { getEndToEndTestTelemetryClient } from '../fixtures/with_telemetry_utils.js';
18
27
  // Use a fixed bootstrap node private key so that we can re-use the same snapshot and the nodes can find each other
19
28
  const BOOTSTRAP_NODE_PRIVATE_KEY = '080212208f988fc0899e4a73a5aee4d271a5f20670603a756ad8d84f2c94263a6427c591';
20
29
  const l1ContractsConfig = getL1ContractsConfigEnvVars();
21
30
  export const WAIT_FOR_TX_TIMEOUT = l1ContractsConfig.aztecSlotDuration * 3;
22
- export const SHORTENED_BLOCK_TIME_CONFIG = {
31
+ export const SHORTENED_BLOCK_TIME_CONFIG_NO_PRUNES = {
23
32
  aztecSlotDuration: 12,
24
- ethereumSlotDuration: 4
33
+ ethereumSlotDuration: 4,
34
+ aztecProofSubmissionEpochs: 640
25
35
  };
26
36
  export class P2PNetworkTest {
37
+ testName;
27
38
  bootstrapNodeEnr;
28
39
  bootNodePort;
40
+ numberOfValidators;
29
41
  numberOfNodes;
30
42
  metricsPort;
31
- snapshotManager;
43
+ context;
44
+ baseAccountPrivateKey;
32
45
  baseAccount;
33
46
  logger;
34
47
  monitor;
35
48
  ctx;
36
49
  attesterPrivateKeys;
37
50
  attesterPublicKeys;
38
- proposerPrivateKeys;
39
51
  peerIdPrivateKeys;
52
+ validators;
40
53
  deployedAccounts;
41
54
  prefilledPublicData;
42
55
  // The re-execution test needs a wallet and a spam contract
43
56
  wallet;
57
+ defaultAccountAddress;
44
58
  spamContract;
45
59
  bootstrapNode;
46
- cleanupInterval;
47
- gasUtils;
48
- constructor(testName, bootstrapNodeEnr, bootNodePort, numberOfNodes, initialValidatorConfig, // If set enable metrics collection
49
- metricsPort){
60
+ // Store setup options for use in setup()
61
+ setupOptions;
62
+ deployL1ContractsArgs;
63
+ constructor(testName, bootstrapNodeEnr, bootNodePort, numberOfValidators, initialValidatorConfig, numberOfNodes = 0, // If set enable metrics collection
64
+ metricsPort, startProverNode){
65
+ this.testName = testName;
50
66
  this.bootstrapNodeEnr = bootstrapNodeEnr;
51
67
  this.bootNodePort = bootNodePort;
68
+ this.numberOfValidators = numberOfValidators;
52
69
  this.numberOfNodes = numberOfNodes;
53
70
  this.metricsPort = metricsPort;
54
71
  this.attesterPrivateKeys = [];
55
72
  this.attesterPublicKeys = [];
56
- this.proposerPrivateKeys = [];
57
73
  this.peerIdPrivateKeys = [];
74
+ this.validators = [];
58
75
  this.deployedAccounts = [];
59
76
  this.prefilledPublicData = [];
60
- this.cleanupInterval = undefined;
61
- this.gasUtils = undefined;
62
77
  this.logger = createLogger(`e2e:e2e_p2p:${testName}`);
63
78
  // Set up the base account and node private keys for the initial network deployment
64
- this.baseAccount = privateKeyToAccount(`0x${getPrivateKeyFromIndex(0).toString('hex')}`);
65
- this.proposerPrivateKeys = generatePrivateKeys(PROPOSER_PRIVATE_KEYS_START_INDEX, numberOfNodes);
66
- this.attesterPrivateKeys = generatePrivateKeys(ATTESTER_PRIVATE_KEYS_START_INDEX, numberOfNodes);
79
+ this.baseAccountPrivateKey = `0x${getPrivateKeyFromIndex(1).toString('hex')}`;
80
+ this.baseAccount = privateKeyToAccount(this.baseAccountPrivateKey);
81
+ this.attesterPrivateKeys = generatePrivateKeys(ATTESTER_PRIVATE_KEYS_START_INDEX + numberOfNodes, numberOfValidators);
67
82
  this.attesterPublicKeys = this.attesterPrivateKeys.map((privateKey)=>privateKeyToAccount(privateKey).address);
68
- this.snapshotManager = createSnapshotManager(`e2e_p2p_network/${testName}`, process.env.E2E_DATA_PATH, {
83
+ const zkPassportParams = ZkPassportProofParams.random();
84
+ // Store setup options for later use
85
+ this.setupOptions = {
69
86
  ...initialValidatorConfig,
70
87
  ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
71
88
  aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
72
89
  aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
73
- aztecProofSubmissionWindow: initialValidatorConfig.aztecProofSubmissionWindow ?? l1ContractsConfig.aztecProofSubmissionWindow,
74
- salt: 420,
90
+ aztecProofSubmissionEpochs: initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
91
+ slashingRoundSizeInEpochs: initialValidatorConfig.slashingRoundSizeInEpochs ?? l1ContractsConfig.slashingRoundSizeInEpochs,
92
+ slasherFlavor: initialValidatorConfig.slasherFlavor ?? 'tally',
93
+ aztecTargetCommitteeSize: numberOfValidators,
75
94
  metricsPort: metricsPort,
76
- numberOfInitialFundedAccounts: 1
77
- }, {
95
+ numberOfInitialFundedAccounts: 2,
96
+ startProverNode,
97
+ walletMinFeePadding: 2.0
98
+ };
99
+ this.deployL1ContractsArgs = {
100
+ ...initialValidatorConfig,
78
101
  aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
102
+ slashingRoundSizeInEpochs: initialValidatorConfig.slashingRoundSizeInEpochs ?? l1ContractsConfig.slashingRoundSizeInEpochs,
103
+ slasherFlavor: initialValidatorConfig.slasherFlavor ?? 'tally',
79
104
  ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
80
105
  aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
81
- aztecProofSubmissionWindow: initialValidatorConfig.aztecProofSubmissionWindow ?? l1ContractsConfig.aztecProofSubmissionWindow,
82
- initialValidators: []
83
- });
106
+ aztecProofSubmissionEpochs: initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
107
+ aztecTargetCommitteeSize: numberOfValidators,
108
+ initialValidators: [],
109
+ zkPassportArgs: {
110
+ zkPassportDomain: zkPassportParams.domain,
111
+ zkPassportScope: zkPassportParams.scope
112
+ }
113
+ };
84
114
  }
85
- static async create({ testName, numberOfNodes, basePort, metricsPort, initialConfig }) {
115
+ static async create({ testName, numberOfNodes, numberOfValidators, basePort, metricsPort, initialConfig, startProverNode }) {
86
116
  const port = basePort || await getPort();
87
117
  const bootstrapNodeENR = await getBootstrapNodeEnr(BOOTSTRAP_NODE_PRIVATE_KEY, port);
88
118
  const bootstrapNodeEnr = bootstrapNodeENR.encodeTxt();
89
119
  const initialValidatorConfig = await createValidatorConfig(initialConfig ?? {}, bootstrapNodeEnr);
90
- return new P2PNetworkTest(testName, bootstrapNodeEnr, port, numberOfNodes, initialValidatorConfig, metricsPort);
120
+ return new P2PNetworkTest(testName, bootstrapNodeEnr, port, numberOfValidators, initialValidatorConfig, numberOfNodes, metricsPort, startProverNode);
91
121
  }
92
122
  get fundedAccount() {
93
123
  if (!this.deployedAccounts[0]) {
94
- throw new Error('Call snapshot t.setupAccount to create a funded account.');
124
+ throw new Error('Call setupAccount to create a funded account.');
95
125
  }
96
126
  return this.deployedAccounts[0];
97
127
  }
98
- /**
99
- * Start a loop to sync the mock system time with the L1 block time
100
- */ startSyncMockSystemTimeInterval() {
101
- this.cleanupInterval = setInterval(()=>{
102
- void this.syncMockSystemTime().catch((err)=>this.logger.error('Error syncing mock system time', err));
103
- }, l1ContractsConfig.aztecSlotDuration * 1000);
128
+ async addBootstrapNode() {
129
+ this.logger.info('Adding bootstrap node');
130
+ const telemetry = await getEndToEndTestTelemetryClient(this.metricsPort);
131
+ this.bootstrapNode = await createBootstrapNodeFromPrivateKey(BOOTSTRAP_NODE_PRIVATE_KEY, this.bootNodePort, telemetry, this.context.config);
132
+ // Overwrite enr with updated info
133
+ this.bootstrapNodeEnr = this.bootstrapNode.getENR().encodeTxt();
104
134
  }
105
- /**
106
- * When using fake timers, we need to keep the system and anvil clocks in sync.
107
- */ async syncMockSystemTime() {
108
- this.logger.info('Syncing mock system time');
109
- const { dateProvider, deployL1ContractsValues } = this.ctx;
110
- // Send a tx and only update the time after the tx is mined, as eth time is not continuous
111
- const { receipt } = await this.gasUtils.sendAndMonitorTransaction({
112
- to: this.baseAccount.address,
113
- data: '0x',
114
- value: 1n
135
+ getValidators() {
136
+ const validators = [];
137
+ for(let i = 0; i < this.numberOfValidators; i++){
138
+ const keyIndex = i;
139
+ const attester = privateKeyToAccount(this.attesterPrivateKeys[keyIndex]);
140
+ validators.push({
141
+ attester: EthAddress.fromString(attester.address),
142
+ withdrawer: EthAddress.fromString(attester.address),
143
+ bn254SecretKey: new SecretValue(Fr.random().toBigInt())
144
+ });
145
+ this.logger.info(`Adding attester ${attester.address} as validator`);
146
+ }
147
+ return {
148
+ validators
149
+ };
150
+ }
151
+ async applyBaseSetup() {
152
+ await this.addBootstrapNode();
153
+ this.logger.info('Adding validators');
154
+ const rollup = getContract({
155
+ address: this.context.deployL1ContractsValues.l1ContractAddresses.rollupAddress.toString(),
156
+ abi: RollupAbi,
157
+ client: this.context.deployL1ContractsValues.l1Client
115
158
  });
116
- const timestamp = await deployL1ContractsValues.publicClient.getBlock({
117
- blockNumber: receipt.blockNumber
159
+ this.logger.info(`Adding ${this.numberOfValidators} validators`);
160
+ const stakingAsset = getContract({
161
+ address: this.context.deployL1ContractsValues.l1ContractAddresses.stakingAssetAddress.toString(),
162
+ abi: TestERC20Abi,
163
+ client: this.context.deployL1ContractsValues.l1Client
118
164
  });
119
- this.logger.info(`Timestamp: ${timestamp.timestamp}`);
120
- dateProvider.setTime(Number(timestamp.timestamp) * 1000);
121
- }
122
- async applyBaseSnapshots() {
123
- await this.snapshotManager.snapshot('add-bootstrap-node', async ({ aztecNodeConfig })=>{
124
- const telemetry = getEndToEndTestTelemetryClient(this.metricsPort);
125
- this.bootstrapNode = await createBootstrapNodeFromPrivateKey(BOOTSTRAP_NODE_PRIVATE_KEY, this.bootNodePort, telemetry, aztecNodeConfig);
126
- // Overwrite enr with updated info
127
- this.bootstrapNodeEnr = this.bootstrapNode.getENR().encodeTxt();
165
+ const { address: multiAdderAddress } = await deployL1Contract(this.context.deployL1ContractsValues.l1Client, MultiAdderArtifact.contractAbi, MultiAdderArtifact.contractBytecode, [
166
+ rollup.address,
167
+ this.context.deployL1ContractsValues.l1Client.account.address
168
+ ]);
169
+ const multiAdder = getContract({
170
+ address: multiAdderAddress.toString(),
171
+ abi: MultiAdderArtifact.contractAbi,
172
+ client: this.context.deployL1ContractsValues.l1Client
128
173
  });
129
- await this.snapshotManager.snapshot('add-validators', async ({ deployL1ContractsValues, aztecNodeConfig, dateProvider })=>{
130
- const rollup = getContract({
131
- address: deployL1ContractsValues.l1ContractAddresses.rollupAddress.toString(),
132
- abi: RollupAbi,
133
- client: deployL1ContractsValues.walletClient
134
- });
135
- this.logger.verbose(`Adding ${this.numberOfNodes} validators`);
136
- const stakingAsset = getContract({
137
- address: deployL1ContractsValues.l1ContractAddresses.stakingAssetAddress.toString(),
138
- abi: TestERC20Abi,
139
- client: deployL1ContractsValues.walletClient
140
- });
141
- const stakeNeeded = l1ContractsConfig.minimumStake * BigInt(this.numberOfNodes);
142
- await Promise.all([
143
- await stakingAsset.write.mint([
144
- deployL1ContractsValues.walletClient.account.address,
145
- stakeNeeded
146
- ], {}),
147
- await stakingAsset.write.approve([
148
- deployL1ContractsValues.l1ContractAddresses.rollupAddress.toString(),
149
- stakeNeeded
150
- ], {})
151
- ].map((txHash)=>deployL1ContractsValues.publicClient.waitForTransactionReceipt({
152
- hash: txHash
153
- })));
154
- const validators = [];
155
- for(let i = 0; i < this.numberOfNodes; i++){
156
- const attester = privateKeyToAccount(this.attesterPrivateKeys[i]);
157
- const proposerEOA = privateKeyToAccount(this.proposerPrivateKeys[i]);
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);
174
+ const stakeNeeded = await rollup.read.getActivationThreshold() * BigInt(this.numberOfValidators);
175
+ await Promise.all([
176
+ await stakingAsset.write.mint([
177
+ multiAdder.address,
178
+ stakeNeeded
179
+ ], {})
180
+ ].map((txHash)=>this.context.deployL1ContractsValues.l1Client.waitForTransactionReceipt({
181
+ hash: txHash
182
+ })));
183
+ const { validators } = this.getValidators();
184
+ this.validators = validators;
185
+ const gseAddress = this.context.deployL1ContractsValues.l1ContractAddresses.gseAddress;
186
+ if (!gseAddress) {
187
+ throw new Error('GSE contract not deployed');
188
+ }
189
+ const gseContract = new GSEContract(this.context.deployL1ContractsValues.l1Client, gseAddress.toString());
190
+ const makeValidatorTuples = async (validator)=>{
191
+ const registrationTuple = await gseContract.makeRegistrationTuple(validator.bn254SecretKey.getValue());
192
+ return {
193
+ attester: validator.attester.toString(),
194
+ withdrawer: validator.withdrawer.toString(),
195
+ ...registrationTuple
196
+ };
197
+ };
198
+ const validatorTuples = await Promise.all(validators.map(makeValidatorTuples));
199
+ await this.context.deployL1ContractsValues.l1Client.waitForTransactionReceipt({
200
+ hash: await multiAdder.write.addValidators([
201
+ validatorTuples
202
+ ])
195
203
  });
204
+ await this.context.cheatCodes.rollup.advanceToEpoch(EpochNumber.fromBigInt(BigInt(await this.context.cheatCodes.rollup.getEpoch()) + await rollup.read.getLagInEpochsForValidatorSet() + 1n));
205
+ // Send and await a tx to make sure we mine a block for the warp to correctly progress.
206
+ await this._sendDummyTx(this.context.deployL1ContractsValues.l1Client);
196
207
  }
197
208
  async setupAccount() {
198
- await this.snapshotManager.snapshot('setup-account', deployAccounts(1, this.logger, false), async ({ deployedAccounts }, { pxe })=>{
199
- this.deployedAccounts = deployedAccounts;
200
- const [account] = deployedAccounts;
201
- this.wallet = await getSchnorrWalletWithSecretKey(pxe, account.secret, account.signingKey, account.salt);
209
+ this.logger.info('Setting up account');
210
+ const { deployedAccounts } = await deployAccounts(1, this.logger)({
211
+ wallet: this.context.wallet,
212
+ initialFundedAccounts: this.context.initialFundedAccounts
202
213
  });
214
+ this.deployedAccounts = deployedAccounts;
215
+ [{ address: this.defaultAccountAddress }] = deployedAccounts;
216
+ this.wallet = this.context.wallet;
203
217
  }
204
218
  async deploySpamContract() {
205
- await this.snapshotManager.snapshot('add-spam-contract', async ()=>{
206
- if (!this.wallet) {
207
- throw new Error('Call snapshot t.setupAccount before deploying account contract');
208
- }
209
- const spamContract = await SpamContract.deploy(this.wallet).send().deployed();
210
- return {
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
- });
219
+ this.logger.info('Deploying spam contract');
220
+ if (!this.wallet) {
221
+ throw new Error('Call setupAccount before deploying spam contract');
222
+ }
223
+ ({ contract: this.spamContract } = await SpamContract.deploy(this.wallet).send({
224
+ from: this.defaultAccountAddress
225
+ }));
219
226
  }
220
227
  async removeInitialNode() {
221
- await this.snapshotManager.snapshot('remove-inital-validator', async ({ deployL1ContractsValues, aztecNode, dateProvider })=>{
222
- // Send and await a tx to make sure we mine a block for the warp to correctly progress.
223
- const receipt = await deployL1ContractsValues.publicClient.waitForTransactionReceipt({
224
- hash: await deployL1ContractsValues.walletClient.sendTransaction({
225
- to: this.baseAccount.address,
226
- value: 1n,
227
- account: this.baseAccount
228
- })
229
- });
230
- const block = await deployL1ContractsValues.publicClient.getBlock({
231
- blockNumber: receipt.blockNumber
232
- });
233
- dateProvider.setTime(Number(block.timestamp) * 1000);
234
- await aztecNode.stop();
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 = createL1TxUtils(l1Client);
242
+ return await l1TxUtils.sendAndMonitorTransaction({
243
+ to: l1Client.account.address,
244
+ value: 1n
235
245
  });
236
246
  }
237
247
  async setup() {
238
- this.ctx = await this.snapshotManager.setup();
239
- this.prefilledPublicData = (await getGenesisValues(this.ctx.initialFundedAccounts.map((a)=>a.address))).prefilledPublicData;
240
- this.startSyncMockSystemTimeInterval();
241
- this.gasUtils = new L1TxUtilsWithBlobs(this.ctx.deployL1ContractsValues.publicClient, this.ctx.deployL1ContractsValues.walletClient, this.logger, {
242
- gasLimitBufferPercentage: 20,
243
- maxGwei: 500n,
244
- maxAttempts: 3,
245
- checkIntervalMs: 100,
246
- stallTimeMs: 1000
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.monitor = new ChainMonitor(RollupContract.getFromL1ContractsValues(this.ctx.deployL1ContractsValues)).start();
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,69 @@ 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, topics = [
291
+ TopicType.tx
292
+ ]) {
293
+ const nodeCount = expectedNodeCount ?? nodes.length;
294
+ const minPeerCount = nodeCount - 1;
295
+ this.logger.warn(`Waiting for all ${nodeCount} nodes to connect to P2P mesh (at least ${minPeerCount} peers each)...`);
296
+ await Promise.all(nodes.map(async (node, index)=>{
297
+ const p2p = node.getP2P();
298
+ await retryUntil(async ()=>{
299
+ const peers = await p2p.getPeers();
300
+ // Each node should be connected to at least N-1 other nodes
301
+ return peers.length >= minPeerCount ? true : undefined;
302
+ }, `Node ${index} to connect to at least ${minPeerCount} peers`, timeoutSeconds, checkIntervalSeconds);
303
+ }));
304
+ this.logger.warn('All nodes connected to P2P mesh');
305
+ // Wait for GossipSub mesh to form for all specified topics.
306
+ // We only require at least 1 mesh peer per node because GossipSub
307
+ // stops grafting once it reaches Dlo peers and won't fill the mesh to all available peers.
308
+ for (const topic of topics){
309
+ this.logger.warn(`Waiting for GossipSub mesh to form for ${topic} topic...`);
310
+ await Promise.all(nodes.map(async (node, index)=>{
311
+ const p2p = node.getP2P();
312
+ await retryUntil(async ()=>{
313
+ const meshPeers = await p2p.getGossipMeshPeerCount(topic);
314
+ this.logger.debug(`Node ${index} has ${meshPeers} gossip mesh peers for ${topic} topic`);
315
+ return meshPeers >= 1 ? true : undefined;
316
+ }, `Node ${index} to have gossip mesh peers for ${topic} topic`, timeoutSeconds, checkIntervalSeconds);
317
+ }));
318
+ this.logger.warn(`All nodes have gossip mesh peers for ${topic} topic`);
319
+ }
320
+ }
259
321
  async teardown() {
260
- this.monitor.stop();
261
- await this.bootstrapNode?.stop();
262
- await this.snapshotManager.teardown();
263
- if (this.cleanupInterval) {
264
- clearInterval(this.cleanupInterval);
322
+ await this.monitor.stop();
323
+ await tryStop(this.bootstrapNode, this.logger);
324
+ await teardown(this.context);
325
+ }
326
+ async getContracts() {
327
+ if (!this.ctx.deployL1ContractsValues) {
328
+ throw new Error('DeployAztecL1ContractsValues not set');
265
329
  }
330
+ const rollup = new RollupContract(this.ctx.deployL1ContractsValues.l1Client, this.ctx.deployL1ContractsValues.l1ContractAddresses.rollupAddress);
331
+ const slasherContract = getContract({
332
+ address: getAddress((await rollup.getSlasherAddress()).toString()),
333
+ abi: SlasherAbi,
334
+ client: this.ctx.deployL1ContractsValues.l1Client
335
+ });
336
+ // Get the actual slashing proposer from rollup (which handles both empire and tally)
337
+ const slashingProposer = await rollup.getSlashingProposer();
338
+ const slashFactory = new SlashFactoryContract(this.ctx.deployL1ContractsValues.l1Client, getAddress(this.ctx.deployL1ContractsValues.l1ContractAddresses.slashFactoryAddress.toString()));
339
+ return {
340
+ rollup,
341
+ slasherContract,
342
+ slashingProposer,
343
+ slashFactory
344
+ };
266
345
  }
267
346
  }
@@ -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 = 4;
5
+ export declare const BOOT_NODE_UDP_PORT: number;
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9lMmVfcDJwL3JlcXJlc3AvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQWdCMUQsT0FBTyxFQUFFLGNBQWMsRUFBdUIsTUFBTSxtQkFBbUIsQ0FBQztBQUl4RSxlQUFPLE1BQU0sY0FBYyxJQUFJLENBQUM7QUFDaEMsZUFBTyxNQUFNLGdCQUFnQixJQUFJLENBQUM7QUFDbEMsZUFBTyxNQUFNLGtCQUFrQixRQUF1QixDQUFDO0FBRXZELGVBQU8sTUFBTSxvQkFBb0IsY0FBMkQsQ0FBQztBQUU3RixLQUFLLGNBQWMsR0FBRztJQUNwQixzQkFBc0IsQ0FBQyxFQUFFLE9BQU8sQ0FBQztDQUNsQyxDQUFDO0FBRUYsd0JBQXNCLGlCQUFpQixDQUFDLE9BQU8sR0FBRSxjQUFtQixHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0EwQjdGO0FBRUQsd0JBQXNCLGtCQUFrQixDQUFDLE1BQU0sRUFBRTtJQUFFLENBQUMsRUFBRSxjQUFjLENBQUM7SUFBQyxLQUFLLENBQUMsRUFBRSxnQkFBZ0IsRUFBRSxDQUFDO0lBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQTtDQUFFLGlCQVNsSDtBQUlELHdCQUFzQixnQkFBZ0IsQ0FBQyxNQUFNLEVBQUU7SUFDN0MsQ0FBQyxFQUFFLGNBQWMsQ0FBQztJQUNsQixPQUFPLEVBQUUsTUFBTSxDQUFDO0lBQ2hCLHNCQUFzQixDQUFDLEVBQUUsT0FBTyxDQUFDO0NBQ2xDLEdBQUcsT0FBTyxDQUFDLGdCQUFnQixFQUFFLENBQUMsQ0FtSjlCIn0=
@@ -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,EAAuB,MAAM,mBAAmB,CAAC;AAIxE,eAAO,MAAM,cAAc,IAAI,CAAC;AAChC,eAAO,MAAM,gBAAgB,IAAI,CAAC;AAClC,eAAO,MAAM,kBAAkB,QAAuB,CAAC;AAEvD,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,CA0B7F;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,CAmJ9B"}