@aztec/end-to-end 0.0.0-test.0 → 0.0.1-commit.0208eb9

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 (247) hide show
  1. package/dest/bench/client_flows/benchmark.d.ts +62 -0
  2. package/dest/bench/client_flows/benchmark.d.ts.map +1 -0
  3. package/dest/bench/client_flows/benchmark.js +281 -0
  4. package/dest/bench/client_flows/client_flows_benchmark.d.ts +79 -0
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -0
  6. package/dest/bench/client_flows/client_flows_benchmark.js +321 -0
  7. package/dest/bench/client_flows/config.d.ts +14 -0
  8. package/dest/bench/client_flows/config.d.ts.map +1 -0
  9. package/dest/bench/client_flows/config.js +106 -0
  10. package/dest/bench/client_flows/data_extractor.d.ts +2 -0
  11. package/dest/bench/client_flows/data_extractor.d.ts.map +1 -0
  12. package/dest/bench/client_flows/data_extractor.js +79 -0
  13. package/dest/bench/utils.d.ts +16 -41
  14. package/dest/bench/utils.d.ts.map +1 -1
  15. package/dest/bench/utils.js +41 -72
  16. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +26 -19
  17. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  18. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +114 -102
  19. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +32 -32
  20. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  21. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +104 -104
  22. package/dest/e2e_deploy_contract/deploy_test.d.ts +19 -10
  23. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  24. package/dest/e2e_deploy_contract/deploy_test.js +26 -27
  25. package/dest/e2e_epochs/epochs_test.d.ts +71 -22
  26. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  27. package/dest/e2e_epochs/epochs_test.js +260 -54
  28. package/dest/e2e_fees/bridging_race.notest.d.ts +2 -0
  29. package/dest/e2e_fees/bridging_race.notest.d.ts.map +1 -0
  30. package/dest/e2e_fees/bridging_race.notest.js +61 -0
  31. package/dest/e2e_fees/fees_test.d.ts +38 -23
  32. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  33. package/dest/e2e_fees/fees_test.js +162 -183
  34. package/dest/e2e_l1_publisher/write_json.d.ts +11 -0
  35. package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -0
  36. package/dest/e2e_l1_publisher/write_json.js +56 -0
  37. package/dest/e2e_multi_validator/utils.d.ts +12 -0
  38. package/dest/e2e_multi_validator/utils.d.ts.map +1 -0
  39. package/dest/e2e_multi_validator/utils.js +214 -0
  40. package/dest/e2e_nested_contract/nested_contract_test.d.ts +15 -15
  41. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  42. package/dest/e2e_nested_contract/nested_contract_test.js +37 -41
  43. package/dest/e2e_p2p/inactivity_slash_test.d.ts +31 -0
  44. package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -0
  45. package/dest/e2e_p2p/inactivity_slash_test.js +136 -0
  46. package/dest/e2e_p2p/p2p_network.d.ts +281 -27
  47. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  48. package/dest/e2e_p2p/p2p_network.js +237 -175
  49. package/dest/e2e_p2p/reqresp/utils.d.ts +22 -0
  50. package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -0
  51. package/dest/e2e_p2p/reqresp/utils.js +153 -0
  52. package/dest/e2e_p2p/shared.d.ts +44 -8
  53. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  54. package/dest/e2e_p2p/shared.js +165 -27
  55. package/dest/e2e_token_contract/token_contract_test.d.ts +27 -14
  56. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  57. package/dest/e2e_token_contract/token_contract_test.js +96 -74
  58. package/dest/fixtures/e2e_prover_test.d.ts +55 -0
  59. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -0
  60. package/dest/fixtures/e2e_prover_test.js +278 -0
  61. package/dest/fixtures/fixtures.d.ts +6 -8
  62. package/dest/fixtures/fixtures.d.ts.map +1 -1
  63. package/dest/fixtures/fixtures.js +5 -5
  64. package/dest/fixtures/get_acvm_config.d.ts +2 -2
  65. package/dest/fixtures/get_acvm_config.d.ts.map +1 -1
  66. package/dest/fixtures/get_acvm_config.js +3 -15
  67. package/dest/fixtures/get_bb_config.d.ts +2 -2
  68. package/dest/fixtures/get_bb_config.d.ts.map +1 -1
  69. package/dest/fixtures/get_bb_config.js +10 -17
  70. package/dest/fixtures/ha_setup.d.ts +71 -0
  71. package/dest/fixtures/ha_setup.d.ts.map +1 -0
  72. package/dest/fixtures/ha_setup.js +114 -0
  73. package/dest/fixtures/index.d.ts +2 -1
  74. package/dest/fixtures/index.d.ts.map +1 -1
  75. package/dest/fixtures/index.js +1 -0
  76. package/dest/fixtures/l1_to_l2_messaging.d.ts +11 -7
  77. package/dest/fixtures/l1_to_l2_messaging.d.ts.map +1 -1
  78. package/dest/fixtures/l1_to_l2_messaging.js +45 -19
  79. package/dest/fixtures/logging.d.ts +1 -1
  80. package/dest/fixtures/setup.d.ts +218 -0
  81. package/dest/fixtures/setup.d.ts.map +1 -0
  82. package/dest/fixtures/setup.js +695 -0
  83. package/dest/fixtures/setup_p2p_test.d.ts +15 -15
  84. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  85. package/dest/fixtures/setup_p2p_test.js +96 -31
  86. package/dest/fixtures/token_utils.d.ts +10 -4
  87. package/dest/fixtures/token_utils.d.ts.map +1 -1
  88. package/dest/fixtures/token_utils.js +31 -12
  89. package/dest/fixtures/utils.d.ts +5 -153
  90. package/dest/fixtures/utils.d.ts.map +1 -1
  91. package/dest/fixtures/utils.js +4 -552
  92. package/dest/fixtures/web3signer.d.ts +5 -0
  93. package/dest/fixtures/web3signer.d.ts.map +1 -0
  94. package/dest/fixtures/web3signer.js +53 -0
  95. package/dest/fixtures/with_telemetry_utils.d.ts +2 -2
  96. package/dest/fixtures/with_telemetry_utils.d.ts.map +1 -1
  97. package/dest/fixtures/with_telemetry_utils.js +2 -2
  98. package/dest/index.d.ts +1 -1
  99. package/dest/quality_of_service/grafana_client.d.ts +41 -0
  100. package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
  101. package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
  102. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  103. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  104. package/dest/quality_of_service/prometheus_client.js +67 -0
  105. package/dest/shared/cross_chain_test_harness.d.ts +44 -27
  106. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  107. package/dest/shared/cross_chain_test_harness.js +105 -51
  108. package/dest/shared/gas_portal_test_harness.d.ts +33 -25
  109. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  110. package/dest/shared/gas_portal_test_harness.js +51 -30
  111. package/dest/shared/index.d.ts +2 -2
  112. package/dest/shared/index.d.ts.map +1 -1
  113. package/dest/shared/jest_setup.d.ts +1 -1
  114. package/dest/shared/jest_setup.js +1 -1
  115. package/dest/shared/submit-transactions.d.ts +6 -4
  116. package/dest/shared/submit-transactions.d.ts.map +1 -1
  117. package/dest/shared/submit-transactions.js +15 -16
  118. package/dest/shared/uniswap_l1_l2.d.ts +3 -25
  119. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  120. package/dest/shared/uniswap_l1_l2.js +176 -126
  121. package/dest/simulators/index.d.ts +1 -1
  122. package/dest/simulators/lending_simulator.d.ts +7 -7
  123. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  124. package/dest/simulators/lending_simulator.js +17 -18
  125. package/dest/simulators/token_simulator.d.ts +6 -3
  126. package/dest/simulators/token_simulator.d.ts.map +1 -1
  127. package/dest/simulators/token_simulator.js +16 -13
  128. package/dest/spartan/setup_test_wallets.d.ts +27 -11
  129. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  130. package/dest/spartan/setup_test_wallets.js +233 -62
  131. package/dest/spartan/tx_metrics.d.ts +88 -0
  132. package/dest/spartan/tx_metrics.d.ts.map +1 -0
  133. package/dest/spartan/tx_metrics.js +422 -0
  134. package/dest/spartan/utils/bot.d.ts +27 -0
  135. package/dest/spartan/utils/bot.d.ts.map +1 -0
  136. package/dest/spartan/utils/bot.js +141 -0
  137. package/dest/spartan/utils/chaos.d.ts +79 -0
  138. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  139. package/dest/spartan/utils/chaos.js +142 -0
  140. package/dest/spartan/utils/clients.d.ts +39 -0
  141. package/dest/spartan/utils/clients.d.ts.map +1 -0
  142. package/dest/spartan/utils/clients.js +90 -0
  143. package/dest/spartan/utils/config.d.ts +39 -0
  144. package/dest/spartan/utils/config.d.ts.map +1 -0
  145. package/dest/spartan/utils/config.js +21 -0
  146. package/dest/spartan/utils/health.d.ts +63 -0
  147. package/dest/spartan/utils/health.d.ts.map +1 -0
  148. package/dest/spartan/utils/health.js +202 -0
  149. package/dest/spartan/utils/helm.d.ts +15 -0
  150. package/dest/spartan/utils/helm.d.ts.map +1 -0
  151. package/dest/spartan/utils/helm.js +47 -0
  152. package/dest/spartan/utils/index.d.ts +9 -0
  153. package/dest/spartan/utils/index.d.ts.map +1 -0
  154. package/dest/spartan/utils/index.js +18 -0
  155. package/dest/spartan/utils/k8s.d.ts +126 -0
  156. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  157. package/dest/spartan/utils/k8s.js +375 -0
  158. package/dest/spartan/utils/nodes.d.ts +41 -0
  159. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  160. package/dest/spartan/utils/nodes.js +461 -0
  161. package/dest/spartan/utils/scripts.d.ts +30 -0
  162. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  163. package/dest/spartan/utils/scripts.js +81 -0
  164. package/dest/spartan/utils.d.ts +2 -415
  165. package/dest/spartan/utils.d.ts.map +1 -1
  166. package/dest/spartan/utils.js +1 -445
  167. package/package.json +69 -58
  168. package/src/bench/client_flows/benchmark.ts +363 -0
  169. package/src/bench/client_flows/client_flows_benchmark.ts +384 -0
  170. package/src/bench/client_flows/config.ts +61 -0
  171. package/src/bench/client_flows/data_extractor.ts +89 -0
  172. package/src/bench/utils.ts +41 -85
  173. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +134 -169
  174. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +156 -182
  175. package/src/e2e_deploy_contract/deploy_test.ts +40 -48
  176. package/src/e2e_epochs/epochs_test.ts +341 -81
  177. package/src/e2e_fees/bridging_race.notest.ts +74 -0
  178. package/src/e2e_fees/fees_test.ts +220 -258
  179. package/src/e2e_l1_publisher/write_json.ts +77 -0
  180. package/src/e2e_multi_validator/utils.ts +258 -0
  181. package/src/e2e_nested_contract/nested_contract_test.ts +46 -59
  182. package/src/e2e_p2p/inactivity_slash_test.ts +179 -0
  183. package/src/e2e_p2p/p2p_network.ts +341 -234
  184. package/src/e2e_p2p/reqresp/utils.ts +207 -0
  185. package/src/e2e_p2p/shared.ts +260 -39
  186. package/src/e2e_token_contract/token_contract_test.ts +115 -126
  187. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  188. package/src/fixtures/e2e_prover_test.ts +336 -0
  189. package/src/fixtures/fixtures.ts +5 -7
  190. package/src/fixtures/get_acvm_config.ts +4 -12
  191. package/src/fixtures/get_bb_config.ts +18 -13
  192. package/src/fixtures/ha_setup.ts +184 -0
  193. package/src/fixtures/index.ts +1 -0
  194. package/src/fixtures/l1_to_l2_messaging.ts +56 -24
  195. package/src/fixtures/setup.ts +1017 -0
  196. package/src/fixtures/setup_p2p_test.ts +133 -50
  197. package/src/fixtures/token_utils.ts +33 -15
  198. package/src/fixtures/utils.ts +27 -820
  199. package/src/fixtures/web3signer.ts +63 -0
  200. package/src/fixtures/with_telemetry_utils.ts +2 -2
  201. package/src/guides/up_quick_start.sh +7 -15
  202. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +2 -2
  203. package/src/quality_of_service/prometheus_client.ts +113 -0
  204. package/src/shared/cross_chain_test_harness.ts +103 -91
  205. package/src/shared/gas_portal_test_harness.ts +59 -50
  206. package/src/shared/index.ts +1 -1
  207. package/src/shared/jest_setup.ts +1 -1
  208. package/src/shared/submit-transactions.ts +18 -20
  209. package/src/shared/uniswap_l1_l2.ts +197 -221
  210. package/src/simulators/lending_simulator.ts +16 -17
  211. package/src/simulators/token_simulator.ts +21 -13
  212. package/src/spartan/DEVELOP.md +128 -0
  213. package/src/spartan/setup_test_wallets.ts +308 -95
  214. package/src/spartan/tx_metrics.ts +376 -0
  215. package/src/spartan/utils/bot.ts +185 -0
  216. package/src/spartan/utils/chaos.ts +253 -0
  217. package/src/spartan/utils/clients.ts +100 -0
  218. package/src/spartan/utils/config.ts +27 -0
  219. package/src/spartan/utils/health.ts +255 -0
  220. package/src/spartan/utils/helm.ts +84 -0
  221. package/src/spartan/utils/index.ts +64 -0
  222. package/src/spartan/utils/k8s.ts +527 -0
  223. package/src/spartan/utils/nodes.ts +538 -0
  224. package/src/spartan/utils/scripts.ts +99 -0
  225. package/src/spartan/utils.ts +1 -582
  226. package/dest/e2e_prover/e2e_prover_test.d.ts +0 -56
  227. package/dest/e2e_prover/e2e_prover_test.d.ts.map +0 -1
  228. package/dest/e2e_prover/e2e_prover_test.js +0 -291
  229. package/dest/fixtures/setup_l1_contracts.d.ts +0 -6
  230. package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
  231. package/dest/fixtures/setup_l1_contracts.js +0 -17
  232. package/dest/fixtures/snapshot_manager.d.ts +0 -87
  233. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  234. package/dest/fixtures/snapshot_manager.js +0 -479
  235. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  236. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  237. package/dest/sample-dapp/connect.js +0 -12
  238. package/dest/sample-dapp/contracts.js +0 -10
  239. package/dest/sample-dapp/deploy.js +0 -35
  240. package/dest/sample-dapp/index.js +0 -98
  241. package/src/e2e_prover/e2e_prover_test.ts +0 -418
  242. package/src/fixtures/setup_l1_contracts.ts +0 -27
  243. package/src/fixtures/snapshot_manager.ts +0 -617
  244. package/src/sample-dapp/connect.mjs +0 -16
  245. package/src/sample-dapp/contracts.mjs +0 -14
  246. package/src/sample-dapp/deploy.mjs +0 -40
  247. package/src/sample-dapp/index.mjs +0 -128
@@ -1,5 +1,6 @@
1
1
  import { parseBooleanEnv } from '@aztec/foundation/config';
2
- import { randomBytes } from '@aztec/foundation/crypto';
2
+ import { randomBytes } from '@aztec/foundation/crypto/random';
3
+ import { tryRmDir } from '@aztec/foundation/fs';
3
4
  import { promises as fs } from 'fs';
4
5
  export { deployAndInitializeTokenAndBridgeContracts } from '../shared/cross_chain_test_harness.js';
5
6
  const { NOIR_RELEASE_DIR = 'noir-repo/target/release', TEMP_DIR = '/tmp', ACVM_BINARY_PATH = '', ACVM_WORKING_DIRECTORY = '', ACVM_FORCE_WASM = '' } = process.env;
@@ -18,20 +19,7 @@ export async function getACVMConfig(logger) {
18
19
  });
19
20
  logger.verbose(`Using native ACVM binary at ${acvmBinaryPath} with working directory ${acvmWorkingDirectory}`);
20
21
  const directoryToCleanup = ACVM_WORKING_DIRECTORY ? undefined : tempWorkingDirectory;
21
- const cleanup = async ()=>{
22
- if (directoryToCleanup) {
23
- try {
24
- logger.info(`Cleaning up ACVM temp directory ${directoryToCleanup}`);
25
- await fs.rm(directoryToCleanup, {
26
- recursive: true,
27
- force: true,
28
- maxRetries: 3
29
- });
30
- } catch (err) {
31
- logger.warn(`Failed to delete ACVM temp directory at ${directoryToCleanup}: ${err}`);
32
- }
33
- }
34
- };
22
+ const cleanup = ()=>tryRmDir(directoryToCleanup, logger);
35
23
  return {
36
24
  acvmWorkingDirectory,
37
25
  acvmBinaryPath,
@@ -1,6 +1,6 @@
1
- import { type Logger } from '@aztec/aztec.js';
1
+ import type { Logger } from '@aztec/aztec.js/log';
2
2
  import type { BBConfig } from '@aztec/bb-prover';
3
3
  export declare const getBBConfig: (logger: Logger) => Promise<(BBConfig & {
4
4
  cleanup: () => Promise<void>;
5
5
  }) | undefined>;
6
- //# sourceMappingURL=get_bb_config.d.ts.map
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0X2JiX2NvbmZpZy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZpeHR1cmVzL2dldF9iYl9jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbEQsT0FBTyxLQUFLLEVBQUUsUUFBUSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFrQmpELGVBQU8sTUFBTSxXQUFXOztlQXVDdkIsQ0FBQyJ9
@@ -1 +1 @@
1
- {"version":3,"file":"get_bb_config.d.ts","sourceRoot":"","sources":["../../src/fixtures/get_bb_config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAiB,MAAM,iBAAiB,CAAC;AAC7D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAcjD,eAAO,MAAM,WAAW,WACd,MAAM,KACb,QAAQ,CAAC,QAAQ,GAAG;IAAE,OAAO,EAAE,MAAM,QAAQ,IAAI,CAAC,CAAA;CAAE,CAAC,GAAG,SAAS,CAoCnE,CAAC"}
1
+ {"version":3,"file":"get_bb_config.d.ts","sourceRoot":"","sources":["../../src/fixtures/get_bb_config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAkBjD,eAAO,MAAM,WAAW;;eAuCvB,CAAC"}
@@ -1,11 +1,12 @@
1
- import { fileURLToPath } from '@aztec/aztec.js';
1
+ import { tryRmDir } from '@aztec/foundation/fs';
2
2
  import fs from 'node:fs/promises';
3
3
  import { tmpdir } from 'node:os';
4
4
  import path from 'path';
5
- const { BB_RELEASE_DIR = 'barretenberg/cpp/build/bin', BB_BINARY_PATH, BB_SKIP_CLEANUP = '', TEMP_DIR = tmpdir(), BB_WORKING_DIRECTORY = '' } = process.env;
5
+ import { fileURLToPath } from 'url';
6
+ const { BB_RELEASE_DIR = 'barretenberg/cpp/build/bin', BB_BINARY_PATH, BB_SKIP_CLEANUP = '', TEMP_DIR = tmpdir(), BB_WORKING_DIRECTORY = '', BB_NUM_IVC_VERIFIERS = '1', BB_IVC_CONCURRENCY = '1' } = process.env;
6
7
  export const getBBConfig = async (logger)=>{
7
8
  try {
8
- const bbBinaryPath = BB_BINARY_PATH ?? path.resolve(path.dirname(fileURLToPath(import.meta.url)), '../../../../', BB_RELEASE_DIR, 'bb');
9
+ const bbBinaryPath = BB_BINARY_PATH ?? path.resolve(path.dirname(fileURLToPath(import.meta.url)), '../../../../', BB_RELEASE_DIR, 'bb-avm');
9
10
  await fs.access(bbBinaryPath, fs.constants.R_OK);
10
11
  let bbWorkingDirectory;
11
12
  let directoryToCleanup;
@@ -22,24 +23,16 @@ export const getBBConfig = async (logger)=>{
22
23
  '1',
23
24
  'true'
24
25
  ].includes(BB_SKIP_CLEANUP);
25
- const cleanup = async ()=>{
26
- if (directoryToCleanup && !bbSkipCleanup) {
27
- try {
28
- await fs.rm(directoryToCleanup, {
29
- recursive: true,
30
- force: true,
31
- maxRetries: 3
32
- });
33
- } catch (err) {
34
- logger.warn(`Failed to delete bb working directory at ${directoryToCleanup}: ${err}`);
35
- }
36
- }
37
- };
26
+ const cleanup = bbSkipCleanup ? ()=>Promise.resolve() : ()=>tryRmDir(directoryToCleanup);
27
+ const numIvcVerifiers = Number(BB_NUM_IVC_VERIFIERS);
28
+ const ivcConcurrency = Number(BB_IVC_CONCURRENCY);
38
29
  return {
39
30
  bbSkipCleanup,
40
31
  bbBinaryPath,
41
32
  bbWorkingDirectory,
42
- cleanup
33
+ cleanup,
34
+ numConcurrentIVCVerifiers: numIvcVerifiers,
35
+ bbIVCConcurrency: ivcConcurrency
43
36
  };
44
37
  } catch (err) {
45
38
  logger.error(`Native BB not available, error: ${err}`);
@@ -0,0 +1,71 @@
1
+ import { EthAddress } from '@aztec/aztec.js/addresses';
2
+ import type { Logger } from '@aztec/aztec.js/log';
3
+ import { SecretValue } from '@aztec/foundation/config';
4
+ import { Pool } from 'pg';
5
+ /**
6
+ * Configuration for HA database connection
7
+ */
8
+ export interface HADatabaseConfig {
9
+ /** PostgreSQL connection URL */
10
+ databaseUrl: string;
11
+ /** Node ID for HA coordination */
12
+ nodeId: string;
13
+ /** Enable HA signing */
14
+ haSigningEnabled: boolean;
15
+ /** Polling interval in ms */
16
+ pollingIntervalMs: number;
17
+ /** Signing timeout in ms */
18
+ signingTimeoutMs: number;
19
+ /** Max stuck duties age in ms */
20
+ maxStuckDutiesAgeMs: number;
21
+ }
22
+ /**
23
+ * Get database configuration from environment variables
24
+ */
25
+ export declare function createHADatabaseConfig(nodeId: string): HADatabaseConfig;
26
+ /**
27
+ * Setup PostgreSQL database connection pool for HA tests
28
+ *
29
+ * Note: Database migrations should be run separately before starting tests,
30
+ * either via docker-compose entrypoint or manually with: aztec migrate-ha-db up
31
+ */
32
+ export declare function setupHADatabase(databaseUrl: string, logger?: Logger): Pool;
33
+ /**
34
+ * Clean up HA database - drop all tables
35
+ * Use this between tests to ensure clean state
36
+ */
37
+ export declare function cleanupHADatabase(pool: Pool, logger?: Logger): Promise<void>;
38
+ /**
39
+ * Query validator duties from the database
40
+ */
41
+ export declare function getValidatorDuties(pool: Pool, slot: bigint, dutyType?: 'ATTESTATION' | 'BLOCK_PROPOSAL' | 'GOVERNANCE_VOTE' | 'SLASHING_VOTE'): Promise<Array<{
42
+ slot: string;
43
+ dutyType: string;
44
+ validatorAddress: string;
45
+ nodeId: string;
46
+ startedAt: Date;
47
+ completedAt: Date | undefined;
48
+ }>>;
49
+ /**
50
+ * Convert private keys to Ethereum addresses
51
+ */
52
+ export declare function getAddressesFromPrivateKeys(privateKeys: `0x${string}`[]): string[];
53
+ /**
54
+ * Create initial validators from private keys for L1 contract deployment
55
+ */
56
+ export declare function createInitialValidatorsFromPrivateKeys(attesterPrivateKeys: `0x${string}`[]): Array<{
57
+ attester: EthAddress;
58
+ withdrawer: EthAddress;
59
+ privateKey: `0x${string}`;
60
+ bn254SecretKey: SecretValue<bigint>;
61
+ }>;
62
+ /**
63
+ * Verify no duplicate attestations per validator (HA coordination check)
64
+ * Groups duties by validator address and verifies each validator attested exactly once
65
+ */
66
+ export declare function verifyNoDuplicateAttestations(attestationDuties: Array<{
67
+ validatorAddress: string;
68
+ nodeId: string;
69
+ completedAt: Date | undefined;
70
+ }>, logger?: Logger): Map<string, typeof attestationDuties>;
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFfc2V0dXAuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9maXh0dXJlcy9oYV9zZXR1cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFdkQsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRXZELE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxJQUFJLENBQUM7QUFHMUI7O0dBRUc7QUFDSCxNQUFNLFdBQVcsZ0JBQWdCO0lBQy9CLGdDQUFnQztJQUNoQyxXQUFXLEVBQUUsTUFBTSxDQUFDO0lBQ3BCLGtDQUFrQztJQUNsQyxNQUFNLEVBQUUsTUFBTSxDQUFDO0lBQ2Ysd0JBQXdCO0lBQ3hCLGdCQUFnQixFQUFFLE9BQU8sQ0FBQztJQUMxQiw2QkFBNkI7SUFDN0IsaUJBQWlCLEVBQUUsTUFBTSxDQUFDO0lBQzFCLDRCQUE0QjtJQUM1QixnQkFBZ0IsRUFBRSxNQUFNLENBQUM7SUFDekIsaUNBQWlDO0lBQ2pDLG1CQUFtQixFQUFFLE1BQU0sQ0FBQztDQUM3QjtBQUVEOztHQUVHO0FBQ0gsd0JBQWdCLHNCQUFzQixDQUFDLE1BQU0sRUFBRSxNQUFNLEdBQUcsZ0JBQWdCLENBV3ZFO0FBRUQ7Ozs7O0dBS0c7QUFDSCx3QkFBZ0IsZUFBZSxDQUFDLFdBQVcsRUFBRSxNQUFNLEVBQUUsTUFBTSxDQUFDLEVBQUUsTUFBTSxHQUFHLElBQUksQ0FhMUU7QUFFRDs7O0dBR0c7QUFDSCx3QkFBc0IsaUJBQWlCLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLENBQUMsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQVlsRjtBQUVEOztHQUVHO0FBQ0gsd0JBQXNCLGtCQUFrQixDQUN0QyxJQUFJLEVBQUUsSUFBSSxFQUNWLElBQUksRUFBRSxNQUFNLEVBQ1osUUFBUSxDQUFDLEVBQUUsYUFBYSxHQUFHLGdCQUFnQixHQUFHLGlCQUFpQixHQUFHLGVBQWUsR0FDaEYsT0FBTyxDQUNSLEtBQUssQ0FBQztJQUNKLElBQUksRUFBRSxNQUFNLENBQUM7SUFDYixRQUFRLEVBQUUsTUFBTSxDQUFDO0lBQ2pCLGdCQUFnQixFQUFFLE1BQU0sQ0FBQztJQUN6QixNQUFNLEVBQUUsTUFBTSxDQUFDO0lBQ2YsU0FBUyxFQUFFLElBQUksQ0FBQztJQUNoQixXQUFXLEVBQUUsSUFBSSxHQUFHLFNBQVMsQ0FBQztDQUMvQixDQUFDLENBQ0gsQ0F3QkE7QUFFRDs7R0FFRztBQUNILHdCQUFnQiwyQkFBMkIsQ0FBQyxXQUFXLEVBQUUsS0FBSyxNQUFNLEVBQUUsRUFBRSxHQUFHLE1BQU0sRUFBRSxDQUtsRjtBQUVEOztHQUVHO0FBQ0gsd0JBQWdCLHNDQUFzQyxDQUFDLG1CQUFtQixFQUFFLEtBQUssTUFBTSxFQUFFLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFDbEcsUUFBUSxFQUFFLFVBQVUsQ0FBQztJQUNyQixVQUFVLEVBQUUsVUFBVSxDQUFDO0lBQ3ZCLFVBQVUsRUFBRSxLQUFLLE1BQU0sRUFBRSxDQUFDO0lBQzFCLGNBQWMsRUFBRSxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUM7Q0FDckMsQ0FBQyxDQVVEO0FBRUQ7OztHQUdHO0FBQ0gsd0JBQWdCLDZCQUE2QixDQUMzQyxpQkFBaUIsRUFBRSxLQUFLLENBQUM7SUFDdkIsZ0JBQWdCLEVBQUUsTUFBTSxDQUFDO0lBQ3pCLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFDZixXQUFXLEVBQUUsSUFBSSxHQUFHLFNBQVMsQ0FBQztDQUMvQixDQUFDLEVBQ0YsTUFBTSxDQUFDLEVBQUUsTUFBTSxHQUNkLEdBQUcsQ0FBQyxNQUFNLEVBQUUsT0FBTyxpQkFBaUIsQ0FBQyxDQW1CdkMifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ha_setup.d.ts","sourceRoot":"","sources":["../../src/fixtures/ha_setup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAEvD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAG1B;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,gCAAgC;IAChC,WAAW,EAAE,MAAM,CAAC;IACpB,kCAAkC;IAClC,MAAM,EAAE,MAAM,CAAC;IACf,wBAAwB;IACxB,gBAAgB,EAAE,OAAO,CAAC;IAC1B,6BAA6B;IAC7B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,4BAA4B;IAC5B,gBAAgB,EAAE,MAAM,CAAC;IACzB,iCAAiC;IACjC,mBAAmB,EAAE,MAAM,CAAC;CAC7B;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,MAAM,GAAG,gBAAgB,CAWvE;AAED;;;;;GAKG;AACH,wBAAgB,eAAe,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAa1E;AAED;;;GAGG;AACH,wBAAsB,iBAAiB,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAYlF;AAED;;GAEG;AACH,wBAAsB,kBAAkB,CACtC,IAAI,EAAE,IAAI,EACV,IAAI,EAAE,MAAM,EACZ,QAAQ,CAAC,EAAE,aAAa,GAAG,gBAAgB,GAAG,iBAAiB,GAAG,eAAe,GAChF,OAAO,CACR,KAAK,CAAC;IACJ,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,gBAAgB,EAAE,MAAM,CAAC;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,IAAI,CAAC;IAChB,WAAW,EAAE,IAAI,GAAG,SAAS,CAAC;CAC/B,CAAC,CACH,CAwBA;AAED;;GAEG;AACH,wBAAgB,2BAA2B,CAAC,WAAW,EAAE,KAAK,MAAM,EAAE,EAAE,GAAG,MAAM,EAAE,CAKlF;AAED;;GAEG;AACH,wBAAgB,sCAAsC,CAAC,mBAAmB,EAAE,KAAK,MAAM,EAAE,EAAE,GAAG,KAAK,CAAC;IAClG,QAAQ,EAAE,UAAU,CAAC;IACrB,UAAU,EAAE,UAAU,CAAC;IACvB,UAAU,EAAE,KAAK,MAAM,EAAE,CAAC;IAC1B,cAAc,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;CACrC,CAAC,CAUD;AAED;;;GAGG;AACH,wBAAgB,6BAA6B,CAC3C,iBAAiB,EAAE,KAAK,CAAC;IACvB,gBAAgB,EAAE,MAAM,CAAC;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,IAAI,GAAG,SAAS,CAAC;CAC/B,CAAC,EACF,MAAM,CAAC,EAAE,MAAM,GACd,GAAG,CAAC,MAAM,EAAE,OAAO,iBAAiB,CAAC,CAmBvC"}
@@ -0,0 +1,114 @@
1
+ import { EthAddress } from '@aztec/aztec.js/addresses';
2
+ import { Fr } from '@aztec/aztec.js/fields';
3
+ import { SecretValue } from '@aztec/foundation/config';
4
+ import { Pool } from 'pg';
5
+ import { privateKeyToAccount } from 'viem/accounts';
6
+ /**
7
+ * Get database configuration from environment variables
8
+ */ export function createHADatabaseConfig(nodeId) {
9
+ const databaseUrl = process.env.DATABASE_URL || 'postgresql://aztec:aztec@localhost:5432/aztec_ha_test';
10
+ return {
11
+ databaseUrl,
12
+ nodeId,
13
+ haSigningEnabled: true,
14
+ pollingIntervalMs: 100,
15
+ signingTimeoutMs: 3000,
16
+ maxStuckDutiesAgeMs: 72000
17
+ };
18
+ }
19
+ /**
20
+ * Setup PostgreSQL database connection pool for HA tests
21
+ *
22
+ * Note: Database migrations should be run separately before starting tests,
23
+ * either via docker-compose entrypoint or manually with: aztec migrate-ha-db up
24
+ */ export function setupHADatabase(databaseUrl, logger) {
25
+ try {
26
+ // Create connection pool for test usage
27
+ // Migrations are already run by docker-compose entrypoint before tests start
28
+ const pool = new Pool({
29
+ connectionString: databaseUrl
30
+ });
31
+ logger?.info('Connected to HA database (migrations should already be applied)');
32
+ return pool;
33
+ } catch (error) {
34
+ logger?.error(`Failed to connect to HA database: ${error}`);
35
+ throw error;
36
+ }
37
+ }
38
+ /**
39
+ * Clean up HA database - drop all tables
40
+ * Use this between tests to ensure clean state
41
+ */ export async function cleanupHADatabase(pool, logger) {
42
+ try {
43
+ // Drop all HA tables
44
+ await pool.query('DROP TABLE IF EXISTS validator_duties CASCADE');
45
+ await pool.query('DROP TABLE IF EXISTS slashing_protection CASCADE');
46
+ await pool.query('DROP TABLE IF EXISTS schema_version CASCADE');
47
+ logger?.info('HA database cleaned up successfully');
48
+ } catch (error) {
49
+ logger?.error(`Failed to cleanup HA database: ${error}`);
50
+ throw error;
51
+ }
52
+ }
53
+ /**
54
+ * Query validator duties from the database
55
+ */ export async function getValidatorDuties(pool, slot, dutyType) {
56
+ const query = dutyType ? 'SELECT slot, duty_type, validator_address, node_id, started_at, completed_at FROM validator_duties WHERE slot = $1 AND duty_type = $2 ORDER BY started_at' : 'SELECT slot, duty_type, validator_address, node_id, started_at, completed_at FROM validator_duties WHERE slot = $1 ORDER BY started_at';
57
+ const params = dutyType ? [
58
+ slot.toString(),
59
+ dutyType
60
+ ] : [
61
+ slot.toString()
62
+ ];
63
+ const result = await pool.query(query, params);
64
+ return result.rows.map((row)=>({
65
+ slot: row.slot,
66
+ dutyType: row.duty_type,
67
+ validatorAddress: row.validator_address,
68
+ nodeId: row.node_id,
69
+ startedAt: row.started_at,
70
+ completedAt: row.completed_at
71
+ }));
72
+ }
73
+ /**
74
+ * Convert private keys to Ethereum addresses
75
+ */ export function getAddressesFromPrivateKeys(privateKeys) {
76
+ return privateKeys.map((pk)=>{
77
+ const account = privateKeyToAccount(pk);
78
+ return account.address;
79
+ });
80
+ }
81
+ /**
82
+ * Create initial validators from private keys for L1 contract deployment
83
+ */ export function createInitialValidatorsFromPrivateKeys(attesterPrivateKeys) {
84
+ return attesterPrivateKeys.map((pk)=>{
85
+ const account = privateKeyToAccount(pk);
86
+ return {
87
+ attester: EthAddress.fromString(account.address),
88
+ withdrawer: EthAddress.fromString(account.address),
89
+ privateKey: pk,
90
+ bn254SecretKey: new SecretValue(Fr.random().toBigInt())
91
+ };
92
+ });
93
+ }
94
+ /**
95
+ * Verify no duplicate attestations per validator (HA coordination check)
96
+ * Groups duties by validator address and verifies each validator attested exactly once
97
+ */ export function verifyNoDuplicateAttestations(attestationDuties, logger) {
98
+ const dutiesByValidator = new Map();
99
+ for (const duty of attestationDuties){
100
+ const existing = dutiesByValidator.get(duty.validatorAddress) || [];
101
+ existing.push(duty);
102
+ dutiesByValidator.set(duty.validatorAddress, existing);
103
+ }
104
+ for (const [validatorAddress, validatorDuties] of dutiesByValidator.entries()){
105
+ if (validatorDuties.length !== 1) {
106
+ throw new Error(`Validator ${validatorAddress} attested ${validatorDuties.length} times (expected exactly once)`);
107
+ }
108
+ if (!validatorDuties[0].completedAt) {
109
+ throw new Error(`Validator ${validatorAddress} attestation duty not completed`);
110
+ }
111
+ logger?.info(`Validator ${validatorAddress} attested once via node ${validatorDuties[0].nodeId}`);
112
+ }
113
+ return dutiesByValidator;
114
+ }
@@ -1,6 +1,7 @@
1
1
  export * from './fixtures.js';
2
+ export * from './ha_setup.js';
2
3
  export * from './logging.js';
3
4
  export * from './utils.js';
4
5
  export * from './token_utils.js';
5
6
  export * from './with_telemetry_utils.js';
6
- //# sourceMappingURL=index.d.ts.map
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9maXh0dXJlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsMkJBQTJCLENBQUMifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/fixtures/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,kBAAkB,CAAC;AACjC,cAAc,2BAA2B,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/fixtures/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,kBAAkB,CAAC;AACjC,cAAc,2BAA2B,CAAC"}
@@ -1,4 +1,5 @@
1
1
  export * from './fixtures.js';
2
+ export * from './ha_setup.js';
2
3
  export * from './logging.js';
3
4
  export * from './utils.js';
4
5
  export * from './token_utils.js';
@@ -1,13 +1,17 @@
1
- import type { L1ContractAddresses, ViemPublicClient, ViemWalletClient } from '@aztec/ethereum';
2
- import { Fr } from '@aztec/foundation/fields';
1
+ import type { L1ContractAddresses } from '@aztec/ethereum/l1-contract-addresses';
2
+ import type { ExtendedViemWalletClient } from '@aztec/ethereum/types';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
4
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
4
5
  export declare function sendL1ToL2Message(message: {
5
6
  recipient: AztecAddress;
6
7
  content: Fr;
7
8
  secretHash: Fr;
8
9
  }, ctx: {
9
- walletClient: ViemWalletClient;
10
- publicClient: ViemPublicClient;
11
- l1ContractAddresses: Pick<L1ContractAddresses, 'inboxAddress'>;
12
- }): Promise<Fr[]>;
13
- //# sourceMappingURL=l1_to_l2_messaging.d.ts.map
10
+ l1Client: ExtendedViemWalletClient;
11
+ l1ContractAddresses: Pick<L1ContractAddresses, 'inboxAddress' | 'rollupAddress'>;
12
+ }): Promise<{
13
+ msgHash: Fr;
14
+ globalLeafIndex: Fr;
15
+ txReceipt: import("viem").TransactionReceipt;
16
+ }>;
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibDFfdG9fbDJfbWVzc2FnaW5nLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZml4dHVyZXMvbDFfdG9fbDJfbWVzc2FnaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sS0FBSyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDakYsT0FBTyxLQUFLLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFHcEQsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFNaEUsd0JBQXNCLGlCQUFpQixDQUNyQyxPQUFPLEVBQUU7SUFBRSxTQUFTLEVBQUUsWUFBWSxDQUFDO0lBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQztJQUFDLFVBQVUsRUFBRSxFQUFFLENBQUE7Q0FBRSxFQUNqRSxHQUFHLEVBQUU7SUFDSCxRQUFRLEVBQUUsd0JBQXdCLENBQUM7SUFDbkMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLG1CQUFtQixFQUFFLGNBQWMsR0FBRyxlQUFlLENBQUMsQ0FBQztDQUNsRjs7OztHQWdFRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"l1_to_l2_messaging.d.ts","sourceRoot":"","sources":["../../src/fixtures/l1_to_l2_messaging.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC/F,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAE9C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAKhE,wBAAsB,iBAAiB,CACrC,OAAO,EAAE;IAAE,SAAS,EAAE,YAAY,CAAC;IAAC,OAAO,EAAE,EAAE,CAAC;IAAC,UAAU,EAAE,EAAE,CAAA;CAAE,EACjE,GAAG,EAAE;IACH,YAAY,EAAE,gBAAgB,CAAC;IAC/B,YAAY,EAAE,gBAAgB,CAAC;IAC/B,mBAAmB,EAAE,IAAI,CAAC,mBAAmB,EAAE,cAAc,CAAC,CAAC;CAChE,iBAmCF"}
1
+ {"version":3,"file":"l1_to_l2_messaging.d.ts","sourceRoot":"","sources":["../../src/fixtures/l1_to_l2_messaging.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AACjF,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AAGpD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAMhE,wBAAsB,iBAAiB,CACrC,OAAO,EAAE;IAAE,SAAS,EAAE,YAAY,CAAC;IAAC,OAAO,EAAE,EAAE,CAAC;IAAC,UAAU,EAAE,EAAE,CAAA;CAAE,EACjE,GAAG,EAAE;IACH,QAAQ,EAAE,wBAAwB,CAAC;IACnC,mBAAmB,EAAE,IAAI,CAAC,mBAAmB,EAAE,cAAc,GAAG,eAAe,CAAC,CAAC;CAClF;;;;GAgEF"}
@@ -1,15 +1,18 @@
1
- import { Fr } from '@aztec/foundation/fields';
1
+ import { RollupContract } from '@aztec/ethereum/contracts';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import { tryJsonStringify } from '@aztec/foundation/json-rpc';
2
4
  import { InboxAbi } from '@aztec/l1-artifacts';
3
- import { expect } from '@jest/globals';
4
5
  import { decodeEventLog, getContract } from 'viem';
6
+ import { getLogger } from './utils.js';
5
7
  export async function sendL1ToL2Message(message, ctx) {
8
+ const logger = getLogger();
6
9
  const inbox = getContract({
7
10
  address: ctx.l1ContractAddresses.inboxAddress.toString(),
8
11
  abi: InboxAbi,
9
- client: ctx.walletClient
12
+ client: ctx.l1Client
10
13
  });
11
14
  const { recipient, content, secretHash } = message;
12
- const version = 1;
15
+ const version = await new RollupContract(ctx.l1Client, ctx.l1ContractAddresses.rollupAddress.toString()).getVersion();
13
16
  // We inject the message to Inbox
14
17
  const txHash = await inbox.write.sendL2Message([
15
18
  {
@@ -18,24 +21,47 @@ export async function sendL1ToL2Message(message, ctx) {
18
21
  },
19
22
  content.toString(),
20
23
  secretHash.toString()
21
- ]);
24
+ ], {
25
+ gas: 1_000_000n
26
+ });
27
+ logger.info(`L1 to L2 message sent in tx ${txHash}`);
22
28
  // We check that the message was correctly injected by checking the emitted event
23
- const txReceipt = await ctx.publicClient.waitForTransactionReceipt({
29
+ const txReceipt = await ctx.l1Client.waitForTransactionReceipt({
24
30
  hash: txHash
25
31
  });
26
- // Exactly 1 event should be emitted in the transaction
27
- expect(txReceipt.logs.length).toBe(1);
28
- // We decode the event and get leaf out of it
29
- const messageSentLog = txReceipt.logs[0];
30
- const topics = decodeEventLog({
31
- abi: InboxAbi,
32
- data: messageSentLog.data,
33
- topics: messageSentLog.topics
34
- });
32
+ if (txReceipt.status !== 'success') {
33
+ throw new Error(`L1 to L2 message failed to be sent in tx ${txHash}. Status: ${txReceipt.status}`);
34
+ }
35
+ logger.info(`L1 to L2 message receipt retrieved for tx ${txReceipt.transactionHash}`, txReceipt);
36
+ if (txReceipt.transactionHash !== txHash) {
37
+ throw new Error(`Receipt transaction hash mismatch: ${txReceipt.transactionHash} !== ${txHash}`);
38
+ }
39
+ // Filter for MessageSent events from the Inbox contract by trying to decode each log
40
+ const messageSentLogs = txReceipt.logs.filter((log)=>log.address.toLowerCase() === ctx.l1ContractAddresses.inboxAddress.toString().toLowerCase()).map((log)=>{
41
+ try {
42
+ const decoded = decodeEventLog({
43
+ abi: InboxAbi,
44
+ data: log.data,
45
+ topics: log.topics
46
+ });
47
+ return {
48
+ log,
49
+ decoded
50
+ };
51
+ } catch {
52
+ return null; // Not a decodable event from this ABI
53
+ }
54
+ }).filter((item)=>item !== null && item.decoded.eventName === 'MessageSent');
55
+ if (messageSentLogs.length !== 1) {
56
+ throw new Error(`Wrong number of MessageSent logs found in ${txHash} transaction (got ${messageSentLogs.length} expected 1)\n${tryJsonStringify(messageSentLogs.map((item)=>item.log))}`);
57
+ }
58
+ // We already have the decoded event
59
+ const topics = messageSentLogs[0].decoded;
35
60
  const receivedMsgHash = topics.args.hash;
36
61
  const receivedGlobalLeafIndex = topics.args.index;
37
- return [
38
- Fr.fromHexString(receivedMsgHash),
39
- new Fr(receivedGlobalLeafIndex)
40
- ];
62
+ return {
63
+ msgHash: Fr.fromHexString(receivedMsgHash),
64
+ globalLeafIndex: new Fr(receivedGlobalLeafIndex),
65
+ txReceipt
66
+ };
41
67
  }
@@ -5,4 +5,4 @@ export declare function isMetricsLoggingRequested(): boolean;
5
5
  * Idempotent and automatically called by `setup` if CI or BENCHMARK env vars are set.
6
6
  */
7
7
  export declare function setupMetricsLogger(filename: string): void;
8
- //# sourceMappingURL=logging.d.ts.map
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZpeHR1cmVzL2xvZ2dpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0Esd0dBQXdHO0FBQ3hHLHdCQUFnQix5QkFBeUIsWUFFeEM7QUFFRDs7O0dBR0c7QUFDSCx3QkFBZ0Isa0JBQWtCLENBQUMsUUFBUSxFQUFFLE1BQU0sUUFPbEQifQ==