@aztec/end-to-end 0.0.1-commit.d3ec352c → 0.0.1-commit.d6f2b3f94

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 (218) 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 +14 -15
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  6. package/dest/bench/client_flows/client_flows_benchmark.js +123 -136
  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.js +3 -1
  11. package/dest/bench/utils.d.ts +9 -8
  12. package/dest/bench/utils.d.ts.map +1 -1
  13. package/dest/bench/utils.js +27 -18
  14. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +6 -7
  15. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  16. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +96 -112
  17. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +19 -13
  18. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  19. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +92 -71
  20. package/dest/e2e_deploy_contract/deploy_test.d.ts +4 -3
  21. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  22. package/dest/e2e_deploy_contract/deploy_test.js +18 -13
  23. package/dest/e2e_epochs/epochs_test.d.ts +9 -2
  24. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  25. package/dest/e2e_epochs/epochs_test.js +51 -21
  26. package/dest/e2e_fees/bridging_race.notest.js +4 -6
  27. package/dest/e2e_fees/fees_test.d.ts +18 -15
  28. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  29. package/dest/e2e_fees/fees_test.js +126 -141
  30. package/dest/e2e_l1_publisher/write_json.d.ts +4 -3
  31. package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
  32. package/dest/e2e_l1_publisher/write_json.js +14 -16
  33. package/dest/e2e_multi_validator/utils.js +1 -1
  34. package/dest/e2e_nested_contract/nested_contract_test.d.ts +6 -9
  35. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  36. package/dest/e2e_nested_contract/nested_contract_test.js +31 -39
  37. package/dest/e2e_p2p/inactivity_slash_test.d.ts +4 -4
  38. package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -1
  39. package/dest/e2e_p2p/inactivity_slash_test.js +6 -9
  40. package/dest/e2e_p2p/p2p_network.d.ts +13 -11
  41. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  42. package/dest/e2e_p2p/p2p_network.js +120 -111
  43. package/dest/e2e_p2p/reqresp/utils.d.ts +22 -0
  44. package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -0
  45. package/dest/e2e_p2p/reqresp/utils.js +153 -0
  46. package/dest/e2e_p2p/shared.d.ts +7 -7
  47. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  48. package/dest/e2e_p2p/shared.js +16 -20
  49. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
  50. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
  51. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
  52. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
  53. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
  54. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
  55. package/dest/e2e_token_contract/token_contract_test.d.ts +16 -9
  56. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  57. package/dest/e2e_token_contract/token_contract_test.js +89 -91
  58. package/dest/fixtures/e2e_prover_test.d.ts +10 -18
  59. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  60. package/dest/fixtures/e2e_prover_test.js +91 -103
  61. package/dest/fixtures/fixtures.d.ts +2 -3
  62. package/dest/fixtures/fixtures.d.ts.map +1 -1
  63. package/dest/fixtures/fixtures.js +1 -2
  64. package/dest/fixtures/get_acvm_config.js +1 -1
  65. package/dest/fixtures/ha_setup.d.ts +71 -0
  66. package/dest/fixtures/ha_setup.d.ts.map +1 -0
  67. package/dest/fixtures/ha_setup.js +114 -0
  68. package/dest/fixtures/index.d.ts +2 -1
  69. package/dest/fixtures/index.d.ts.map +1 -1
  70. package/dest/fixtures/index.js +1 -0
  71. package/dest/fixtures/l1_to_l2_messaging.d.ts +4 -3
  72. package/dest/fixtures/l1_to_l2_messaging.d.ts.map +1 -1
  73. package/dest/fixtures/l1_to_l2_messaging.js +2 -2
  74. package/dest/fixtures/setup.d.ts +218 -0
  75. package/dest/fixtures/setup.d.ts.map +1 -0
  76. package/dest/fixtures/setup.js +630 -0
  77. package/dest/fixtures/setup_p2p_test.d.ts +12 -8
  78. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  79. package/dest/fixtures/setup_p2p_test.js +32 -24
  80. package/dest/fixtures/token_utils.d.ts +1 -1
  81. package/dest/fixtures/token_utils.d.ts.map +1 -1
  82. package/dest/fixtures/token_utils.js +7 -4
  83. package/dest/fixtures/utils.d.ts +5 -638
  84. package/dest/fixtures/utils.d.ts.map +1 -1
  85. package/dest/fixtures/utils.js +4 -647
  86. package/dest/fixtures/web3signer.js +1 -1
  87. package/dest/fixtures/with_telemetry_utils.d.ts +2 -2
  88. package/dest/fixtures/with_telemetry_utils.d.ts.map +1 -1
  89. package/dest/fixtures/with_telemetry_utils.js +2 -2
  90. package/dest/quality_of_service/grafana_client.d.ts +41 -0
  91. package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
  92. package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
  93. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  94. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  95. package/dest/quality_of_service/prometheus_client.js +67 -0
  96. package/dest/shared/cross_chain_test_harness.d.ts +18 -7
  97. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  98. package/dest/shared/cross_chain_test_harness.js +14 -14
  99. package/dest/shared/gas_portal_test_harness.d.ts +12 -2
  100. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  101. package/dest/shared/gas_portal_test_harness.js +1 -1
  102. package/dest/shared/index.d.ts +2 -2
  103. package/dest/shared/index.d.ts.map +1 -1
  104. package/dest/shared/submit-transactions.d.ts +3 -3
  105. package/dest/shared/submit-transactions.d.ts.map +1 -1
  106. package/dest/shared/submit-transactions.js +9 -11
  107. package/dest/shared/uniswap_l1_l2.d.ts +3 -27
  108. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  109. package/dest/shared/uniswap_l1_l2.js +57 -35
  110. package/dest/simulators/lending_simulator.d.ts +6 -2
  111. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  112. package/dest/simulators/lending_simulator.js +2 -2
  113. package/dest/spartan/setup_test_wallets.d.ts +4 -3
  114. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  115. package/dest/spartan/setup_test_wallets.js +63 -35
  116. package/dest/spartan/tx_metrics.d.ts +88 -0
  117. package/dest/spartan/tx_metrics.d.ts.map +1 -0
  118. package/dest/spartan/tx_metrics.js +422 -0
  119. package/dest/spartan/utils/bot.d.ts +27 -0
  120. package/dest/spartan/utils/bot.d.ts.map +1 -0
  121. package/dest/spartan/utils/bot.js +141 -0
  122. package/dest/spartan/utils/chaos.d.ts +79 -0
  123. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  124. package/dest/spartan/utils/chaos.js +142 -0
  125. package/dest/spartan/utils/clients.d.ts +39 -0
  126. package/dest/spartan/utils/clients.d.ts.map +1 -0
  127. package/dest/spartan/utils/clients.js +90 -0
  128. package/dest/spartan/utils/config.d.ts +39 -0
  129. package/dest/spartan/utils/config.d.ts.map +1 -0
  130. package/dest/spartan/utils/config.js +21 -0
  131. package/dest/spartan/utils/health.d.ts +63 -0
  132. package/dest/spartan/utils/health.d.ts.map +1 -0
  133. package/dest/spartan/utils/health.js +202 -0
  134. package/dest/spartan/utils/helm.d.ts +15 -0
  135. package/dest/spartan/utils/helm.d.ts.map +1 -0
  136. package/dest/spartan/utils/helm.js +47 -0
  137. package/dest/spartan/utils/index.d.ts +9 -0
  138. package/dest/spartan/utils/index.d.ts.map +1 -0
  139. package/dest/spartan/utils/index.js +18 -0
  140. package/dest/spartan/utils/k8s.d.ts +126 -0
  141. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  142. package/dest/spartan/utils/k8s.js +375 -0
  143. package/dest/spartan/utils/nodes.d.ts +41 -0
  144. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  145. package/dest/spartan/utils/nodes.js +461 -0
  146. package/dest/spartan/utils/scripts.d.ts +30 -0
  147. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  148. package/dest/spartan/utils/scripts.js +81 -0
  149. package/dest/spartan/utils.d.ts +2 -221
  150. package/dest/spartan/utils.d.ts.map +1 -1
  151. package/dest/spartan/utils.js +1 -782
  152. package/package.json +43 -39
  153. package/src/bench/client_flows/benchmark.ts +24 -2
  154. package/src/bench/client_flows/client_flows_benchmark.ts +145 -208
  155. package/src/bench/client_flows/config.ts +9 -1
  156. package/src/bench/client_flows/data_extractor.ts +1 -1
  157. package/src/bench/utils.ts +31 -21
  158. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +104 -142
  159. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +139 -125
  160. package/src/e2e_deploy_contract/deploy_test.ts +21 -14
  161. package/src/e2e_epochs/epochs_test.ts +96 -47
  162. package/src/e2e_fees/bridging_race.notest.ts +4 -10
  163. package/src/e2e_fees/fees_test.ts +176 -219
  164. package/src/e2e_l1_publisher/write_json.ts +16 -16
  165. package/src/e2e_multi_validator/utils.ts +1 -1
  166. package/src/e2e_nested_contract/nested_contract_test.ts +33 -56
  167. package/src/e2e_p2p/inactivity_slash_test.ts +7 -10
  168. package/src/e2e_p2p/p2p_network.ts +180 -183
  169. package/src/e2e_p2p/reqresp/utils.ts +207 -0
  170. package/src/e2e_p2p/shared.ts +32 -28
  171. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  172. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  173. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  174. package/src/e2e_token_contract/token_contract_test.ts +103 -118
  175. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  176. package/src/fixtures/e2e_prover_test.ts +103 -140
  177. package/src/fixtures/fixtures.ts +1 -3
  178. package/src/fixtures/get_acvm_config.ts +1 -1
  179. package/src/fixtures/ha_setup.ts +184 -0
  180. package/src/fixtures/index.ts +1 -0
  181. package/src/fixtures/l1_to_l2_messaging.ts +4 -2
  182. package/src/fixtures/setup.ts +932 -0
  183. package/src/fixtures/setup_p2p_test.ts +34 -30
  184. package/src/fixtures/token_utils.ts +6 -5
  185. package/src/fixtures/utils.ts +27 -966
  186. package/src/fixtures/web3signer.ts +1 -1
  187. package/src/fixtures/with_telemetry_utils.ts +2 -2
  188. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +1 -1
  189. package/src/quality_of_service/prometheus_client.ts +113 -0
  190. package/src/shared/cross_chain_test_harness.ts +19 -37
  191. package/src/shared/gas_portal_test_harness.ts +2 -2
  192. package/src/shared/index.ts +1 -1
  193. package/src/shared/submit-transactions.ts +9 -15
  194. package/src/shared/uniswap_l1_l2.ts +65 -88
  195. package/src/simulators/lending_simulator.ts +3 -3
  196. package/src/spartan/setup_test_wallets.ts +81 -26
  197. package/src/spartan/tx_metrics.ts +376 -0
  198. package/src/spartan/utils/bot.ts +185 -0
  199. package/src/spartan/utils/chaos.ts +253 -0
  200. package/src/spartan/utils/clients.ts +100 -0
  201. package/src/spartan/utils/config.ts +27 -0
  202. package/src/spartan/utils/health.ts +255 -0
  203. package/src/spartan/utils/helm.ts +84 -0
  204. package/src/spartan/utils/index.ts +64 -0
  205. package/src/spartan/utils/k8s.ts +527 -0
  206. package/src/spartan/utils/nodes.ts +538 -0
  207. package/src/spartan/utils/scripts.ts +99 -0
  208. package/src/spartan/utils.ts +1 -983
  209. package/dest/fixtures/setup_l1_contracts.d.ts +0 -477
  210. package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
  211. package/dest/fixtures/setup_l1_contracts.js +0 -17
  212. package/dest/fixtures/snapshot_manager.d.ts +0 -95
  213. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  214. package/dest/fixtures/snapshot_manager.js +0 -505
  215. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  216. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  217. package/src/fixtures/setup_l1_contracts.ts +0 -26
  218. package/src/fixtures/snapshot_manager.ts +0 -665
@@ -4,14 +4,13 @@
4
4
  import { type AztecNodeConfig, AztecNodeService } from '@aztec/aztec-node';
5
5
  import { range } from '@aztec/foundation/array';
6
6
  import { SecretValue } from '@aztec/foundation/config';
7
- import { addLogNameHandler, removeLogNameHandler } from '@aztec/foundation/log';
7
+ import { withLoggerBindings } from '@aztec/foundation/log/server';
8
8
  import { bufferToHex } from '@aztec/foundation/string';
9
9
  import type { DateProvider } from '@aztec/foundation/timer';
10
10
  import type { ProverNodeConfig, ProverNodeDeps } from '@aztec/prover-node';
11
11
  import type { PublicDataTreeLeaf } from '@aztec/stdlib/trees';
12
12
 
13
13
  import getPort from 'get-port';
14
- import { AsyncLocalStorage } from 'node:async_hooks';
15
14
 
16
15
  import { TEST_PEER_CHECK_INTERVAL_MS } from './fixtures.js';
17
16
  import { createAndSyncProverNode, getPrivateKeyFromIndex } from './utils.js';
@@ -22,6 +21,11 @@ import { getEndToEndTestTelemetryClient } from './with_telemetry_utils.js';
22
21
  // to avoid running validators with the same key
23
22
  export const ATTESTER_PRIVATE_KEYS_START_INDEX = 3;
24
23
 
24
+ // Global counters for actor naming (start at 1)
25
+ let validatorCounter = 1;
26
+ let nodeCounter = 1;
27
+ let proverCounter = 1;
28
+
25
29
  export function generatePrivateKeys(startIndex: number, numberOfKeys: number): `0x${string}`[] {
26
30
  const privateKeys: `0x${string}`[] = [];
27
31
  // Do not start from 0 as it is used during setup
@@ -44,10 +48,6 @@ export async function createNodes(
44
48
  validatorsPerNode = 1,
45
49
  ): Promise<AztecNodeService[]> {
46
50
  const nodePromises: Promise<AztecNodeService>[] = [];
47
- const loggerIdStorage = new AsyncLocalStorage<string>();
48
- const logNameHandler = (module: string) =>
49
- loggerIdStorage.getStore() ? `${module}:${loggerIdStorage.getStore()}` : module;
50
- addLogNameHandler(logNameHandler);
51
51
 
52
52
  for (let i = 0; i < numNodes; i++) {
53
53
  const index = indexOffset + i;
@@ -69,7 +69,6 @@ export async function createNodes(
69
69
  prefilledPublicData,
70
70
  dataDir,
71
71
  metricsPort,
72
- loggerIdStorage,
73
72
  );
74
73
  nodePromises.push(nodePromise);
75
74
  }
@@ -81,13 +80,20 @@ export async function createNodes(
81
80
  throw new Error('Sequencer not found');
82
81
  }
83
82
 
84
- removeLogNameHandler(logNameHandler);
85
83
  return nodes;
86
84
  }
87
85
 
88
- /** Creates a P2P enabled instance of Aztec Node Service with a validator */
86
+ /** Extended config type for createNode with test-specific overrides. */
87
+ export type CreateNodeConfig = AztecNodeConfig & {
88
+ /** Whether to skip starting the sequencer. */
89
+ dontStartSequencer?: boolean;
90
+ /** Override the private key (instead of deriving from addressIndex). */
91
+ validatorPrivateKey?: `0x${string}`;
92
+ };
93
+
94
+ /** Creates a P2P enabled instance of Aztec Node Service with a validator. */
89
95
  export async function createNode(
90
- config: AztecNodeConfig & { dontStartSequencer?: boolean },
96
+ config: CreateNodeConfig,
91
97
  dateProvider: DateProvider,
92
98
  tcpPort: number,
93
99
  bootstrapNode: string | undefined,
@@ -95,18 +101,17 @@ export async function createNode(
95
101
  prefilledPublicData?: PublicDataTreeLeaf[],
96
102
  dataDirectory?: string,
97
103
  metricsPort?: number,
98
- loggerIdStorage?: AsyncLocalStorage<string>,
99
104
  ) {
100
- const createNode = async () => {
105
+ const actorIndex = validatorCounter++;
106
+ return await withLoggerBindings({ actor: `validator-${actorIndex}` }, async () => {
101
107
  const validatorConfig = await createValidatorConfig(config, bootstrapNode, tcpPort, addressIndex, dataDirectory);
102
- const telemetry = getEndToEndTestTelemetryClient(metricsPort);
108
+ const telemetry = await getEndToEndTestTelemetryClient(metricsPort);
103
109
  return await AztecNodeService.createAndSync(
104
110
  validatorConfig,
105
111
  { telemetry, dateProvider },
106
112
  { prefilledPublicData, dontStartSequencer: config.dontStartSequencer },
107
113
  );
108
- };
109
- return loggerIdStorage ? await loggerIdStorage.run(tcpPort.toString(), createNode) : createNode();
114
+ });
110
115
  }
111
116
 
112
117
  /** Creates a P2P enabled instance of Aztec Node Service without a validator */
@@ -118,9 +123,9 @@ export async function createNonValidatorNode(
118
123
  prefilledPublicData?: PublicDataTreeLeaf[],
119
124
  dataDirectory?: string,
120
125
  metricsPort?: number,
121
- loggerIdStorage?: AsyncLocalStorage<string>,
122
126
  ) {
123
- const createNode = async () => {
127
+ const actorIndex = nodeCounter++;
128
+ return await withLoggerBindings({ actor: `node-${actorIndex}` }, async () => {
124
129
  const p2pConfig = await createP2PConfig(baseConfig, bootstrapNode, tcpPort, dataDirectory);
125
130
  const config: AztecNodeConfig = {
126
131
  ...p2pConfig,
@@ -128,10 +133,9 @@ export async function createNonValidatorNode(
128
133
  validatorPrivateKeys: undefined,
129
134
  publisherPrivateKeys: [],
130
135
  };
131
- const telemetry = getEndToEndTestTelemetryClient(metricsPort);
136
+ const telemetry = await getEndToEndTestTelemetryClient(metricsPort);
132
137
  return await AztecNodeService.createAndSync(config, { telemetry, dateProvider }, { prefilledPublicData });
133
- };
134
- return loggerIdStorage ? await loggerIdStorage.run(tcpPort.toString(), createNode) : createNode();
138
+ });
135
139
  }
136
140
 
137
141
  export async function createProverNode(
@@ -143,11 +147,11 @@ export async function createProverNode(
143
147
  prefilledPublicData?: PublicDataTreeLeaf[],
144
148
  dataDirectory?: string,
145
149
  metricsPort?: number,
146
- loggerIdStorage?: AsyncLocalStorage<string>,
147
150
  ) {
148
- const createProverNode = async () => {
151
+ const actorIndex = proverCounter++;
152
+ return await withLoggerBindings({ actor: `prover-${actorIndex}` }, async () => {
149
153
  const proverNodePrivateKey = getPrivateKeyFromIndex(ATTESTER_PRIVATE_KEYS_START_INDEX + addressIndex)!;
150
- const telemetry = getEndToEndTestTelemetryClient(metricsPort);
154
+ const telemetry = await getEndToEndTestTelemetryClient(metricsPort);
151
155
 
152
156
  const proverConfig: Partial<ProverNodeConfig> = await createP2PConfig(
153
157
  config,
@@ -165,8 +169,7 @@ export async function createProverNode(
165
169
  prefilledPublicData,
166
170
  { ...proverNodeDeps, telemetry },
167
171
  );
168
- };
169
- return loggerIdStorage ? await loggerIdStorage.run(tcpPort.toString(), createProverNode) : createProverNode();
172
+ });
170
173
  }
171
174
 
172
175
  export async function createP2PConfig(
@@ -192,20 +195,21 @@ export async function createP2PConfig(
192
195
  }
193
196
 
194
197
  export async function createValidatorConfig(
195
- config: AztecNodeConfig,
198
+ config: CreateNodeConfig,
196
199
  bootstrapNodeEnr?: string,
197
200
  port?: number,
198
201
  addressIndex: number | number[] = 1,
199
202
  dataDirectory?: string,
200
203
  ) {
201
204
  const addressIndices = Array.isArray(addressIndex) ? addressIndex : [addressIndex];
202
- if (addressIndices.length === 0) {
205
+ if (addressIndices.length === 0 && !config.validatorPrivateKey) {
203
206
  throw new Error('At least one address index must be provided to create a validator config');
204
207
  }
205
208
 
206
- const attesterPrivateKeys = addressIndices.map(index =>
207
- bufferToHex(getPrivateKeyFromIndex(ATTESTER_PRIVATE_KEYS_START_INDEX + index)!),
208
- );
209
+ // Use override private key if provided, otherwise derive from address indices
210
+ const attesterPrivateKeys = config.validatorPrivateKey
211
+ ? [config.validatorPrivateKey]
212
+ : addressIndices.map(index => bufferToHex(getPrivateKeyFromIndex(ATTESTER_PRIVATE_KEYS_START_INDEX + index)!));
209
213
  const p2pConfig = await createP2PConfig(config, bootstrapNodeEnr, port, dataDirectory);
210
214
  const nodeConfig: AztecNodeConfig = {
211
215
  ...config,
@@ -6,9 +6,10 @@ 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, instance } = await TokenContract.deploy(wallet, admin, 'TokenName', 'TokenSymbol', 18)
10
- .send({ from: admin })
11
- .wait();
9
+ const { contract, instance } = await TokenContract.deploy(wallet, admin, 'TokenName', 'TokenSymbol', 18).send({
10
+ from: admin,
11
+ wait: { returnReceipt: true },
12
+ });
12
13
 
13
14
  if (initialAdminBalance > 0n) {
14
15
  await mintTokensToPrivate(contract, admin, admin, initialAdminBalance);
@@ -25,7 +26,7 @@ export async function mintTokensToPrivate(
25
26
  recipient: AztecAddress,
26
27
  amount: bigint,
27
28
  ) {
28
- await token.methods.mint_to_private(recipient, amount).send({ from: minter }).wait();
29
+ await token.methods.mint_to_private(recipient, amount).send({ from: minter });
29
30
  }
30
31
 
31
32
  export async function expectTokenBalance(
@@ -55,7 +56,7 @@ export async function mintNotes(
55
56
  for (let mintedNotes = 0; mintedNotes < noteAmounts.length; mintedNotes += notesPerIteration) {
56
57
  const toMint = noteAmounts.slice(mintedNotes, mintedNotes + notesPerIteration);
57
58
  const actions = toMint.map(amt => asset.methods.mint_to_private(recipient, amt));
58
- await new BatchCall(wallet, actions).send({ from: minter }).wait();
59
+ await new BatchCall(wallet, actions).send({ from: minter });
59
60
  }
60
61
 
61
62
  return noteAmounts.reduce((prev, curr) => prev + curr, 0n);