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

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 (270) 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 +133 -122
  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 +27 -18
  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 +106 -112
  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 +25 -15
  25. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  26. package/dest/e2e_epochs/epochs_test.js +103 -53
  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 +129 -141
  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 +31 -38
  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 +226 -19
  44. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  45. package/dest/e2e_p2p/p2p_network.js +136 -111
  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 +177 -0
  49. package/dest/e2e_p2p/shared.d.ts +11 -11
  50. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  51. package/dest/e2e_p2p/shared.js +20 -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 +99 -91
  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 +234 -0
  88. package/dest/fixtures/setup.d.ts.map +1 -0
  89. package/dest/fixtures/setup.js +605 -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 +16 -9
  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 +14 -14
  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 +2 -2
  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 +57 -35
  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 +6 -4
  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 +2 -23
  138. package/dest/spartan/setup_test_wallets.d.ts +16 -6
  139. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  140. package/dest/spartan/setup_test_wallets.js +115 -23
  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 +42 -0
  154. package/dest/spartan/utils/config.d.ts.map +1 -0
  155. package/dest/spartan/utils/config.js +22 -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 +10 -0
  163. package/dest/spartan/utils/index.d.ts.map +1 -0
  164. package/dest/spartan/utils/index.js +20 -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/scripts.d.ts +30 -0
  172. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  173. package/dest/spartan/utils/scripts.js +81 -0
  174. package/dest/spartan/utils.d.ts +2 -218
  175. package/dest/spartan/utils.d.ts.map +1 -1
  176. package/dest/spartan/utils.js +1 -749
  177. package/dest/test-wallet/test_wallet.d.ts +83 -0
  178. package/dest/test-wallet/test_wallet.d.ts.map +1 -0
  179. package/dest/test-wallet/test_wallet.js +214 -0
  180. package/dest/test-wallet/utils.d.ts +41 -0
  181. package/dest/test-wallet/utils.d.ts.map +1 -0
  182. package/dest/test-wallet/utils.js +71 -0
  183. package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
  184. package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
  185. package/dest/test-wallet/wallet_worker_script.js +48 -0
  186. package/dest/test-wallet/worker_wallet.d.ts +52 -0
  187. package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
  188. package/dest/test-wallet/worker_wallet.js +151 -0
  189. package/dest/test-wallet/worker_wallet_schema.d.ts +274 -0
  190. package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
  191. package/dest/test-wallet/worker_wallet_schema.js +10 -0
  192. package/package.json +50 -44
  193. package/src/bench/client_flows/benchmark.ts +24 -2
  194. package/src/bench/client_flows/client_flows_benchmark.ts +156 -177
  195. package/src/bench/client_flows/config.ts +9 -1
  196. package/src/bench/client_flows/data_extractor.ts +6 -28
  197. package/src/bench/utils.ts +31 -21
  198. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +114 -143
  199. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +140 -125
  200. package/src/e2e_deploy_contract/deploy_test.ts +23 -16
  201. package/src/e2e_epochs/epochs_test.ts +166 -116
  202. package/src/e2e_fees/bridging_race.notest.ts +6 -12
  203. package/src/e2e_fees/fees_test.ts +172 -226
  204. package/src/e2e_l1_publisher/write_json.ts +20 -19
  205. package/src/e2e_multi_validator/utils.ts +1 -1
  206. package/src/e2e_nested_contract/nested_contract_test.ts +33 -55
  207. package/src/e2e_p2p/inactivity_slash_test.ts +8 -7
  208. package/src/e2e_p2p/p2p_network.ts +205 -182
  209. package/src/e2e_p2p/reqresp/utils.ts +235 -0
  210. package/src/e2e_p2p/shared.ts +37 -29
  211. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  212. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  213. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  214. package/src/e2e_token_contract/token_contract_test.ts +113 -119
  215. package/src/fixtures/authwit_proxy.ts +50 -0
  216. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  217. package/src/fixtures/e2e_prover_test.ts +138 -186
  218. package/src/fixtures/elu_monitor.ts +126 -0
  219. package/src/fixtures/fixtures.ts +12 -5
  220. package/src/fixtures/get_acvm_config.ts +1 -1
  221. package/src/fixtures/ha_setup.ts +186 -0
  222. package/src/fixtures/index.ts +1 -0
  223. package/src/fixtures/l1_to_l2_messaging.ts +4 -2
  224. package/src/fixtures/setup.ts +895 -0
  225. package/src/fixtures/setup_p2p_test.ts +58 -48
  226. package/src/fixtures/token_utils.ts +9 -7
  227. package/src/fixtures/utils.ts +27 -947
  228. package/src/fixtures/web3signer.ts +1 -1
  229. package/src/fixtures/with_telemetry_utils.ts +2 -2
  230. package/src/guides/up_quick_start.sh +4 -4
  231. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +1 -1
  232. package/src/quality_of_service/prometheus_client.ts +113 -0
  233. package/src/shared/cross_chain_test_harness.ts +19 -36
  234. package/src/shared/gas_portal_test_harness.ts +3 -3
  235. package/src/shared/index.ts +2 -1
  236. package/src/shared/jest_setup.ts +51 -1
  237. package/src/shared/mock_state_view.ts +188 -0
  238. package/src/shared/submit-transactions.ts +14 -16
  239. package/src/shared/uniswap_l1_l2.ts +66 -89
  240. package/src/simulators/lending_simulator.ts +7 -5
  241. package/src/simulators/token_simulator.ts +1 -29
  242. package/src/spartan/DEVELOP.md +7 -0
  243. package/src/spartan/setup_test_wallets.ts +173 -28
  244. package/src/spartan/tx_metrics.ts +376 -0
  245. package/src/spartan/utils/bot.ts +188 -0
  246. package/src/spartan/utils/chaos.ts +253 -0
  247. package/src/spartan/utils/clients.ts +100 -0
  248. package/src/spartan/utils/config.ts +28 -0
  249. package/src/spartan/utils/health.ts +255 -0
  250. package/src/spartan/utils/helm.ts +84 -0
  251. package/src/spartan/utils/index.ts +68 -0
  252. package/src/spartan/utils/k8s.ts +535 -0
  253. package/src/spartan/utils/nodes.ts +543 -0
  254. package/src/spartan/utils/scripts.ts +99 -0
  255. package/src/spartan/utils.ts +1 -942
  256. package/src/test-wallet/test_wallet.ts +306 -0
  257. package/src/test-wallet/utils.ts +112 -0
  258. package/src/test-wallet/wallet_worker_script.ts +60 -0
  259. package/src/test-wallet/worker_wallet.ts +213 -0
  260. package/src/test-wallet/worker_wallet_schema.ts +13 -0
  261. package/dest/fixtures/setup_l1_contracts.d.ts +0 -6
  262. package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
  263. package/dest/fixtures/setup_l1_contracts.js +0 -17
  264. package/dest/fixtures/snapshot_manager.d.ts +0 -95
  265. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  266. package/dest/fixtures/snapshot_manager.js +0 -505
  267. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  268. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  269. package/src/fixtures/setup_l1_contracts.ts +0 -26
  270. package/src/fixtures/snapshot_manager.ts +0 -665
@@ -1,8 +1,11 @@
1
1
  import type { AztecNodeService } from '@aztec/aztec-node';
2
- import { BatchCall, type SentTx, type WaitOpts } from '@aztec/aztec.js/contracts';
2
+ import { AztecAddress } from '@aztec/aztec.js/addresses';
3
+ import { BatchCall, NO_WAIT, type WaitOpts } from '@aztec/aztec.js/contracts';
4
+ import { waitForTx } from '@aztec/aztec.js/node';
3
5
  import { mean, stdDev, times } from '@aztec/foundation/collection';
4
6
  import { BenchmarkingContract } from '@aztec/noir-test-contracts.js/Benchmarking';
5
- import type { MetricsType } from '@aztec/telemetry-client';
7
+ import type { TxHash } from '@aztec/stdlib/tx';
8
+ import type { MetricDefinition } from '@aztec/telemetry-client';
6
9
  import type { BenchmarkDataPoint, BenchmarkMetricsType, BenchmarkTelemetryClient } from '@aztec/telemetry-client/bench';
7
10
 
8
11
  import { mkdirSync, writeFileSync } from 'fs';
@@ -15,17 +18,17 @@ import { type EndToEndContext, type SetupOptions, setup } from '../fixtures/util
15
18
  */
16
19
  export async function benchmarkSetup(
17
20
  opts: Partial<SetupOptions> & {
18
- /** What metrics to export */ metrics: (MetricsType | MetricFilter)[];
21
+ /** What metrics to export */ metrics: (MetricDefinition | MetricFilter)[];
19
22
  /** Where to output the benchmark data (defaults to BENCH_OUTPUT or bench.json) */
20
23
  benchOutput?: string;
21
24
  },
22
25
  ) {
23
26
  const context = await setup(1, { ...opts, telemetryConfig: { benchmark: true } });
24
27
  const defaultAccountAddress = context.accounts[0];
25
- const contract = await BenchmarkingContract.deploy(context.wallet).send({ from: defaultAccountAddress }).deployed();
28
+ const contract = await BenchmarkingContract.deploy(context.wallet).send({ from: defaultAccountAddress });
26
29
  context.logger.info(`Deployed benchmarking contract at ${contract.address}`);
27
30
  const sequencer = (context.aztecNode as AztecNodeService).getSequencer()!;
28
- const telemetry = context.telemetryClient! as BenchmarkTelemetryClient;
31
+ const telemetry = context.telemetryClient as BenchmarkTelemetryClient;
29
32
  context.logger.warn(`Cleared benchmark data points from setup`);
30
33
  telemetry.clear();
31
34
  const origTeardown = context.teardown.bind(context);
@@ -46,7 +49,7 @@ export async function benchmarkSetup(
46
49
  }
47
50
 
48
51
  type MetricFilter = {
49
- source: MetricsType;
52
+ source: MetricDefinition;
50
53
  transform: (value: number) => number;
51
54
  name: string;
52
55
  unit?: string;
@@ -61,17 +64,21 @@ export type GithubActionBenchmarkResult = {
61
64
  extra?: string;
62
65
  };
63
66
 
67
+ function isMetricDefinition(f: MetricDefinition | MetricFilter): f is MetricDefinition {
68
+ return 'description' in f;
69
+ }
70
+
64
71
  function formatMetricsForGithubBenchmarkAction(
65
72
  data: BenchmarkMetricsType,
66
- filter: (MetricsType | MetricFilter)[],
73
+ filter: (MetricDefinition | MetricFilter)[],
67
74
  ): GithubActionBenchmarkResult[] {
68
75
  const allFilters: MetricFilter[] = filter.map(f =>
69
- typeof f === 'string' ? { name: f, source: f, transform: (x: number) => x, unit: undefined } : f,
76
+ isMetricDefinition(f) ? { name: f.name, source: f, transform: (x: number) => x, unit: f.unit } : f,
70
77
  );
71
78
  return data.flatMap(meter => {
72
79
  return meter.metrics
73
- .filter(metric => allFilters.map(f => f.source).includes(metric.name as MetricsType))
74
- .map(metric => [metric, allFilters.find(f => f.source === metric.name)!] as const)
80
+ .filter(metric => allFilters.map(f => f.source.name).includes(metric.name))
81
+ .map(metric => [metric, allFilters.find(f => f.source.name === metric.name)!] as const)
75
82
  .map(([metric, filter]) => ({
76
83
  name: `${meter.name}/${filter.name}`,
77
84
  unit: filter.unit ?? metric.unit ?? 'unknown',
@@ -103,19 +110,22 @@ function getMetricValues(points: BenchmarkDataPoint[]) {
103
110
  * @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
104
111
  * @returns A BatchCall instance.
105
112
  */
106
- function makeCall(
113
+ async function makeCall(
107
114
  index: number,
108
115
  context: EndToEndContext,
109
116
  contract: BenchmarkingContract,
110
117
  heavyPublicCompute: boolean,
111
118
  ) {
112
- const [owner] = context.accounts;
113
119
  if (heavyPublicCompute) {
114
120
  return new BatchCall(context.wallet, [contract.methods.sha256_hash_1024(randomBytesAsBigInts(1024))]);
115
121
  } else {
122
+ // We use random address for the new note owner because we can emit at most UNFINALIZED_TAGGING_INDEXES_WINDOW_LEN
123
+ // logs for a given sender-recipient-contract tuple.
124
+ const ownerOfNewNote = await AztecAddress.random();
125
+ const [ownerOfBalance] = context.accounts;
116
126
  return new BatchCall(context.wallet, [
117
- contract.methods.create_note(owner, index + 1),
118
- contract.methods.increment_balance(owner, index + 1),
127
+ contract.methods.create_note(ownerOfNewNote, index + 1),
128
+ contract.methods.increment_balance(ownerOfBalance, index + 1),
119
129
  ]);
120
130
  }
121
131
  }
@@ -129,23 +139,23 @@ function makeCall(
129
139
  * @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
130
140
  * @returns Array of sent txs.
131
141
  */
132
- export function sendTxs(
142
+ export async function sendTxs(
133
143
  txCount: number,
134
144
  context: EndToEndContext,
135
145
  contract: BenchmarkingContract,
136
146
  heavyPublicCompute: boolean = false,
137
- ): SentTx[] {
138
- const calls = times(txCount, index => makeCall(index, context, contract, heavyPublicCompute));
147
+ ): Promise<TxHash[]> {
148
+ const calls = await Promise.all(times(txCount, index => makeCall(index, context, contract, heavyPublicCompute)));
139
149
  context.logger.info(`Creating ${txCount} txs`);
140
150
  const [from] = context.accounts;
141
151
  context.logger.info(`Sending ${txCount} txs`);
142
- return calls.map(call => call.send({ from }));
152
+ return Promise.all(calls.map(call => call.send({ from, wait: NO_WAIT })));
143
153
  }
144
154
 
145
- export async function waitTxs(txs: SentTx[], context: EndToEndContext, txWaitOpts?: WaitOpts) {
155
+ export async function waitTxs(txs: TxHash[], context: EndToEndContext, txWaitOpts?: WaitOpts) {
146
156
  context.logger.info(`Awaiting ${txs.length} txs to be mined`);
147
- await Promise.all(txs.map(tx => tx.wait(txWaitOpts)));
148
- context.logger.info(`All ${txs.length} txs have been mined`);
157
+ await Promise.all(txs.map(txHash => waitForTx(context.aztecNode, txHash, txWaitOpts)));
158
+ context.logger.info(`${txs.length} txs have been mined`);
149
159
  }
150
160
 
151
161
  function randomBytesAsBigInts(length: number): bigint[] {
@@ -7,22 +7,15 @@ import type { TxHash } from '@aztec/aztec.js/tx';
7
7
  import type { CheatCodes } from '@aztec/aztec/testing';
8
8
  import type { TokenContract } from '@aztec/noir-contracts.js/Token';
9
9
  import { TokenBlacklistContract } from '@aztec/noir-contracts.js/TokenBlacklist';
10
+ import { GenericProxyContract } from '@aztec/noir-test-contracts.js/GenericProxy';
10
11
  import { InvalidAccountContract } from '@aztec/noir-test-contracts.js/InvalidAccount';
11
12
  import type { SequencerClient } from '@aztec/sequencer-client';
12
- import type { TestWallet } from '@aztec/test-wallet/server';
13
13
 
14
14
  import { jest } from '@jest/globals';
15
15
 
16
- import {
17
- type ISnapshotManager,
18
- type SubsystemsContext,
19
- createSnapshotManager,
20
- deployAccounts,
21
- publicDeployAccounts,
22
- } from '../fixtures/snapshot_manager.js';
16
+ import { type EndToEndContext, deployAccounts, publicDeployAccounts, setup, teardown } from '../fixtures/setup.js';
23
17
  import { TokenSimulator } from '../simulators/token_simulator.js';
24
-
25
- const { E2E_DATA_PATH: dataPath } = process.env;
18
+ import type { TestWallet } from '../test-wallet/test_wallet.js';
26
19
 
27
20
  export class Role {
28
21
  private isAdmin = false;
@@ -55,12 +48,13 @@ export class BlacklistTokenContractTest {
55
48
  // This value MUST match the same value that we have in the contract
56
49
  static CHANGE_ROLES_DELAY = 86400;
57
50
 
58
- private snapshotManager: ISnapshotManager;
51
+ context!: EndToEndContext;
59
52
  logger: Logger;
60
53
  wallet!: TestWallet;
61
54
  asset!: TokenBlacklistContract;
62
55
  tokenSim!: TokenSimulator;
63
56
  badAccount!: InvalidAccountContract;
57
+ authwitProxy!: GenericProxyContract;
64
58
  cheatCodes!: CheatCodes;
65
59
  sequencer!: SequencerClient;
66
60
  aztecNode!: AztecNode;
@@ -71,7 +65,6 @@ export class BlacklistTokenContractTest {
71
65
 
72
66
  constructor(testName: string) {
73
67
  this.logger = createLogger(`e2e:e2e_blacklist_token_contract:${testName}`);
74
- this.snapshotManager = createSnapshotManager(`e2e_blacklist_token_contract/${testName}`, dataPath);
75
68
  }
76
69
 
77
70
  async crossTimestampOfChange() {
@@ -83,86 +76,79 @@ export class BlacklistTokenContractTest {
83
76
  }
84
77
 
85
78
  /**
86
- * Adds two state shifts to snapshot manager.
79
+ * Applies base setup:
87
80
  * 1. Add 3 accounts.
88
81
  * 2. Publicly deploy accounts, deploy token contract and a "bad account".
89
82
  */
90
- async applyBaseSnapshots() {
83
+ async applyBaseSetup() {
91
84
  // Adding a timeout of 2 minutes in here such that it is propagated to the underlying tests
92
85
  jest.setTimeout(120_000);
93
86
 
94
- await this.snapshotManager.snapshot(
95
- '3_accounts',
96
- deployAccounts(3, this.logger),
97
- ({ deployedAccounts }, { cheatCodes, aztecNode, sequencer, wallet }) => {
98
- this.cheatCodes = cheatCodes;
99
- this.aztecNode = aztecNode;
100
- this.sequencer = sequencer;
101
- this.wallet = wallet;
102
- this.adminAddress = deployedAccounts[0].address;
103
- this.otherAddress = deployedAccounts[1].address;
104
- this.blacklistedAddress = deployedAccounts[2].address;
105
- return Promise.resolve();
106
- },
87
+ this.logger.info('Deploying 3 accounts');
88
+ const { deployedAccounts } = await deployAccounts(
89
+ 3,
90
+ this.logger,
91
+ )({
92
+ wallet: this.context.wallet,
93
+ initialFundedAccounts: this.context.initialFundedAccounts,
94
+ });
95
+
96
+ this.cheatCodes = this.context.cheatCodes;
97
+ this.aztecNode = this.context.aztecNodeService;
98
+ this.sequencer = this.context.sequencer!;
99
+ this.wallet = this.context.wallet;
100
+ this.adminAddress = deployedAccounts[0].address;
101
+ this.otherAddress = deployedAccounts[1].address;
102
+ this.blacklistedAddress = deployedAccounts[2].address;
103
+
104
+ this.logger.info('Setting up blacklist token contract');
105
+ // Create the token contract state.
106
+ this.logger.verbose(`Public deploy accounts...`);
107
+ await publicDeployAccounts(this.wallet, [this.adminAddress, this.otherAddress, this.blacklistedAddress]);
108
+
109
+ this.logger.verbose(`Deploying TokenContract...`);
110
+ this.asset = await TokenBlacklistContract.deploy(this.wallet, this.adminAddress).send({
111
+ from: this.adminAddress,
112
+ });
113
+ this.logger.verbose(`Token deployed to ${this.asset.address}`);
114
+
115
+ this.logger.verbose(`Deploying bad account...`);
116
+ this.badAccount = await InvalidAccountContract.deploy(this.wallet).send({ from: this.adminAddress });
117
+ this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
118
+
119
+ // Deploy a proxy contract for "on behalf of other" tests. The note owner must be the tx sender
120
+ // (so their notes are in scope), but msg_sender in the target must differ from the note owner
121
+ // to trigger authwit validation. The proxy forwards calls so that msg_sender != tx sender.
122
+ this.logger.verbose(`Deploying generic proxy...`);
123
+ this.authwitProxy = await GenericProxyContract.deploy(this.wallet).send({ from: this.adminAddress });
124
+ this.logger.verbose(`Deployed to ${this.authwitProxy.address}.`);
125
+
126
+ await this.crossTimestampOfChange();
127
+
128
+ this.tokenSim = new TokenSimulator(
129
+ this.asset as unknown as TokenContract,
130
+ this.wallet,
131
+ this.adminAddress,
132
+ this.logger,
133
+ [this.adminAddress, this.otherAddress, this.blacklistedAddress],
107
134
  );
108
135
 
109
- await this.snapshotManager.snapshot(
110
- 'e2e_blacklist_token_contract',
111
- async () => {
112
- // Create the token contract state.
113
- // Move this account thing to addAccounts above?
114
- this.logger.verbose(`Public deploy accounts...`);
115
- await publicDeployAccounts(this.wallet, [this.adminAddress, this.otherAddress, this.blacklistedAddress]);
116
-
117
- this.logger.verbose(`Deploying TokenContract...`);
118
- this.asset = await TokenBlacklistContract.deploy(this.wallet, this.adminAddress)
119
- .send({ from: this.adminAddress })
120
- .deployed();
121
- this.logger.verbose(`Token deployed to ${this.asset.address}`);
122
-
123
- this.logger.verbose(`Deploying bad account...`);
124
- this.badAccount = await InvalidAccountContract.deploy(this.wallet).send({ from: this.adminAddress }).deployed();
125
- this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
126
-
127
- await this.crossTimestampOfChange();
128
-
129
- return { tokenContractAddress: this.asset.address, badAccountAddress: this.badAccount.address };
130
- },
131
- async ({ tokenContractAddress, badAccountAddress }) => {
132
- // Restore the token contract state.
133
- this.asset = await TokenBlacklistContract.at(tokenContractAddress, this.wallet);
134
- this.logger.verbose(`Token contract address: ${this.asset.address}`);
135
-
136
- this.tokenSim = new TokenSimulator(
137
- this.asset as unknown as TokenContract,
138
- this.wallet,
139
- this.adminAddress,
140
- this.logger,
141
- [this.adminAddress, this.otherAddress, this.blacklistedAddress],
142
- );
143
-
144
- this.badAccount = await InvalidAccountContract.at(badAccountAddress, this.wallet);
145
- this.logger.verbose(`Bad account address: ${this.badAccount.address}`);
146
-
147
- expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
148
- new Role().withAdmin().toNoirStruct(),
149
- );
150
- },
136
+ expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
137
+ new Role().withAdmin().toNoirStruct(),
151
138
  );
152
139
  }
153
140
 
154
141
  async setup() {
155
- await this.snapshotManager.setup();
142
+ this.logger.info('Setting up fresh context');
143
+ this.context = await setup(0, {
144
+ fundSponsoredFPC: true,
145
+ skipAccountDeployment: true,
146
+ });
147
+ await this.applyBaseSetup();
156
148
  }
157
149
 
158
- snapshot = <T>(
159
- name: string,
160
- apply: (context: SubsystemsContext) => Promise<T>,
161
- restore: (snapshotData: T, context: SubsystemsContext) => Promise<void> = () => Promise.resolve(),
162
- ): Promise<void> => this.snapshotManager.snapshot(name, apply, restore);
163
-
164
150
  async teardown() {
165
- await this.snapshotManager.teardown();
151
+ await teardown(this.context);
166
152
  }
167
153
 
168
154
  async addPendingShieldNoteToPXE(
@@ -174,7 +160,7 @@ export class BlacklistTokenContractTest {
174
160
  ) {
175
161
  const txEffects = await this.aztecNode.getTxEffect(txHash);
176
162
  await contract.methods
177
- .deliver_transparent_note(
163
+ .process_transparent_note(
178
164
  contract.address,
179
165
  amount,
180
166
  secretHash,
@@ -186,71 +172,56 @@ export class BlacklistTokenContractTest {
186
172
  .simulate({ from: recipient });
187
173
  }
188
174
 
189
- async applyMintSnapshot() {
190
- await this.snapshotManager.snapshot(
191
- 'mint',
192
- async () => {
193
- const { asset } = this;
194
- const amount = 10000n;
195
-
196
- const adminMinterRole = new Role().withAdmin().withMinter();
197
- await this.asset.methods
198
- .update_roles(this.adminAddress, adminMinterRole.toNoirStruct())
199
- .send({ from: this.adminAddress })
200
- .wait();
201
-
202
- const blacklistRole = new Role().withBlacklisted();
203
- await this.asset.methods
204
- .update_roles(this.blacklistedAddress, blacklistRole.toNoirStruct())
205
- .send({ from: this.adminAddress })
206
- .wait();
207
-
208
- await this.crossTimestampOfChange();
209
-
210
- expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
211
- adminMinterRole.toNoirStruct(),
212
- );
213
-
214
- this.logger.verbose(`Minting ${amount} publicly...`);
215
- await asset.methods.mint_public(this.adminAddress, amount).send({ from: this.adminAddress }).wait();
216
-
217
- this.logger.verbose(`Minting ${amount} privately...`);
218
- const secret = Fr.random();
219
- const secretHash = await computeSecretHash(secret);
220
- const receipt = await asset.methods.mint_private(amount, secretHash).send({ from: this.adminAddress }).wait();
221
-
222
- await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
223
- const txClaim = asset.methods
224
- .redeem_shield(this.adminAddress, amount, secret)
225
- .send({ from: this.adminAddress });
226
- await txClaim.wait();
227
- this.logger.verbose(`Minting complete.`);
228
-
229
- return { amount };
230
- },
231
- async ({ amount }) => {
232
- const { asset, tokenSim } = this;
233
- tokenSim.mintPublic(this.adminAddress, amount);
234
-
235
- const publicBalance = await asset.methods
236
- .balance_of_public(this.adminAddress)
237
- .simulate({ from: this.adminAddress });
238
- this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
239
- expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(this.adminAddress));
240
-
241
- tokenSim.mintPrivate(this.adminAddress, amount);
242
- const privateBalance = await asset.methods
243
- .balance_of_private(this.adminAddress)
244
- .simulate({ from: this.adminAddress });
245
- this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
246
- expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
247
-
248
- const totalSupply = await asset.methods.total_supply().simulate({ from: this.adminAddress });
249
- this.logger.verbose(`Total supply: ${totalSupply}`);
250
- expect(totalSupply).toEqual(tokenSim.totalSupply);
251
-
252
- return Promise.resolve();
253
- },
175
+ async applyMint() {
176
+ this.logger.info('Applying mint setup');
177
+ const { asset, tokenSim } = this;
178
+ const amount = 10000n;
179
+
180
+ const adminMinterRole = new Role().withAdmin().withMinter();
181
+ await this.asset.methods
182
+ .update_roles(this.adminAddress, adminMinterRole.toNoirStruct())
183
+ .send({ from: this.adminAddress });
184
+
185
+ const blacklistRole = new Role().withBlacklisted();
186
+ await this.asset.methods
187
+ .update_roles(this.blacklistedAddress, blacklistRole.toNoirStruct())
188
+ .send({ from: this.adminAddress });
189
+
190
+ await this.crossTimestampOfChange();
191
+
192
+ expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
193
+ adminMinterRole.toNoirStruct(),
254
194
  );
195
+
196
+ this.logger.verbose(`Minting ${amount} publicly...`);
197
+ await asset.methods.mint_public(this.adminAddress, amount).send({ from: this.adminAddress });
198
+
199
+ this.logger.verbose(`Minting ${amount} privately...`);
200
+ const secret = Fr.random();
201
+ const secretHash = await computeSecretHash(secret);
202
+ const receipt = await asset.methods.mint_private(amount, secretHash).send({ from: this.adminAddress });
203
+
204
+ await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
205
+ await asset.methods.redeem_shield(this.adminAddress, amount, secret).send({ from: this.adminAddress });
206
+ this.logger.verbose(`Minting complete.`);
207
+
208
+ tokenSim.mintPublic(this.adminAddress, amount);
209
+
210
+ const publicBalance = await asset.methods
211
+ .balance_of_public(this.adminAddress)
212
+ .simulate({ from: this.adminAddress });
213
+ this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
214
+ expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(this.adminAddress));
215
+
216
+ tokenSim.mintPrivate(this.adminAddress, amount);
217
+ const privateBalance = await asset.methods
218
+ .balance_of_private(this.adminAddress)
219
+ .simulate({ from: this.adminAddress });
220
+ this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
221
+ expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
222
+
223
+ const totalSupply = await asset.methods.total_supply().simulate({ from: this.adminAddress });
224
+ this.logger.verbose(`Total supply: ${totalSupply}`);
225
+ expect(totalSupply).toEqual(tokenSim.totalSupply);
255
226
  }
256
227
  }