@aztec/end-to-end 0.0.1-commit.343b43af6 → 0.0.1-commit.35158ae7e
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.
- package/dest/bench/client_flows/client_flows_benchmark.d.ts +1 -1
- package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
- package/dest/bench/client_flows/client_flows_benchmark.js +2 -2
- package/dest/e2e_epochs/epochs_test.d.ts +3 -1
- package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
- package/dest/e2e_epochs/epochs_test.js +3 -1
- package/dest/fixtures/e2e_prover_test.d.ts +4 -3
- package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
- package/dest/fixtures/e2e_prover_test.js +3 -5
- package/dest/fixtures/get_bb_config.d.ts +1 -1
- package/dest/fixtures/get_bb_config.d.ts.map +1 -1
- package/dest/fixtures/get_bb_config.js +5 -5
- package/dest/fixtures/setup.d.ts +1 -1
- package/dest/fixtures/setup.d.ts.map +1 -1
- package/dest/fixtures/setup.js +12 -9
- package/dest/shared/uniswap_l1_l2.d.ts +1 -1
- package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
- package/dest/shared/uniswap_l1_l2.js +9 -12
- package/dest/simulators/lending_simulator.d.ts +1 -1
- package/dest/simulators/lending_simulator.d.ts.map +1 -1
- package/dest/simulators/lending_simulator.js +2 -2
- package/dest/simulators/token_simulator.js +1 -1
- package/dest/spartan/setup_test_wallets.d.ts +1 -1
- package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
- package/dest/spartan/setup_test_wallets.js +58 -7
- package/dest/test-wallet/test_wallet.d.ts +10 -17
- package/dest/test-wallet/test_wallet.d.ts.map +1 -1
- package/dest/test-wallet/test_wallet.js +47 -48
- package/dest/test-wallet/worker_wallet_schema.d.ts +2 -2
- package/package.json +39 -40
- package/src/bench/client_flows/client_flows_benchmark.ts +2 -1
- package/src/e2e_epochs/epochs_test.ts +13 -2
- package/src/fixtures/e2e_prover_test.ts +5 -11
- package/src/fixtures/get_bb_config.ts +7 -6
- package/src/fixtures/setup.ts +11 -8
- package/src/shared/uniswap_l1_l2.ts +29 -24
- package/src/simulators/lending_simulator.ts +4 -2
- package/src/simulators/token_simulator.ts +1 -1
- package/src/spartan/setup_test_wallets.ts +53 -7
- package/src/test-wallet/test_wallet.ts +60 -65
package/src/fixtures/setup.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { SchnorrAccountContractArtifact } from '@aztec/accounts/schnorr';
|
|
2
2
|
import { type InitialAccountData, generateSchnorrAccounts } from '@aztec/accounts/testing';
|
|
3
3
|
import { type AztecNodeConfig, AztecNodeService, getConfigEnvVars } from '@aztec/aztec-node';
|
|
4
|
+
import { NO_FROM } from '@aztec/aztec.js/account';
|
|
4
5
|
import { AztecAddress, EthAddress } from '@aztec/aztec.js/addresses';
|
|
5
6
|
import {
|
|
6
7
|
BatchCall,
|
|
@@ -302,6 +303,8 @@ export async function setup(
|
|
|
302
303
|
config.dataDirectory = directoryToCleanup;
|
|
303
304
|
}
|
|
304
305
|
|
|
306
|
+
const dateProvider = new TestDateProvider();
|
|
307
|
+
|
|
305
308
|
if (!config.l1RpcUrls?.length) {
|
|
306
309
|
if (!isAnvilTestChain(chain.id)) {
|
|
307
310
|
throw new Error(`No ETHEREUM_HOSTS set but non anvil chain requested`);
|
|
@@ -311,6 +314,7 @@ export async function setup(
|
|
|
311
314
|
accounts: opts.anvilAccounts,
|
|
312
315
|
port: opts.anvilPort ?? (process.env.ANVIL_PORT ? parseInt(process.env.ANVIL_PORT) : undefined),
|
|
313
316
|
slotsInAnEpoch: opts.anvilSlotsInAnEpoch,
|
|
317
|
+
dateProvider,
|
|
314
318
|
});
|
|
315
319
|
anvil = res.anvil;
|
|
316
320
|
config.l1RpcUrls = [res.rpcUrl];
|
|
@@ -322,8 +326,6 @@ export async function setup(
|
|
|
322
326
|
logger.info(`Logging metrics to ${filename}`);
|
|
323
327
|
setupMetricsLogger(filename);
|
|
324
328
|
}
|
|
325
|
-
|
|
326
|
-
const dateProvider = new TestDateProvider();
|
|
327
329
|
const ethCheatCodes = new EthCheatCodesWithState(config.l1RpcUrls, dateProvider);
|
|
328
330
|
|
|
329
331
|
if (opts.stateLoad) {
|
|
@@ -419,11 +421,12 @@ export async function setup(
|
|
|
419
421
|
await ethCheatCodes.setIntervalMining(config.ethereumSlotDuration);
|
|
420
422
|
}
|
|
421
423
|
|
|
422
|
-
//
|
|
423
|
-
//
|
|
424
|
-
//
|
|
425
|
-
|
|
426
|
-
|
|
424
|
+
// In compose mode (no local anvil), sync dateProvider to L1 time since it may have drifted
|
|
425
|
+
// ahead of system time due to the local-network watcher warping time forward on each filled slot.
|
|
426
|
+
// When running with a local anvil, the dateProvider is kept in sync via the stdout listener.
|
|
427
|
+
if (!anvil) {
|
|
428
|
+
dateProvider.setTime((await ethCheatCodes.lastBlockTimestamp()) * 1000);
|
|
429
|
+
}
|
|
427
430
|
|
|
428
431
|
if (opts.l2StartTime) {
|
|
429
432
|
await ethCheatCodes.warp(opts.l2StartTime, { resetBlockInterval: true });
|
|
@@ -847,7 +850,7 @@ export const deployAccounts =
|
|
|
847
850
|
);
|
|
848
851
|
const deployMethod = await accountManager.getDeployMethod();
|
|
849
852
|
await deployMethod.send({
|
|
850
|
-
from:
|
|
853
|
+
from: NO_FROM,
|
|
851
854
|
skipClassPublication: i !== 0, // Publish the contract class at most once.
|
|
852
855
|
});
|
|
853
856
|
}
|
|
@@ -252,8 +252,12 @@ export const uniswapL1L2TestSuite = (
|
|
|
252
252
|
await wethCrossChainHarness.expectPublicBalanceOnL2(uniswapL2Contract.address, 0n);
|
|
253
253
|
|
|
254
254
|
// Since the outbox is only consumable when the epoch is proven, we need to advance to the next epoch.
|
|
255
|
-
const
|
|
256
|
-
|
|
255
|
+
const swapResult = (await computeL2ToL1MembershipWitness(
|
|
256
|
+
aztecNode,
|
|
257
|
+
swapPrivateLeaf,
|
|
258
|
+
l2UniswapInteractionReceipt.txHash,
|
|
259
|
+
))!;
|
|
260
|
+
const { epochNumber: epoch } = swapResult;
|
|
257
261
|
await cheatCodes.rollup.advanceToEpoch(EpochNumber(epoch + 1));
|
|
258
262
|
await waitForProven(aztecNode, l2UniswapInteractionReceipt, { provenTimeout: 300 });
|
|
259
263
|
|
|
@@ -262,14 +266,17 @@ export const uniswapL1L2TestSuite = (
|
|
|
262
266
|
const daiL1BalanceOfPortalBeforeSwap = await daiCrossChainHarness.getL1BalanceOf(
|
|
263
267
|
daiCrossChainHarness.tokenPortalAddress,
|
|
264
268
|
);
|
|
265
|
-
const
|
|
266
|
-
|
|
269
|
+
const withdrawResult = (await computeL2ToL1MembershipWitness(
|
|
270
|
+
aztecNode,
|
|
271
|
+
withdrawLeaf,
|
|
272
|
+
l2UniswapInteractionReceipt.txHash,
|
|
273
|
+
))!;
|
|
267
274
|
|
|
268
|
-
const swapPrivateL2MessageIndex = swapResult
|
|
269
|
-
const swapPrivateSiblingPath = swapResult
|
|
275
|
+
const swapPrivateL2MessageIndex = swapResult.leafIndex;
|
|
276
|
+
const swapPrivateSiblingPath = swapResult.siblingPath;
|
|
270
277
|
|
|
271
|
-
const withdrawL2MessageIndex = withdrawResult
|
|
272
|
-
const withdrawSiblingPath = withdrawResult
|
|
278
|
+
const withdrawL2MessageIndex = withdrawResult.leafIndex;
|
|
279
|
+
const withdrawSiblingPath = withdrawResult.siblingPath;
|
|
273
280
|
|
|
274
281
|
const withdrawMessageMetadata = {
|
|
275
282
|
_epoch: BigInt(epoch),
|
|
@@ -840,16 +847,15 @@ export const uniswapL1L2TestSuite = (
|
|
|
840
847
|
chainId: new Fr(l1Client.chain.id),
|
|
841
848
|
});
|
|
842
849
|
|
|
843
|
-
const
|
|
844
|
-
const epoch =
|
|
845
|
-
const
|
|
846
|
-
const withdrawResult = await computeL2ToL1MembershipWitness(aztecNode, epoch, withdrawLeaf);
|
|
850
|
+
const swapResult = (await computeL2ToL1MembershipWitness(aztecNode, swapPrivateLeaf, withdrawReceipt.txHash))!;
|
|
851
|
+
const { epochNumber: epoch } = swapResult;
|
|
852
|
+
const withdrawResult = (await computeL2ToL1MembershipWitness(aztecNode, withdrawLeaf, withdrawReceipt.txHash))!;
|
|
847
853
|
|
|
848
|
-
const swapPrivateL2MessageIndex = swapResult
|
|
849
|
-
const swapPrivateSiblingPath = swapResult
|
|
854
|
+
const swapPrivateL2MessageIndex = swapResult.leafIndex;
|
|
855
|
+
const swapPrivateSiblingPath = swapResult.siblingPath;
|
|
850
856
|
|
|
851
|
-
const withdrawL2MessageIndex = withdrawResult
|
|
852
|
-
const withdrawSiblingPath = withdrawResult
|
|
857
|
+
const withdrawL2MessageIndex = withdrawResult.leafIndex;
|
|
858
|
+
const withdrawSiblingPath = withdrawResult.siblingPath;
|
|
853
859
|
|
|
854
860
|
const withdrawMessageMetadata = {
|
|
855
861
|
_epoch: BigInt(epoch),
|
|
@@ -973,16 +979,15 @@ export const uniswapL1L2TestSuite = (
|
|
|
973
979
|
chainId: new Fr(l1Client.chain.id),
|
|
974
980
|
});
|
|
975
981
|
|
|
976
|
-
const
|
|
977
|
-
const epoch =
|
|
978
|
-
const
|
|
979
|
-
const withdrawResult = await computeL2ToL1MembershipWitness(aztecNode, epoch, withdrawLeaf);
|
|
982
|
+
const swapResult = (await computeL2ToL1MembershipWitness(aztecNode, swapPublicLeaf, withdrawReceipt.txHash))!;
|
|
983
|
+
const { epochNumber: epoch } = swapResult;
|
|
984
|
+
const withdrawResult = (await computeL2ToL1MembershipWitness(aztecNode, withdrawLeaf, withdrawReceipt.txHash))!;
|
|
980
985
|
|
|
981
|
-
const swapPublicL2MessageIndex = swapResult
|
|
982
|
-
const swapPublicSiblingPath = swapResult
|
|
986
|
+
const swapPublicL2MessageIndex = swapResult.leafIndex;
|
|
987
|
+
const swapPublicSiblingPath = swapResult.siblingPath;
|
|
983
988
|
|
|
984
|
-
const withdrawL2MessageIndex = withdrawResult
|
|
985
|
-
const withdrawSiblingPath = withdrawResult
|
|
989
|
+
const withdrawL2MessageIndex = withdrawResult.leafIndex;
|
|
990
|
+
const withdrawSiblingPath = withdrawResult.siblingPath;
|
|
986
991
|
|
|
987
992
|
const withdrawMessageMetadata = {
|
|
988
993
|
_epoch: BigInt(epoch),
|
|
@@ -94,7 +94,9 @@ export class LendingSimulator {
|
|
|
94
94
|
|
|
95
95
|
async prepare() {
|
|
96
96
|
this.accumulator = BASE;
|
|
97
|
-
const slot = await this.rollup.getSlotAt(
|
|
97
|
+
const slot = await this.rollup.getSlotAt(
|
|
98
|
+
BigInt(await this.cc.eth.lastBlockTimestamp()) + BigInt(this.ethereumSlotDuration),
|
|
99
|
+
);
|
|
98
100
|
this.time = Number(await this.rollup.getTimestampForSlot(slot));
|
|
99
101
|
}
|
|
100
102
|
|
|
@@ -103,7 +105,7 @@ export class LendingSimulator {
|
|
|
103
105
|
return;
|
|
104
106
|
}
|
|
105
107
|
|
|
106
|
-
const slot = await this.rollup.getSlotAt(BigInt(await this.cc.eth.
|
|
108
|
+
const slot = await this.rollup.getSlotAt(BigInt(await this.cc.eth.lastBlockTimestamp()));
|
|
107
109
|
const targetSlot = SlotNumber(slot + diff);
|
|
108
110
|
const ts = Number(await this.rollup.getTimestampForSlot(targetSlot));
|
|
109
111
|
const timeDiff = ts - this.time;
|
|
@@ -110,7 +110,7 @@ export class TokenSimulator {
|
|
|
110
110
|
chunk(calls, 5).map(batch => new BatchCall(this.defaultWallet, batch).simulate({ from: this.defaultAddress })),
|
|
111
111
|
)
|
|
112
112
|
)
|
|
113
|
-
.
|
|
113
|
+
.flatMap(r => r.result)
|
|
114
114
|
.map(r => r.result);
|
|
115
115
|
expect(results[0]).toEqual(this.totalSupply);
|
|
116
116
|
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { generateSchnorrAccounts } from '@aztec/accounts/testing';
|
|
2
|
+
import { NO_FROM } from '@aztec/aztec.js/account';
|
|
2
3
|
import { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
3
4
|
import { NO_WAIT } from '@aztec/aztec.js/contracts';
|
|
4
5
|
import { L1FeeJuicePortalManager } from '@aztec/aztec.js/ethereum';
|
|
@@ -10,7 +11,7 @@ import type { Wallet } from '@aztec/aztec.js/wallet';
|
|
|
10
11
|
import { createEthereumChain } from '@aztec/ethereum/chain';
|
|
11
12
|
import { createExtendedL1Client } from '@aztec/ethereum/client';
|
|
12
13
|
import type { Logger } from '@aztec/foundation/log';
|
|
13
|
-
import { retryUntil } from '@aztec/foundation/retry';
|
|
14
|
+
import { makeBackoff, retry, retryUntil } from '@aztec/foundation/retry';
|
|
14
15
|
import { TokenContract } from '@aztec/noir-contracts.js/Token';
|
|
15
16
|
import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
|
|
16
17
|
import { registerInitialLocalNetworkAccountsInWallet } from '@aztec/wallets/testing';
|
|
@@ -89,7 +90,7 @@ export async function deploySponsoredTestAccountsWithTokens(
|
|
|
89
90
|
const paymentMethod = new SponsoredFeePaymentMethod(await getSponsoredFPCAddress());
|
|
90
91
|
const recipientDeployMethod = await recipientAccount.getDeployMethod();
|
|
91
92
|
await recipientDeployMethod.send({
|
|
92
|
-
from:
|
|
93
|
+
from: NO_FROM,
|
|
93
94
|
fee: { paymentMethod },
|
|
94
95
|
wait: { timeout: 2400 },
|
|
95
96
|
});
|
|
@@ -97,7 +98,7 @@ export async function deploySponsoredTestAccountsWithTokens(
|
|
|
97
98
|
fundedAccounts.map(async a => {
|
|
98
99
|
const deployMethod = await a.getDeployMethod();
|
|
99
100
|
await deployMethod.send({
|
|
100
|
-
from:
|
|
101
|
+
from: NO_FROM,
|
|
101
102
|
fee: { paymentMethod },
|
|
102
103
|
wait: { timeout: 2400 },
|
|
103
104
|
}); // increase timeout on purpose in order to account for two empty epochs
|
|
@@ -138,15 +139,15 @@ async function deployAccountWithDiagnostics(
|
|
|
138
139
|
): Promise<void> {
|
|
139
140
|
const deployMethod = await account.getDeployMethod();
|
|
140
141
|
let txHash;
|
|
142
|
+
let gasSettings: any;
|
|
141
143
|
try {
|
|
142
|
-
let gasSettings;
|
|
143
144
|
if (estimateGas) {
|
|
144
|
-
const sim = await deployMethod.simulate({ from:
|
|
145
|
+
const sim = await deployMethod.simulate({ from: NO_FROM, fee: { paymentMethod } });
|
|
145
146
|
gasSettings = sim.estimatedGas;
|
|
146
147
|
logger.info(`${accountLabel} estimated gas: DA=${gasSettings.gasLimits.daGas} L2=${gasSettings.gasLimits.l2Gas}`);
|
|
147
148
|
}
|
|
148
149
|
const deployResult = await deployMethod.send({
|
|
149
|
-
from:
|
|
150
|
+
from: NO_FROM,
|
|
150
151
|
fee: { paymentMethod, gasSettings },
|
|
151
152
|
wait: NO_WAIT,
|
|
152
153
|
});
|
|
@@ -169,6 +170,51 @@ async function deployAccountWithDiagnostics(
|
|
|
169
170
|
});
|
|
170
171
|
throw error;
|
|
171
172
|
}
|
|
173
|
+
|
|
174
|
+
// Track the tx hash across retries so we don't re-send when the previous tx is still pending.
|
|
175
|
+
let sentTxHash: { txHash: any } | undefined;
|
|
176
|
+
|
|
177
|
+
await retry(
|
|
178
|
+
async () => {
|
|
179
|
+
// Check if already deployed (handles case where previous attempt succeeded but waitForTx timed out)
|
|
180
|
+
const existing = await aztecNode.getContract(account.address);
|
|
181
|
+
if (existing) {
|
|
182
|
+
logger.info(`${accountLabel} already deployed at ${account.address}, skipping`);
|
|
183
|
+
return;
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
// If we already sent a tx, check if it was dropped before deciding to re-send.
|
|
187
|
+
if (sentTxHash) {
|
|
188
|
+
const prevReceipt = await aztecNode.getTxReceipt(sentTxHash.txHash);
|
|
189
|
+
if (prevReceipt.isDropped()) {
|
|
190
|
+
logger.info(`${accountLabel} previous tx ${sentTxHash.txHash} was dropped, re-sending`);
|
|
191
|
+
sentTxHash = undefined;
|
|
192
|
+
} else {
|
|
193
|
+
logger.info(`${accountLabel} previous tx ${sentTxHash.txHash} still pending, waiting again...`);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
if (!sentTxHash) {
|
|
198
|
+
const deployResult = await deployMethod.send({
|
|
199
|
+
from: AztecAddress.ZERO,
|
|
200
|
+
fee: { paymentMethod, gasSettings },
|
|
201
|
+
wait: NO_WAIT,
|
|
202
|
+
});
|
|
203
|
+
sentTxHash = { txHash: deployResult.txHash };
|
|
204
|
+
logger.info(`${accountLabel} tx sent`, { txHash: sentTxHash.txHash.toString() });
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
const receipt = await waitForTx(aztecNode, sentTxHash.txHash, { timeout: 600 });
|
|
208
|
+
if (receipt.isDropped()) {
|
|
209
|
+
sentTxHash = undefined;
|
|
210
|
+
throw new Error(`${accountLabel} tx was dropped, retrying...`);
|
|
211
|
+
}
|
|
212
|
+
logger.info(`${accountLabel} deployed at ${account.address}`);
|
|
213
|
+
},
|
|
214
|
+
`deploy ${accountLabel}`,
|
|
215
|
+
makeBackoff([1, 2, 4, 8, 16]),
|
|
216
|
+
logger,
|
|
217
|
+
);
|
|
172
218
|
}
|
|
173
219
|
|
|
174
220
|
async function deployAccountsInBatches(
|
|
@@ -269,7 +315,7 @@ export async function deployTestAccountsWithTokens(
|
|
|
269
315
|
fundedAccounts.map(async (a, i) => {
|
|
270
316
|
const paymentMethod = new FeeJuicePaymentMethodWithClaim(a.address, claims[i]);
|
|
271
317
|
const deployMethod = await a.getDeployMethod();
|
|
272
|
-
await deployMethod.send({ from:
|
|
318
|
+
await deployMethod.send({ from: NO_FROM, fee: { paymentMethod } });
|
|
273
319
|
logger.info(`Account deployed at ${a.address}`);
|
|
274
320
|
}),
|
|
275
321
|
);
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { EcdsaKAccountContract, EcdsaRAccountContract } from '@aztec/accounts/ecdsa';
|
|
2
2
|
import { SchnorrAccountContract } from '@aztec/accounts/schnorr';
|
|
3
3
|
import { StubAccountContractArtifact, createStubAccount } from '@aztec/accounts/stub';
|
|
4
|
-
import { type Account, type AccountContract,
|
|
4
|
+
import { type Account, type AccountContract, NO_FROM } from '@aztec/aztec.js/account';
|
|
5
5
|
import {
|
|
6
6
|
type CallIntent,
|
|
7
7
|
type ContractFunctionInteractionCallIntent,
|
|
@@ -14,9 +14,10 @@ import {
|
|
|
14
14
|
import type { AztecNode } from '@aztec/aztec.js/node';
|
|
15
15
|
import { AccountManager, type SendOptions } from '@aztec/aztec.js/wallet';
|
|
16
16
|
import type { DefaultAccountEntrypointOptions } from '@aztec/entrypoints/account';
|
|
17
|
+
import { DefaultEntrypoint } from '@aztec/entrypoints/default';
|
|
17
18
|
import { Fq, Fr } from '@aztec/foundation/curves/bn254';
|
|
18
19
|
import { GrumpkinScalar } from '@aztec/foundation/curves/grumpkin';
|
|
19
|
-
import type {
|
|
20
|
+
import type { NotesFilter } from '@aztec/pxe/client/lazy';
|
|
20
21
|
import { type PXEConfig, getPXEConfig } from '@aztec/pxe/config';
|
|
21
22
|
import { PXE, type PXECreationOptions, createPXE } from '@aztec/pxe/server';
|
|
22
23
|
import { AuthWitness } from '@aztec/stdlib/auth-witness';
|
|
@@ -24,9 +25,16 @@ import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
|
24
25
|
import { getContractInstanceFromInstantiationParams } from '@aztec/stdlib/contract';
|
|
25
26
|
import { deriveSigningKey } from '@aztec/stdlib/keys';
|
|
26
27
|
import type { NoteDao } from '@aztec/stdlib/note';
|
|
27
|
-
import type {
|
|
28
|
+
import type {
|
|
29
|
+
BlockHeader,
|
|
30
|
+
SimulationOverrides,
|
|
31
|
+
TxExecutionRequest,
|
|
32
|
+
TxHash,
|
|
33
|
+
TxReceipt,
|
|
34
|
+
TxSimulationResult,
|
|
35
|
+
} from '@aztec/stdlib/tx';
|
|
28
36
|
import { ExecutionPayload, mergeExecutionPayloads } from '@aztec/stdlib/tx';
|
|
29
|
-
import { BaseWallet, type
|
|
37
|
+
import { BaseWallet, type SimulateViaEntrypointOptions } from '@aztec/wallet-sdk/base-wallet';
|
|
30
38
|
|
|
31
39
|
import { AztecNodeProxy, ProvenTx } from './utils.js';
|
|
32
40
|
|
|
@@ -104,10 +112,7 @@ export class TestWallet extends BaseWallet {
|
|
|
104
112
|
|
|
105
113
|
async getFakeAccountDataFor(address: AztecAddress) {
|
|
106
114
|
const originalAccount = await this.getAccountFromAddress(address);
|
|
107
|
-
|
|
108
|
-
throw new Error(`Cannot create fake account data for SignerlessAccount at address: ${address}`);
|
|
109
|
-
}
|
|
110
|
-
const originalAddress = (originalAccount as Account).getCompleteAddress();
|
|
115
|
+
const originalAddress = originalAccount.getCompleteAddress();
|
|
111
116
|
const contractInstance = await this.pxe.getContractInstance(originalAddress.address);
|
|
112
117
|
if (!contractInstance) {
|
|
113
118
|
throw new Error(`No contract instance found for address: ${originalAddress.address}`);
|
|
@@ -125,21 +130,15 @@ export class TestWallet extends BaseWallet {
|
|
|
125
130
|
protected accounts: Map<string, Account> = new Map();
|
|
126
131
|
|
|
127
132
|
/**
|
|
128
|
-
*
|
|
129
|
-
*
|
|
130
|
-
*
|
|
131
|
-
*
|
|
132
|
-
* generating kernel witnesses. When false, simulateViaEntrypoint defers to the standard
|
|
133
|
-
* simulation path via the real account entrypoint.
|
|
133
|
+
* Controls how the test wallet simulates transactions:
|
|
134
|
+
* - `kernelless`: Skips kernel circuits but uses the real account contract. Default.
|
|
135
|
+
* - `kernelless-override`: Skips kernels and replaces the account with a stub that doesn't do authwit validation.
|
|
136
|
+
* - `full`: Uses real kernel circuits and real account contracts. Slow!
|
|
134
137
|
*/
|
|
135
|
-
private
|
|
136
|
-
|
|
137
|
-
enableSimulatedSimulations() {
|
|
138
|
-
this.simulatedSimulations = true;
|
|
139
|
-
}
|
|
138
|
+
private simulationMode: 'kernelless' | 'kernelless-override' | 'full' = 'kernelless';
|
|
140
139
|
|
|
141
|
-
|
|
142
|
-
this.
|
|
140
|
+
setSimulationMode(mode: 'kernelless' | 'kernelless-override' | 'full') {
|
|
141
|
+
this.simulationMode = mode;
|
|
143
142
|
}
|
|
144
143
|
|
|
145
144
|
setMinFeePadding(value?: number) {
|
|
@@ -147,12 +146,7 @@ export class TestWallet extends BaseWallet {
|
|
|
147
146
|
}
|
|
148
147
|
|
|
149
148
|
protected getAccountFromAddress(address: AztecAddress): Promise<Account> {
|
|
150
|
-
|
|
151
|
-
if (address.equals(AztecAddress.ZERO)) {
|
|
152
|
-
account = new SignerlessAccount();
|
|
153
|
-
} else {
|
|
154
|
-
account = this.accounts.get(address?.toString() ?? '');
|
|
155
|
-
}
|
|
149
|
+
const account = this.accounts.get(address?.toString() ?? '');
|
|
156
150
|
|
|
157
151
|
if (!account) {
|
|
158
152
|
throw new Error(`Account not found in wallet for address: ${address}`);
|
|
@@ -220,54 +214,55 @@ export class TestWallet extends BaseWallet {
|
|
|
220
214
|
return account.createAuthWit(intentInnerHash, chainInfo);
|
|
221
215
|
}
|
|
222
216
|
|
|
223
|
-
/**
|
|
224
|
-
* Override simulateViaEntrypoint to use fake accounts for kernelless simulation
|
|
225
|
-
* when simulatedSimulations is enabled. Otherwise falls through to the real entrypoint path.
|
|
226
|
-
*/
|
|
227
217
|
protected override async simulateViaEntrypoint(
|
|
228
218
|
executionPayload: ExecutionPayload,
|
|
229
|
-
|
|
230
|
-
feeOptions: FeeOptions,
|
|
231
|
-
scopes: AccessScopes,
|
|
232
|
-
skipTxValidation?: boolean,
|
|
233
|
-
skipFeeEnforcement?: boolean,
|
|
219
|
+
opts: SimulateViaEntrypointOptions,
|
|
234
220
|
): Promise<TxSimulationResult> {
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
executionPayload,
|
|
238
|
-
from,
|
|
239
|
-
feeOptions,
|
|
240
|
-
scopes,
|
|
241
|
-
skipTxValidation,
|
|
242
|
-
skipFeeEnforcement,
|
|
243
|
-
);
|
|
244
|
-
}
|
|
245
|
-
|
|
221
|
+
const { from, feeOptions, scopes, skipTxValidation, skipFeeEnforcement } = opts;
|
|
222
|
+
const skipKernels = this.simulationMode !== 'full';
|
|
246
223
|
const feeExecutionPayload = await feeOptions.walletFeePaymentMethod?.getExecutionPayload();
|
|
247
|
-
const executionOptions: DefaultAccountEntrypointOptions = {
|
|
248
|
-
txNonce: Fr.random(),
|
|
249
|
-
cancellable: this.cancellableTransactions,
|
|
250
|
-
feePaymentMethodOptions: feeOptions.accountFeePaymentMethodOptions,
|
|
251
|
-
};
|
|
252
224
|
const finalExecutionPayload = feeExecutionPayload
|
|
253
225
|
? mergeExecutionPayloads([feeExecutionPayload, executionPayload])
|
|
254
226
|
: executionPayload;
|
|
255
|
-
const { account: fromAccount, instance, artifact } = await this.getFakeAccountDataFor(from);
|
|
256
227
|
const chainInfo = await this.getChainInfo();
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
228
|
+
|
|
229
|
+
let overrides: SimulationOverrides | undefined;
|
|
230
|
+
let txRequest: TxExecutionRequest;
|
|
231
|
+
if (from === NO_FROM) {
|
|
232
|
+
const entrypoint = new DefaultEntrypoint();
|
|
233
|
+
txRequest = await entrypoint.createTxExecutionRequest(finalExecutionPayload, feeOptions.gasSettings, chainInfo);
|
|
234
|
+
} else {
|
|
235
|
+
const useOverride = this.simulationMode === 'kernelless-override';
|
|
236
|
+
let fromAccount: Account;
|
|
237
|
+
if (useOverride) {
|
|
238
|
+
const { account, instance, artifact } = await this.getFakeAccountDataFor(from);
|
|
239
|
+
fromAccount = account;
|
|
240
|
+
overrides = {
|
|
241
|
+
contracts: { [from.toString()]: { instance, artifact } },
|
|
242
|
+
};
|
|
243
|
+
} else {
|
|
244
|
+
fromAccount = await this.getAccountFromAddress(from);
|
|
245
|
+
}
|
|
246
|
+
const executionOptions: DefaultAccountEntrypointOptions = {
|
|
247
|
+
txNonce: Fr.random(),
|
|
248
|
+
cancellable: this.cancellableTransactions,
|
|
249
|
+
// If from is an address, feeOptions include the way the account contract should handle the fee payment
|
|
250
|
+
feePaymentMethodOptions: feeOptions.accountFeePaymentMethodOptions!,
|
|
251
|
+
};
|
|
252
|
+
txRequest = await fromAccount.createTxExecutionRequest(
|
|
253
|
+
finalExecutionPayload,
|
|
254
|
+
feeOptions.gasSettings,
|
|
255
|
+
chainInfo,
|
|
256
|
+
executionOptions,
|
|
257
|
+
);
|
|
258
|
+
}
|
|
259
|
+
|
|
266
260
|
return this.pxe.simulateTx(txRequest, {
|
|
267
261
|
simulatePublic: true,
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
262
|
+
skipKernels,
|
|
263
|
+
skipFeeEnforcement,
|
|
264
|
+
skipTxValidation,
|
|
265
|
+
overrides,
|
|
271
266
|
scopes,
|
|
272
267
|
});
|
|
273
268
|
}
|