@aztec/end-to-end 0.0.1-commit.358457c → 0.0.1-commit.3895657bc

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 (88) hide show
  1. package/dest/bench/client_flows/client_flows_benchmark.d.ts +1 -1
  2. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  3. package/dest/bench/client_flows/client_flows_benchmark.js +16 -8
  4. package/dest/bench/utils.d.ts +1 -1
  5. package/dest/bench/utils.d.ts.map +1 -1
  6. package/dest/bench/utils.js +6 -3
  7. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +1 -1
  8. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  9. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +14 -14
  10. package/dest/e2e_fees/fees_test.d.ts +1 -1
  11. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  12. package/dest/e2e_fees/fees_test.js +12 -5
  13. package/dest/e2e_nested_contract/nested_contract_test.d.ts +1 -1
  14. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  15. package/dest/e2e_nested_contract/nested_contract_test.js +4 -6
  16. package/dest/e2e_p2p/p2p_network.d.ts +4 -3
  17. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  18. package/dest/e2e_p2p/p2p_network.js +19 -16
  19. package/dest/e2e_p2p/shared.d.ts +15 -1
  20. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  21. package/dest/e2e_p2p/shared.js +25 -2
  22. package/dest/e2e_token_contract/token_contract_test.d.ts +1 -1
  23. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  24. package/dest/e2e_token_contract/token_contract_test.js +11 -11
  25. package/dest/fixtures/authwit_proxy.d.ts +3 -3
  26. package/dest/fixtures/authwit_proxy.d.ts.map +1 -1
  27. package/dest/fixtures/e2e_prover_test.d.ts +1 -1
  28. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  29. package/dest/fixtures/e2e_prover_test.js +6 -6
  30. package/dest/fixtures/setup.d.ts +3 -4
  31. package/dest/fixtures/setup.d.ts.map +1 -1
  32. package/dest/fixtures/setup.js +3 -3
  33. package/dest/fixtures/token_utils.d.ts +1 -1
  34. package/dest/fixtures/token_utils.d.ts.map +1 -1
  35. package/dest/fixtures/token_utils.js +2 -2
  36. package/dest/shared/cross_chain_test_harness.d.ts +1 -1
  37. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  38. package/dest/shared/cross_chain_test_harness.js +13 -13
  39. package/dest/shared/gas_portal_test_harness.js +2 -2
  40. package/dest/shared/jest_setup.js +32 -1
  41. package/dest/shared/submit-transactions.d.ts +1 -1
  42. package/dest/shared/submit-transactions.d.ts.map +1 -1
  43. package/dest/shared/submit-transactions.js +1 -1
  44. package/dest/shared/uniswap_l1_l2.d.ts +1 -1
  45. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  46. package/dest/shared/uniswap_l1_l2.js +5 -5
  47. package/dest/simulators/lending_simulator.d.ts +1 -1
  48. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  49. package/dest/simulators/lending_simulator.js +2 -2
  50. package/dest/simulators/token_simulator.d.ts +1 -1
  51. package/dest/simulators/token_simulator.d.ts.map +1 -1
  52. package/dest/simulators/token_simulator.js +2 -2
  53. package/dest/spartan/setup_test_wallets.d.ts +1 -1
  54. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  55. package/dest/spartan/setup_test_wallets.js +4 -3
  56. package/dest/spartan/tx_metrics.js +1 -1
  57. package/dest/spartan/utils/config.d.ts +4 -1
  58. package/dest/spartan/utils/config.d.ts.map +1 -1
  59. package/dest/spartan/utils/config.js +2 -1
  60. package/dest/spartan/utils/index.d.ts +2 -1
  61. package/dest/spartan/utils/index.d.ts.map +1 -1
  62. package/dest/spartan/utils/index.js +2 -0
  63. package/dest/spartan/utils/nodes.js +1 -1
  64. package/dest/test-wallet/worker_wallet_schema.d.ts +1 -1
  65. package/package.json +43 -44
  66. package/src/bench/client_flows/client_flows_benchmark.ts +38 -30
  67. package/src/bench/utils.ts +7 -2
  68. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +18 -14
  69. package/src/e2e_fees/fees_test.ts +12 -5
  70. package/src/e2e_nested_contract/nested_contract_test.ts +6 -4
  71. package/src/e2e_p2p/p2p_network.ts +25 -21
  72. package/src/e2e_p2p/shared.ts +45 -2
  73. package/src/e2e_token_contract/token_contract_test.ts +16 -8
  74. package/src/fixtures/e2e_prover_test.ts +11 -5
  75. package/src/fixtures/setup.ts +8 -7
  76. package/src/fixtures/token_utils.ts +4 -2
  77. package/src/shared/cross_chain_test_harness.ts +13 -9
  78. package/src/shared/gas_portal_test_harness.ts +1 -1
  79. package/src/shared/jest_setup.ts +36 -1
  80. package/src/shared/submit-transactions.ts +1 -4
  81. package/src/shared/uniswap_l1_l2.ts +6 -4
  82. package/src/simulators/lending_simulator.ts +4 -2
  83. package/src/simulators/token_simulator.ts +6 -2
  84. package/src/spartan/setup_test_wallets.ts +6 -13
  85. package/src/spartan/tx_metrics.ts +1 -1
  86. package/src/spartan/utils/config.ts +1 -0
  87. package/src/spartan/utils/index.ts +3 -0
  88. package/src/spartan/utils/nodes.ts +1 -1
@@ -1,6 +1,7 @@
1
1
  import { createLogger } from '@aztec/aztec.js/log';
2
2
 
3
- import { afterEach, beforeEach, expect } from '@jest/globals';
3
+ import { afterAll, afterEach, beforeEach, expect } from '@jest/globals';
4
+ import { readlinkSync } from 'fs';
4
5
  import { basename } from 'path';
5
6
 
6
7
  import { EluMonitor } from '../fixtures/elu_monitor.js';
@@ -26,3 +27,37 @@ beforeEach(() => {
26
27
  afterEach(() => {
27
28
  eluMonitor?.stopTest();
28
29
  });
30
+
31
+ // Log leaked handles after all tests complete. This runs after test-level afterAll hooks,
32
+ // so any handles still alive at this point were not properly cleaned up during teardown.
33
+ // This diagnostic helps identify the source of exit hangs without masking them.
34
+ afterAll(() => {
35
+ const handles = (process as any)._getActiveHandles();
36
+ if (handles.length > 0) {
37
+ const details = handles.map((h: any) => {
38
+ const type = h?.constructor?.name ?? typeof h;
39
+ const fd = h?.fd ?? h?._handle?.fd ?? '?';
40
+ const destroyed = h?.destroyed ?? '?';
41
+ const hasRef = typeof h?.hasRef === 'function' ? h.hasRef() : '?';
42
+ const localAddr = h?.localAddress ?? '';
43
+ const remoteAddr = h?.remoteAddress ?? '';
44
+ const localPort = h?.localPort ?? '';
45
+ const remotePort = h?.remotePort ?? '';
46
+ const proto = Object.getPrototypeOf(h)?.constructor?.name ?? '?';
47
+ const keys = Object.keys(h).slice(0, 10).join(',');
48
+ let fdTarget = '';
49
+ if (typeof fd === 'number') {
50
+ try {
51
+ fdTarget = ` -> ${readlinkSync(`/proc/self/fd/${fd}`)}`;
52
+ } catch {
53
+ // ignore
54
+ }
55
+ }
56
+ return ` ${type}(fd=${fd}, destroyed=${destroyed}, hasRef=${hasRef}${fdTarget}) proto=${proto} addr=${localAddr}:${localPort}->${remoteAddr}:${remotePort} keys=[${keys}]`;
57
+ });
58
+ process.stderr.write(
59
+ `\n[jest_setup] WARNING: ${handles.length} handle(s) still active after teardown:\n${details.join('\n')}\n` +
60
+ `These may prevent Jest from exiting. Investigate and fix the leak.\n\n`,
61
+ );
62
+ }
63
+ });
@@ -19,10 +19,7 @@ export const submitTxsTo = async (
19
19
  times(numTxs, async () => {
20
20
  const accountManager = await wallet.createSchnorrAccount(Fr.random(), Fr.random(), GrumpkinScalar.random());
21
21
  const deployMethod = await accountManager.getDeployMethod();
22
- const txHash = await deployMethod.send({
23
- from: submitter,
24
- wait: NO_WAIT,
25
- });
22
+ const { txHash } = await deployMethod.send({ from: submitter, wait: NO_WAIT });
26
23
 
27
24
  logger.info(`Tx sent with hash ${txHash}`);
28
25
  const receipt: TxReceipt = await wallet.getTxReceipt(txHash);
@@ -130,7 +130,9 @@ export const uniswapL1L2TestSuite = (
130
130
  client: l1Client,
131
131
  });
132
132
  // deploy l2 uniswap contract and attach to portal
133
- uniswapL2Contract = await UniswapContract.deploy(wallet, uniswapPortalAddress).send({ from: ownerAddress });
133
+ ({ contract: uniswapL2Contract } = await UniswapContract.deploy(wallet, uniswapPortalAddress).send({
134
+ from: ownerAddress,
135
+ }));
134
136
 
135
137
  const registryAddress = (await aztecNode.getNodeInfo()).l1ContractAddresses.registryAddress;
136
138
 
@@ -195,7 +197,7 @@ export const uniswapL1L2TestSuite = (
195
197
  logger.info('Withdrawing weth to L1 and sending message to swap to dai');
196
198
  const [secretForDepositingSwappedDai, secretHashForDepositingSwappedDai] = await generateClaimSecret();
197
199
 
198
- const l2UniswapInteractionReceipt = await uniswapL2Contract.methods
200
+ const { receipt: l2UniswapInteractionReceipt } = await uniswapL2Contract.methods
199
201
  .swap_private(
200
202
  wethCrossChainHarness.l2Token.address,
201
203
  wethCrossChainHarness.l2Bridge.address,
@@ -787,7 +789,7 @@ export const uniswapL1L2TestSuite = (
787
789
  logger.info('Withdrawing weth to L1 and sending message to swap to dai');
788
790
 
789
791
  const [, secretHashForDepositingSwappedDai] = await generateClaimSecret();
790
- const withdrawReceipt = await uniswapL2Contract.methods
792
+ const { receipt: withdrawReceipt } = await uniswapL2Contract.methods
791
793
  .swap_private(
792
794
  wethCrossChainHarness.l2Token.address,
793
795
  wethCrossChainHarness.l2Bridge.address,
@@ -915,7 +917,7 @@ export const uniswapL1L2TestSuite = (
915
917
 
916
918
  // Call swap_public on L2
917
919
  const secretHashForDepositingSwappedDai = Fr.random();
918
- const withdrawReceipt = await uniswapL2Contract.methods
920
+ const { receipt: withdrawReceipt } = await uniswapL2Contract.methods
919
921
  .swap_public(
920
922
  ownerAddress,
921
923
  wethCrossChainHarness.l2Bridge.address,
@@ -186,14 +186,16 @@ export class LendingSimulator {
186
186
 
187
187
  expect(this.borrowed).toEqual(this.stableCoin.totalSupply - this.mintedOutside);
188
188
 
189
- const asset = await this.lendingContract.methods.get_asset(0).simulate({ from: this.account.address });
189
+ const { result: asset } = await this.lendingContract.methods.get_asset(0).simulate({ from: this.account.address });
190
190
 
191
191
  const interestAccumulator = asset['interest_accumulator'];
192
192
  expect(interestAccumulator).toEqual(this.accumulator);
193
193
  expect(asset['last_updated_ts']).toEqual(BigInt(this.time));
194
194
 
195
195
  for (const key of [this.account.address, AztecAddress.fromField(await this.account.key())]) {
196
- const privatePos = await this.lendingContract.methods.get_position(key).simulate({ from: this.account.address });
196
+ const { result: privatePos } = await this.lendingContract.methods
197
+ .get_position(key)
198
+ .simulate({ from: this.account.address });
197
199
  expect(new Fr(privatePos['collateral'])).toEqual(this.collateral[key.toString()] ?? Fr.ZERO);
198
200
  expect(new Fr(privatePos['static_debt'])).toEqual(this.staticDebt[key.toString()] ?? Fr.ZERO);
199
201
  expect(privatePos['debt']).toEqual(
@@ -109,7 +109,9 @@ export class TokenSimulator {
109
109
  await Promise.all(
110
110
  chunk(calls, 5).map(batch => new BatchCall(this.defaultWallet, batch).simulate({ from: this.defaultAddress })),
111
111
  )
112
- ).flat();
112
+ )
113
+ .flat()
114
+ .map(r => r.result);
113
115
  expect(results[0]).toEqual(this.totalSupply);
114
116
 
115
117
  // Check that all our balances match
@@ -123,7 +125,9 @@ export class TokenSimulator {
123
125
  const wallet = this.lookupProvider.get(address.toString());
124
126
  const asset = wallet ? this.token.withWallet(wallet) : this.token;
125
127
 
126
- const actualPrivateBalance = await asset.methods.balance_of_private(address).simulate({ from: address });
128
+ const { result: actualPrivateBalance } = await asset.methods
129
+ .balance_of_private(address)
130
+ .simulate({ from: address });
127
131
  expect(actualPrivateBalance).toEqual(this.balanceOfPrivate(address));
128
132
  }
129
133
  }
@@ -138,11 +138,8 @@ async function deployAccountWithDiagnostics(
138
138
  const deployMethod = await account.getDeployMethod();
139
139
  let txHash;
140
140
  try {
141
- txHash = await deployMethod.send({
142
- from: AztecAddress.ZERO,
143
- fee: { paymentMethod },
144
- wait: NO_WAIT,
145
- });
141
+ const deployResult = await deployMethod.send({ from: AztecAddress.ZERO, fee: { paymentMethod }, wait: NO_WAIT });
142
+ txHash = deployResult.txHash;
146
143
  await waitForTx(aztecNode, txHash, { timeout: 2400 });
147
144
  logger.info(`${accountLabel} deployed at ${account.address}`);
148
145
  } catch (error) {
@@ -278,7 +275,7 @@ async function bridgeL1FeeJuice(
278
275
  const claim = await portal.bridgeTokensPublic(recipient, amount, true /* mint */);
279
276
 
280
277
  const isSynced = async () =>
281
- (await aztecNode.getL1ToL2MessageBlock(Fr.fromHexString(claim.messageHash))) !== undefined;
278
+ (await aztecNode.getL1ToL2MessageCheckpoint(Fr.fromHexString(claim.messageHash))) !== undefined;
282
279
  await retryUntil(isSynced, `message ${claim.messageHash} sync`, 24, 0.5);
283
280
 
284
281
  log.info(`Created a claim for ${amount} L1 fee juice to ${recipient}.`, claim);
@@ -310,13 +307,9 @@ async function deployTokenAndMint(
310
307
  logger: Logger,
311
308
  ) {
312
309
  logger.verbose(`Deploying TokenContract...`);
313
- const { contract: tokenContract } = await TokenContract.deploy(
314
- wallet,
315
- admin,
316
- TOKEN_NAME,
317
- TOKEN_SYMBOL,
318
- TOKEN_DECIMALS,
319
- ).send({
310
+ const {
311
+ receipt: { contract: tokenContract },
312
+ } = await TokenContract.deploy(wallet, admin, TOKEN_NAME, TOKEN_SYMBOL, TOKEN_DECIMALS).send({
320
313
  from: admin,
321
314
  fee: {
322
315
  paymentMethod,
@@ -296,7 +296,7 @@ export class TxInclusionMetrics {
296
296
  value: stats.mean,
297
297
  },
298
298
  {
299
- name: `${group}/median_inclusion`,
299
+ name: `${group}/p50_inclusion`,
300
300
  unit: 's',
301
301
  value: stats.median,
302
302
  },
@@ -16,6 +16,7 @@ const testConfigSchema = z.object({
16
16
  AZTEC_PROOF_SUBMISSION_WINDOW: z.coerce.number().optional().default(5),
17
17
  AZTEC_LAG_IN_EPOCHS_FOR_VALIDATOR_SET: z.coerce.number().optional().default(2),
18
18
  FUNDING_PRIVATE_KEY: z.string().optional(),
19
+ AZTEC_ADMIN_API_KEY: z.string().optional(),
19
20
  });
20
21
 
21
22
  export type TestConfig = z.infer<typeof testConfigSchema>;
@@ -41,6 +41,9 @@ export {
41
41
  applyNetworkShaping,
42
42
  } from './chaos.js';
43
43
 
44
+ // Helm
45
+ export { hasDeployedHelmRelease } from './helm.js';
46
+
44
47
  // Bot management
45
48
  export { restartBot, installTransferBot, uninstallTransferBot } from './bot.js';
46
49
 
@@ -173,7 +173,7 @@ export async function withSequencersAdmin<T>(env: TestConfig, fn: (node: AztecNo
173
173
  if (statusRes.status !== 200) {
174
174
  throw new Error(`Admin endpoint returned status ${statusRes.status}`);
175
175
  }
176
- const client = createAztecNodeAdminClient(url);
176
+ const client = createAztecNodeAdminClient(url, {}, undefined, env.AZTEC_ADMIN_API_KEY);
177
177
  return { result: await fn(client), process };
178
178
  } catch (err) {
179
179
  // Kill the port-forward before retrying