@aztec/end-to-end 0.0.1-commit.6230a0c → 0.0.1-commit.643667a5cb

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 (146) hide show
  1. package/dest/bench/client_flows/client_flows_benchmark.d.ts +2 -2
  2. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  3. package/dest/bench/client_flows/client_flows_benchmark.js +3 -3
  4. package/dest/bench/client_flows/config.d.ts +2 -2
  5. package/dest/bench/client_flows/config.d.ts.map +1 -1
  6. package/dest/bench/client_flows/config.js +18 -0
  7. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +4 -2
  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 +10 -0
  10. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +2 -2
  11. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  12. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +3 -2
  13. package/dest/e2e_deploy_contract/deploy_test.d.ts +2 -2
  14. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  15. package/dest/e2e_epochs/epochs_test.d.ts +9 -7
  16. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  17. package/dest/e2e_epochs/epochs_test.js +58 -33
  18. package/dest/e2e_fees/fees_test.d.ts +2 -2
  19. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  20. package/dest/e2e_fees/fees_test.js +5 -5
  21. package/dest/e2e_p2p/p2p_network.d.ts +2 -2
  22. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  23. package/dest/e2e_p2p/p2p_network.js +16 -2
  24. package/dest/e2e_p2p/reqresp/utils.d.ts +3 -3
  25. package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -1
  26. package/dest/e2e_p2p/reqresp/utils.js +32 -8
  27. package/dest/e2e_p2p/shared.d.ts +2 -2
  28. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  29. package/dest/e2e_p2p/shared.js +5 -1
  30. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
  31. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
  32. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
  33. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
  34. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
  35. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
  36. package/dest/e2e_token_contract/token_contract_test.d.ts +4 -2
  37. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  38. package/dest/e2e_token_contract/token_contract_test.js +10 -0
  39. package/dest/fixtures/authwit_proxy.d.ts +15 -0
  40. package/dest/fixtures/authwit_proxy.d.ts.map +1 -0
  41. package/dest/fixtures/authwit_proxy.js +30 -0
  42. package/dest/fixtures/e2e_prover_test.d.ts +4 -4
  43. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  44. package/dest/fixtures/e2e_prover_test.js +27 -34
  45. package/dest/fixtures/fixtures.d.ts +5 -1
  46. package/dest/fixtures/fixtures.d.ts.map +1 -1
  47. package/dest/fixtures/fixtures.js +6 -0
  48. package/dest/fixtures/ha_setup.d.ts +1 -1
  49. package/dest/fixtures/ha_setup.d.ts.map +1 -1
  50. package/dest/fixtures/ha_setup.js +3 -1
  51. package/dest/fixtures/setup.d.ts +39 -22
  52. package/dest/fixtures/setup.d.ts.map +1 -1
  53. package/dest/fixtures/setup.js +59 -149
  54. package/dest/fixtures/setup_p2p_test.d.ts +15 -7
  55. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  56. package/dest/fixtures/setup_p2p_test.js +18 -12
  57. package/dest/fixtures/token_utils.d.ts +2 -2
  58. package/dest/fixtures/token_utils.d.ts.map +1 -1
  59. package/dest/fixtures/token_utils.js +3 -2
  60. package/dest/shared/index.d.ts +2 -1
  61. package/dest/shared/index.d.ts.map +1 -1
  62. package/dest/shared/index.js +1 -0
  63. package/dest/shared/mock_state_view.d.ts +86 -0
  64. package/dest/shared/mock_state_view.d.ts.map +1 -0
  65. package/dest/shared/mock_state_view.js +186 -0
  66. package/dest/shared/submit-transactions.d.ts +2 -2
  67. package/dest/shared/submit-transactions.d.ts.map +1 -1
  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 +8 -6
  71. package/dest/simulators/token_simulator.d.ts +1 -1
  72. package/dest/simulators/token_simulator.d.ts.map +1 -1
  73. package/dest/simulators/token_simulator.js +2 -23
  74. package/dest/spartan/setup_test_wallets.d.ts +9 -2
  75. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  76. package/dest/spartan/setup_test_wallets.js +31 -1
  77. package/dest/spartan/utils/bot.d.ts +3 -2
  78. package/dest/spartan/utils/bot.d.ts.map +1 -1
  79. package/dest/spartan/utils/bot.js +2 -1
  80. package/dest/spartan/utils/index.d.ts +2 -2
  81. package/dest/spartan/utils/index.d.ts.map +1 -1
  82. package/dest/spartan/utils/index.js +1 -1
  83. package/dest/spartan/utils/k8s.d.ts +3 -1
  84. package/dest/spartan/utils/k8s.d.ts.map +1 -1
  85. package/dest/spartan/utils/k8s.js +6 -0
  86. package/dest/spartan/utils/nodes.d.ts +4 -5
  87. package/dest/spartan/utils/nodes.d.ts.map +1 -1
  88. package/dest/spartan/utils/nodes.js +8 -8
  89. package/dest/test-wallet/test_wallet.d.ts +83 -0
  90. package/dest/test-wallet/test_wallet.d.ts.map +1 -0
  91. package/dest/test-wallet/test_wallet.js +214 -0
  92. package/dest/test-wallet/utils.d.ts +41 -0
  93. package/dest/test-wallet/utils.d.ts.map +1 -0
  94. package/dest/test-wallet/utils.js +71 -0
  95. package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
  96. package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
  97. package/dest/test-wallet/wallet_worker_script.js +48 -0
  98. package/dest/test-wallet/worker_wallet.d.ts +52 -0
  99. package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
  100. package/dest/test-wallet/worker_wallet.js +151 -0
  101. package/dest/test-wallet/worker_wallet_schema.d.ts +274 -0
  102. package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
  103. package/dest/test-wallet/worker_wallet_schema.js +10 -0
  104. package/package.json +40 -39
  105. package/src/bench/client_flows/client_flows_benchmark.ts +8 -12
  106. package/src/bench/client_flows/config.ts +9 -1
  107. package/src/bench/utils.ts +1 -1
  108. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +11 -2
  109. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +7 -8
  110. package/src/e2e_deploy_contract/deploy_test.ts +3 -3
  111. package/src/e2e_epochs/epochs_test.ts +73 -63
  112. package/src/e2e_fees/bridging_race.notest.ts +1 -1
  113. package/src/e2e_fees/fees_test.ts +11 -26
  114. package/src/e2e_nested_contract/nested_contract_test.ts +1 -1
  115. package/src/e2e_p2p/inactivity_slash_test.ts +4 -4
  116. package/src/e2e_p2p/p2p_network.ts +29 -7
  117. package/src/e2e_p2p/reqresp/utils.ts +40 -12
  118. package/src/e2e_p2p/shared.ts +3 -1
  119. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  120. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  121. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  122. package/src/e2e_token_contract/token_contract_test.ts +11 -2
  123. package/src/fixtures/authwit_proxy.ts +50 -0
  124. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  125. package/src/fixtures/e2e_prover_test.ts +28 -38
  126. package/src/fixtures/fixtures.ts +10 -0
  127. package/src/fixtures/ha_setup.ts +3 -1
  128. package/src/fixtures/setup.ts +89 -210
  129. package/src/fixtures/setup_p2p_test.ts +25 -24
  130. package/src/fixtures/token_utils.ts +2 -1
  131. package/src/guides/up_quick_start.sh +3 -3
  132. package/src/shared/index.ts +1 -0
  133. package/src/shared/mock_state_view.ts +188 -0
  134. package/src/shared/submit-transactions.ts +6 -2
  135. package/src/shared/uniswap_l1_l2.ts +9 -11
  136. package/src/simulators/token_simulator.ts +1 -29
  137. package/src/spartan/setup_test_wallets.ts +58 -4
  138. package/src/spartan/utils/bot.ts +4 -1
  139. package/src/spartan/utils/index.ts +1 -0
  140. package/src/spartan/utils/k8s.ts +8 -0
  141. package/src/spartan/utils/nodes.ts +14 -9
  142. package/src/test-wallet/test_wallet.ts +306 -0
  143. package/src/test-wallet/utils.ts +112 -0
  144. package/src/test-wallet/wallet_worker_script.ts +60 -0
  145. package/src/test-wallet/worker_wallet.ts +213 -0
  146. package/src/test-wallet/worker_wallet_schema.ts +13 -0
@@ -3,24 +3,24 @@ import { createLogger } from '@aztec/aztec.js/log';
3
3
  import { waitForTx } from '@aztec/aztec.js/node';
4
4
  import { Tx } from '@aztec/aztec.js/tx';
5
5
  import { RollupContract } from '@aztec/ethereum/contracts';
6
- import { SlotNumber } from '@aztec/foundation/branded-types';
6
+ import { CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
7
7
  import { timesAsync } from '@aztec/foundation/collection';
8
8
  import { retryUntil } from '@aztec/foundation/retry';
9
9
 
10
- import { jest } from '@jest/globals';
10
+ import { expect, jest } from '@jest/globals';
11
11
  import fs from 'fs';
12
12
  import os from 'os';
13
13
  import path from 'path';
14
14
 
15
- import { shouldCollectMetrics } from '../../fixtures/fixtures.js';
15
+ import { getBootNodeUdpPort, shouldCollectMetrics } from '../../fixtures/fixtures.js';
16
16
  import { createNodes } from '../../fixtures/setup_p2p_test.js';
17
- import { P2PNetworkTest, SHORTENED_BLOCK_TIME_CONFIG_NO_PRUNES, WAIT_FOR_TX_TIMEOUT } from '../p2p_network.js';
17
+ import { P2PNetworkTest, WAIT_FOR_TX_TIMEOUT } from '../p2p_network.js';
18
18
  import { prepareTransactions } from '../shared.js';
19
19
 
20
20
  // Don't set this to a higher value than 9 because each node will use a different L1 publisher account and anvil seeds
21
21
  export const NUM_VALIDATORS = 6;
22
- export const NUM_TXS_PER_NODE = 2;
23
- export const BOOT_NODE_UDP_PORT = 4500;
22
+ export const NUM_TXS_PER_NODE = 4;
23
+ export const BOOT_NODE_UDP_PORT = getBootNodeUdpPort();
24
24
 
25
25
  export const createReqrespDataDir = () => fs.mkdtempSync(path.join(os.tmpdir(), 'reqresp-'));
26
26
 
@@ -38,8 +38,14 @@ export async function createReqrespTest(options: ReqrespOptions = {}): Promise<P
38
38
  // To collect metrics - run in aztec-packages `docker compose --profile metrics up`
39
39
  metricsPort: shouldCollectMetrics(),
40
40
  initialConfig: {
41
- ...SHORTENED_BLOCK_TIME_CONFIG_NO_PRUNES,
42
- aztecSlotDuration: 24,
41
+ ethereumSlotDuration: 8,
42
+ aztecSlotDuration: 36,
43
+ blockDurationMs: 6000,
44
+ l1PublishingTime: 8,
45
+ minTxsPerBlock: 1,
46
+ maxTxsPerBlock: 2,
47
+ enforceTimeTable: true,
48
+ aztecProofSubmissionEpochs: 1024, // effectively do not reorg
43
49
  ...(disableStatusHandshake ? { p2pDisableStatusHandshake: true } : {}),
44
50
  listenAddress: '127.0.0.1',
45
51
  aztecEpochDuration: 64, // stable committee
@@ -81,7 +87,7 @@ export async function runReqrespTxTest(params: {
81
87
 
82
88
  const nodes = await createNodes(
83
89
  aztecNodeConfig,
84
- t.ctx.dateProvider!,
90
+ t.ctx.dateProvider,
85
91
  t.bootstrapNodeEnr,
86
92
  NUM_VALIDATORS,
87
93
  BOOT_NODE_UDP_PORT,
@@ -95,7 +101,7 @@ export async function runReqrespTxTest(params: {
95
101
 
96
102
  await t.setupAccount();
97
103
 
98
- const targetBlockNumber = await t.ctx.aztecNodeService!.getBlockNumber();
104
+ const targetBlockNumber = await t.ctx.aztecNodeService.getBlockNumber();
99
105
  await retryUntil(
100
106
  async () => {
101
107
  const blockNumbers = await Promise.all(nodes.map(node => node.getBlockNumber()));
@@ -108,7 +114,7 @@ export async function runReqrespTxTest(params: {
108
114
 
109
115
  t.logger.info('Preparing transactions to send');
110
116
  const txBatches = await timesAsync(2, () =>
111
- prepareTransactions(t.logger, t.ctx.aztecNodeService!, NUM_TXS_PER_NODE, t.fundedAccount),
117
+ prepareTransactions(t.logger, t.ctx.aztecNodeService, NUM_TXS_PER_NODE, t.fundedAccount),
112
118
  );
113
119
 
114
120
  t.logger.info('Removing initial node');
@@ -116,7 +122,7 @@ export async function runReqrespTxTest(params: {
116
122
 
117
123
  t.logger.info('Starting fresh slot');
118
124
  const [timestamp] = await t.ctx.cheatCodes.rollup.advanceToNextSlot();
119
- t.ctx.dateProvider!.setTime(Number(timestamp) * 1000);
125
+ t.ctx.dateProvider.setTime(Number(timestamp) * 1000);
120
126
  const startSlotTimestamp = BigInt(timestamp);
121
127
 
122
128
  const { proposerIndexes, nodesToTurnOffTxGossip } = await getProposerIndexes(t, startSlotTimestamp);
@@ -170,6 +176,28 @@ export async function runReqrespTxTest(params: {
170
176
 
171
177
  t.logger.info('All transactions mined');
172
178
 
179
+ // Assert that multiple blocks were built for at least one slot
180
+ t.logger.info('Verifying multiple blocks for at least one checkpoint');
181
+ const checkpoints = await nodes[0].getCheckpoints(CheckpointNumber(1), 50);
182
+ expect(checkpoints.length).toBeGreaterThan(0);
183
+
184
+ let mbpsFound = false;
185
+ let expectedBlockNumber = checkpoints[0].checkpoint.blocks[0].number;
186
+
187
+ for (const published of checkpoints) {
188
+ const blockCount = published.checkpoint.blocks.length;
189
+ mbpsFound = mbpsFound || blockCount >= 2;
190
+
191
+ for (let i = 0; i < blockCount; i++) {
192
+ const block = published.checkpoint.blocks[i];
193
+ expect(block.indexWithinCheckpoint).toBe(i);
194
+ expect(block.checkpointNumber).toBe(published.checkpoint.number);
195
+ expect(block.number).toBe(expectedBlockNumber);
196
+ expectedBlockNumber++;
197
+ }
198
+ }
199
+
200
+ expect(mbpsFound).toBe(true);
173
201
  return nodes;
174
202
  }
175
203
 
@@ -22,9 +22,10 @@ import { getPXEConfig, getPXEConfig as getRpcConfig } from '@aztec/pxe/server';
22
22
  import { getRoundForOffense } from '@aztec/slasher';
23
23
  import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
24
24
  import type { SlashFactoryContract } from '@aztec/stdlib/l1-contracts';
25
- import { type ProvenTx, TestWallet, proveInteraction } from '@aztec/test-wallet/server';
26
25
 
27
26
  import { submitTxsTo } from '../shared/submit-transactions.js';
27
+ import { TestWallet } from '../test-wallet/test_wallet.js';
28
+ import { type ProvenTx, proveInteraction } from '../test-wallet/utils.js';
28
29
 
29
30
  // submits a set of transactions to the provided Private eXecution Environment (PXE)
30
31
  export const submitComplexTxsTo = async (
@@ -145,6 +146,7 @@ export async function awaitCommitteeExists({
145
146
  'non-empty committee',
146
147
  60,
147
148
  );
149
+ logger.warn(`Committee has been formed`, { committee: committee!.map(c => c.toString()) });
148
150
  return committee!.map(c => c.toString() as `0x${string}`);
149
151
  }
150
152