@aztec/end-to-end 0.0.1-commit.e558bd1c → 0.0.1-commit.e5a3663dd

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 (202) hide show
  1. package/README.md +27 -0
  2. package/dest/bench/client_flows/client_flows_benchmark.d.ts +2 -2
  3. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  4. package/dest/bench/client_flows/client_flows_benchmark.js +24 -31
  5. package/dest/bench/client_flows/config.d.ts +2 -2
  6. package/dest/bench/client_flows/config.d.ts.map +1 -1
  7. package/dest/bench/client_flows/config.js +18 -0
  8. package/dest/bench/utils.d.ts +1 -1
  9. package/dest/bench/utils.d.ts.map +1 -1
  10. package/dest/bench/utils.js +6 -3
  11. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +6 -3
  12. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  13. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +23 -13
  14. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +2 -2
  15. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  16. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +1 -1
  17. package/dest/e2e_deploy_contract/deploy_test.d.ts +2 -2
  18. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  19. package/dest/e2e_epochs/epochs_test.d.ts +26 -7
  20. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  21. package/dest/e2e_epochs/epochs_test.js +117 -41
  22. package/dest/e2e_fees/fees_test.d.ts +2 -2
  23. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  24. package/dest/e2e_fees/fees_test.js +22 -15
  25. package/dest/e2e_nested_contract/nested_contract_test.d.ts +1 -1
  26. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  27. package/dest/e2e_nested_contract/nested_contract_test.js +4 -6
  28. package/dest/e2e_p2p/inactivity_slash_test.js +3 -3
  29. package/dest/e2e_p2p/p2p_network.d.ts +14 -12
  30. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  31. package/dest/e2e_p2p/p2p_network.js +70 -34
  32. package/dest/e2e_p2p/reqresp/utils.d.ts +3 -3
  33. package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -1
  34. package/dest/e2e_p2p/reqresp/utils.js +49 -9
  35. package/dest/e2e_p2p/shared.d.ts +26 -8
  36. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  37. package/dest/e2e_p2p/shared.js +71 -50
  38. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
  39. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
  40. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
  41. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
  42. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
  43. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
  44. package/dest/e2e_token_contract/token_contract_test.d.ts +4 -2
  45. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  46. package/dest/e2e_token_contract/token_contract_test.js +19 -9
  47. package/dest/fixtures/authwit_proxy.d.ts +15 -0
  48. package/dest/fixtures/authwit_proxy.d.ts.map +1 -0
  49. package/dest/fixtures/authwit_proxy.js +34 -0
  50. package/dest/fixtures/e2e_prover_test.d.ts +7 -6
  51. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  52. package/dest/fixtures/e2e_prover_test.js +37 -49
  53. package/dest/fixtures/elu_monitor.d.ts +21 -0
  54. package/dest/fixtures/elu_monitor.d.ts.map +1 -0
  55. package/dest/fixtures/elu_monitor.js +102 -0
  56. package/dest/fixtures/fixtures.d.ts +16 -1
  57. package/dest/fixtures/fixtures.d.ts.map +1 -1
  58. package/dest/fixtures/fixtures.js +16 -0
  59. package/dest/fixtures/get_bb_config.d.ts +1 -1
  60. package/dest/fixtures/get_bb_config.d.ts.map +1 -1
  61. package/dest/fixtures/get_bb_config.js +5 -5
  62. package/dest/fixtures/ha_setup.d.ts +2 -2
  63. package/dest/fixtures/ha_setup.d.ts.map +1 -1
  64. package/dest/fixtures/ha_setup.js +4 -2
  65. package/dest/fixtures/schnorr_hardcoded_account_contract.d.ts +25 -0
  66. package/dest/fixtures/schnorr_hardcoded_account_contract.d.ts.map +1 -0
  67. package/dest/fixtures/schnorr_hardcoded_account_contract.js +39 -0
  68. package/dest/fixtures/setup.d.ts +59 -31
  69. package/dest/fixtures/setup.d.ts.map +1 -1
  70. package/dest/fixtures/setup.js +97 -167
  71. package/dest/fixtures/setup_p2p_test.d.ts +10 -7
  72. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  73. package/dest/fixtures/setup_p2p_test.js +18 -15
  74. package/dest/fixtures/token_utils.d.ts +2 -2
  75. package/dest/fixtures/token_utils.d.ts.map +1 -1
  76. package/dest/fixtures/token_utils.js +5 -7
  77. package/dest/forward-compatibility/wallet_rpc_client.d.ts +7 -0
  78. package/dest/forward-compatibility/wallet_rpc_client.d.ts.map +1 -0
  79. package/dest/forward-compatibility/wallet_rpc_client.js +15 -0
  80. package/dest/forward-compatibility/wallet_service.d.ts +3 -0
  81. package/dest/forward-compatibility/wallet_service.d.ts.map +1 -0
  82. package/dest/forward-compatibility/wallet_service.js +109 -0
  83. package/dest/legacy-jest-resolver.d.cts +3 -0
  84. package/dest/legacy-jest-resolver.d.cts.map +1 -0
  85. package/dest/shared/cross_chain_test_harness.d.ts +1 -1
  86. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  87. package/dest/shared/cross_chain_test_harness.js +13 -13
  88. package/dest/shared/gas_portal_test_harness.js +3 -3
  89. package/dest/shared/index.d.ts +2 -1
  90. package/dest/shared/index.d.ts.map +1 -1
  91. package/dest/shared/index.js +1 -0
  92. package/dest/shared/jest_setup.js +41 -1
  93. package/dest/shared/mock_state_view.d.ts +86 -0
  94. package/dest/shared/mock_state_view.d.ts.map +1 -0
  95. package/dest/shared/mock_state_view.js +186 -0
  96. package/dest/shared/submit-transactions.d.ts +2 -2
  97. package/dest/shared/submit-transactions.d.ts.map +1 -1
  98. package/dest/shared/submit-transactions.js +1 -1
  99. package/dest/shared/uniswap_l1_l2.d.ts +1 -1
  100. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  101. package/dest/shared/uniswap_l1_l2.js +15 -22
  102. package/dest/simulators/lending_simulator.d.ts +1 -1
  103. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  104. package/dest/simulators/lending_simulator.js +4 -4
  105. package/dest/simulators/token_simulator.d.ts +1 -1
  106. package/dest/simulators/token_simulator.d.ts.map +1 -1
  107. package/dest/simulators/token_simulator.js +3 -24
  108. package/dest/spartan/setup_test_wallets.d.ts +12 -3
  109. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  110. package/dest/spartan/setup_test_wallets.js +100 -39
  111. package/dest/spartan/tx_metrics.d.ts +1 -1
  112. package/dest/spartan/tx_metrics.d.ts.map +1 -1
  113. package/dest/spartan/tx_metrics.js +19 -3
  114. package/dest/spartan/utils/bot.d.ts +3 -2
  115. package/dest/spartan/utils/bot.d.ts.map +1 -1
  116. package/dest/spartan/utils/bot.js +2 -1
  117. package/dest/spartan/utils/config.d.ts +7 -1
  118. package/dest/spartan/utils/config.d.ts.map +1 -1
  119. package/dest/spartan/utils/config.js +3 -1
  120. package/dest/spartan/utils/index.d.ts +4 -2
  121. package/dest/spartan/utils/index.d.ts.map +1 -1
  122. package/dest/spartan/utils/index.js +5 -1
  123. package/dest/spartan/utils/k8s.d.ts +3 -1
  124. package/dest/spartan/utils/k8s.d.ts.map +1 -1
  125. package/dest/spartan/utils/k8s.js +6 -0
  126. package/dest/spartan/utils/nodes.d.ts +4 -5
  127. package/dest/spartan/utils/nodes.d.ts.map +1 -1
  128. package/dest/spartan/utils/nodes.js +9 -9
  129. package/dest/spartan/utils/pod_logs.d.ts +25 -0
  130. package/dest/spartan/utils/pod_logs.d.ts.map +1 -0
  131. package/dest/spartan/utils/pod_logs.js +74 -0
  132. package/dest/test-wallet/test_wallet.d.ts +84 -0
  133. package/dest/test-wallet/test_wallet.d.ts.map +1 -0
  134. package/dest/test-wallet/test_wallet.js +255 -0
  135. package/dest/test-wallet/utils.d.ts +41 -0
  136. package/dest/test-wallet/utils.d.ts.map +1 -0
  137. package/dest/test-wallet/utils.js +71 -0
  138. package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
  139. package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
  140. package/dest/test-wallet/wallet_worker_script.js +48 -0
  141. package/dest/test-wallet/worker_wallet.d.ts +52 -0
  142. package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
  143. package/dest/test-wallet/worker_wallet.js +151 -0
  144. package/dest/test-wallet/worker_wallet_schema.d.ts +279 -0
  145. package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
  146. package/dest/test-wallet/worker_wallet_schema.js +10 -0
  147. package/package.json +43 -43
  148. package/src/bench/client_flows/client_flows_benchmark.ts +33 -20
  149. package/src/bench/client_flows/config.ts +9 -1
  150. package/src/bench/utils.ts +8 -3
  151. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +31 -21
  152. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +5 -5
  153. package/src/e2e_deploy_contract/deploy_test.ts +3 -3
  154. package/src/e2e_epochs/epochs_test.ts +138 -67
  155. package/src/e2e_fees/bridging_race.notest.ts +1 -1
  156. package/src/e2e_fees/fees_test.ts +25 -31
  157. package/src/e2e_nested_contract/nested_contract_test.ts +7 -5
  158. package/src/e2e_p2p/inactivity_slash_test.ts +7 -7
  159. package/src/e2e_p2p/p2p_network.ts +93 -49
  160. package/src/e2e_p2p/reqresp/utils.ts +63 -13
  161. package/src/e2e_p2p/shared.ts +90 -64
  162. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  163. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  164. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  165. package/src/e2e_token_contract/token_contract_test.ts +26 -9
  166. package/src/fixtures/authwit_proxy.ts +54 -0
  167. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  168. package/src/fixtures/e2e_prover_test.ts +46 -55
  169. package/src/fixtures/elu_monitor.ts +126 -0
  170. package/src/fixtures/fixtures.ts +32 -0
  171. package/src/fixtures/get_bb_config.ts +7 -6
  172. package/src/fixtures/ha_setup.ts +7 -3
  173. package/src/fixtures/schnorr_hardcoded_account_contract.ts +49 -0
  174. package/src/fixtures/setup.ts +147 -232
  175. package/src/fixtures/setup_p2p_test.ts +17 -25
  176. package/src/fixtures/token_utils.ts +3 -3
  177. package/src/forward-compatibility/wallet_rpc_client.ts +14 -0
  178. package/src/forward-compatibility/wallet_service.ts +104 -0
  179. package/src/guides/up_quick_start.sh +3 -5
  180. package/src/legacy-jest-resolver.cjs +135 -0
  181. package/src/shared/cross_chain_test_harness.ts +13 -9
  182. package/src/shared/gas_portal_test_harness.ts +1 -2
  183. package/src/shared/index.ts +1 -0
  184. package/src/shared/jest_setup.ts +51 -1
  185. package/src/shared/mock_state_view.ts +188 -0
  186. package/src/shared/submit-transactions.ts +3 -2
  187. package/src/shared/uniswap_l1_l2.ts +37 -34
  188. package/src/simulators/lending_simulator.ts +8 -4
  189. package/src/simulators/token_simulator.ts +6 -30
  190. package/src/spartan/setup_test_wallets.ts +141 -32
  191. package/src/spartan/tx_metrics.ts +17 -5
  192. package/src/spartan/utils/bot.ts +4 -1
  193. package/src/spartan/utils/config.ts +2 -0
  194. package/src/spartan/utils/index.ts +7 -0
  195. package/src/spartan/utils/k8s.ts +8 -0
  196. package/src/spartan/utils/nodes.ts +15 -10
  197. package/src/spartan/utils/pod_logs.ts +99 -0
  198. package/src/test-wallet/test_wallet.ts +357 -0
  199. package/src/test-wallet/utils.ts +112 -0
  200. package/src/test-wallet/wallet_worker_script.ts +60 -0
  201. package/src/test-wallet/worker_wallet.ts +214 -0
  202. package/src/test-wallet/worker_wallet_schema.ts +13 -0
@@ -1,18 +1,14 @@
1
- import type { InitialAccountData } from '@aztec/accounts/testing';
1
+ import { type InitialAccountData, generateSchnorrAccounts } from '@aztec/accounts/testing';
2
2
  import type { AztecNodeConfig, AztecNodeService } from '@aztec/aztec-node';
3
+ import { getAccountContractAddress } from '@aztec/aztec.js/account';
3
4
  import { AztecAddress, EthAddress } from '@aztec/aztec.js/addresses';
4
5
  import { Fr } from '@aztec/aztec.js/fields';
5
6
  import { getL1ContractsConfigEnvVars } from '@aztec/ethereum/config';
6
- import {
7
- type EmpireSlashingProposerContract,
8
- GSEContract,
9
- RollupContract,
10
- type TallySlashingProposerContract,
11
- } from '@aztec/ethereum/contracts';
7
+ import { GSEContract, RollupContract, type SlashingProposerContract } from '@aztec/ethereum/contracts';
12
8
  import type { Operator } from '@aztec/ethereum/deploy-aztec-l1-contracts';
13
9
  import { deployL1Contract } from '@aztec/ethereum/deploy-l1-contract';
14
10
  import { MultiAdderArtifact } from '@aztec/ethereum/l1-artifacts';
15
- import { createL1TxUtilsFromViemWallet } from '@aztec/ethereum/l1-tx-utils';
11
+ import { createL1TxUtils } from '@aztec/ethereum/l1-tx-utils';
16
12
  import { ChainMonitor } from '@aztec/ethereum/test';
17
13
  import type { ExtendedViemWalletClient, ViemClient } from '@aztec/ethereum/types';
18
14
  import { EpochNumber } from '@aztec/foundation/branded-types';
@@ -24,20 +20,22 @@ import { SpamContract } from '@aztec/noir-test-contracts.js/Spam';
24
20
  import type { BootstrapNode } from '@aztec/p2p/bootstrap';
25
21
  import { createBootstrapNodeFromPrivateKey, getBootstrapNodeEnr } from '@aztec/p2p/test-helpers';
26
22
  import { tryStop } from '@aztec/stdlib/interfaces/server';
27
- import { SlashFactoryContract } from '@aztec/stdlib/l1-contracts';
28
- import type { PublicDataTreeLeaf } from '@aztec/stdlib/trees';
23
+ import { TopicType } from '@aztec/stdlib/p2p';
24
+ import type { GenesisData } from '@aztec/stdlib/world-state';
29
25
  import { ZkPassportProofParams } from '@aztec/stdlib/zkpassport';
30
- import type { TestWallet } from '@aztec/test-wallet/server';
31
26
  import { getGenesisValues } from '@aztec/world-state/testing';
32
27
 
33
28
  import getPort from 'get-port';
34
29
  import { type GetContractReturnType, getAddress, getContract } from 'viem';
35
30
  import { privateKeyToAccount } from 'viem/accounts';
36
31
 
32
+ import {
33
+ SCHNORR_HARDCODED_PRIVATE_KEY,
34
+ SchnorrHardcodedKeyAccountContract,
35
+ } from '../fixtures/schnorr_hardcoded_account_contract.js';
37
36
  import {
38
37
  type EndToEndContext,
39
38
  type SetupOptions,
40
- deployAccounts,
41
39
  getPrivateKeyFromIndex,
42
40
  getSponsoredFPCAddress,
43
41
  setup,
@@ -49,6 +47,7 @@ import {
49
47
  generatePrivateKeys,
50
48
  } from '../fixtures/setup_p2p_test.js';
51
49
  import { getEndToEndTestTelemetryClient } from '../fixtures/with_telemetry_utils.js';
50
+ import type { TestWallet } from '../test-wallet/test_wallet.js';
52
51
 
53
52
  // Use a fixed bootstrap node private key so that we can re-use the same snapshot and the nodes can find each other
54
53
  const BOOTSTRAP_NODE_PRIVATE_KEY = '080212208f988fc0899e4a73a5aee4d271a5f20670603a756ad8d84f2c94263a6427c591';
@@ -58,7 +57,7 @@ export const WAIT_FOR_TX_TIMEOUT = l1ContractsConfig.aztecSlotDuration * 3;
58
57
  export const SHORTENED_BLOCK_TIME_CONFIG_NO_PRUNES = {
59
58
  aztecSlotDuration: 12,
60
59
  ethereumSlotDuration: 4,
61
- aztecProofSubmissionWindow: 640,
60
+ aztecProofSubmissionEpochs: 640,
62
61
  };
63
62
 
64
63
  export class P2PNetworkTest {
@@ -75,8 +74,8 @@ export class P2PNetworkTest {
75
74
  public peerIdPrivateKeys: string[] = [];
76
75
  public validators: Operator[] = [];
77
76
 
78
- public deployedAccounts: InitialAccountData[] = [];
79
- public prefilledPublicData: PublicDataTreeLeaf[] = [];
77
+ public hardcodedAccountData!: InitialAccountData;
78
+ public genesis: GenesisData | undefined;
80
79
 
81
80
  // The re-execution test needs a wallet and a spam contract
82
81
  public wallet?: TestWallet;
@@ -123,12 +122,11 @@ export class P2PNetworkTest {
123
122
  initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
124
123
  slashingRoundSizeInEpochs:
125
124
  initialValidatorConfig.slashingRoundSizeInEpochs ?? l1ContractsConfig.slashingRoundSizeInEpochs,
126
- slasherFlavor: initialValidatorConfig.slasherFlavor ?? 'tally',
125
+ slasherEnabled: initialValidatorConfig.slasherEnabled ?? true,
127
126
  aztecTargetCommitteeSize: numberOfValidators,
128
127
  metricsPort: metricsPort,
129
128
  numberOfInitialFundedAccounts: 2,
130
129
  startProverNode,
131
- walletMinFeePadding: 2.0,
132
130
  };
133
131
 
134
132
  this.deployL1ContractsArgs = {
@@ -136,7 +134,7 @@ export class P2PNetworkTest {
136
134
  aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
137
135
  slashingRoundSizeInEpochs:
138
136
  initialValidatorConfig.slashingRoundSizeInEpochs ?? l1ContractsConfig.slashingRoundSizeInEpochs,
139
- slasherFlavor: initialValidatorConfig.slasherFlavor ?? 'tally',
137
+ slasherEnabled: initialValidatorConfig.slasherEnabled ?? true,
140
138
 
141
139
  ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
142
140
  aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
@@ -191,10 +189,10 @@ export class P2PNetworkTest {
191
189
  }
192
190
 
193
191
  get fundedAccount() {
194
- if (!this.deployedAccounts[0]) {
195
- throw new Error('Call setupAccount to create a funded account.');
192
+ if (!this.hardcodedAccountData) {
193
+ throw new Error('Call setup to initialize the hardcoded account.');
196
194
  }
197
- return this.deployedAccounts[0];
195
+ return this.hardcodedAccountData;
198
196
  }
199
197
 
200
198
  async addBootstrapNode() {
@@ -302,17 +300,22 @@ export class P2PNetworkTest {
302
300
  await this._sendDummyTx(this.context.deployL1ContractsValues.l1Client);
303
301
  }
304
302
 
303
+ /** Points the wallet to a P2P-enabled node so transactions can propagate through the network. */
304
+ setupWalletOnNode(node: AztecNodeService) {
305
+ this.logger.info('Pointing wallet to a P2P-enabled node');
306
+ this.context.wallet.updateNode(node);
307
+ }
308
+
309
+ /** Registers the hardcoded account in PXE without on-chain deployment. No sequencer needed. */
305
310
  async setupAccount() {
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,
311
+ this.logger.info('Registering hardcoded account (no deployment)');
312
+ const contract = new SchnorrHardcodedKeyAccountContract();
313
+ const accountManager = await (this.context.wallet as TestWallet).createAccount({
314
+ secret: this.hardcodedAccountData.secret,
315
+ salt: this.hardcodedAccountData.salt,
316
+ contract,
313
317
  });
314
- this.deployedAccounts = deployedAccounts;
315
- [{ address: this.defaultAccountAddress }] = deployedAccounts;
318
+ this.defaultAccountAddress = accountManager.address;
316
319
  this.wallet = this.context.wallet;
317
320
  }
318
321
 
@@ -322,8 +325,9 @@ export class P2PNetworkTest {
322
325
  throw new Error('Call setupAccount before deploying spam contract');
323
326
  }
324
327
 
325
- const spamContract = await SpamContract.deploy(this.wallet).send({ from: this.defaultAccountAddress! });
326
- this.spamContract = spamContract;
328
+ ({ contract: this.spamContract } = await SpamContract.deploy(this.wallet).send({
329
+ from: this.defaultAccountAddress!,
330
+ }));
327
331
  }
328
332
 
329
333
  async removeInitialNode() {
@@ -333,9 +337,9 @@ export class P2PNetworkTest {
333
337
  const block = await this.context.deployL1ContractsValues.l1Client.getBlock({
334
338
  blockNumber: receipt.blockNumber,
335
339
  });
336
- this.context.dateProvider!.setTime(Number(block.timestamp) * 1000);
340
+ this.context.dateProvider.setTime(Number(block.timestamp) * 1000);
337
341
 
338
- await this.context.aztecNodeService!.stop();
342
+ await this.context.aztecNodeService.stop();
339
343
  }
340
344
 
341
345
  async sendDummyTx() {
@@ -343,7 +347,7 @@ export class P2PNetworkTest {
343
347
  }
344
348
 
345
349
  private async _sendDummyTx(l1Client: ExtendedViemWalletClient) {
346
- const l1TxUtils = createL1TxUtilsFromViemWallet(l1Client);
350
+ const l1TxUtils = createL1TxUtils(l1Client);
347
351
  return await l1TxUtils.sendAndMonitorTransaction({
348
352
  to: l1Client.account!.address,
349
353
  value: 1n,
@@ -352,13 +356,30 @@ export class P2PNetworkTest {
352
356
 
353
357
  async setup() {
354
358
  this.logger.info('Setting up subsystems from fresh');
359
+
360
+ // Pre-compute hardcoded account data so it gets funded in genesis.
361
+ const contract = new SchnorrHardcodedKeyAccountContract();
362
+ const secret = Fr.random();
363
+ const salt = Fr.random();
364
+ this.hardcodedAccountData = {
365
+ secret,
366
+ salt,
367
+ signingKey: SCHNORR_HARDCODED_PRIVATE_KEY,
368
+ address: await getAccountContractAddress(contract, secret, salt),
369
+ };
370
+
371
+ // Generate regular Schnorr accounts for tests that need deployable accounts (e.g. add_rollup).
372
+ const regularAccounts = await generateSchnorrAccounts(this.setupOptions.numberOfInitialFundedAccounts ?? 2);
373
+
355
374
  this.context = await setup(
356
375
  0,
357
376
  {
358
377
  ...this.setupOptions,
359
378
  fundSponsoredFPC: true,
360
379
  skipAccountDeployment: true,
361
- slasherFlavor: this.setupOptions.slasherFlavor ?? this.deployL1ContractsArgs.slasherFlavor ?? 'none',
380
+ skipInitialSequencer: true,
381
+ initialFundedAccounts: [...regularAccounts, this.hardcodedAccountData],
382
+ slasherEnabled: this.setupOptions.slasherEnabled ?? this.deployL1ContractsArgs.slasherEnabled ?? false,
362
383
  aztecTargetCommitteeSize: 0,
363
384
  l1ContractsArgs: this.deployL1ContractsArgs,
364
385
  },
@@ -370,12 +391,17 @@ export class P2PNetworkTest {
370
391
  const sponsoredFPCAddress = await getSponsoredFPCAddress();
371
392
  const initialFundedAccounts = [...this.context.initialFundedAccounts.map(a => a.address), sponsoredFPCAddress];
372
393
 
373
- const { prefilledPublicData } = await getGenesisValues(initialFundedAccounts);
374
- this.prefilledPublicData = prefilledPublicData;
394
+ const { genesis } = await getGenesisValues(
395
+ initialFundedAccounts,
396
+ undefined,
397
+ undefined,
398
+ this.context.genesis!.genesisTimestamp,
399
+ );
400
+ this.genesis = genesis;
375
401
 
376
402
  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));
403
+ this.monitor = new ChainMonitor(rollupContract, this.context.dateProvider).start();
404
+ this.monitor.on('l1-block', ({ timestamp }) => this.context.dateProvider.setTime(Number(timestamp) * 1000));
379
405
  }
380
406
 
381
407
  async stopNodes(nodes: AztecNodeService[]) {
@@ -406,6 +432,7 @@ export class P2PNetworkTest {
406
432
  expectedNodeCount?: number,
407
433
  timeoutSeconds = 30,
408
434
  checkIntervalSeconds = 0.1,
435
+ topics: TopicType[] = [TopicType.tx],
409
436
  ) {
410
437
  const nodeCount = expectedNodeCount ?? nodes.length;
411
438
  const minPeerCount = nodeCount - 1;
@@ -431,6 +458,29 @@ export class P2PNetworkTest {
431
458
  );
432
459
 
433
460
  this.logger.warn('All nodes connected to P2P mesh');
461
+
462
+ // Wait for GossipSub mesh to form for all specified topics.
463
+ // We only require at least 1 mesh peer per node because GossipSub
464
+ // stops grafting once it reaches Dlo peers and won't fill the mesh to all available peers.
465
+ for (const topic of topics) {
466
+ this.logger.warn(`Waiting for GossipSub mesh to form for ${topic} topic...`);
467
+ await Promise.all(
468
+ nodes.map(async (node, index) => {
469
+ const p2p = node.getP2P();
470
+ await retryUntil(
471
+ async () => {
472
+ const meshPeers = await p2p.getGossipMeshPeerCount(topic);
473
+ this.logger.debug(`Node ${index} has ${meshPeers} gossip mesh peers for ${topic} topic`);
474
+ return meshPeers >= 1 ? true : undefined;
475
+ },
476
+ `Node ${index} to have gossip mesh peers for ${topic} topic`,
477
+ timeoutSeconds,
478
+ checkIntervalSeconds,
479
+ );
480
+ }),
481
+ );
482
+ this.logger.warn(`All nodes have gossip mesh peers for ${topic} topic`);
483
+ }
434
484
  }
435
485
 
436
486
  async teardown() {
@@ -442,8 +492,7 @@ export class P2PNetworkTest {
442
492
  async getContracts(): Promise<{
443
493
  rollup: RollupContract;
444
494
  slasherContract: GetContractReturnType<typeof SlasherAbi, ViemClient>;
445
- slashingProposer: EmpireSlashingProposerContract | TallySlashingProposerContract | undefined;
446
- slashFactory: SlashFactoryContract;
495
+ slashingProposer: SlashingProposerContract | undefined;
447
496
  }> {
448
497
  if (!this.ctx.deployL1ContractsValues) {
449
498
  throw new Error('DeployAztecL1ContractsValues not set');
@@ -460,14 +509,9 @@ export class P2PNetworkTest {
460
509
  client: this.ctx.deployL1ContractsValues.l1Client,
461
510
  });
462
511
 
463
- // Get the actual slashing proposer from rollup (which handles both empire and tally)
512
+ // Get the actual slashing proposer from rollup
464
513
  const slashingProposer = await rollup.getSlashingProposer();
465
514
 
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 };
515
+ return { rollup, slasherContract, slashingProposer };
472
516
  }
473
517
  }
@@ -3,24 +3,24 @@ import { createLogger } from '@aztec/aztec.js/log';
3
3
  import { waitForTx } from '@aztec/aztec.js/node';
4
4
  import { Tx } from '@aztec/aztec.js/tx';
5
5
  import { RollupContract } from '@aztec/ethereum/contracts';
6
- import { SlotNumber } from '@aztec/foundation/branded-types';
6
+ import { CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
7
7
  import { timesAsync } from '@aztec/foundation/collection';
8
8
  import { retryUntil } from '@aztec/foundation/retry';
9
9
 
10
- import { jest } from '@jest/globals';
10
+ import { expect, jest } from '@jest/globals';
11
11
  import fs from 'fs';
12
12
  import os from 'os';
13
13
  import path from 'path';
14
14
 
15
- import { shouldCollectMetrics } from '../../fixtures/fixtures.js';
15
+ import { getBootNodeUdpPort, shouldCollectMetrics } from '../../fixtures/fixtures.js';
16
16
  import { createNodes } from '../../fixtures/setup_p2p_test.js';
17
- import { P2PNetworkTest, SHORTENED_BLOCK_TIME_CONFIG_NO_PRUNES, WAIT_FOR_TX_TIMEOUT } from '../p2p_network.js';
17
+ import { P2PNetworkTest, WAIT_FOR_TX_TIMEOUT } from '../p2p_network.js';
18
18
  import { prepareTransactions } from '../shared.js';
19
19
 
20
20
  // Don't set this to a higher value than 9 because each node will use a different L1 publisher account and anvil seeds
21
21
  export const NUM_VALIDATORS = 6;
22
- export const NUM_TXS_PER_NODE = 2;
23
- export const BOOT_NODE_UDP_PORT = 4500;
22
+ export const NUM_TXS_PER_NODE = 4;
23
+ export const BOOT_NODE_UDP_PORT = getBootNodeUdpPort();
24
24
 
25
25
  export const createReqrespDataDir = () => fs.mkdtempSync(path.join(os.tmpdir(), 'reqresp-'));
26
26
 
@@ -38,8 +38,14 @@ export async function createReqrespTest(options: ReqrespOptions = {}): Promise<P
38
38
  // To collect metrics - run in aztec-packages `docker compose --profile metrics up`
39
39
  metricsPort: shouldCollectMetrics(),
40
40
  initialConfig: {
41
- ...SHORTENED_BLOCK_TIME_CONFIG_NO_PRUNES,
42
- aztecSlotDuration: 24,
41
+ ethereumSlotDuration: 8,
42
+ aztecSlotDuration: 36,
43
+ blockDurationMs: 6000,
44
+ l1PublishingTime: 8,
45
+ minTxsPerBlock: 1,
46
+ maxTxsPerBlock: 2,
47
+ enforceTimeTable: true,
48
+ aztecProofSubmissionEpochs: 1024, // effectively do not reorg
43
49
  ...(disableStatusHandshake ? { p2pDisableStatusHandshake: true } : {}),
44
50
  listenAddress: '127.0.0.1',
45
51
  aztecEpochDuration: 64, // stable committee
@@ -81,11 +87,11 @@ export async function runReqrespTxTest(params: {
81
87
 
82
88
  const nodes = await createNodes(
83
89
  aztecNodeConfig,
84
- t.ctx.dateProvider!,
90
+ t.ctx.dateProvider,
85
91
  t.bootstrapNodeEnr,
86
92
  NUM_VALIDATORS,
87
93
  BOOT_NODE_UDP_PORT,
88
- t.prefilledPublicData,
94
+ t.genesis,
89
95
  dataDir,
90
96
  shouldCollectMetrics(),
91
97
  );
@@ -95,7 +101,7 @@ export async function runReqrespTxTest(params: {
95
101
 
96
102
  await t.setupAccount();
97
103
 
98
- const targetBlockNumber = await t.ctx.aztecNodeService!.getBlockNumber();
104
+ const targetBlockNumber = await t.ctx.aztecNodeService.getBlockNumber();
99
105
  await retryUntil(
100
106
  async () => {
101
107
  const blockNumbers = await Promise.all(nodes.map(node => node.getBlockNumber()));
@@ -108,7 +114,7 @@ export async function runReqrespTxTest(params: {
108
114
 
109
115
  t.logger.info('Preparing transactions to send');
110
116
  const txBatches = await timesAsync(2, () =>
111
- prepareTransactions(t.logger, t.ctx.aztecNodeService!, NUM_TXS_PER_NODE, t.fundedAccount),
117
+ prepareTransactions(t.logger, t.ctx.aztecNodeService, NUM_TXS_PER_NODE, t.fundedAccount),
112
118
  );
113
119
 
114
120
  t.logger.info('Removing initial node');
@@ -116,7 +122,7 @@ export async function runReqrespTxTest(params: {
116
122
 
117
123
  t.logger.info('Starting fresh slot');
118
124
  const [timestamp] = await t.ctx.cheatCodes.rollup.advanceToNextSlot();
119
- t.ctx.dateProvider!.setTime(Number(timestamp) * 1000);
125
+ t.ctx.dateProvider.setTime(Number(timestamp) * 1000);
120
126
  const startSlotTimestamp = BigInt(timestamp);
121
127
 
122
128
  const { proposerIndexes, nodesToTurnOffTxGossip } = await getProposerIndexes(t, startSlotTimestamp);
@@ -143,6 +149,13 @@ export async function runReqrespTxTest(params: {
143
149
  const submittedTxs = await Promise.all(
144
150
  txBatches.map(async (batch, batchIndex) => {
145
151
  const proposerNode = nodes[proposerIndexes[batchIndex]];
152
+ for (const tx of batch) {
153
+ t.logger.info(`Tx ${tx.getTxHash().toString()} base64: ${tx.toBuffer().toString('base64')}`);
154
+ }
155
+ const txHashes = batch.map(tx => tx.getTxHash().toString());
156
+ t.logger.info(
157
+ `Sending batch ${batchIndex} to proposer ${getNodePort(proposerIndexes[batchIndex])}: ${txHashes.join(', ')}`,
158
+ );
146
159
  await Promise.all(
147
160
  batch.map(async tx => {
148
161
  try {
@@ -157,6 +170,12 @@ export async function runReqrespTxTest(params: {
157
170
  }),
158
171
  );
159
172
 
173
+ // Log pool state per node after sending
174
+ for (let i = 0; i < NUM_VALIDATORS; i++) {
175
+ const count = await nodes[i].getPendingTxCount();
176
+ t.logger.info(`Node ${getNodePort(i)} pool has ${count} pending txs`);
177
+ }
178
+
160
179
  t.logger.info('Waiting for all transactions to be mined');
161
180
  await Promise.all(
162
181
  submittedTxs.flatMap((batch, batchIndex) =>
@@ -170,6 +189,37 @@ export async function runReqrespTxTest(params: {
170
189
 
171
190
  t.logger.info('All transactions mined');
172
191
 
192
+ // Assert that multiple blocks were built for at least one slot
193
+ t.logger.info('Verifying multiple blocks for at least one checkpoint');
194
+ // Wait for L1 checkpoint sync, which may lag behind P2P block propagation.
195
+ const checkpoints = await retryUntil(
196
+ async () => {
197
+ const cps = await nodes[0].getCheckpoints(CheckpointNumber(1), 50, { includeBlocks: true });
198
+ return cps.length > 0 && cps.some(cp => (cp.blocks?.length ?? 0) >= 2) ? cps : undefined;
199
+ },
200
+ 'waiting for multi-block checkpoint to sync from L1',
201
+ 30,
202
+ 1,
203
+ );
204
+
205
+ let mbpsFound = false;
206
+ let expectedBlockNumber = checkpoints[0].blocks![0].number;
207
+
208
+ for (const published of checkpoints) {
209
+ const blocks = published.blocks!;
210
+ const blockCount = blocks.length;
211
+ mbpsFound = mbpsFound || blockCount >= 2;
212
+
213
+ for (let i = 0; i < blockCount; i++) {
214
+ const block = blocks[i];
215
+ expect(block.indexWithinCheckpoint).toBe(i);
216
+ expect(block.checkpointNumber).toBe(published.number);
217
+ expect(block.number).toBe(expectedBlockNumber);
218
+ expectedBlockNumber++;
219
+ }
220
+ }
221
+
222
+ expect(mbpsFound).toBe(true);
173
223
  return nodes;
174
224
  }
175
225