@aztec/end-to-end 0.0.1-commit.b655e406 → 0.0.1-commit.b6e433891

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 (274) hide show
  1. package/dest/bench/client_flows/benchmark.d.ts +3 -2
  2. package/dest/bench/client_flows/benchmark.d.ts.map +1 -1
  3. package/dest/bench/client_flows/benchmark.js +21 -1
  4. package/dest/bench/client_flows/client_flows_benchmark.d.ts +22 -16
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  6. package/dest/bench/client_flows/client_flows_benchmark.js +142 -124
  7. package/dest/bench/client_flows/config.d.ts +2 -2
  8. package/dest/bench/client_flows/config.d.ts.map +1 -1
  9. package/dest/bench/client_flows/config.js +18 -0
  10. package/dest/bench/client_flows/data_extractor.d.ts +1 -1
  11. package/dest/bench/client_flows/data_extractor.js +7 -27
  12. package/dest/bench/utils.d.ts +8 -7
  13. package/dest/bench/utils.d.ts.map +1 -1
  14. package/dest/bench/utils.js +31 -19
  15. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +9 -8
  16. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  17. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +107 -113
  18. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +20 -14
  19. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  20. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +92 -70
  21. package/dest/e2e_deploy_contract/deploy_test.d.ts +6 -5
  22. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  23. package/dest/e2e_deploy_contract/deploy_test.js +18 -13
  24. package/dest/e2e_epochs/epochs_test.d.ts +27 -15
  25. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  26. package/dest/e2e_epochs/epochs_test.js +107 -54
  27. package/dest/e2e_fees/bridging_race.notest.d.ts +1 -1
  28. package/dest/e2e_fees/bridging_race.notest.js +5 -7
  29. package/dest/e2e_fees/fees_test.d.ts +21 -17
  30. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  31. package/dest/e2e_fees/fees_test.js +138 -143
  32. package/dest/e2e_l1_publisher/write_json.d.ts +4 -3
  33. package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
  34. package/dest/e2e_l1_publisher/write_json.js +18 -19
  35. package/dest/e2e_multi_validator/utils.d.ts +1 -1
  36. package/dest/e2e_multi_validator/utils.js +1 -1
  37. package/dest/e2e_nested_contract/nested_contract_test.d.ts +6 -9
  38. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  39. package/dest/e2e_nested_contract/nested_contract_test.js +30 -39
  40. package/dest/e2e_p2p/inactivity_slash_test.d.ts +3 -3
  41. package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -1
  42. package/dest/e2e_p2p/inactivity_slash_test.js +7 -6
  43. package/dest/e2e_p2p/p2p_network.d.ts +229 -21
  44. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  45. package/dest/e2e_p2p/p2p_network.js +142 -114
  46. package/dest/e2e_p2p/reqresp/utils.d.ts +22 -0
  47. package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -0
  48. package/dest/e2e_p2p/reqresp/utils.js +190 -0
  49. package/dest/e2e_p2p/shared.d.ts +31 -11
  50. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  51. package/dest/e2e_p2p/shared.js +51 -22
  52. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
  53. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
  54. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
  55. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
  56. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
  57. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
  58. package/dest/e2e_token_contract/token_contract_test.d.ts +19 -10
  59. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  60. package/dest/e2e_token_contract/token_contract_test.js +100 -92
  61. package/dest/fixtures/authwit_proxy.d.ts +15 -0
  62. package/dest/fixtures/authwit_proxy.d.ts.map +1 -0
  63. package/dest/fixtures/authwit_proxy.js +30 -0
  64. package/dest/fixtures/e2e_prover_test.d.ts +15 -21
  65. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  66. package/dest/fixtures/e2e_prover_test.js +123 -138
  67. package/dest/fixtures/elu_monitor.d.ts +21 -0
  68. package/dest/fixtures/elu_monitor.d.ts.map +1 -0
  69. package/dest/fixtures/elu_monitor.js +102 -0
  70. package/dest/fixtures/fixtures.d.ts +6 -3
  71. package/dest/fixtures/fixtures.d.ts.map +1 -1
  72. package/dest/fixtures/fixtures.js +8 -3
  73. package/dest/fixtures/get_acvm_config.d.ts +1 -1
  74. package/dest/fixtures/get_acvm_config.js +1 -1
  75. package/dest/fixtures/get_bb_config.d.ts +1 -1
  76. package/dest/fixtures/get_bb_config.d.ts.map +1 -1
  77. package/dest/fixtures/ha_setup.d.ts +71 -0
  78. package/dest/fixtures/ha_setup.d.ts.map +1 -0
  79. package/dest/fixtures/ha_setup.js +116 -0
  80. package/dest/fixtures/index.d.ts +2 -1
  81. package/dest/fixtures/index.d.ts.map +1 -1
  82. package/dest/fixtures/index.js +1 -0
  83. package/dest/fixtures/l1_to_l2_messaging.d.ts +4 -3
  84. package/dest/fixtures/l1_to_l2_messaging.d.ts.map +1 -1
  85. package/dest/fixtures/l1_to_l2_messaging.js +2 -2
  86. package/dest/fixtures/logging.d.ts +1 -1
  87. package/dest/fixtures/setup.d.ts +239 -0
  88. package/dest/fixtures/setup.d.ts.map +1 -0
  89. package/dest/fixtures/setup.js +606 -0
  90. package/dest/fixtures/setup_p2p_test.d.ts +17 -10
  91. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  92. package/dest/fixtures/setup_p2p_test.js +55 -36
  93. package/dest/fixtures/token_utils.d.ts +6 -3
  94. package/dest/fixtures/token_utils.d.ts.map +1 -1
  95. package/dest/fixtures/token_utils.js +17 -10
  96. package/dest/fixtures/utils.d.ts +5 -192
  97. package/dest/fixtures/utils.d.ts.map +1 -1
  98. package/dest/fixtures/utils.js +4 -648
  99. package/dest/fixtures/web3signer.d.ts +1 -1
  100. package/dest/fixtures/web3signer.js +1 -1
  101. package/dest/fixtures/with_telemetry_utils.d.ts +2 -2
  102. package/dest/fixtures/with_telemetry_utils.d.ts.map +1 -1
  103. package/dest/fixtures/with_telemetry_utils.js +2 -2
  104. package/dest/index.d.ts +1 -1
  105. package/dest/quality_of_service/grafana_client.d.ts +41 -0
  106. package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
  107. package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
  108. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  109. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  110. package/dest/quality_of_service/prometheus_client.js +67 -0
  111. package/dest/shared/cross_chain_test_harness.d.ts +7 -6
  112. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  113. package/dest/shared/cross_chain_test_harness.js +27 -27
  114. package/dest/shared/gas_portal_test_harness.d.ts +2 -2
  115. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  116. package/dest/shared/gas_portal_test_harness.js +4 -4
  117. package/dest/shared/index.d.ts +3 -2
  118. package/dest/shared/index.d.ts.map +1 -1
  119. package/dest/shared/index.js +1 -0
  120. package/dest/shared/jest_setup.d.ts +1 -1
  121. package/dest/shared/jest_setup.js +41 -1
  122. package/dest/shared/mock_state_view.d.ts +86 -0
  123. package/dest/shared/mock_state_view.d.ts.map +1 -0
  124. package/dest/shared/mock_state_view.js +186 -0
  125. package/dest/shared/submit-transactions.d.ts +4 -4
  126. package/dest/shared/submit-transactions.d.ts.map +1 -1
  127. package/dest/shared/submit-transactions.js +9 -11
  128. package/dest/shared/uniswap_l1_l2.d.ts +3 -27
  129. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  130. package/dest/shared/uniswap_l1_l2.js +58 -39
  131. package/dest/simulators/index.d.ts +1 -1
  132. package/dest/simulators/lending_simulator.d.ts +2 -2
  133. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  134. package/dest/simulators/lending_simulator.js +8 -6
  135. package/dest/simulators/token_simulator.d.ts +1 -1
  136. package/dest/simulators/token_simulator.d.ts.map +1 -1
  137. package/dest/simulators/token_simulator.js +3 -24
  138. package/dest/spartan/setup_test_wallets.d.ts +18 -6
  139. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  140. package/dest/spartan/setup_test_wallets.js +129 -24
  141. package/dest/spartan/tx_metrics.d.ts +88 -0
  142. package/dest/spartan/tx_metrics.d.ts.map +1 -0
  143. package/dest/spartan/tx_metrics.js +422 -0
  144. package/dest/spartan/utils/bot.d.ts +28 -0
  145. package/dest/spartan/utils/bot.d.ts.map +1 -0
  146. package/dest/spartan/utils/bot.js +142 -0
  147. package/dest/spartan/utils/chaos.d.ts +79 -0
  148. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  149. package/dest/spartan/utils/chaos.js +142 -0
  150. package/dest/spartan/utils/clients.d.ts +39 -0
  151. package/dest/spartan/utils/clients.d.ts.map +1 -0
  152. package/dest/spartan/utils/clients.js +90 -0
  153. package/dest/spartan/utils/config.d.ts +45 -0
  154. package/dest/spartan/utils/config.d.ts.map +1 -0
  155. package/dest/spartan/utils/config.js +23 -0
  156. package/dest/spartan/utils/health.d.ts +63 -0
  157. package/dest/spartan/utils/health.d.ts.map +1 -0
  158. package/dest/spartan/utils/health.js +202 -0
  159. package/dest/spartan/utils/helm.d.ts +15 -0
  160. package/dest/spartan/utils/helm.d.ts.map +1 -0
  161. package/dest/spartan/utils/helm.js +47 -0
  162. package/dest/spartan/utils/index.d.ts +11 -0
  163. package/dest/spartan/utils/index.d.ts.map +1 -0
  164. package/dest/spartan/utils/index.js +22 -0
  165. package/dest/spartan/utils/k8s.d.ts +128 -0
  166. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  167. package/dest/spartan/utils/k8s.js +381 -0
  168. package/dest/spartan/utils/nodes.d.ts +40 -0
  169. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  170. package/dest/spartan/utils/nodes.js +461 -0
  171. package/dest/spartan/utils/pod_logs.d.ts +25 -0
  172. package/dest/spartan/utils/pod_logs.d.ts.map +1 -0
  173. package/dest/spartan/utils/pod_logs.js +74 -0
  174. package/dest/spartan/utils/scripts.d.ts +30 -0
  175. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  176. package/dest/spartan/utils/scripts.js +81 -0
  177. package/dest/spartan/utils.d.ts +2 -218
  178. package/dest/spartan/utils.d.ts.map +1 -1
  179. package/dest/spartan/utils.js +1 -749
  180. package/dest/test-wallet/test_wallet.d.ts +76 -0
  181. package/dest/test-wallet/test_wallet.d.ts.map +1 -0
  182. package/dest/test-wallet/test_wallet.js +214 -0
  183. package/dest/test-wallet/utils.d.ts +41 -0
  184. package/dest/test-wallet/utils.d.ts.map +1 -0
  185. package/dest/test-wallet/utils.js +71 -0
  186. package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
  187. package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
  188. package/dest/test-wallet/wallet_worker_script.js +48 -0
  189. package/dest/test-wallet/worker_wallet.d.ts +52 -0
  190. package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
  191. package/dest/test-wallet/worker_wallet.js +151 -0
  192. package/dest/test-wallet/worker_wallet_schema.d.ts +274 -0
  193. package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
  194. package/dest/test-wallet/worker_wallet_schema.js +10 -0
  195. package/package.json +49 -44
  196. package/src/bench/client_flows/benchmark.ts +24 -2
  197. package/src/bench/client_flows/client_flows_benchmark.ts +163 -177
  198. package/src/bench/client_flows/config.ts +9 -1
  199. package/src/bench/client_flows/data_extractor.ts +6 -28
  200. package/src/bench/utils.ts +36 -21
  201. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +120 -145
  202. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +140 -125
  203. package/src/e2e_deploy_contract/deploy_test.ts +23 -16
  204. package/src/e2e_epochs/epochs_test.ts +176 -114
  205. package/src/e2e_fees/bridging_race.notest.ts +6 -12
  206. package/src/e2e_fees/fees_test.ts +179 -226
  207. package/src/e2e_l1_publisher/write_json.ts +20 -19
  208. package/src/e2e_multi_validator/utils.ts +1 -1
  209. package/src/e2e_nested_contract/nested_contract_test.ts +35 -55
  210. package/src/e2e_p2p/inactivity_slash_test.ts +8 -7
  211. package/src/e2e_p2p/p2p_network.ts +205 -178
  212. package/src/e2e_p2p/reqresp/utils.ts +256 -0
  213. package/src/e2e_p2p/shared.ts +90 -29
  214. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  215. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  216. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  217. package/src/e2e_token_contract/token_contract_test.ts +121 -119
  218. package/src/fixtures/authwit_proxy.ts +50 -0
  219. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  220. package/src/fixtures/e2e_prover_test.ts +144 -186
  221. package/src/fixtures/elu_monitor.ts +126 -0
  222. package/src/fixtures/fixtures.ts +12 -5
  223. package/src/fixtures/get_acvm_config.ts +1 -1
  224. package/src/fixtures/ha_setup.ts +186 -0
  225. package/src/fixtures/index.ts +1 -0
  226. package/src/fixtures/l1_to_l2_messaging.ts +4 -2
  227. package/src/fixtures/setup.ts +903 -0
  228. package/src/fixtures/setup_p2p_test.ts +58 -48
  229. package/src/fixtures/token_utils.ts +12 -8
  230. package/src/fixtures/utils.ts +27 -947
  231. package/src/fixtures/web3signer.ts +1 -1
  232. package/src/fixtures/with_telemetry_utils.ts +2 -2
  233. package/src/guides/up_quick_start.sh +4 -4
  234. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +1 -1
  235. package/src/quality_of_service/prometheus_client.ts +113 -0
  236. package/src/shared/cross_chain_test_harness.ts +30 -43
  237. package/src/shared/gas_portal_test_harness.ts +4 -4
  238. package/src/shared/index.ts +2 -1
  239. package/src/shared/jest_setup.ts +51 -1
  240. package/src/shared/mock_state_view.ts +188 -0
  241. package/src/shared/submit-transactions.ts +11 -16
  242. package/src/shared/uniswap_l1_l2.ts +86 -102
  243. package/src/simulators/lending_simulator.ts +11 -7
  244. package/src/simulators/token_simulator.ts +6 -30
  245. package/src/spartan/DEVELOP.md +7 -0
  246. package/src/spartan/setup_test_wallets.ts +205 -29
  247. package/src/spartan/tx_metrics.ts +376 -0
  248. package/src/spartan/utils/bot.ts +188 -0
  249. package/src/spartan/utils/chaos.ts +253 -0
  250. package/src/spartan/utils/clients.ts +100 -0
  251. package/src/spartan/utils/config.ts +29 -0
  252. package/src/spartan/utils/health.ts +255 -0
  253. package/src/spartan/utils/helm.ts +84 -0
  254. package/src/spartan/utils/index.ts +71 -0
  255. package/src/spartan/utils/k8s.ts +535 -0
  256. package/src/spartan/utils/nodes.ts +543 -0
  257. package/src/spartan/utils/pod_logs.ts +99 -0
  258. package/src/spartan/utils/scripts.ts +99 -0
  259. package/src/spartan/utils.ts +1 -942
  260. package/src/test-wallet/test_wallet.ts +294 -0
  261. package/src/test-wallet/utils.ts +112 -0
  262. package/src/test-wallet/wallet_worker_script.ts +60 -0
  263. package/src/test-wallet/worker_wallet.ts +213 -0
  264. package/src/test-wallet/worker_wallet_schema.ts +13 -0
  265. package/dest/fixtures/setup_l1_contracts.d.ts +0 -6
  266. package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
  267. package/dest/fixtures/setup_l1_contracts.js +0 -17
  268. package/dest/fixtures/snapshot_manager.d.ts +0 -95
  269. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  270. package/dest/fixtures/snapshot_manager.js +0 -505
  271. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  272. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  273. package/src/fixtures/setup_l1_contracts.ts +0 -26
  274. package/src/fixtures/snapshot_manager.ts +0 -665
@@ -2,15 +2,14 @@
2
2
  * Test fixtures and utilities to set up and run a test using multiple validators
3
3
  */
4
4
  import { type AztecNodeConfig, AztecNodeService } from '@aztec/aztec-node';
5
+ import { range } from '@aztec/foundation/array';
5
6
  import { SecretValue } from '@aztec/foundation/config';
6
- import { addLogNameHandler, removeLogNameHandler } from '@aztec/foundation/log';
7
+ import { withLoggerBindings } from '@aztec/foundation/log/server';
7
8
  import { bufferToHex } from '@aztec/foundation/string';
8
9
  import type { DateProvider } from '@aztec/foundation/timer';
9
- import type { ProverNodeConfig, ProverNodeDeps } from '@aztec/prover-node';
10
10
  import type { PublicDataTreeLeaf } from '@aztec/stdlib/trees';
11
11
 
12
12
  import getPort from 'get-port';
13
- import { AsyncLocalStorage } from 'node:async_hooks';
14
13
 
15
14
  import { TEST_PEER_CHECK_INTERVAL_MS } from './fixtures.js';
16
15
  import { createAndSyncProverNode, getPrivateKeyFromIndex } from './utils.js';
@@ -21,6 +20,11 @@ import { getEndToEndTestTelemetryClient } from './with_telemetry_utils.js';
21
20
  // to avoid running validators with the same key
22
21
  export const ATTESTER_PRIVATE_KEYS_START_INDEX = 3;
23
22
 
23
+ // Global counters for actor naming (start at 1)
24
+ let validatorCounter = 1;
25
+ let nodeCounter = 1;
26
+ let proverCounter = 1;
27
+
24
28
  export function generatePrivateKeys(startIndex: number, numberOfKeys: number): `0x${string}`[] {
25
29
  const privateKeys: `0x${string}`[] = [];
26
30
  // Do not start from 0 as it is used during setup
@@ -40,29 +44,30 @@ export async function createNodes(
40
44
  dataDirectory?: string,
41
45
  metricsPort?: number,
42
46
  indexOffset = 0,
47
+ validatorsPerNode = 1,
43
48
  ): Promise<AztecNodeService[]> {
44
49
  const nodePromises: Promise<AztecNodeService>[] = [];
45
- const loggerIdStorage = new AsyncLocalStorage<string>();
46
- const logNameHandler = (module: string) =>
47
- loggerIdStorage.getStore() ? `${module}:${loggerIdStorage.getStore()}` : module;
48
- addLogNameHandler(logNameHandler);
49
50
 
50
51
  for (let i = 0; i < numNodes; i++) {
51
52
  const index = indexOffset + i;
52
53
  // We run on ports from the bootnode upwards
53
54
  const port = bootNodePort + 1 + index;
54
55
 
56
+ // Determine validator indices for this node
57
+ const validatorIndices = validatorsPerNode === 1 ? index : range(validatorsPerNode, validatorsPerNode * index);
58
+
59
+ // Assign data directory
55
60
  const dataDir = dataDirectory ? `${dataDirectory}-${index}` : undefined;
61
+
56
62
  const nodePromise = createNode(
57
63
  config,
58
64
  dateProvider,
59
65
  port,
60
66
  bootstrapNodeEnr,
61
- index,
67
+ validatorIndices,
62
68
  prefilledPublicData,
63
69
  dataDir,
64
70
  metricsPort,
65
- loggerIdStorage,
66
71
  );
67
72
  nodePromises.push(nodePromise);
68
73
  }
@@ -74,32 +79,38 @@ export async function createNodes(
74
79
  throw new Error('Sequencer not found');
75
80
  }
76
81
 
77
- removeLogNameHandler(logNameHandler);
78
82
  return nodes;
79
83
  }
80
84
 
81
- /** Creates a P2P enabled instance of Aztec Node Service with a validator */
85
+ /** Extended config type for createNode with test-specific overrides. */
86
+ export type CreateNodeConfig = AztecNodeConfig & {
87
+ /** Whether to skip starting the sequencer. */
88
+ dontStartSequencer?: boolean;
89
+ /** Override the private key (instead of deriving from addressIndex). */
90
+ validatorPrivateKey?: `0x${string}`;
91
+ };
92
+
93
+ /** Creates a P2P enabled instance of Aztec Node Service with a validator. */
82
94
  export async function createNode(
83
- config: AztecNodeConfig & { dontStartSequencer?: boolean },
95
+ config: CreateNodeConfig,
84
96
  dateProvider: DateProvider,
85
97
  tcpPort: number,
86
98
  bootstrapNode: string | undefined,
87
- addressIndex: number,
99
+ addressIndex: number | number[],
88
100
  prefilledPublicData?: PublicDataTreeLeaf[],
89
101
  dataDirectory?: string,
90
102
  metricsPort?: number,
91
- loggerIdStorage?: AsyncLocalStorage<string>,
92
103
  ) {
93
- const createNode = async () => {
104
+ const actorIndex = validatorCounter++;
105
+ return await withLoggerBindings({ actor: `validator-${actorIndex}` }, async () => {
94
106
  const validatorConfig = await createValidatorConfig(config, bootstrapNode, tcpPort, addressIndex, dataDirectory);
95
- const telemetry = getEndToEndTestTelemetryClient(metricsPort);
107
+ const telemetry = await getEndToEndTestTelemetryClient(metricsPort);
96
108
  return await AztecNodeService.createAndSync(
97
109
  validatorConfig,
98
110
  { telemetry, dateProvider },
99
111
  { prefilledPublicData, dontStartSequencer: config.dontStartSequencer },
100
112
  );
101
- };
102
- return loggerIdStorage ? await loggerIdStorage.run(tcpPort.toString(), createNode) : createNode();
113
+ });
103
114
  }
104
115
 
105
116
  /** Creates a P2P enabled instance of Aztec Node Service without a validator */
@@ -111,20 +122,19 @@ export async function createNonValidatorNode(
111
122
  prefilledPublicData?: PublicDataTreeLeaf[],
112
123
  dataDirectory?: string,
113
124
  metricsPort?: number,
114
- loggerIdStorage?: AsyncLocalStorage<string>,
115
125
  ) {
116
- const createNode = async () => {
126
+ const actorIndex = nodeCounter++;
127
+ return await withLoggerBindings({ actor: `node-${actorIndex}` }, async () => {
117
128
  const p2pConfig = await createP2PConfig(baseConfig, bootstrapNode, tcpPort, dataDirectory);
118
129
  const config: AztecNodeConfig = {
119
130
  ...p2pConfig,
120
131
  disableValidator: true,
121
132
  validatorPrivateKeys: undefined,
122
- publisherPrivateKeys: [],
133
+ sequencerPublisherPrivateKeys: [],
123
134
  };
124
- const telemetry = getEndToEndTestTelemetryClient(metricsPort);
135
+ const telemetry = await getEndToEndTestTelemetryClient(metricsPort);
125
136
  return await AztecNodeService.createAndSync(config, { telemetry, dateProvider }, { prefilledPublicData });
126
- };
127
- return loggerIdStorage ? await loggerIdStorage.run(tcpPort.toString(), createNode) : createNode();
137
+ });
128
138
  }
129
139
 
130
140
  export async function createProverNode(
@@ -132,34 +142,26 @@ export async function createProverNode(
132
142
  tcpPort: number,
133
143
  bootstrapNode: string | undefined,
134
144
  addressIndex: number,
135
- proverNodeDeps: ProverNodeDeps & Required<Pick<ProverNodeDeps, 'dateProvider'>>,
145
+ deps: { dateProvider: DateProvider },
136
146
  prefilledPublicData?: PublicDataTreeLeaf[],
137
147
  dataDirectory?: string,
138
148
  metricsPort?: number,
139
- loggerIdStorage?: AsyncLocalStorage<string>,
140
- ) {
141
- const createProverNode = async () => {
149
+ ): Promise<{ proverNode: AztecNodeService }> {
150
+ const actorIndex = proverCounter++;
151
+ return await withLoggerBindings({ actor: `prover-${actorIndex}` }, async () => {
142
152
  const proverNodePrivateKey = getPrivateKeyFromIndex(ATTESTER_PRIVATE_KEYS_START_INDEX + addressIndex)!;
143
- const telemetry = getEndToEndTestTelemetryClient(metricsPort);
153
+ const telemetry = await getEndToEndTestTelemetryClient(metricsPort);
144
154
 
145
- const proverConfig: Partial<ProverNodeConfig> = await createP2PConfig(
146
- config,
147
- bootstrapNode,
148
- tcpPort,
149
- dataDirectory,
150
- );
155
+ const p2pConfig = await createP2PConfig(config, bootstrapNode, tcpPort, dataDirectory);
151
156
 
152
- const aztecNodeRpcTxProvider = undefined;
153
157
  return await createAndSyncProverNode(
154
158
  bufferToHex(proverNodePrivateKey),
155
- config,
156
- { ...proverConfig, dataDirectory },
157
- aztecNodeRpcTxProvider,
158
- prefilledPublicData,
159
- { ...proverNodeDeps, telemetry },
159
+ { ...config, ...p2pConfig },
160
+ { dataDirectory },
161
+ { ...deps, telemetry },
162
+ { prefilledPublicData: prefilledPublicData ?? [] },
160
163
  );
161
- };
162
- return loggerIdStorage ? await loggerIdStorage.run(tcpPort.toString(), createProverNode) : createProverNode();
164
+ });
163
165
  }
164
166
 
165
167
  export async function createP2PConfig(
@@ -185,19 +187,27 @@ export async function createP2PConfig(
185
187
  }
186
188
 
187
189
  export async function createValidatorConfig(
188
- config: AztecNodeConfig,
190
+ config: CreateNodeConfig,
189
191
  bootstrapNodeEnr?: string,
190
192
  port?: number,
191
- addressIndex: number = 1,
193
+ addressIndex: number | number[] = 1,
192
194
  dataDirectory?: string,
193
195
  ) {
194
- const attesterPrivateKey = bufferToHex(getPrivateKeyFromIndex(ATTESTER_PRIVATE_KEYS_START_INDEX + addressIndex)!);
196
+ const addressIndices = Array.isArray(addressIndex) ? addressIndex : [addressIndex];
197
+ if (addressIndices.length === 0 && !config.validatorPrivateKey) {
198
+ throw new Error('At least one address index must be provided to create a validator config');
199
+ }
200
+
201
+ // Use override private key if provided, otherwise derive from address indices
202
+ const attesterPrivateKeys = config.validatorPrivateKey
203
+ ? [config.validatorPrivateKey]
204
+ : addressIndices.map(index => bufferToHex(getPrivateKeyFromIndex(ATTESTER_PRIVATE_KEYS_START_INDEX + index)!));
195
205
  const p2pConfig = await createP2PConfig(config, bootstrapNodeEnr, port, dataDirectory);
196
206
  const nodeConfig: AztecNodeConfig = {
197
207
  ...config,
198
208
  ...p2pConfig,
199
- validatorPrivateKeys: new SecretValue([attesterPrivateKey]),
200
- publisherPrivateKeys: [new SecretValue(attesterPrivateKey)],
209
+ validatorPrivateKeys: new SecretValue(attesterPrivateKeys),
210
+ sequencerPublisherPrivateKeys: [new SecretValue(attesterPrivateKeys[0])],
201
211
  };
202
212
 
203
213
  return nodeConfig;
@@ -6,9 +6,12 @@ import { TokenContract } from '@aztec/noir-contracts.js/Token';
6
6
 
7
7
  export async function deployToken(wallet: Wallet, admin: AztecAddress, initialAdminBalance: bigint, logger: Logger) {
8
8
  logger.info(`Deploying Token contract...`);
9
- const contract = await TokenContract.deploy(wallet, admin, 'TokenName', 'TokenSymbol', 18)
10
- .send({ from: admin })
11
- .deployed();
9
+ const {
10
+ receipt: { contract, instance },
11
+ } = await TokenContract.deploy(wallet, admin, 'TokenName', 'TokenSymbol', 18).send({
12
+ from: admin,
13
+ wait: { returnReceipt: true },
14
+ });
12
15
 
13
16
  if (initialAdminBalance > 0n) {
14
17
  await mintTokensToPrivate(contract, admin, admin, initialAdminBalance);
@@ -16,7 +19,7 @@ export async function deployToken(wallet: Wallet, admin: AztecAddress, initialAd
16
19
 
17
20
  logger.info('L2 contract deployed');
18
21
 
19
- return contract;
22
+ return { contract, instance };
20
23
  }
21
24
 
22
25
  export async function mintTokensToPrivate(
@@ -24,8 +27,9 @@ export async function mintTokensToPrivate(
24
27
  minter: AztecAddress,
25
28
  recipient: AztecAddress,
26
29
  amount: bigint,
30
+ additionalScopes?: AztecAddress[],
27
31
  ) {
28
- await token.methods.mint_to_private(recipient, amount).send({ from: minter }).wait();
32
+ await token.methods.mint_to_private(recipient, amount).send({ from: minter, additionalScopes });
29
33
  }
30
34
 
31
35
  export async function expectTokenBalance(
@@ -36,8 +40,8 @@ export async function expectTokenBalance(
36
40
  logger: Logger,
37
41
  ) {
38
42
  // Then check the balance
39
- const contractWithWallet = await TokenContract.at(token.address, wallet);
40
- const balance = await contractWithWallet.methods.balance_of_private(owner).simulate({ from: owner });
43
+ const contractWithWallet = TokenContract.at(token.address, wallet);
44
+ const { result: balance } = await contractWithWallet.methods.balance_of_private(owner).simulate({ from: owner });
41
45
  logger.info(`Account ${owner} balance: ${balance}`);
42
46
  expect(balance).toBe(expectedBalance);
43
47
  }
@@ -55,7 +59,7 @@ export async function mintNotes(
55
59
  for (let mintedNotes = 0; mintedNotes < noteAmounts.length; mintedNotes += notesPerIteration) {
56
60
  const toMint = noteAmounts.slice(mintedNotes, mintedNotes + notesPerIteration);
57
61
  const actions = toMint.map(amt => asset.methods.mint_to_private(recipient, amt));
58
- await new BatchCall(wallet, actions).send({ from: minter }).wait();
62
+ await new BatchCall(wallet, actions).send({ from: minter });
59
63
  }
60
64
 
61
65
  return noteAmounts.reduce((prev, curr) => prev + curr, 0n);