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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (274) hide show
  1. package/dest/bench/client_flows/benchmark.d.ts +3 -2
  2. package/dest/bench/client_flows/benchmark.d.ts.map +1 -1
  3. package/dest/bench/client_flows/benchmark.js +21 -1
  4. package/dest/bench/client_flows/client_flows_benchmark.d.ts +22 -16
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  6. package/dest/bench/client_flows/client_flows_benchmark.js +142 -124
  7. package/dest/bench/client_flows/config.d.ts +2 -2
  8. package/dest/bench/client_flows/config.d.ts.map +1 -1
  9. package/dest/bench/client_flows/config.js +18 -0
  10. package/dest/bench/client_flows/data_extractor.d.ts +1 -1
  11. package/dest/bench/client_flows/data_extractor.js +7 -27
  12. package/dest/bench/utils.d.ts +8 -7
  13. package/dest/bench/utils.d.ts.map +1 -1
  14. package/dest/bench/utils.js +31 -19
  15. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +9 -8
  16. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  17. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +107 -113
  18. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +20 -14
  19. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  20. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +92 -70
  21. package/dest/e2e_deploy_contract/deploy_test.d.ts +6 -5
  22. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  23. package/dest/e2e_deploy_contract/deploy_test.js +18 -13
  24. package/dest/e2e_epochs/epochs_test.d.ts +27 -15
  25. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  26. package/dest/e2e_epochs/epochs_test.js +107 -54
  27. package/dest/e2e_fees/bridging_race.notest.d.ts +1 -1
  28. package/dest/e2e_fees/bridging_race.notest.js +5 -7
  29. package/dest/e2e_fees/fees_test.d.ts +21 -17
  30. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  31. package/dest/e2e_fees/fees_test.js +138 -143
  32. package/dest/e2e_l1_publisher/write_json.d.ts +4 -3
  33. package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
  34. package/dest/e2e_l1_publisher/write_json.js +18 -19
  35. package/dest/e2e_multi_validator/utils.d.ts +1 -1
  36. package/dest/e2e_multi_validator/utils.js +1 -1
  37. package/dest/e2e_nested_contract/nested_contract_test.d.ts +6 -9
  38. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  39. package/dest/e2e_nested_contract/nested_contract_test.js +30 -39
  40. package/dest/e2e_p2p/inactivity_slash_test.d.ts +3 -3
  41. package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -1
  42. package/dest/e2e_p2p/inactivity_slash_test.js +7 -6
  43. package/dest/e2e_p2p/p2p_network.d.ts +229 -21
  44. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  45. package/dest/e2e_p2p/p2p_network.js +142 -114
  46. package/dest/e2e_p2p/reqresp/utils.d.ts +22 -0
  47. package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -0
  48. package/dest/e2e_p2p/reqresp/utils.js +190 -0
  49. package/dest/e2e_p2p/shared.d.ts +31 -11
  50. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  51. package/dest/e2e_p2p/shared.js +51 -22
  52. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
  53. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
  54. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
  55. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
  56. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
  57. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
  58. package/dest/e2e_token_contract/token_contract_test.d.ts +19 -10
  59. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  60. package/dest/e2e_token_contract/token_contract_test.js +100 -92
  61. package/dest/fixtures/authwit_proxy.d.ts +15 -0
  62. package/dest/fixtures/authwit_proxy.d.ts.map +1 -0
  63. package/dest/fixtures/authwit_proxy.js +30 -0
  64. package/dest/fixtures/e2e_prover_test.d.ts +15 -21
  65. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  66. package/dest/fixtures/e2e_prover_test.js +123 -138
  67. package/dest/fixtures/elu_monitor.d.ts +21 -0
  68. package/dest/fixtures/elu_monitor.d.ts.map +1 -0
  69. package/dest/fixtures/elu_monitor.js +102 -0
  70. package/dest/fixtures/fixtures.d.ts +6 -3
  71. package/dest/fixtures/fixtures.d.ts.map +1 -1
  72. package/dest/fixtures/fixtures.js +8 -3
  73. package/dest/fixtures/get_acvm_config.d.ts +1 -1
  74. package/dest/fixtures/get_acvm_config.js +1 -1
  75. package/dest/fixtures/get_bb_config.d.ts +1 -1
  76. package/dest/fixtures/get_bb_config.d.ts.map +1 -1
  77. package/dest/fixtures/ha_setup.d.ts +71 -0
  78. package/dest/fixtures/ha_setup.d.ts.map +1 -0
  79. package/dest/fixtures/ha_setup.js +116 -0
  80. package/dest/fixtures/index.d.ts +2 -1
  81. package/dest/fixtures/index.d.ts.map +1 -1
  82. package/dest/fixtures/index.js +1 -0
  83. package/dest/fixtures/l1_to_l2_messaging.d.ts +4 -3
  84. package/dest/fixtures/l1_to_l2_messaging.d.ts.map +1 -1
  85. package/dest/fixtures/l1_to_l2_messaging.js +2 -2
  86. package/dest/fixtures/logging.d.ts +1 -1
  87. package/dest/fixtures/setup.d.ts +239 -0
  88. package/dest/fixtures/setup.d.ts.map +1 -0
  89. package/dest/fixtures/setup.js +606 -0
  90. package/dest/fixtures/setup_p2p_test.d.ts +17 -10
  91. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  92. package/dest/fixtures/setup_p2p_test.js +55 -36
  93. package/dest/fixtures/token_utils.d.ts +6 -3
  94. package/dest/fixtures/token_utils.d.ts.map +1 -1
  95. package/dest/fixtures/token_utils.js +17 -10
  96. package/dest/fixtures/utils.d.ts +5 -192
  97. package/dest/fixtures/utils.d.ts.map +1 -1
  98. package/dest/fixtures/utils.js +4 -648
  99. package/dest/fixtures/web3signer.d.ts +1 -1
  100. package/dest/fixtures/web3signer.js +1 -1
  101. package/dest/fixtures/with_telemetry_utils.d.ts +2 -2
  102. package/dest/fixtures/with_telemetry_utils.d.ts.map +1 -1
  103. package/dest/fixtures/with_telemetry_utils.js +2 -2
  104. package/dest/index.d.ts +1 -1
  105. package/dest/quality_of_service/grafana_client.d.ts +41 -0
  106. package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
  107. package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
  108. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  109. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  110. package/dest/quality_of_service/prometheus_client.js +67 -0
  111. package/dest/shared/cross_chain_test_harness.d.ts +7 -6
  112. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  113. package/dest/shared/cross_chain_test_harness.js +27 -27
  114. package/dest/shared/gas_portal_test_harness.d.ts +2 -2
  115. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  116. package/dest/shared/gas_portal_test_harness.js +4 -4
  117. package/dest/shared/index.d.ts +3 -2
  118. package/dest/shared/index.d.ts.map +1 -1
  119. package/dest/shared/index.js +1 -0
  120. package/dest/shared/jest_setup.d.ts +1 -1
  121. package/dest/shared/jest_setup.js +41 -1
  122. package/dest/shared/mock_state_view.d.ts +86 -0
  123. package/dest/shared/mock_state_view.d.ts.map +1 -0
  124. package/dest/shared/mock_state_view.js +186 -0
  125. package/dest/shared/submit-transactions.d.ts +4 -4
  126. package/dest/shared/submit-transactions.d.ts.map +1 -1
  127. package/dest/shared/submit-transactions.js +9 -11
  128. package/dest/shared/uniswap_l1_l2.d.ts +3 -27
  129. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  130. package/dest/shared/uniswap_l1_l2.js +58 -39
  131. package/dest/simulators/index.d.ts +1 -1
  132. package/dest/simulators/lending_simulator.d.ts +2 -2
  133. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  134. package/dest/simulators/lending_simulator.js +8 -6
  135. package/dest/simulators/token_simulator.d.ts +1 -1
  136. package/dest/simulators/token_simulator.d.ts.map +1 -1
  137. package/dest/simulators/token_simulator.js +3 -24
  138. package/dest/spartan/setup_test_wallets.d.ts +18 -6
  139. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  140. package/dest/spartan/setup_test_wallets.js +129 -24
  141. package/dest/spartan/tx_metrics.d.ts +88 -0
  142. package/dest/spartan/tx_metrics.d.ts.map +1 -0
  143. package/dest/spartan/tx_metrics.js +422 -0
  144. package/dest/spartan/utils/bot.d.ts +28 -0
  145. package/dest/spartan/utils/bot.d.ts.map +1 -0
  146. package/dest/spartan/utils/bot.js +142 -0
  147. package/dest/spartan/utils/chaos.d.ts +79 -0
  148. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  149. package/dest/spartan/utils/chaos.js +142 -0
  150. package/dest/spartan/utils/clients.d.ts +39 -0
  151. package/dest/spartan/utils/clients.d.ts.map +1 -0
  152. package/dest/spartan/utils/clients.js +90 -0
  153. package/dest/spartan/utils/config.d.ts +45 -0
  154. package/dest/spartan/utils/config.d.ts.map +1 -0
  155. package/dest/spartan/utils/config.js +23 -0
  156. package/dest/spartan/utils/health.d.ts +63 -0
  157. package/dest/spartan/utils/health.d.ts.map +1 -0
  158. package/dest/spartan/utils/health.js +202 -0
  159. package/dest/spartan/utils/helm.d.ts +15 -0
  160. package/dest/spartan/utils/helm.d.ts.map +1 -0
  161. package/dest/spartan/utils/helm.js +47 -0
  162. package/dest/spartan/utils/index.d.ts +11 -0
  163. package/dest/spartan/utils/index.d.ts.map +1 -0
  164. package/dest/spartan/utils/index.js +22 -0
  165. package/dest/spartan/utils/k8s.d.ts +128 -0
  166. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  167. package/dest/spartan/utils/k8s.js +381 -0
  168. package/dest/spartan/utils/nodes.d.ts +40 -0
  169. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  170. package/dest/spartan/utils/nodes.js +461 -0
  171. package/dest/spartan/utils/pod_logs.d.ts +25 -0
  172. package/dest/spartan/utils/pod_logs.d.ts.map +1 -0
  173. package/dest/spartan/utils/pod_logs.js +74 -0
  174. package/dest/spartan/utils/scripts.d.ts +30 -0
  175. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  176. package/dest/spartan/utils/scripts.js +81 -0
  177. package/dest/spartan/utils.d.ts +2 -218
  178. package/dest/spartan/utils.d.ts.map +1 -1
  179. package/dest/spartan/utils.js +1 -749
  180. package/dest/test-wallet/test_wallet.d.ts +76 -0
  181. package/dest/test-wallet/test_wallet.d.ts.map +1 -0
  182. package/dest/test-wallet/test_wallet.js +214 -0
  183. package/dest/test-wallet/utils.d.ts +41 -0
  184. package/dest/test-wallet/utils.d.ts.map +1 -0
  185. package/dest/test-wallet/utils.js +71 -0
  186. package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
  187. package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
  188. package/dest/test-wallet/wallet_worker_script.js +48 -0
  189. package/dest/test-wallet/worker_wallet.d.ts +52 -0
  190. package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
  191. package/dest/test-wallet/worker_wallet.js +151 -0
  192. package/dest/test-wallet/worker_wallet_schema.d.ts +274 -0
  193. package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
  194. package/dest/test-wallet/worker_wallet_schema.js +10 -0
  195. package/package.json +49 -44
  196. package/src/bench/client_flows/benchmark.ts +24 -2
  197. package/src/bench/client_flows/client_flows_benchmark.ts +163 -177
  198. package/src/bench/client_flows/config.ts +9 -1
  199. package/src/bench/client_flows/data_extractor.ts +6 -28
  200. package/src/bench/utils.ts +36 -21
  201. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +120 -145
  202. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +140 -125
  203. package/src/e2e_deploy_contract/deploy_test.ts +23 -16
  204. package/src/e2e_epochs/epochs_test.ts +176 -114
  205. package/src/e2e_fees/bridging_race.notest.ts +6 -12
  206. package/src/e2e_fees/fees_test.ts +179 -226
  207. package/src/e2e_l1_publisher/write_json.ts +20 -19
  208. package/src/e2e_multi_validator/utils.ts +1 -1
  209. package/src/e2e_nested_contract/nested_contract_test.ts +35 -55
  210. package/src/e2e_p2p/inactivity_slash_test.ts +8 -7
  211. package/src/e2e_p2p/p2p_network.ts +205 -178
  212. package/src/e2e_p2p/reqresp/utils.ts +256 -0
  213. package/src/e2e_p2p/shared.ts +90 -29
  214. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  215. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  216. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  217. package/src/e2e_token_contract/token_contract_test.ts +121 -119
  218. package/src/fixtures/authwit_proxy.ts +50 -0
  219. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  220. package/src/fixtures/e2e_prover_test.ts +144 -186
  221. package/src/fixtures/elu_monitor.ts +126 -0
  222. package/src/fixtures/fixtures.ts +12 -5
  223. package/src/fixtures/get_acvm_config.ts +1 -1
  224. package/src/fixtures/ha_setup.ts +186 -0
  225. package/src/fixtures/index.ts +1 -0
  226. package/src/fixtures/l1_to_l2_messaging.ts +4 -2
  227. package/src/fixtures/setup.ts +903 -0
  228. package/src/fixtures/setup_p2p_test.ts +58 -48
  229. package/src/fixtures/token_utils.ts +12 -8
  230. package/src/fixtures/utils.ts +27 -947
  231. package/src/fixtures/web3signer.ts +1 -1
  232. package/src/fixtures/with_telemetry_utils.ts +2 -2
  233. package/src/guides/up_quick_start.sh +4 -4
  234. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +1 -1
  235. package/src/quality_of_service/prometheus_client.ts +113 -0
  236. package/src/shared/cross_chain_test_harness.ts +30 -43
  237. package/src/shared/gas_portal_test_harness.ts +4 -4
  238. package/src/shared/index.ts +2 -1
  239. package/src/shared/jest_setup.ts +51 -1
  240. package/src/shared/mock_state_view.ts +188 -0
  241. package/src/shared/submit-transactions.ts +11 -16
  242. package/src/shared/uniswap_l1_l2.ts +86 -102
  243. package/src/simulators/lending_simulator.ts +11 -7
  244. package/src/simulators/token_simulator.ts +6 -30
  245. package/src/spartan/DEVELOP.md +7 -0
  246. package/src/spartan/setup_test_wallets.ts +205 -29
  247. package/src/spartan/tx_metrics.ts +376 -0
  248. package/src/spartan/utils/bot.ts +188 -0
  249. package/src/spartan/utils/chaos.ts +253 -0
  250. package/src/spartan/utils/clients.ts +100 -0
  251. package/src/spartan/utils/config.ts +29 -0
  252. package/src/spartan/utils/health.ts +255 -0
  253. package/src/spartan/utils/helm.ts +84 -0
  254. package/src/spartan/utils/index.ts +71 -0
  255. package/src/spartan/utils/k8s.ts +535 -0
  256. package/src/spartan/utils/nodes.ts +543 -0
  257. package/src/spartan/utils/pod_logs.ts +99 -0
  258. package/src/spartan/utils/scripts.ts +99 -0
  259. package/src/spartan/utils.ts +1 -942
  260. package/src/test-wallet/test_wallet.ts +294 -0
  261. package/src/test-wallet/utils.ts +112 -0
  262. package/src/test-wallet/wallet_worker_script.ts +60 -0
  263. package/src/test-wallet/worker_wallet.ts +213 -0
  264. package/src/test-wallet/worker_wallet_schema.ts +13 -0
  265. package/dest/fixtures/setup_l1_contracts.d.ts +0 -6
  266. package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
  267. package/dest/fixtures/setup_l1_contracts.js +0 -17
  268. package/dest/fixtures/snapshot_manager.d.ts +0 -95
  269. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  270. package/dest/fixtures/snapshot_manager.js +0 -505
  271. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  272. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  273. package/src/fixtures/setup_l1_contracts.ts +0 -26
  274. package/src/fixtures/snapshot_manager.ts +0 -665
@@ -1,9 +1,12 @@
1
1
  import type { AztecAddress } from '@aztec/aztec.js/addresses';
2
2
  import { type Logger, createLogger } from '@aztec/aztec.js/log';
3
3
  import type { AztecNode } from '@aztec/aztec.js/node';
4
- import { CheatCodes } from '@aztec/aztec/testing';
5
- import { type DeployL1ContractsArgs, RollupContract, createExtendedL1Client } from '@aztec/ethereum';
4
+ import { CheatCodes, getTokenAllowedSetupFunctions } from '@aztec/aztec/testing';
5
+ import { createExtendedL1Client } from '@aztec/ethereum/client';
6
+ import { RollupContract } from '@aztec/ethereum/contracts';
7
+ import type { DeployAztecL1ContractsArgs } from '@aztec/ethereum/deploy-aztec-l1-contracts';
6
8
  import { ChainMonitor } from '@aztec/ethereum/test';
9
+ import { BlockNumber } from '@aztec/foundation/branded-types';
7
10
  import { EthAddress } from '@aztec/foundation/eth-address';
8
11
  import { sleep } from '@aztec/foundation/sleep';
9
12
  import { TestERC20Abi } from '@aztec/l1-artifacts';
@@ -16,31 +19,26 @@ import { CounterContract } from '@aztec/noir-test-contracts.js/Counter';
16
19
  import { ProtocolContractAddress } from '@aztec/protocol-contracts';
17
20
  import { getCanonicalFeeJuice } from '@aztec/protocol-contracts/fee-juice';
18
21
  import { GasSettings } from '@aztec/stdlib/gas';
19
- import { TestWallet } from '@aztec/test-wallet/server';
22
+ import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
20
23
 
21
24
  import { getContract } from 'viem';
22
25
 
23
26
  import { MNEMONIC } from '../fixtures/fixtures.js';
24
27
  import {
25
- type ISnapshotManager,
26
- type SubsystemsContext,
27
- createSnapshotManager,
28
+ type EndToEndContext,
29
+ type SetupOptions,
28
30
  deployAccounts,
29
- } from '../fixtures/snapshot_manager.js';
31
+ publicDeployAccounts,
32
+ setup,
33
+ teardown,
34
+ } from '../fixtures/setup.js';
30
35
  import { mintTokensToPrivate } from '../fixtures/token_utils.js';
31
- import {
32
- type BalancesFn,
33
- type SetupOptions,
34
- ensureAccountContractsPublished,
35
- getBalancesFn,
36
- setupSponsoredFPC,
37
- } from '../fixtures/utils.js';
36
+ import { type BalancesFn, getBalancesFn, setupSponsoredFPC } from '../fixtures/utils.js';
38
37
  import { FeeJuicePortalTestingHarnessFactory, type GasBridgingTestHarness } from '../shared/gas_portal_test_harness.js';
39
-
40
- const { E2E_DATA_PATH: dataPath } = process.env;
38
+ import { TestWallet } from '../test-wallet/test_wallet.js';
41
39
 
42
40
  /**
43
- * Test fixture for testing fees. Provides the following snapshots:
41
+ * Test fixture for testing fees. Provides the following setup steps:
44
42
  * InitialAccounts: Initializes 3 Schnorr account contracts.
45
43
  * PublicDeployAccounts: Deploys the accounts publicly.
46
44
  * DeployFeeJuice: Deploys the Fee Juice contract.
@@ -50,11 +48,12 @@ const { E2E_DATA_PATH: dataPath } = process.env;
50
48
  * SetupSubscription: Deploys a counter contract and a subscription contract, and mints Fee Juice to the subscription contract.
51
49
  */
52
50
  export class FeesTest {
53
- private snapshotManager: ISnapshotManager;
54
51
  private accounts: AztecAddress[] = [];
52
+ public context!: EndToEndContext;
55
53
 
56
54
  public logger: Logger;
57
55
  public aztecNode!: AztecNode;
56
+ public aztecNodeAdmin!: AztecNodeAdmin;
58
57
  public cheatCodes!: CheatCodes;
59
58
 
60
59
  public wallet!: TestWallet;
@@ -77,7 +76,6 @@ export class FeesTest {
77
76
  public subscriptionContract!: AppSubscriptionContract;
78
77
  public feeJuiceBridgeTestHarness!: GasBridgingTestHarness;
79
78
 
80
- public context!: SubsystemsContext;
81
79
  public chainMonitor!: ChainMonitor;
82
80
 
83
81
  public getCoinbaseBalance!: () => Promise<bigint>;
@@ -85,7 +83,7 @@ export class FeesTest {
85
83
  public getGasBalanceFn!: BalancesFn;
86
84
  public getBananaPublicBalanceFn!: BalancesFn;
87
85
  public getBananaPrivateBalanceFn!: BalancesFn;
88
- public getProverFee!: (blockNumber: number) => Promise<bigint>;
86
+ public getProverFee!: (blockNumber: BlockNumber) => Promise<bigint>;
89
87
 
90
88
  public readonly ALICE_INITIAL_BANANAS = BigInt(1e22);
91
89
  public readonly SUBSCRIPTION_AMOUNT = BigInt(1e19);
@@ -94,7 +92,7 @@ export class FeesTest {
94
92
  constructor(
95
93
  testName: string,
96
94
  private numberOfAccounts = 3,
97
- setupOptions: Partial<SetupOptions & DeployL1ContractsArgs> = {},
95
+ private setupOptions: Partial<SetupOptions & DeployAztecL1ContractsArgs> = {},
98
96
  ) {
99
97
  if (!numberOfAccounts) {
100
98
  throw new Error('There must be at least 1 initial account.');
@@ -102,26 +100,32 @@ export class FeesTest {
102
100
  setupOptions.coinbase ??= EthAddress.random();
103
101
  this.coinbase = setupOptions.coinbase!;
104
102
  this.logger = createLogger(`e2e:e2e_fees:${testName}`);
105
- this.snapshotManager = createSnapshotManager(
106
- `e2e_fees/${testName}-${numberOfAccounts}`,
107
- dataPath,
108
- { startProverNode: true, ...setupOptions },
109
- { ...setupOptions },
110
- );
111
103
  }
112
104
 
113
105
  async setup() {
114
- const context = await this.snapshotManager.setup();
115
-
116
- this.rollupContract = RollupContract.getFromConfig(context.aztecNodeConfig);
117
- this.chainMonitor = new ChainMonitor(this.rollupContract, context.dateProvider, this.logger, 200).start();
106
+ this.logger.verbose('Setting up fresh context...');
107
+ // Token allowlist entries are test-only: FPC-based fee payment with custom tokens won't work on mainnet alpha.
108
+ const tokenAllowList = await getTokenAllowedSetupFunctions();
109
+ this.context = await setup(0, {
110
+ startProverNode: true,
111
+ ...this.setupOptions,
112
+ fundSponsoredFPC: true,
113
+ skipAccountDeployment: true,
114
+ l1ContractsArgs: { ...this.setupOptions },
115
+ txPublicSetupAllowListExtend: [...(this.setupOptions.txPublicSetupAllowListExtend ?? []), ...tokenAllowList],
116
+ });
117
+
118
+ this.rollupContract = RollupContract.getFromConfig(this.context.config);
119
+ this.chainMonitor = new ChainMonitor(this.rollupContract, this.context.dateProvider, this.logger, 200).start();
120
+
121
+ await this.applyBaseSetup();
118
122
 
119
123
  return this;
120
124
  }
121
125
 
122
126
  async teardown() {
123
127
  await this.chainMonitor.stop();
124
- await this.snapshotManager.teardown();
128
+ await teardown(this.context);
125
129
  }
126
130
 
127
131
  setIsMarkingAsProven(b: boolean) {
@@ -136,12 +140,10 @@ export class FeesTest {
136
140
  }
137
141
 
138
142
  async getBlockRewards() {
139
- const blockReward = await this.rollupContract.getBlockReward();
143
+ const blockReward = await this.rollupContract.getCheckpointReward();
140
144
  const rewardConfig = await this.rollupContract.getRewardConfig();
141
145
 
142
- const balance = await this.feeJuiceBridgeTestHarness.getL1FeeJuiceBalance(
143
- EthAddress.fromString(rewardConfig.rewardDistributor),
144
- );
146
+ const balance = await this.feeJuiceBridgeTestHarness.getL1FeeJuiceBalance(rewardConfig.rewardDistributor);
145
147
 
146
148
  const toDistribute = balance > blockReward ? blockReward : balance;
147
149
  const sequencerBlockRewards = (toDistribute * BigInt(rewardConfig.sequencerBps)) / 10000n;
@@ -153,226 +155,177 @@ export class FeesTest {
153
155
  async mintAndBridgeFeeJuice(minter: AztecAddress, recipient: AztecAddress) {
154
156
  const claim = await this.feeJuiceBridgeTestHarness.prepareTokensOnL1(recipient);
155
157
  const { claimSecret: secret, messageLeafIndex: index } = claim;
156
- await this.feeJuiceContract.methods
157
- .claim(recipient, claim.claimAmount, secret, index)
158
- .send({ from: minter })
159
- .wait();
158
+ await this.feeJuiceContract.methods.claim(recipient, claim.claimAmount, secret, index).send({ from: minter });
160
159
  }
161
160
 
162
161
  /** Alice mints bananaCoin tokens privately to the target address and redeems them. */
163
162
  async mintPrivateBananas(amount: bigint, address: AztecAddress) {
164
- const balanceBefore = await this.bananaCoin.methods
163
+ const { result: balanceBefore } = await this.bananaCoin.methods
165
164
  .balance_of_private(address)
166
- .simulate({ from: this.aliceAddress });
165
+ .simulate({ from: address });
167
166
 
168
167
  await mintTokensToPrivate(this.bananaCoin, this.aliceAddress, address, amount);
169
168
 
170
- const balanceAfter = await this.bananaCoin.methods
169
+ const { result: balanceAfter } = await this.bananaCoin.methods
171
170
  .balance_of_private(address)
172
- .simulate({ from: this.aliceAddress });
171
+ .simulate({ from: address });
173
172
  expect(balanceAfter).toEqual(balanceBefore + amount);
174
173
  }
175
174
 
176
- public async applyBaseSnapshots() {
177
- await this.applyInitialAccountsSnapshot();
178
- await this.applyPublicDeployAccountsSnapshot();
179
- await this.applySetupFeeJuiceSnapshot();
180
- await this.applyDeployBananaTokenSnapshot();
175
+ public async applyBaseSetup() {
176
+ await this.applyInitialAccounts();
177
+ await this.applyPublicDeployAccounts();
178
+ await this.applySetupFeeJuice();
179
+ await this.applyDeployBananaToken();
181
180
  }
182
181
 
183
- async applyInitialAccountsSnapshot() {
184
- await this.snapshotManager.snapshot(
185
- 'initial_accounts',
186
- deployAccounts(this.numberOfAccounts, this.logger),
187
- async ({ deployedAccounts }, { wallet, aztecNode, cheatCodes }) => {
188
- this.wallet = wallet;
189
- this.aztecNode = aztecNode;
190
- this.gasSettings = GasSettings.default({ maxFeesPerGas: (await this.aztecNode.getCurrentBaseFees()).mul(2) });
191
- this.cheatCodes = cheatCodes;
192
- this.accounts = deployedAccounts.map(a => a.address);
193
- this.accounts.forEach((a, i) => this.logger.verbose(`Account ${i} address: ${a}`));
194
- [this.aliceAddress, this.bobAddress, this.sequencerAddress] = this.accounts.slice(0, 3);
195
-
196
- // We set Alice as the FPC admin to avoid the need for deployment of another account.
197
- this.fpcAdmin = this.aliceAddress;
198
-
199
- const canonicalFeeJuice = await getCanonicalFeeJuice();
200
- this.feeJuiceContract = await FeeJuiceContract.at(canonicalFeeJuice.address, this.wallet);
201
- },
202
- );
182
+ async applyInitialAccounts() {
183
+ this.logger.info('Applying initial accounts setup');
184
+
185
+ const { deployedAccounts } = await deployAccounts(
186
+ this.numberOfAccounts,
187
+ this.logger,
188
+ )({
189
+ wallet: this.context.wallet,
190
+ initialFundedAccounts: this.context.initialFundedAccounts,
191
+ });
192
+
193
+ this.wallet = this.context.wallet;
194
+ this.aztecNode = this.context.aztecNodeService;
195
+ this.aztecNodeAdmin = this.context.aztecNodeService;
196
+ this.gasSettings = GasSettings.default({ maxFeesPerGas: (await this.aztecNode.getCurrentMinFees()).mul(2) });
197
+ this.cheatCodes = this.context.cheatCodes;
198
+ this.accounts = deployedAccounts.map(a => a.address);
199
+ this.accounts.forEach((a, i) => this.logger.verbose(`Account ${i} address: ${a}`));
200
+ [this.aliceAddress, this.bobAddress, this.sequencerAddress] = this.accounts.slice(0, 3);
201
+
202
+ // We set Alice as the FPC admin to avoid the need for deployment of another account.
203
+ this.fpcAdmin = this.aliceAddress;
204
+
205
+ const canonicalFeeJuice = await getCanonicalFeeJuice();
206
+ this.feeJuiceContract = FeeJuiceContract.at(canonicalFeeJuice.address, this.wallet);
203
207
  }
204
208
 
205
- async applyPublicDeployAccountsSnapshot() {
206
- await this.snapshotManager.snapshot('public_deploy_accounts', () =>
207
- ensureAccountContractsPublished(this.wallet, this.accounts),
208
- );
209
+ async applyPublicDeployAccounts() {
210
+ this.logger.info('Applying public deploy accounts setup');
211
+ await publicDeployAccounts(this.wallet, this.accounts);
209
212
  }
210
213
 
211
- async applySetupFeeJuiceSnapshot() {
212
- await this.snapshotManager.snapshot(
213
- 'setup_fee_juice',
214
- async () => {},
215
- async (_data, context) => {
216
- this.context = context;
217
-
218
- this.feeJuiceContract = await FeeJuiceContract.at(ProtocolContractAddress.FeeJuice, this.wallet);
219
-
220
- this.getGasBalanceFn = getBalancesFn(
221
- '⛽',
222
- this.feeJuiceContract.methods.balance_of_public,
223
- this.aliceAddress,
224
- this.logger,
225
- );
226
-
227
- this.feeJuiceBridgeTestHarness = await FeeJuicePortalTestingHarnessFactory.create({
228
- aztecNode: context.aztecNode,
229
- aztecNodeAdmin: context.aztecNode,
230
- l1Client: context.deployL1ContractsValues.l1Client,
231
- wallet: this.wallet,
232
- logger: this.logger,
233
- });
234
- },
235
- );
214
+ async applySetupFeeJuice() {
215
+ this.logger.info('Applying fee juice setup');
216
+
217
+ this.feeJuiceContract = FeeJuiceContract.at(ProtocolContractAddress.FeeJuice, this.wallet);
218
+
219
+ this.getGasBalanceFn = getBalancesFn('⛽', this.feeJuiceContract.methods.balance_of_public, this.logger);
220
+
221
+ this.feeJuiceBridgeTestHarness = await FeeJuicePortalTestingHarnessFactory.create({
222
+ aztecNode: this.context.aztecNodeService,
223
+ aztecNodeAdmin: this.context.aztecNodeService,
224
+ l1Client: this.context.deployL1ContractsValues.l1Client,
225
+ wallet: this.wallet,
226
+ logger: this.logger,
227
+ });
236
228
  }
237
229
 
238
- async applyDeployBananaTokenSnapshot() {
239
- await this.snapshotManager.snapshot(
240
- 'deploy_banana_token',
241
- async () => {
242
- const bananaCoin = await BananaCoin.deploy(this.wallet, this.aliceAddress, 'BC', 'BC', 18n)
243
- .send({ from: this.aliceAddress })
244
- .deployed();
245
- this.logger.info(`BananaCoin deployed at ${bananaCoin.address}`);
246
- return { bananaCoinAddress: bananaCoin.address };
247
- },
248
- async ({ bananaCoinAddress }) => {
249
- this.bananaCoin = await BananaCoin.at(bananaCoinAddress, this.wallet);
250
- const logger = this.logger;
251
- this.getBananaPublicBalanceFn = getBalancesFn(
252
- '🍌.public',
253
- this.bananaCoin.methods.balance_of_public,
254
- this.aliceAddress,
255
- logger,
256
- );
257
- this.getBananaPrivateBalanceFn = getBalancesFn(
258
- '🍌.private',
259
- this.bananaCoin.methods.balance_of_private,
260
- this.aliceAddress,
261
- logger,
262
- );
263
- },
230
+ async applyDeployBananaToken() {
231
+ this.logger.info('Applying deploy banana token setup');
232
+
233
+ const { contract: bananaCoin } = await BananaCoin.deploy(this.wallet, this.aliceAddress, 'BC', 'BC', 18n).send({
234
+ from: this.aliceAddress,
235
+ });
236
+ this.logger.info(`BananaCoin deployed at ${bananaCoin.address}`);
237
+
238
+ this.bananaCoin = bananaCoin;
239
+ this.getBananaPublicBalanceFn = getBalancesFn('🍌.public', this.bananaCoin.methods.balance_of_public, this.logger);
240
+ this.getBananaPrivateBalanceFn = getBalancesFn(
241
+ '🍌.private',
242
+ this.bananaCoin.methods.balance_of_private,
243
+ this.logger,
264
244
  );
265
245
  }
266
246
 
267
- public async applyFPCSetupSnapshot() {
268
- await this.snapshotManager.snapshot(
269
- 'fpc_setup',
270
- async context => {
271
- const feeJuiceContract = this.feeJuiceBridgeTestHarness.feeJuice;
272
- expect((await context.wallet.getContractMetadata(feeJuiceContract.address)).isContractPublished).toBe(true);
273
-
274
- const bananaCoin = this.bananaCoin;
275
- const bananaFPC = await FPCContract.deploy(this.wallet, bananaCoin.address, this.fpcAdmin)
276
- .send({ from: this.aliceAddress })
277
- .deployed();
278
-
279
- this.logger.info(`BananaPay deployed at ${bananaFPC.address}`);
280
-
281
- await this.feeJuiceBridgeTestHarness.bridgeFromL1ToL2(bananaFPC.address, this.aliceAddress);
282
-
283
- return {
284
- bananaFPCAddress: bananaFPC.address,
285
- feeJuiceAddress: feeJuiceContract.address,
286
- l1FeeJuiceAddress: this.feeJuiceBridgeTestHarness.l1FeeJuiceAddress,
287
- rollupAddress: context.deployL1ContractsValues.l1ContractAddresses.rollupAddress,
288
- };
289
- },
290
- async (data, context) => {
291
- const bananaFPC = await FPCContract.at(data.bananaFPCAddress, this.wallet);
292
- this.bananaFPC = bananaFPC;
293
-
294
- this.getCoinbaseBalance = async () => {
295
- const l1Client = createExtendedL1Client(context.aztecNodeConfig.l1RpcUrls, MNEMONIC);
296
- const gasL1 = getContract({
297
- address: data.l1FeeJuiceAddress.toString(),
298
- abi: TestERC20Abi,
299
- client: l1Client,
300
- });
301
- return await gasL1.read.balanceOf([this.coinbase.toString()]);
302
- };
303
-
304
- this.getCoinbaseSequencerRewards = async () => {
305
- return await this.rollupContract.getSequencerRewards(this.coinbase);
306
- };
307
-
308
- this.getProverFee = async (blockNumber: number) => {
309
- const block = await this.aztecNode.getBlock(blockNumber);
310
-
311
- // @todo @lherskind As we deal with #13601
312
- // Right now the value is from `FeeLib.sol`
313
- const L1_GAS_PER_EPOCH_VERIFIED = 1000000n;
314
-
315
- // We round up
316
- const mulDiv = (a: bigint, b: bigint, c: bigint) => (a * b) / c + ((a * b) % c > 0n ? 1n : 0n);
317
-
318
- const { baseFee } = await this.rollupContract.getL1FeesAt(block!.header.globalVariables.timestamp);
319
- const proverCost =
320
- mulDiv(
321
- mulDiv(L1_GAS_PER_EPOCH_VERIFIED, baseFee, await this.rollupContract.getEpochDuration()),
322
- 1n,
323
- await this.rollupContract.getManaTarget(),
324
- ) + (await this.rollupContract.getProvingCostPerMana());
325
-
326
- const price = await this.rollupContract.getFeeAssetPerEth();
327
-
328
- const mana = block!.header.totalManaUsed.toBigInt();
329
- return mulDiv(mana * proverCost, price, 10n ** 9n);
330
- };
331
- },
332
- );
247
+ public async applyFPCSetup() {
248
+ this.logger.info('Applying FPC setup');
249
+
250
+ const feeJuiceContract = this.feeJuiceBridgeTestHarness.feeJuice;
251
+ expect((await this.wallet.getContractMetadata(feeJuiceContract.address)).isContractPublished).toBe(true);
252
+
253
+ const bananaCoin = this.bananaCoin;
254
+ const { contract: bananaFPC } = await FPCContract.deploy(this.wallet, bananaCoin.address, this.fpcAdmin).send({
255
+ from: this.aliceAddress,
256
+ });
257
+
258
+ this.logger.info(`BananaPay deployed at ${bananaFPC.address}`);
259
+
260
+ await this.feeJuiceBridgeTestHarness.bridgeFromL1ToL2(bananaFPC.address, this.aliceAddress);
261
+
262
+ this.bananaFPC = bananaFPC;
263
+
264
+ const l1FeeJuiceAddress = this.feeJuiceBridgeTestHarness.l1FeeJuiceAddress;
265
+
266
+ this.getCoinbaseBalance = async () => {
267
+ const l1Client = createExtendedL1Client(this.context.config.l1RpcUrls, MNEMONIC);
268
+ const gasL1 = getContract({
269
+ address: l1FeeJuiceAddress.toString(),
270
+ abi: TestERC20Abi,
271
+ client: l1Client,
272
+ });
273
+ return await gasL1.read.balanceOf([this.coinbase.toString()]);
274
+ };
275
+
276
+ this.getCoinbaseSequencerRewards = async () => {
277
+ return await this.rollupContract.getSequencerRewards(this.coinbase);
278
+ };
279
+
280
+ this.getProverFee = async (blockNumber: BlockNumber) => {
281
+ const block = await this.aztecNode.getBlock(blockNumber);
282
+
283
+ // @todo @lherskind As we deal with #13601
284
+ // Right now the value is from `FeeLib.sol`
285
+ const L1_GAS_PER_EPOCH_VERIFIED = 3600000n;
286
+
287
+ // We round up
288
+ const mulDiv = (a: bigint, b: bigint, c: bigint) => (a * b) / c + ((a * b) % c > 0n ? 1n : 0n);
289
+
290
+ const { baseFee } = await this.rollupContract.getL1FeesAt(block!.header.globalVariables.timestamp);
291
+ const proverCost =
292
+ mulDiv(
293
+ mulDiv(L1_GAS_PER_EPOCH_VERIFIED, baseFee, BigInt(await this.rollupContract.getEpochDuration())),
294
+ 1n,
295
+ await this.rollupContract.getManaTarget(),
296
+ ) + (await this.rollupContract.getProvingCostPerMana());
297
+
298
+ const price = await this.rollupContract.getEthPerFeeAsset();
299
+
300
+ const mana = block!.header.totalManaUsed.toBigInt();
301
+ return mulDiv(mana * proverCost, 10n ** 12n, price);
302
+ };
333
303
  }
334
304
 
335
- public async applySponsoredFPCSetupSnapshot() {
336
- await this.snapshotManager.snapshot(
337
- 'sponsored_fpc_setup',
338
- async context => {
339
- const feeJuiceContract = this.feeJuiceBridgeTestHarness.feeJuice;
340
- expect((await context.wallet.getContractMetadata(feeJuiceContract.address)).isContractPublished).toBe(true);
341
-
342
- const sponsoredFPC = await setupSponsoredFPC(this.wallet);
343
- this.logger.info(`SponsoredFPC at ${sponsoredFPC.address}`);
344
-
345
- return {
346
- sponsoredFPCAddress: sponsoredFPC.address,
347
- };
348
- },
349
- async data => {
350
- this.sponsoredFPC = await SponsoredFPCContract.at(data.sponsoredFPCAddress, this.wallet);
351
- },
352
- );
305
+ public async applySponsoredFPCSetup() {
306
+ this.logger.info('Applying sponsored FPC setup');
307
+
308
+ const feeJuiceContract = this.feeJuiceBridgeTestHarness.feeJuice;
309
+ expect((await this.wallet.getContractMetadata(feeJuiceContract.address)).isContractPublished).toBe(true);
310
+
311
+ const sponsoredFPCInstance = await setupSponsoredFPC(this.wallet);
312
+ this.logger.info(`SponsoredFPC at ${sponsoredFPCInstance.address}`);
313
+
314
+ this.sponsoredFPC = SponsoredFPCContract.at(sponsoredFPCInstance.address, this.wallet);
353
315
  }
354
316
 
355
317
  public async applyFundAliceWithBananas() {
356
- await this.snapshotManager.snapshot(
357
- 'fund_alice',
358
- async () => {
359
- await this.mintPrivateBananas(this.ALICE_INITIAL_BANANAS, this.aliceAddress);
360
- await this.bananaCoin.methods
361
- .mint_to_public(this.aliceAddress, this.ALICE_INITIAL_BANANAS)
362
- .send({ from: this.aliceAddress })
363
- .wait();
364
- },
365
- () => Promise.resolve(),
366
- );
318
+ this.logger.info('Applying fund Alice with bananas setup');
319
+
320
+ await this.mintPrivateBananas(this.ALICE_INITIAL_BANANAS, this.aliceAddress);
321
+ await this.bananaCoin.methods
322
+ .mint_to_public(this.aliceAddress, this.ALICE_INITIAL_BANANAS)
323
+ .send({ from: this.aliceAddress });
367
324
  }
368
325
 
369
326
  public async applyFundAliceWithPrivateBananas() {
370
- await this.snapshotManager.snapshot(
371
- 'fund_alice_with_private_bananas',
372
- async () => {
373
- await this.mintPrivateBananas(this.ALICE_INITIAL_BANANAS, this.aliceAddress);
374
- },
375
- () => Promise.resolve(),
376
- );
327
+ this.logger.info('Applying fund Alice with private bananas setup');
328
+
329
+ await this.mintPrivateBananas(this.ALICE_INITIAL_BANANAS, this.aliceAddress);
377
330
  }
378
331
  }
@@ -1,8 +1,9 @@
1
1
  import { AztecAddress } from '@aztec/aztec.js/addresses';
2
- import type { L2Block } from '@aztec/aztec.js/block';
3
2
  import { Fr } from '@aztec/aztec.js/fields';
4
- import { BatchedBlob, Blob, getPrefixedEthBlobCommitments } from '@aztec/blob-lib';
3
+ import { BatchedBlob, Blob, getEthBlobEvaluationInputs, getPrefixedEthBlobCommitments } from '@aztec/blob-lib';
5
4
  import { EthAddress } from '@aztec/foundation/eth-address';
5
+ import { L2Block } from '@aztec/stdlib/block';
6
+ import { CheckpointHeader } from '@aztec/stdlib/rollup';
6
7
 
7
8
  import { writeFile } from 'fs/promises';
8
9
 
@@ -14,6 +15,7 @@ const AZTEC_GENERATE_TEST_DATA = !!process.env.AZTEC_GENERATE_TEST_DATA;
14
15
  */
15
16
  export async function writeJson(
16
17
  fileName: string,
18
+ checkpointHeader: CheckpointHeader,
17
19
  block: L2Block,
18
20
  l1ToL2Content: Fr[],
19
21
  blobs: Blob[],
@@ -41,32 +43,31 @@ export async function writeJson(
41
43
  messages: {
42
44
  l2ToL1Messages: block.body.txEffects.flatMap(txEffect => txEffect.l2ToL1Msgs).map(value => asHex(value)),
43
45
  },
44
- block: {
46
+ checkpoint: {
45
47
  // The json formatting in forge is a bit brittle, so we convert Fr to a number in the few values below.
46
48
  // This should not be a problem for testing as long as the values are not larger than u32.
47
49
  archive: asHex(block.archive.root),
48
50
  blobCommitments: getPrefixedEthBlobCommitments(blobs),
49
- batchedBlobInputs: batchedBlob.getEthBlobEvaluationInputs(),
50
- blockNumber: block.number,
51
+ batchedBlobInputs: getEthBlobEvaluationInputs(batchedBlob),
52
+ checkpointNumber: block.number,
51
53
  body: `0x${block.body.toBuffer().toString('hex')}`,
52
54
  header: {
53
- lastArchiveRoot: asHex(block.header.lastArchive.root),
54
- contentCommitment: {
55
- blobsHash: asHex(block.header.contentCommitment.blobsHash),
56
- inHash: asHex(block.header.contentCommitment.inHash),
57
- outHash: asHex(block.header.contentCommitment.outHash),
58
- },
59
- slotNumber: Number(block.header.globalVariables.slotNumber),
60
- timestamp: Number(block.header.globalVariables.timestamp),
61
- coinbase: asHex(block.header.globalVariables.coinbase, 40),
62
- feeRecipient: asHex(block.header.globalVariables.feeRecipient),
55
+ lastArchiveRoot: asHex(checkpointHeader.lastArchiveRoot),
56
+ blockHeadersHash: asHex(checkpointHeader.blockHeadersHash),
57
+ blobsHash: asHex(checkpointHeader.blobsHash),
58
+ inHash: asHex(checkpointHeader.inHash),
59
+ outHash: asHex(checkpointHeader.epochOutHash),
60
+ slotNumber: Number(checkpointHeader.slotNumber),
61
+ timestamp: Number(checkpointHeader.timestamp),
62
+ coinbase: asHex(checkpointHeader.coinbase, 40),
63
+ feeRecipient: asHex(checkpointHeader.feeRecipient),
63
64
  gasFees: {
64
- feePerDaGas: Number(block.header.globalVariables.gasFees.feePerDaGas),
65
- feePerL2Gas: Number(block.header.globalVariables.gasFees.feePerL2Gas),
65
+ feePerDaGas: Number(checkpointHeader.gasFees.feePerDaGas),
66
+ feePerL2Gas: Number(checkpointHeader.gasFees.feePerL2Gas),
66
67
  },
67
- totalManaUsed: block.header.totalManaUsed.toNumber(),
68
+ totalManaUsed: checkpointHeader.totalManaUsed.toNumber(),
68
69
  },
69
- headerHash: asHex(block.getCheckpointHeader().hash()),
70
+ headerHash: asHex(checkpointHeader.hash()),
70
71
  numTxs: block.body.txEffects.length,
71
72
  },
72
73
  };
@@ -1,5 +1,5 @@
1
1
  import { AztecAddress } from '@aztec/aztec.js/addresses';
2
- import { getAddressFromPrivateKey } from '@aztec/ethereum';
2
+ import { getAddressFromPrivateKey } from '@aztec/ethereum/account';
3
3
  import { EthAddress } from '@aztec/foundation/eth-address';
4
4
  import type { EthPrivateKey } from '@aztec/node-keystore';
5
5