@aztec/end-to-end 0.0.1-commit.1142ef1 → 0.0.1-commit.1bea0213

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 (155) 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 +12 -13
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  6. package/dest/bench/client_flows/client_flows_benchmark.js +117 -132
  7. package/dest/bench/utils.d.ts +6 -5
  8. package/dest/bench/utils.d.ts.map +1 -1
  9. package/dest/bench/utils.js +9 -7
  10. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +6 -7
  11. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  12. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +96 -112
  13. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +6 -7
  14. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  15. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +65 -62
  16. package/dest/e2e_deploy_contract/deploy_test.d.ts +4 -3
  17. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  18. package/dest/e2e_deploy_contract/deploy_test.js +18 -13
  19. package/dest/e2e_epochs/epochs_test.d.ts +1 -1
  20. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  21. package/dest/e2e_epochs/epochs_test.js +4 -1
  22. package/dest/e2e_fees/bridging_race.notest.js +3 -5
  23. package/dest/e2e_fees/fees_test.d.ts +13 -13
  24. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  25. package/dest/e2e_fees/fees_test.js +122 -140
  26. package/dest/e2e_l1_publisher/write_json.d.ts +2 -2
  27. package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
  28. package/dest/e2e_l1_publisher/write_json.js +19 -12
  29. package/dest/e2e_nested_contract/nested_contract_test.d.ts +6 -9
  30. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  31. package/dest/e2e_nested_contract/nested_contract_test.js +31 -39
  32. package/dest/e2e_p2p/inactivity_slash_test.d.ts +3 -3
  33. package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -1
  34. package/dest/e2e_p2p/inactivity_slash_test.js +3 -3
  35. package/dest/e2e_p2p/p2p_network.d.ts +7 -6
  36. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  37. package/dest/e2e_p2p/p2p_network.js +110 -103
  38. package/dest/e2e_p2p/shared.d.ts +6 -6
  39. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  40. package/dest/e2e_p2p/shared.js +7 -14
  41. package/dest/e2e_token_contract/token_contract_test.d.ts +16 -9
  42. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  43. package/dest/e2e_token_contract/token_contract_test.js +89 -91
  44. package/dest/fixtures/e2e_prover_test.d.ts +8 -14
  45. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  46. package/dest/fixtures/e2e_prover_test.js +84 -92
  47. package/dest/fixtures/setup.d.ts +218 -0
  48. package/dest/fixtures/setup.d.ts.map +1 -0
  49. package/dest/fixtures/setup.js +690 -0
  50. package/dest/fixtures/token_utils.d.ts +1 -1
  51. package/dest/fixtures/token_utils.d.ts.map +1 -1
  52. package/dest/fixtures/token_utils.js +7 -4
  53. package/dest/fixtures/utils.d.ts +5 -191
  54. package/dest/fixtures/utils.d.ts.map +1 -1
  55. package/dest/fixtures/utils.js +4 -615
  56. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  57. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  58. package/dest/quality_of_service/prometheus_client.js +67 -0
  59. package/dest/shared/cross_chain_test_harness.d.ts +14 -4
  60. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  61. package/dest/shared/cross_chain_test_harness.js +11 -11
  62. package/dest/shared/gas_portal_test_harness.d.ts +11 -1
  63. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  64. package/dest/shared/gas_portal_test_harness.js +1 -1
  65. package/dest/shared/submit-transactions.d.ts +3 -3
  66. package/dest/shared/submit-transactions.d.ts.map +1 -1
  67. package/dest/shared/submit-transactions.js +9 -11
  68. package/dest/shared/uniswap_l1_l2.d.ts +1 -1
  69. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  70. package/dest/shared/uniswap_l1_l2.js +12 -12
  71. package/dest/simulators/lending_simulator.d.ts +5 -1
  72. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  73. package/dest/simulators/lending_simulator.js +2 -2
  74. package/dest/spartan/setup_test_wallets.d.ts +1 -1
  75. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  76. package/dest/spartan/setup_test_wallets.js +61 -34
  77. package/dest/spartan/tx_metrics.d.ts +17 -2
  78. package/dest/spartan/tx_metrics.d.ts.map +1 -1
  79. package/dest/spartan/tx_metrics.js +183 -6
  80. package/dest/spartan/utils/bot.d.ts +27 -0
  81. package/dest/spartan/utils/bot.d.ts.map +1 -0
  82. package/dest/spartan/utils/bot.js +141 -0
  83. package/dest/spartan/utils/chaos.d.ts +79 -0
  84. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  85. package/dest/spartan/utils/chaos.js +142 -0
  86. package/dest/spartan/utils/clients.d.ts +39 -0
  87. package/dest/spartan/utils/clients.d.ts.map +1 -0
  88. package/dest/spartan/utils/clients.js +90 -0
  89. package/dest/spartan/utils/config.d.ts +36 -0
  90. package/dest/spartan/utils/config.d.ts.map +1 -0
  91. package/dest/spartan/utils/config.js +20 -0
  92. package/dest/spartan/utils/health.d.ts +63 -0
  93. package/dest/spartan/utils/health.d.ts.map +1 -0
  94. package/dest/spartan/utils/health.js +202 -0
  95. package/dest/spartan/utils/helm.d.ts +15 -0
  96. package/dest/spartan/utils/helm.d.ts.map +1 -0
  97. package/dest/spartan/utils/helm.js +47 -0
  98. package/dest/spartan/utils/index.d.ts +9 -0
  99. package/dest/spartan/utils/index.d.ts.map +1 -0
  100. package/dest/spartan/utils/index.js +18 -0
  101. package/dest/spartan/utils/k8s.d.ts +98 -0
  102. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  103. package/dest/spartan/utils/k8s.js +257 -0
  104. package/dest/spartan/utils/nodes.d.ts +31 -0
  105. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  106. package/dest/spartan/utils/nodes.js +290 -0
  107. package/dest/spartan/utils/scripts.d.ts +16 -0
  108. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  109. package/dest/spartan/utils/scripts.js +66 -0
  110. package/dest/spartan/utils.d.ts +2 -253
  111. package/dest/spartan/utils.d.ts.map +1 -1
  112. package/dest/spartan/utils.js +1 -892
  113. package/package.json +40 -39
  114. package/src/bench/client_flows/benchmark.ts +24 -2
  115. package/src/bench/client_flows/client_flows_benchmark.ts +137 -203
  116. package/src/bench/utils.ts +9 -7
  117. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +104 -142
  118. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +99 -106
  119. package/src/e2e_deploy_contract/deploy_test.ts +21 -14
  120. package/src/e2e_epochs/epochs_test.ts +30 -25
  121. package/src/e2e_fees/bridging_race.notest.ts +3 -9
  122. package/src/e2e_fees/fees_test.ts +171 -217
  123. package/src/e2e_l1_publisher/write_json.ts +21 -13
  124. package/src/e2e_nested_contract/nested_contract_test.ts +33 -56
  125. package/src/e2e_p2p/inactivity_slash_test.ts +5 -5
  126. package/src/e2e_p2p/p2p_network.ts +171 -167
  127. package/src/e2e_p2p/shared.ts +10 -20
  128. package/src/e2e_token_contract/token_contract_test.ts +103 -118
  129. package/src/fixtures/e2e_prover_test.ts +98 -132
  130. package/src/fixtures/setup.ts +1017 -0
  131. package/src/fixtures/token_utils.ts +6 -5
  132. package/src/fixtures/utils.ts +27 -901
  133. package/src/quality_of_service/prometheus_client.ts +113 -0
  134. package/src/shared/cross_chain_test_harness.ts +13 -27
  135. package/src/shared/gas_portal_test_harness.ts +1 -1
  136. package/src/shared/submit-transactions.ts +9 -15
  137. package/src/shared/uniswap_l1_l2.ts +12 -19
  138. package/src/simulators/lending_simulator.ts +2 -2
  139. package/src/spartan/setup_test_wallets.ts +72 -24
  140. package/src/spartan/tx_metrics.ts +129 -9
  141. package/src/spartan/utils/bot.ts +185 -0
  142. package/src/spartan/utils/chaos.ts +253 -0
  143. package/src/spartan/utils/clients.ts +100 -0
  144. package/src/spartan/utils/config.ts +26 -0
  145. package/src/spartan/utils/health.ts +255 -0
  146. package/src/spartan/utils/helm.ts +84 -0
  147. package/src/spartan/utils/index.ts +62 -0
  148. package/src/spartan/utils/k8s.ts +375 -0
  149. package/src/spartan/utils/nodes.ts +323 -0
  150. package/src/spartan/utils/scripts.ts +63 -0
  151. package/src/spartan/utils.ts +1 -1158
  152. package/dest/fixtures/snapshot_manager.d.ts +0 -93
  153. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  154. package/dest/fixtures/snapshot_manager.js +0 -488
  155. package/src/fixtures/snapshot_manager.ts +0 -646
@@ -121,30 +121,35 @@ export class EpochsTestContext {
121
121
 
122
122
  // Set up system without any account nor protocol contracts
123
123
  // and with faster block times and shorter epochs.
124
- const context = await setup(opts.numberOfAccounts ?? 0, {
125
- automineL1Setup: true,
126
- checkIntervalMs: 50,
127
- archiverPollingIntervalMS: ARCHIVER_POLL_INTERVAL,
128
- worldStateBlockCheckIntervalMS: WORLD_STATE_BLOCK_CHECK_INTERVAL,
129
- aztecEpochDuration,
130
- aztecSlotDuration,
131
- ethereumSlotDuration,
132
- aztecProofSubmissionEpochs,
133
- aztecTargetCommitteeSize: opts.initialValidators?.length ?? 0,
134
- minTxsPerBlock: 0,
135
- realProofs: false,
136
- startProverNode: true,
137
- proverTestDelayMs: opts.proverTestDelayMs ?? 0,
138
- // We use numeric incremental prover ids for simplicity, but we can switch to
139
- // using the prover's eth address if the proverId is used for something in the rollup contract
140
- // Use numeric EthAddress for deterministic prover id
141
- proverId: EthAddress.fromNumber(1),
142
- worldStateBlockHistory: WORLD_STATE_BLOCK_HISTORY,
143
- exitDelaySeconds: DefaultL1ContractsConfig.exitDelaySeconds,
144
- slasherFlavor: 'none',
145
- l1PublishingTime,
146
- ...opts,
147
- });
124
+ const context = await setup(
125
+ opts.numberOfAccounts ?? 0,
126
+ {
127
+ automineL1Setup: true,
128
+ checkIntervalMs: 50,
129
+ archiverPollingIntervalMS: ARCHIVER_POLL_INTERVAL,
130
+ worldStateBlockCheckIntervalMS: WORLD_STATE_BLOCK_CHECK_INTERVAL,
131
+ aztecEpochDuration,
132
+ aztecSlotDuration,
133
+ ethereumSlotDuration,
134
+ aztecProofSubmissionEpochs,
135
+ aztecTargetCommitteeSize: opts.initialValidators?.length ?? 0,
136
+ minTxsPerBlock: 0,
137
+ realProofs: false,
138
+ startProverNode: true,
139
+ proverTestDelayMs: opts.proverTestDelayMs ?? 0,
140
+ // We use numeric incremental prover ids for simplicity, but we can switch to
141
+ // using the prover's eth address if the proverId is used for something in the rollup contract
142
+ // Use numeric EthAddress for deterministic prover id
143
+ proverId: EthAddress.fromNumber(1),
144
+ worldStateBlockHistory: WORLD_STATE_BLOCK_HISTORY,
145
+ exitDelaySeconds: DefaultL1ContractsConfig.exitDelaySeconds,
146
+ slasherFlavor: 'none',
147
+ l1PublishingTime,
148
+ ...opts,
149
+ },
150
+ // Use checkpointed chain tip for PXE to avoid issues with blocks being dropped due to pruned anchor blocks.
151
+ { syncChainTip: 'checkpointed' },
152
+ );
148
153
 
149
154
  this.context = context;
150
155
  this.proverNodes = context.proverNode ? [context.proverNode] : [];
@@ -211,7 +216,7 @@ export class EpochsTestContext {
211
216
  ...opts,
212
217
  },
213
218
  this.context.aztecNode,
214
- undefined,
219
+ this.context.prefilledPublicData ?? [],
215
220
  { dateProvider: this.context.dateProvider },
216
221
  ),
217
222
  );
@@ -26,11 +26,8 @@ describe('e2e_fees bridging_race', () => {
26
26
  });
27
27
 
28
28
  beforeAll(async () => {
29
- await t.applyInitialAccountsSnapshot();
30
- await t.applyPublicDeployAccountsSnapshot();
31
- await t.applySetupFeeJuiceSnapshot();
32
-
33
- ({ wallet, logger } = await t.setup());
29
+ await t.setup();
30
+ ({ wallet, logger } = t);
34
31
  });
35
32
 
36
33
  afterAll(async () => {
@@ -70,10 +67,7 @@ describe('e2e_fees bridging_race', () => {
70
67
  // Yes, we need to REFACTOR it at some point
71
68
  const claim = await t.feeJuiceBridgeTestHarness.prepareTokensOnL1(bobsAddress);
72
69
  const { claimSecret: secret, messageLeafIndex: index } = claim;
73
- await t.feeJuiceContract.methods
74
- .claim(bobsAddress, claim.claimAmount, secret, index)
75
- .send({ from: bobsAddress })
76
- .wait();
70
+ await t.feeJuiceContract.methods.claim(bobsAddress, claim.claimAmount, secret, index).send({ from: bobsAddress });
77
71
  const [balance] = await t.getGasBalanceFn(bobsAddress);
78
72
  expect(balance).toEqual(claim.claimAmount);
79
73
  });
@@ -26,25 +26,19 @@ import { getContract } from 'viem';
26
26
 
27
27
  import { MNEMONIC } from '../fixtures/fixtures.js';
28
28
  import {
29
- type ISnapshotManager,
30
- type SubsystemsContext,
31
- createSnapshotManager,
29
+ type EndToEndContext,
30
+ type SetupOptions,
32
31
  deployAccounts,
33
- } from '../fixtures/snapshot_manager.js';
32
+ publicDeployAccounts,
33
+ setup,
34
+ teardown,
35
+ } from '../fixtures/setup.js';
34
36
  import { mintTokensToPrivate } from '../fixtures/token_utils.js';
35
- import {
36
- type BalancesFn,
37
- type SetupOptions,
38
- ensureAccountContractsPublished,
39
- getBalancesFn,
40
- setupSponsoredFPC,
41
- } from '../fixtures/utils.js';
37
+ import { type BalancesFn, getBalancesFn, setupSponsoredFPC } from '../fixtures/utils.js';
42
38
  import { FeeJuicePortalTestingHarnessFactory, type GasBridgingTestHarness } from '../shared/gas_portal_test_harness.js';
43
39
 
44
- const { E2E_DATA_PATH: dataPath } = process.env;
45
-
46
40
  /**
47
- * Test fixture for testing fees. Provides the following snapshots:
41
+ * Test fixture for testing fees. Provides the following setup steps:
48
42
  * InitialAccounts: Initializes 3 Schnorr account contracts.
49
43
  * PublicDeployAccounts: Deploys the accounts publicly.
50
44
  * DeployFeeJuice: Deploys the Fee Juice contract.
@@ -54,8 +48,8 @@ const { E2E_DATA_PATH: dataPath } = process.env;
54
48
  * SetupSubscription: Deploys a counter contract and a subscription contract, and mints Fee Juice to the subscription contract.
55
49
  */
56
50
  export class FeesTest {
57
- private snapshotManager: ISnapshotManager;
58
51
  private accounts: AztecAddress[] = [];
52
+ public context!: EndToEndContext;
59
53
 
60
54
  public logger: Logger;
61
55
  public aztecNode!: AztecNode;
@@ -82,7 +76,6 @@ export class FeesTest {
82
76
  public subscriptionContract!: AppSubscriptionContract;
83
77
  public feeJuiceBridgeTestHarness!: GasBridgingTestHarness;
84
78
 
85
- public context!: SubsystemsContext;
86
79
  public chainMonitor!: ChainMonitor;
87
80
 
88
81
  public getCoinbaseBalance!: () => Promise<bigint>;
@@ -99,7 +92,7 @@ export class FeesTest {
99
92
  constructor(
100
93
  testName: string,
101
94
  private numberOfAccounts = 3,
102
- setupOptions: Partial<SetupOptions & DeployAztecL1ContractsArgs> = {},
95
+ private setupOptions: Partial<SetupOptions & DeployAztecL1ContractsArgs> = {},
103
96
  ) {
104
97
  if (!numberOfAccounts) {
105
98
  throw new Error('There must be at least 1 initial account.');
@@ -107,30 +100,33 @@ export class FeesTest {
107
100
  setupOptions.coinbase ??= EthAddress.random();
108
101
  this.coinbase = setupOptions.coinbase!;
109
102
  this.logger = createLogger(`e2e:e2e_fees:${testName}`);
110
- this.snapshotManager = createSnapshotManager(
111
- `e2e_fees/${testName}-${numberOfAccounts}`,
112
- dataPath,
113
- { startProverNode: true, ...setupOptions },
114
- { ...setupOptions },
115
- );
116
103
  }
117
104
 
118
105
  async setup() {
119
- const context = await this.snapshotManager.setup();
106
+ this.logger.verbose('Setting up fresh context...');
107
+ this.context = await setup(0, {
108
+ startProverNode: true,
109
+ ...this.setupOptions,
110
+ fundSponsoredFPC: true,
111
+ skipAccountDeployment: true,
112
+ l1ContractsArgs: { ...this.setupOptions },
113
+ });
120
114
 
121
- this.rollupContract = RollupContract.getFromConfig(context.aztecNodeConfig);
122
- this.chainMonitor = new ChainMonitor(this.rollupContract, context.dateProvider, this.logger, 200).start();
115
+ this.rollupContract = RollupContract.getFromConfig(this.context.config);
116
+ this.chainMonitor = new ChainMonitor(this.rollupContract, this.context.dateProvider!, this.logger, 200).start();
117
+
118
+ await this.applyBaseSetup();
123
119
 
124
120
  return this;
125
121
  }
126
122
 
127
123
  async teardown() {
128
124
  await this.chainMonitor.stop();
129
- await this.snapshotManager.teardown();
125
+ await teardown(this.context);
130
126
  }
131
127
 
132
128
  setIsMarkingAsProven(b: boolean) {
133
- this.context.watcher.setIsMarkingAsProven(b);
129
+ this.context.watcher!.setIsMarkingAsProven(b);
134
130
  }
135
131
 
136
132
  async catchUpProvenChain() {
@@ -156,10 +152,7 @@ export class FeesTest {
156
152
  async mintAndBridgeFeeJuice(minter: AztecAddress, recipient: AztecAddress) {
157
153
  const claim = await this.feeJuiceBridgeTestHarness.prepareTokensOnL1(recipient);
158
154
  const { claimSecret: secret, messageLeafIndex: index } = claim;
159
- await this.feeJuiceContract.methods
160
- .claim(recipient, claim.claimAmount, secret, index)
161
- .send({ from: minter })
162
- .wait();
155
+ await this.feeJuiceContract.methods.claim(recipient, claim.claimAmount, secret, index).send({ from: minter });
163
156
  }
164
157
 
165
158
  /** Alice mints bananaCoin tokens privately to the target address and redeems them. */
@@ -176,210 +169,171 @@ export class FeesTest {
176
169
  expect(balanceAfter).toEqual(balanceBefore + amount);
177
170
  }
178
171
 
179
- public async applyBaseSnapshots() {
180
- await this.applyInitialAccountsSnapshot();
181
- await this.applyPublicDeployAccountsSnapshot();
182
- await this.applySetupFeeJuiceSnapshot();
183
- await this.applyDeployBananaTokenSnapshot();
172
+ public async applyBaseSetup() {
173
+ await this.applyInitialAccounts();
174
+ await this.applyPublicDeployAccounts();
175
+ await this.applySetupFeeJuice();
176
+ await this.applyDeployBananaToken();
184
177
  }
185
178
 
186
- async applyInitialAccountsSnapshot() {
187
- await this.snapshotManager.snapshot(
188
- 'initial_accounts',
189
- deployAccounts(this.numberOfAccounts, this.logger),
190
- async ({ deployedAccounts }, { wallet, aztecNode, cheatCodes }) => {
191
- this.wallet = wallet;
192
- this.aztecNode = aztecNode;
193
- this.aztecNodeAdmin = aztecNode;
194
- this.gasSettings = GasSettings.default({ maxFeesPerGas: (await this.aztecNode.getCurrentMinFees()).mul(2) });
195
- this.cheatCodes = cheatCodes;
196
- this.accounts = deployedAccounts.map(a => a.address);
197
- this.accounts.forEach((a, i) => this.logger.verbose(`Account ${i} address: ${a}`));
198
- [this.aliceAddress, this.bobAddress, this.sequencerAddress] = this.accounts.slice(0, 3);
199
-
200
- // We set Alice as the FPC admin to avoid the need for deployment of another account.
201
- this.fpcAdmin = this.aliceAddress;
202
-
203
- const canonicalFeeJuice = await getCanonicalFeeJuice();
204
- this.feeJuiceContract = FeeJuiceContract.at(canonicalFeeJuice.address, this.wallet);
205
- },
206
- );
179
+ async applyInitialAccounts() {
180
+ this.logger.info('Applying initial accounts setup');
181
+
182
+ const { deployedAccounts } = await deployAccounts(
183
+ this.numberOfAccounts,
184
+ this.logger,
185
+ )({
186
+ wallet: this.context.wallet,
187
+ initialFundedAccounts: this.context.initialFundedAccounts,
188
+ });
189
+
190
+ this.wallet = this.context.wallet;
191
+ this.aztecNode = this.context.aztecNodeService!;
192
+ this.aztecNodeAdmin = this.context.aztecNodeService!;
193
+ this.gasSettings = GasSettings.default({ maxFeesPerGas: (await this.aztecNode.getCurrentMinFees()).mul(2) });
194
+ this.cheatCodes = this.context.cheatCodes;
195
+ this.accounts = deployedAccounts.map(a => a.address);
196
+ this.accounts.forEach((a, i) => this.logger.verbose(`Account ${i} address: ${a}`));
197
+ [this.aliceAddress, this.bobAddress, this.sequencerAddress] = this.accounts.slice(0, 3);
198
+
199
+ // We set Alice as the FPC admin to avoid the need for deployment of another account.
200
+ this.fpcAdmin = this.aliceAddress;
201
+
202
+ const canonicalFeeJuice = await getCanonicalFeeJuice();
203
+ this.feeJuiceContract = FeeJuiceContract.at(canonicalFeeJuice.address, this.wallet);
207
204
  }
208
205
 
209
- async applyPublicDeployAccountsSnapshot() {
210
- await this.snapshotManager.snapshot('public_deploy_accounts', () =>
211
- ensureAccountContractsPublished(this.wallet, this.accounts),
212
- );
206
+ async applyPublicDeployAccounts() {
207
+ this.logger.info('Applying public deploy accounts setup');
208
+ await publicDeployAccounts(this.wallet, this.accounts);
213
209
  }
214
210
 
215
- async applySetupFeeJuiceSnapshot() {
216
- await this.snapshotManager.snapshot(
217
- 'setup_fee_juice',
218
- async () => {},
219
- async (_data, context) => {
220
- this.context = context;
221
-
222
- this.feeJuiceContract = FeeJuiceContract.at(ProtocolContractAddress.FeeJuice, this.wallet);
223
-
224
- this.getGasBalanceFn = getBalancesFn(
225
- '⛽',
226
- this.feeJuiceContract.methods.balance_of_public,
227
- this.aliceAddress,
228
- this.logger,
229
- );
230
-
231
- this.feeJuiceBridgeTestHarness = await FeeJuicePortalTestingHarnessFactory.create({
232
- aztecNode: context.aztecNode,
233
- aztecNodeAdmin: context.aztecNode,
234
- l1Client: context.deployL1ContractsValues.l1Client,
235
- wallet: this.wallet,
236
- logger: this.logger,
237
- });
238
- },
211
+ async applySetupFeeJuice() {
212
+ this.logger.info('Applying fee juice setup');
213
+
214
+ this.feeJuiceContract = FeeJuiceContract.at(ProtocolContractAddress.FeeJuice, this.wallet);
215
+
216
+ this.getGasBalanceFn = getBalancesFn(
217
+ '⛽',
218
+ this.feeJuiceContract.methods.balance_of_public,
219
+ this.aliceAddress,
220
+ this.logger,
239
221
  );
222
+
223
+ this.feeJuiceBridgeTestHarness = await FeeJuicePortalTestingHarnessFactory.create({
224
+ aztecNode: this.context.aztecNodeService!,
225
+ aztecNodeAdmin: this.context.aztecNodeService!,
226
+ l1Client: this.context.deployL1ContractsValues.l1Client,
227
+ wallet: this.wallet,
228
+ logger: this.logger,
229
+ });
240
230
  }
241
231
 
242
- async applyDeployBananaTokenSnapshot() {
243
- await this.snapshotManager.snapshot(
244
- 'deploy_banana_token',
245
- async () => {
246
- const bananaCoin = await BananaCoin.deploy(this.wallet, this.aliceAddress, 'BC', 'BC', 18n)
247
- .send({ from: this.aliceAddress })
248
- .deployed();
249
- this.logger.info(`BananaCoin deployed at ${bananaCoin.address}`);
250
- return { bananaCoinAddress: bananaCoin.address };
251
- },
252
- ({ bananaCoinAddress }) => {
253
- this.bananaCoin = BananaCoin.at(bananaCoinAddress, this.wallet);
254
- const logger = this.logger;
255
- this.getBananaPublicBalanceFn = getBalancesFn(
256
- '🍌.public',
257
- this.bananaCoin.methods.balance_of_public,
258
- this.aliceAddress,
259
- logger,
260
- );
261
- this.getBananaPrivateBalanceFn = getBalancesFn(
262
- '🍌.private',
263
- this.bananaCoin.methods.balance_of_private,
264
- this.aliceAddress,
265
- logger,
266
- );
267
- return Promise.resolve();
268
- },
232
+ async applyDeployBananaToken() {
233
+ this.logger.info('Applying deploy banana token setup');
234
+
235
+ const bananaCoin = await BananaCoin.deploy(this.wallet, this.aliceAddress, 'BC', 'BC', 18n).send({
236
+ from: this.aliceAddress,
237
+ });
238
+ this.logger.info(`BananaCoin deployed at ${bananaCoin.address}`);
239
+
240
+ this.bananaCoin = bananaCoin;
241
+ this.getBananaPublicBalanceFn = getBalancesFn(
242
+ '🍌.public',
243
+ this.bananaCoin.methods.balance_of_public,
244
+ this.aliceAddress,
245
+ this.logger,
246
+ );
247
+ this.getBananaPrivateBalanceFn = getBalancesFn(
248
+ '🍌.private',
249
+ this.bananaCoin.methods.balance_of_private,
250
+ this.aliceAddress,
251
+ this.logger,
269
252
  );
270
253
  }
271
254
 
272
- public async applyFPCSetupSnapshot() {
273
- await this.snapshotManager.snapshot(
274
- 'fpc_setup',
275
- async context => {
276
- const feeJuiceContract = this.feeJuiceBridgeTestHarness.feeJuice;
277
- expect((await context.wallet.getContractMetadata(feeJuiceContract.address)).isContractPublished).toBe(true);
278
-
279
- const bananaCoin = this.bananaCoin;
280
- const bananaFPC = await FPCContract.deploy(this.wallet, bananaCoin.address, this.fpcAdmin)
281
- .send({ from: this.aliceAddress })
282
- .deployed();
283
-
284
- this.logger.info(`BananaPay deployed at ${bananaFPC.address}`);
285
-
286
- await this.feeJuiceBridgeTestHarness.bridgeFromL1ToL2(bananaFPC.address, this.aliceAddress);
287
-
288
- return {
289
- bananaFPCAddress: bananaFPC.address,
290
- feeJuiceAddress: feeJuiceContract.address,
291
- l1FeeJuiceAddress: this.feeJuiceBridgeTestHarness.l1FeeJuiceAddress,
292
- rollupAddress: context.deployL1ContractsValues.l1ContractAddresses.rollupAddress,
293
- };
294
- },
295
- (data, context) => {
296
- const bananaFPC = FPCContract.at(data.bananaFPCAddress, this.wallet);
297
- this.bananaFPC = bananaFPC;
298
-
299
- this.getCoinbaseBalance = async () => {
300
- const l1Client = createExtendedL1Client(context.aztecNodeConfig.l1RpcUrls, MNEMONIC);
301
- const gasL1 = getContract({
302
- address: data.l1FeeJuiceAddress.toString(),
303
- abi: TestERC20Abi,
304
- client: l1Client,
305
- });
306
- return await gasL1.read.balanceOf([this.coinbase.toString()]);
307
- };
308
-
309
- this.getCoinbaseSequencerRewards = async () => {
310
- return await this.rollupContract.getSequencerRewards(this.coinbase);
311
- };
312
-
313
- this.getProverFee = async (blockNumber: BlockNumber) => {
314
- const block = await this.aztecNode.getBlock(blockNumber);
315
-
316
- // @todo @lherskind As we deal with #13601
317
- // Right now the value is from `FeeLib.sol`
318
- const L1_GAS_PER_EPOCH_VERIFIED = 1000000n;
319
-
320
- // We round up
321
- const mulDiv = (a: bigint, b: bigint, c: bigint) => (a * b) / c + ((a * b) % c > 0n ? 1n : 0n);
322
-
323
- const { baseFee } = await this.rollupContract.getL1FeesAt(block!.header.globalVariables.timestamp);
324
- const proverCost =
325
- mulDiv(
326
- mulDiv(L1_GAS_PER_EPOCH_VERIFIED, baseFee, BigInt(await this.rollupContract.getEpochDuration())),
327
- 1n,
328
- await this.rollupContract.getManaTarget(),
329
- ) + (await this.rollupContract.getProvingCostPerMana());
330
-
331
- const price = await this.rollupContract.getFeeAssetPerEth();
332
-
333
- const mana = block!.header.totalManaUsed.toBigInt();
334
- return mulDiv(mana * proverCost, price, 10n ** 9n);
335
- };
336
- return Promise.resolve();
337
- },
338
- );
255
+ public async applyFPCSetup() {
256
+ this.logger.info('Applying FPC setup');
257
+
258
+ const feeJuiceContract = this.feeJuiceBridgeTestHarness.feeJuice;
259
+ expect((await this.wallet.getContractMetadata(feeJuiceContract.address)).isContractPublished).toBe(true);
260
+
261
+ const bananaCoin = this.bananaCoin;
262
+ const bananaFPC = await FPCContract.deploy(this.wallet, bananaCoin.address, this.fpcAdmin).send({
263
+ from: this.aliceAddress,
264
+ });
265
+
266
+ this.logger.info(`BananaPay deployed at ${bananaFPC.address}`);
267
+
268
+ await this.feeJuiceBridgeTestHarness.bridgeFromL1ToL2(bananaFPC.address, this.aliceAddress);
269
+
270
+ this.bananaFPC = bananaFPC;
271
+
272
+ const l1FeeJuiceAddress = this.feeJuiceBridgeTestHarness.l1FeeJuiceAddress;
273
+
274
+ this.getCoinbaseBalance = async () => {
275
+ const l1Client = createExtendedL1Client(this.context.config.l1RpcUrls, MNEMONIC);
276
+ const gasL1 = getContract({
277
+ address: l1FeeJuiceAddress.toString(),
278
+ abi: TestERC20Abi,
279
+ client: l1Client,
280
+ });
281
+ return await gasL1.read.balanceOf([this.coinbase.toString()]);
282
+ };
283
+
284
+ this.getCoinbaseSequencerRewards = async () => {
285
+ return await this.rollupContract.getSequencerRewards(this.coinbase);
286
+ };
287
+
288
+ this.getProverFee = async (blockNumber: BlockNumber) => {
289
+ const block = await this.aztecNode.getBlock(blockNumber);
290
+
291
+ // @todo @lherskind As we deal with #13601
292
+ // Right now the value is from `FeeLib.sol`
293
+ const L1_GAS_PER_EPOCH_VERIFIED = 1000000n;
294
+
295
+ // We round up
296
+ const mulDiv = (a: bigint, b: bigint, c: bigint) => (a * b) / c + ((a * b) % c > 0n ? 1n : 0n);
297
+
298
+ const { baseFee } = await this.rollupContract.getL1FeesAt(block!.header.globalVariables.timestamp);
299
+ const proverCost =
300
+ mulDiv(
301
+ mulDiv(L1_GAS_PER_EPOCH_VERIFIED, baseFee, BigInt(await this.rollupContract.getEpochDuration())),
302
+ 1n,
303
+ await this.rollupContract.getManaTarget(),
304
+ ) + (await this.rollupContract.getProvingCostPerMana());
305
+
306
+ const price = await this.rollupContract.getEthPerFeeAsset();
307
+
308
+ const mana = block!.header.totalManaUsed.toBigInt();
309
+ return mulDiv(mana * proverCost, 10n ** 12n, price);
310
+ };
339
311
  }
340
312
 
341
- public async applySponsoredFPCSetupSnapshot() {
342
- await this.snapshotManager.snapshot(
343
- 'sponsored_fpc_setup',
344
- async context => {
345
- const feeJuiceContract = this.feeJuiceBridgeTestHarness.feeJuice;
346
- expect((await context.wallet.getContractMetadata(feeJuiceContract.address)).isContractPublished).toBe(true);
347
-
348
- const sponsoredFPC = await setupSponsoredFPC(this.wallet);
349
- this.logger.info(`SponsoredFPC at ${sponsoredFPC.address}`);
350
-
351
- return {
352
- sponsoredFPCAddress: sponsoredFPC.address,
353
- };
354
- },
355
- data => {
356
- this.sponsoredFPC = SponsoredFPCContract.at(data.sponsoredFPCAddress, this.wallet);
357
- return Promise.resolve();
358
- },
359
- );
313
+ public async applySponsoredFPCSetup() {
314
+ this.logger.info('Applying sponsored FPC setup');
315
+
316
+ const feeJuiceContract = this.feeJuiceBridgeTestHarness.feeJuice;
317
+ expect((await this.wallet.getContractMetadata(feeJuiceContract.address)).isContractPublished).toBe(true);
318
+
319
+ const sponsoredFPCInstance = await setupSponsoredFPC(this.wallet);
320
+ this.logger.info(`SponsoredFPC at ${sponsoredFPCInstance.address}`);
321
+
322
+ this.sponsoredFPC = SponsoredFPCContract.at(sponsoredFPCInstance.address, this.wallet);
360
323
  }
361
324
 
362
325
  public async applyFundAliceWithBananas() {
363
- await this.snapshotManager.snapshot(
364
- 'fund_alice',
365
- async () => {
366
- await this.mintPrivateBananas(this.ALICE_INITIAL_BANANAS, this.aliceAddress);
367
- await this.bananaCoin.methods
368
- .mint_to_public(this.aliceAddress, this.ALICE_INITIAL_BANANAS)
369
- .send({ from: this.aliceAddress })
370
- .wait();
371
- },
372
- () => Promise.resolve(),
373
- );
326
+ this.logger.info('Applying fund Alice with bananas setup');
327
+
328
+ await this.mintPrivateBananas(this.ALICE_INITIAL_BANANAS, this.aliceAddress);
329
+ await this.bananaCoin.methods
330
+ .mint_to_public(this.aliceAddress, this.ALICE_INITIAL_BANANAS)
331
+ .send({ from: this.aliceAddress });
374
332
  }
375
333
 
376
334
  public async applyFundAliceWithPrivateBananas() {
377
- await this.snapshotManager.snapshot(
378
- 'fund_alice_with_private_bananas',
379
- async () => {
380
- await this.mintPrivateBananas(this.ALICE_INITIAL_BANANAS, this.aliceAddress);
381
- },
382
- () => Promise.resolve(),
383
- );
335
+ this.logger.info('Applying fund Alice with private bananas setup');
336
+
337
+ await this.mintPrivateBananas(this.ALICE_INITIAL_BANANAS, this.aliceAddress);
384
338
  }
385
339
  }
@@ -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
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
 
@@ -32,6 +33,12 @@ export async function writeJson(
32
33
  return `0x${buffer.toString('hex').padStart(size, '0')}`;
33
34
  };
34
35
 
36
+ // Create a checkpoint header for this block
37
+ const checkpointHeader = CheckpointHeader.random({
38
+ slotNumber: block.slot,
39
+ timestamp: block.timestamp,
40
+ });
41
+
35
42
  const jsonObject = {
36
43
  populate: {
37
44
  l1ToL2Content: l1ToL2Content.map(value => asHex(value)),
@@ -50,21 +57,22 @@ export async function writeJson(
50
57
  checkpointNumber: block.number,
51
58
  body: `0x${block.body.toBuffer().toString('hex')}`,
52
59
  header: {
53
- lastArchiveRoot: asHex(block.header.lastArchive.root),
54
- blockHeadersHash: asHex(block.header.blockHeadersHash),
55
- blobsHash: asHex(block.header.blobsHash),
56
- inHash: asHex(block.header.inHash),
57
- slotNumber: Number(block.header.globalVariables.slotNumber),
58
- timestamp: Number(block.header.globalVariables.timestamp),
59
- coinbase: asHex(block.header.globalVariables.coinbase, 40),
60
- feeRecipient: asHex(block.header.globalVariables.feeRecipient),
60
+ lastArchiveRoot: asHex(checkpointHeader.lastArchiveRoot),
61
+ blockHeadersHash: asHex(checkpointHeader.blockHeadersHash),
62
+ blobsHash: asHex(checkpointHeader.blobsHash),
63
+ inHash: asHex(checkpointHeader.inHash),
64
+ outHash: asHex(checkpointHeader.epochOutHash),
65
+ slotNumber: Number(checkpointHeader.slotNumber),
66
+ timestamp: Number(checkpointHeader.timestamp),
67
+ coinbase: asHex(checkpointHeader.coinbase, 40),
68
+ feeRecipient: asHex(checkpointHeader.feeRecipient),
61
69
  gasFees: {
62
- feePerDaGas: Number(block.header.globalVariables.gasFees.feePerDaGas),
63
- feePerL2Gas: Number(block.header.globalVariables.gasFees.feePerL2Gas),
70
+ feePerDaGas: Number(checkpointHeader.gasFees.feePerDaGas),
71
+ feePerL2Gas: Number(checkpointHeader.gasFees.feePerL2Gas),
64
72
  },
65
- totalManaUsed: block.header.totalManaUsed.toNumber(),
73
+ totalManaUsed: checkpointHeader.totalManaUsed.toNumber(),
66
74
  },
67
- headerHash: asHex(block.getCheckpointHeader().hash()),
75
+ headerHash: asHex(checkpointHeader.hash()),
68
76
  numTxs: block.body.txEffects.length,
69
77
  },
70
78
  };