@aztec/end-to-end 4.0.0-nightly.20260113 → 4.0.0-nightly.20260114
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 +10 -10
- package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
- package/dest/bench/client_flows/client_flows_benchmark.js +98 -133
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +5 -6
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +94 -112
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +5 -5
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +60 -62
- package/dest/e2e_deploy_contract/deploy_test.d.ts +4 -3
- package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
- package/dest/e2e_deploy_contract/deploy_test.js +15 -13
- package/dest/e2e_fees/bridging_race.notest.js +2 -4
- package/dest/e2e_fees/fees_test.d.ts +11 -11
- package/dest/e2e_fees/fees_test.d.ts.map +1 -1
- package/dest/e2e_fees/fees_test.js +118 -139
- package/dest/e2e_l1_publisher/write_json.d.ts +1 -1
- package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
- package/dest/e2e_l1_publisher/write_json.js +1 -0
- package/dest/e2e_nested_contract/nested_contract_test.d.ts +5 -8
- package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
- package/dest/e2e_nested_contract/nested_contract_test.js +29 -40
- package/dest/e2e_p2p/inactivity_slash_test.js +1 -1
- package/dest/e2e_p2p/p2p_network.d.ts +5 -3
- package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
- package/dest/e2e_p2p/p2p_network.js +99 -102
- package/dest/e2e_token_contract/token_contract_test.d.ts +15 -8
- package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
- package/dest/e2e_token_contract/token_contract_test.js +88 -92
- package/dest/fixtures/e2e_prover_test.d.ts +7 -13
- package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
- package/dest/fixtures/e2e_prover_test.js +78 -91
- package/dest/fixtures/snapshot_manager.d.ts +10 -44
- package/dest/fixtures/snapshot_manager.d.ts.map +1 -1
- package/dest/fixtures/snapshot_manager.js +12 -255
- package/dest/fixtures/utils.js +3 -3
- package/dest/quality_of_service/prometheus_client.d.ts +38 -0
- package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
- package/dest/quality_of_service/prometheus_client.js +67 -0
- package/dest/spartan/tx_metrics.d.ts +4 -1
- package/dest/spartan/tx_metrics.d.ts.map +1 -1
- package/dest/spartan/tx_metrics.js +21 -1
- package/dest/spartan/utils.d.ts +5 -1
- package/dest/spartan/utils.d.ts.map +1 -1
- package/dest/spartan/utils.js +25 -8
- package/package.json +38 -38
- package/src/bench/client_flows/client_flows_benchmark.ts +134 -192
- package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +104 -136
- package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +91 -103
- package/src/e2e_deploy_contract/deploy_test.ts +18 -14
- package/src/e2e_fees/bridging_race.notest.ts +2 -5
- package/src/e2e_fees/fees_test.ts +165 -210
- package/src/e2e_l1_publisher/write_json.ts +1 -0
- package/src/e2e_nested_contract/nested_contract_test.ts +30 -54
- package/src/e2e_p2p/inactivity_slash_test.ts +1 -1
- package/src/e2e_p2p/p2p_network.ts +149 -165
- package/src/e2e_token_contract/token_contract_test.ts +104 -113
- package/src/fixtures/e2e_prover_test.ts +97 -130
- package/src/fixtures/snapshot_manager.ts +12 -325
- package/src/fixtures/utils.ts +3 -3
- package/src/quality_of_service/prometheus_client.ts +113 -0
- package/src/spartan/tx_metrics.ts +21 -1
- package/src/spartan/utils.ts +26 -8
|
@@ -15,25 +15,21 @@ import { privateKeyToAddress } from 'viem/accounts';
|
|
|
15
15
|
import { TokenSimulator } from '../simulators/token_simulator.js';
|
|
16
16
|
import { getACVMConfig } from './get_acvm_config.js';
|
|
17
17
|
import { getBBConfig } from './get_bb_config.js';
|
|
18
|
-
import {
|
|
18
|
+
import { deployAccounts, publicDeployAccounts, setupFromFresh, teardown } from './snapshot_manager.js';
|
|
19
19
|
import { getPrivateKeyFromIndex, getSponsoredFPCAddress, setupPXEAndGetWallet } from './utils.js';
|
|
20
|
-
const { E2E_DATA_PATH: dataPath } = process.env;
|
|
21
20
|
/**
|
|
22
21
|
* Largely taken from the e2e_token_contract test file. We deploy 2 accounts and a token contract.
|
|
23
22
|
* However, we then setup a second PXE with a full prover instance.
|
|
24
23
|
* We configure this instance with all of the accounts and contracts.
|
|
25
24
|
* We then prove and verify transactions created via this full prover PXE.
|
|
26
25
|
*/ export class FullProverTest {
|
|
27
|
-
minNumberOfTxsPerBlock;
|
|
28
|
-
realProofs;
|
|
29
26
|
static TOKEN_NAME = 'USDC';
|
|
30
27
|
static TOKEN_SYMBOL = 'USD';
|
|
31
28
|
static TOKEN_DECIMALS = 18n;
|
|
32
|
-
snapshotManager;
|
|
33
29
|
logger;
|
|
34
30
|
wallet;
|
|
35
31
|
provenWallet;
|
|
36
|
-
accounts;
|
|
32
|
+
accounts = [];
|
|
37
33
|
deployedAccounts;
|
|
38
34
|
fakeProofsAsset;
|
|
39
35
|
fakeProofsAssetInstance;
|
|
@@ -41,7 +37,7 @@ const { E2E_DATA_PATH: dataPath } = process.env;
|
|
|
41
37
|
aztecNode;
|
|
42
38
|
aztecNodeAdmin;
|
|
43
39
|
cheatCodes;
|
|
44
|
-
provenComponents;
|
|
40
|
+
provenComponents = [];
|
|
45
41
|
bbConfigCleanup;
|
|
46
42
|
acvmConfigCleanup;
|
|
47
43
|
circuitProofVerifier;
|
|
@@ -51,58 +47,54 @@ const { E2E_DATA_PATH: dataPath } = process.env;
|
|
|
51
47
|
simulatedProverNode;
|
|
52
48
|
l1Contracts;
|
|
53
49
|
proverAddress;
|
|
50
|
+
minNumberOfTxsPerBlock;
|
|
51
|
+
coinbase;
|
|
52
|
+
realProofs;
|
|
54
53
|
constructor(testName, minNumberOfTxsPerBlock, coinbase, realProofs = true){
|
|
54
|
+
this.logger = createLogger(`e2e:full_prover_test:${testName}`);
|
|
55
55
|
this.minNumberOfTxsPerBlock = minNumberOfTxsPerBlock;
|
|
56
|
+
this.coinbase = coinbase;
|
|
56
57
|
this.realProofs = realProofs;
|
|
57
|
-
this.accounts = [];
|
|
58
|
-
this.provenComponents = [];
|
|
59
|
-
this.snapshot = (name, apply, restore = ()=>Promise.resolve())=>this.snapshotManager.snapshot(name, apply, restore);
|
|
60
|
-
this.logger = createLogger(`e2e:full_prover_test:${testName}`);
|
|
61
|
-
this.snapshotManager = createSnapshotManager(`full_prover_integration/${testName}`, dataPath, {
|
|
62
|
-
startProverNode: true,
|
|
63
|
-
coinbase
|
|
64
|
-
}, {
|
|
65
|
-
realVerifier: realProofs
|
|
66
|
-
});
|
|
67
58
|
}
|
|
68
59
|
/**
|
|
69
|
-
*
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
this.
|
|
75
|
-
this.accounts = deployedAccounts.map((a)=>a.address);
|
|
76
|
-
this.wallet = wallet;
|
|
77
|
-
return Promise.resolve();
|
|
78
|
-
});
|
|
79
|
-
await this.snapshotManager.snapshot('client_prover_integration', async ()=>{
|
|
80
|
-
// Create the token contract state.
|
|
81
|
-
// Move this account thing to addAccounts above?
|
|
82
|
-
this.logger.verbose(`Public deploy accounts...`);
|
|
83
|
-
await publicDeployAccounts(this.wallet, this.accounts.slice(0, 2));
|
|
84
|
-
this.logger.verbose(`Deploying TokenContract...`);
|
|
85
|
-
const { contract: asset, instance } = await TokenContract.deploy(this.wallet, this.accounts[0], FullProverTest.TOKEN_NAME, FullProverTest.TOKEN_SYMBOL, FullProverTest.TOKEN_DECIMALS).send({
|
|
86
|
-
from: this.accounts[0]
|
|
87
|
-
}).wait();
|
|
88
|
-
this.logger.verbose(`Token deployed to ${asset.address}`);
|
|
89
|
-
return {
|
|
90
|
-
tokenContractAddress: asset.address,
|
|
91
|
-
tokenContractInstance: instance
|
|
92
|
-
};
|
|
93
|
-
}, async ({ tokenContractAddress, tokenContractInstance })=>{
|
|
94
|
-
// Restore the token contract state.
|
|
95
|
-
this.fakeProofsAsset = TokenContract.at(tokenContractAddress, this.wallet);
|
|
96
|
-
this.fakeProofsAssetInstance = tokenContractInstance;
|
|
97
|
-
this.logger.verbose(`Token contract address: ${this.fakeProofsAsset.address}`);
|
|
98
|
-
this.tokenSim = new TokenSimulator(this.fakeProofsAsset, this.wallet, this.accounts[0], this.logger, this.accounts);
|
|
99
|
-
expect(await this.fakeProofsAsset.methods.get_admin().simulate({
|
|
100
|
-
from: this.accounts[0]
|
|
101
|
-
})).toBe(this.accounts[0].toBigInt());
|
|
60
|
+
* Applies base setup: deploys 2 accounts and token contract.
|
|
61
|
+
*/ async applyBaseSetup() {
|
|
62
|
+
this.logger.info('Applying base setup: deploying accounts');
|
|
63
|
+
const { deployedAccounts } = await deployAccounts(2, this.logger)({
|
|
64
|
+
wallet: this.context.wallet,
|
|
65
|
+
initialFundedAccounts: this.context.initialFundedAccounts
|
|
102
66
|
});
|
|
67
|
+
this.deployedAccounts = deployedAccounts;
|
|
68
|
+
this.accounts = deployedAccounts.map((a)=>a.address);
|
|
69
|
+
this.wallet = this.context.wallet;
|
|
70
|
+
this.logger.info('Applying base setup: publicly deploying accounts');
|
|
71
|
+
await publicDeployAccounts(this.wallet, this.accounts.slice(0, 2));
|
|
72
|
+
this.logger.info('Applying base setup: deploying token contract');
|
|
73
|
+
const { contract: asset, instance } = await TokenContract.deploy(this.wallet, this.accounts[0], FullProverTest.TOKEN_NAME, FullProverTest.TOKEN_SYMBOL, FullProverTest.TOKEN_DECIMALS).send({
|
|
74
|
+
from: this.accounts[0]
|
|
75
|
+
}).wait();
|
|
76
|
+
this.logger.verbose(`Token deployed to ${asset.address}`);
|
|
77
|
+
this.fakeProofsAsset = asset;
|
|
78
|
+
this.fakeProofsAssetInstance = instance;
|
|
79
|
+
this.logger.verbose(`Token contract address: ${this.fakeProofsAsset.address}`);
|
|
80
|
+
this.tokenSim = new TokenSimulator(this.fakeProofsAsset, this.wallet, this.accounts[0], this.logger, this.accounts);
|
|
81
|
+
expect(await this.fakeProofsAsset.methods.get_admin().simulate({
|
|
82
|
+
from: this.accounts[0]
|
|
83
|
+
})).toBe(this.accounts[0].toBigInt());
|
|
103
84
|
}
|
|
104
85
|
async setup() {
|
|
105
|
-
this.
|
|
86
|
+
this.logger.info('Setting up subsystems from fresh');
|
|
87
|
+
this.context = await setupFromFresh(this.logger, {
|
|
88
|
+
startProverNode: true,
|
|
89
|
+
coinbase: this.coinbase
|
|
90
|
+
}, {
|
|
91
|
+
realVerifier: this.realProofs
|
|
92
|
+
});
|
|
93
|
+
await this.applyBaseSetup();
|
|
94
|
+
await this.applyMint();
|
|
95
|
+
this.logger.info(`Enabling proving`, {
|
|
96
|
+
realProofs: this.realProofs
|
|
97
|
+
});
|
|
106
98
|
// We don't wish to mark as proven automatically, so we set the flag to false
|
|
107
99
|
this.context.watcher.setIsMarkingAsProven(false);
|
|
108
100
|
this.simulatedProverNode = this.context.proverNode;
|
|
@@ -212,7 +204,9 @@ const { E2E_DATA_PATH: dataPath } = process.env;
|
|
|
212
204
|
prefilledPublicData
|
|
213
205
|
});
|
|
214
206
|
await this.proverNode.start();
|
|
215
|
-
this.logger.warn(`Proofs are now enabled
|
|
207
|
+
this.logger.warn(`Proofs are now enabled`, {
|
|
208
|
+
realProofs: this.realProofs
|
|
209
|
+
});
|
|
216
210
|
return this;
|
|
217
211
|
}
|
|
218
212
|
async mintFeeJuice(recipient) {
|
|
@@ -231,9 +225,7 @@ const { E2E_DATA_PATH: dataPath } = process.env;
|
|
|
231
225
|
hash
|
|
232
226
|
});
|
|
233
227
|
}
|
|
234
|
-
snapshot;
|
|
235
228
|
async teardown() {
|
|
236
|
-
await this.snapshotManager.teardown();
|
|
237
229
|
// Cleanup related to the full prover PXEs
|
|
238
230
|
for(let i = 0; i < this.provenComponents.length; i++){
|
|
239
231
|
await this.provenComponents[i].teardown();
|
|
@@ -243,44 +235,39 @@ const { E2E_DATA_PATH: dataPath } = process.env;
|
|
|
243
235
|
await Barretenberg.destroySingleton();
|
|
244
236
|
await this.bbConfigCleanup?.();
|
|
245
237
|
await this.acvmConfigCleanup?.();
|
|
238
|
+
await teardown(this.context);
|
|
246
239
|
}
|
|
247
|
-
async
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
|
|
277
|
-
expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(address));
|
|
278
|
-
const totalSupply = await asset.methods.total_supply().simulate({
|
|
279
|
-
from: address
|
|
280
|
-
});
|
|
281
|
-
this.logger.verbose(`Total supply: ${totalSupply}`);
|
|
282
|
-
expect(totalSupply).toEqual(tokenSim.totalSupply);
|
|
283
|
-
return Promise.resolve();
|
|
240
|
+
async applyMint() {
|
|
241
|
+
this.logger.info('Applying mint setup');
|
|
242
|
+
const { fakeProofsAsset: asset, accounts } = this;
|
|
243
|
+
const privateAmount = 10000n;
|
|
244
|
+
const publicAmount = 10000n;
|
|
245
|
+
this.logger.verbose(`Minting ${privateAmount + publicAmount} publicly...`);
|
|
246
|
+
await asset.methods.mint_to_public(accounts[0], privateAmount + publicAmount).send({
|
|
247
|
+
from: accounts[0]
|
|
248
|
+
}).wait();
|
|
249
|
+
this.logger.verbose(`Transferring ${privateAmount} to private...`);
|
|
250
|
+
await asset.methods.transfer_to_private(accounts[0], privateAmount).send({
|
|
251
|
+
from: accounts[0]
|
|
252
|
+
}).wait();
|
|
253
|
+
this.logger.info(`Minting complete`);
|
|
254
|
+
const { fakeProofsAsset, accounts: [address], tokenSim } = this;
|
|
255
|
+
tokenSim.mintPublic(address, publicAmount);
|
|
256
|
+
const publicBalance = await fakeProofsAsset.methods.balance_of_public(address).simulate({
|
|
257
|
+
from: address
|
|
258
|
+
});
|
|
259
|
+
this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
|
|
260
|
+
expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(address));
|
|
261
|
+
tokenSim.mintPrivate(address, publicAmount);
|
|
262
|
+
const privateBalance = await fakeProofsAsset.methods.balance_of_private(address).simulate({
|
|
263
|
+
from: address
|
|
264
|
+
});
|
|
265
|
+
this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
|
|
266
|
+
expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(address));
|
|
267
|
+
const totalSupply = await fakeProofsAsset.methods.total_supply().simulate({
|
|
268
|
+
from: address
|
|
284
269
|
});
|
|
270
|
+
this.logger.verbose(`Total supply: ${totalSupply}`);
|
|
271
|
+
expect(totalSupply).toEqual(tokenSim.totalSupply);
|
|
285
272
|
}
|
|
286
273
|
}
|
|
@@ -28,51 +28,18 @@ export type SubsystemsContext = {
|
|
|
28
28
|
initialFundedAccounts: InitialAccountData[];
|
|
29
29
|
directoryToCleanup?: string;
|
|
30
30
|
};
|
|
31
|
-
export declare function createSnapshotManager(testName: string, dataPath?: string, config?: Partial<SetupOptions>, deployL1ContractsArgs?: Partial<DeployAztecL1ContractsArgs>): MockSnapshotManager | SnapshotManager;
|
|
32
|
-
export interface ISnapshotManager {
|
|
33
|
-
snapshot<T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>): Promise<void>;
|
|
34
|
-
setup(): Promise<SubsystemsContext>;
|
|
35
|
-
teardown(): Promise<void>;
|
|
36
|
-
}
|
|
37
|
-
/** Snapshot manager that does not perform snapshotting, it just applies transition and restoration functions as it receives them. */
|
|
38
|
-
declare class MockSnapshotManager implements ISnapshotManager {
|
|
39
|
-
private config;
|
|
40
|
-
private deployL1ContractsArgs;
|
|
41
|
-
private context?;
|
|
42
|
-
private logger;
|
|
43
|
-
constructor(testName: string, config?: Partial<AztecNodeConfig>, deployL1ContractsArgs?: Partial<DeployAztecL1ContractsArgs>);
|
|
44
|
-
snapshot<T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>): Promise<void>;
|
|
45
|
-
setup(): Promise<SubsystemsContext>;
|
|
46
|
-
teardown(): Promise<void>;
|
|
47
|
-
}
|
|
48
31
|
/**
|
|
49
|
-
*
|
|
50
|
-
* https://github.com/AztecProtocol/aztec-packages/pull/5526
|
|
32
|
+
* Destroys the current subsystem context.
|
|
51
33
|
*/
|
|
52
|
-
declare
|
|
53
|
-
private dataPath;
|
|
54
|
-
private config;
|
|
55
|
-
private deployL1ContractsArgs;
|
|
56
|
-
private snapshotStack;
|
|
57
|
-
private context?;
|
|
58
|
-
private livePath;
|
|
59
|
-
private logger;
|
|
60
|
-
constructor(testName: string, dataPath: string, config?: Partial<SetupOptions>, deployL1ContractsArgs?: Partial<DeployAztecL1ContractsArgs>);
|
|
61
|
-
snapshot<T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>): Promise<void>;
|
|
62
|
-
/**
|
|
63
|
-
* Creates and returns the subsystem context based on the current snapshot stack.
|
|
64
|
-
* If the subsystem context already exists, just return it.
|
|
65
|
-
* If you want to be sure to get a clean snapshot, be sure to call teardown() before calling setup().
|
|
66
|
-
*/
|
|
67
|
-
setup(): Promise<SubsystemsContext>;
|
|
68
|
-
/**
|
|
69
|
-
* Destroys the current subsystem context.
|
|
70
|
-
*/
|
|
71
|
-
teardown(): Promise<void>;
|
|
72
|
-
}
|
|
34
|
+
export declare function teardown(context: SubsystemsContext | undefined): Promise<void>;
|
|
73
35
|
/**
|
|
74
|
-
*
|
|
75
|
-
*
|
|
36
|
+
* Initializes a fresh set of subsystems.
|
|
37
|
+
* State is stored in temporary in-memory locations.
|
|
38
|
+
*/
|
|
39
|
+
export declare function setupFromFresh(logger: Logger, { numberOfInitialFundedAccounts, ...opts }?: SetupOptions, deployL1ContractsArgs?: Partial<DeployAztecL1ContractsArgs>): Promise<SubsystemsContext>;
|
|
40
|
+
/**
|
|
41
|
+
* Helper function to deploy accounts.
|
|
42
|
+
* Returns deployed account data that can be used by tests.
|
|
76
43
|
*/
|
|
77
44
|
export declare const deployAccounts: (numberOfAccounts: number, logger: Logger) => ({ wallet, initialFundedAccounts }: {
|
|
78
45
|
wallet: TestWallet;
|
|
@@ -89,5 +56,4 @@ export declare const deployAccounts: (numberOfAccounts: number, logger: Logger)
|
|
|
89
56
|
* @param node - AztecNode used to wait for proven tx.
|
|
90
57
|
*/
|
|
91
58
|
export declare function publicDeployAccounts(wallet: Wallet, accountsToDeploy: AztecAddress[], waitUntilProven?: boolean, node?: AztecNode): Promise<void>;
|
|
92
|
-
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hcHNob3RfbWFuYWdlci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZpeHR1cmVzL3NuYXBzaG90X21hbmFnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEtBQUssa0JBQWtCLEVBQTJCLE1BQU0seUJBQXlCLENBQUM7QUFDM0YsT0FBTyxFQUFFLEtBQUssZUFBZSxFQUFFLGdCQUFnQixFQUFvQixNQUFNLG1CQUFtQixDQUFDO0FBQzdGLE9BQU8sRUFBRSxZQUFZLEVBQWMsTUFBTSwyQkFBMkIsQ0FBQztBQUlyRSxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNsRCxPQUFPLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN0RCxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFJcEUsT0FBTyxFQUNMLEtBQUssMEJBQTBCLEVBQy9CLEtBQUssZ0NBQWdDLEVBRXRDLE1BQU0sMkNBQTJDLENBQUM7QUFRbkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFHM0QsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFckQsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFHL0QsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBR3ZELE9BQU8sS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLGFBQWEsQ0FBQztBQWF6QyxPQUFPLEVBQ0wsS0FBSyxZQUFZLEVBTWxCLE1BQU0sWUFBWSxDQUFDO0FBR3BCLE1BQU0sTUFBTSxpQkFBaUIsR0FBRztJQUM5QixLQUFLLEVBQUUsS0FBSyxDQUFDO0lBQ2IsVUFBVSxF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
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hcHNob3RfbWFuYWdlci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZpeHR1cmVzL3NuYXBzaG90X21hbmFnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEtBQUssa0JBQWtCLEVBQTJCLE1BQU0seUJBQXlCLENBQUM7QUFDM0YsT0FBTyxFQUFFLEtBQUssZUFBZSxFQUFFLGdCQUFnQixFQUFvQixNQUFNLG1CQUFtQixDQUFDO0FBQzdGLE9BQU8sRUFBRSxZQUFZLEVBQWMsTUFBTSwyQkFBMkIsQ0FBQztBQUdyRSxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNsRCxPQUFPLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN0RCxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFJcEUsT0FBTyxFQUNMLEtBQUssMEJBQTBCLEVBQy9CLEtBQUssZ0NBQWdDLEVBRXRDLE1BQU0sMkNBQTJDLENBQUM7QUFLbkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFHM0QsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFckQsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFL0QsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBR3ZELE9BQU8sS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLGFBQWEsQ0FBQztBQVV6QyxPQUFPLEVBQ0wsS0FBSyxZQUFZLEVBTWxCLE1BQU0sWUFBWSxDQUFDO0FBR3BCLE1BQU0sTUFBTSxpQkFBaUIsR0FBRztJQUM5QixLQUFLLEVBQUUsS0FBSyxDQUFDO0lBQ2IsVUFBVSxFQUFFLEdBQUcsQ0FBQztJQUNoQixRQUFRLEVBQUUsR0FBRyxDQUFDO0lBQ2QsU0FBUyxFQUFFLGdCQUFnQixDQUFDO0lBQzVCLGVBQWUsRUFBRSxlQUFlLENBQUM7SUFDakMsTUFBTSxFQUFFLFVBQVUsQ0FBQztJQUNuQix1QkFBdUIsRUFBRSxnQ0FBZ0MsQ0FBQztJQUMxRCxVQUFVLENBQUMsRUFBRSxVQUFVLENBQUM7SUFDeEIsT0FBTyxFQUFFLGdCQUFnQixDQUFDO0lBQzFCLFVBQVUsRUFBRSxVQUFVLENBQUM7SUFDdkIsU0FBUyxFQUFFLGVBQWUsQ0FBQztJQUMzQixZQUFZLEVBQUUsZ0JBQWdCLENBQUM7SUFDL0IscUJBQXFCLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQztJQUM1QyxrQkFBa0IsQ0FBQyxFQUFFLE1BQU0sQ0FBQztDQUM3QixDQUFDO0FBRUY7O0dBRUc7QUFDSCx3QkFBc0IsUUFBUSxDQUFDLE9BQU8sRUFBRSxpQkFBaUIsR0FBRyxTQUFTLGlCQWlCcEU7QUFFRDs7O0dBR0c7QUFDSCx3QkFBc0IsY0FBYyxDQUNsQyxNQUFNLEVBQUUsTUFBTSxFQUNkLEVBQUUsNkJBQWtDLEVBQUUsR0FBRyxJQUFJLEVBQUUsR0FBRSxZQUFpQixFQUNsRSxxQkFBcUIsR0FBRSxPQUFPLENBQUMsMEJBQTBCLENBRXhELEdBQ0EsT0FBTyxDQUFDLGlCQUFpQixDQUFDLENBaUs1QjtBQUVEOzs7R0FHRztBQUNILGVBQU8sTUFBTSxjQUFjOzs7OztFQTBCeEIsQ0FBQztBQUVKOzs7Ozs7O0dBT0c7QUFDSCx3QkFBc0Isb0JBQW9CLENBQ3hDLE1BQU0sRUFBRSxNQUFNLEVBQ2QsZ0JBQWdCLEVBQUUsWUFBWSxFQUFFLEVBQ2hDLGVBQWUsVUFBUSxFQUN2QixJQUFJLENBQUMsRUFBRSxTQUFTLGlCQXdCakIifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"snapshot_manager.d.ts","sourceRoot":"","sources":["../../src/fixtures/snapshot_manager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,kBAAkB,EAA2B,MAAM,yBAAyB,CAAC;AAC3F,OAAO,EAAE,KAAK,eAAe,EAAE,gBAAgB,EAAoB,MAAM,mBAAmB,CAAC;AAC7F,OAAO,EAAE,YAAY,EAAc,MAAM,2BAA2B,CAAC;
|
|
1
|
+
{"version":3,"file":"snapshot_manager.d.ts","sourceRoot":"","sources":["../../src/fixtures/snapshot_manager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,kBAAkB,EAA2B,MAAM,yBAAyB,CAAC;AAC3F,OAAO,EAAE,KAAK,eAAe,EAAE,gBAAgB,EAAoB,MAAM,mBAAmB,CAAC;AAC7F,OAAO,EAAE,YAAY,EAAc,MAAM,2BAA2B,CAAC;AAGrE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAIpE,OAAO,EACL,KAAK,0BAA0B,EAC/B,KAAK,gCAAgC,EAEtC,MAAM,2CAA2C,CAAC;AAKnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAG3D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAErD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE/D,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAGvD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAUzC,OAAO,EACL,KAAK,YAAY,EAMlB,MAAM,YAAY,CAAC;AAGpB,MAAM,MAAM,iBAAiB,GAAG;IAC9B,KAAK,EAAE,KAAK,CAAC;IACb,UAAU,EAAE,GAAG,CAAC;IAChB,QAAQ,EAAE,GAAG,CAAC;IACd,SAAS,EAAE,gBAAgB,CAAC;IAC5B,eAAe,EAAE,eAAe,CAAC;IACjC,MAAM,EAAE,UAAU,CAAC;IACnB,uBAAuB,EAAE,gCAAgC,CAAC;IAC1D,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,OAAO,EAAE,gBAAgB,CAAC;IAC1B,UAAU,EAAE,UAAU,CAAC;IACvB,SAAS,EAAE,eAAe,CAAC;IAC3B,YAAY,EAAE,gBAAgB,CAAC;IAC/B,qBAAqB,EAAE,kBAAkB,EAAE,CAAC;IAC5C,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B,CAAC;AAEF;;GAEG;AACH,wBAAsB,QAAQ,CAAC,OAAO,EAAE,iBAAiB,GAAG,SAAS,iBAiBpE;AAED;;;GAGG;AACH,wBAAsB,cAAc,CAClC,MAAM,EAAE,MAAM,EACd,EAAE,6BAAkC,EAAE,GAAG,IAAI,EAAE,GAAE,YAAiB,EAClE,qBAAqB,GAAE,OAAO,CAAC,0BAA0B,CAExD,GACA,OAAO,CAAC,iBAAiB,CAAC,CAiK5B;AAED;;;GAGG;AACH,eAAO,MAAM,cAAc;;;;;EA0BxB,CAAC;AAEJ;;;;;;;GAOG;AACH,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,MAAM,EACd,gBAAgB,EAAE,YAAY,EAAE,EAChC,eAAe,UAAQ,EACvB,IAAI,CAAC,EAAE,SAAS,iBAwBjB"}
|