@aztec/end-to-end 3.0.0-canary.a9708bd → 3.0.0-devnet.20251212
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/benchmark.d.ts +4 -3
- package/dest/bench/client_flows/benchmark.d.ts.map +1 -1
- package/dest/bench/client_flows/benchmark.js +2 -2
- package/dest/bench/client_flows/client_flows_benchmark.d.ts +25 -14
- package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
- package/dest/bench/client_flows/client_flows_benchmark.js +111 -90
- package/dest/bench/client_flows/config.d.ts +1 -1
- package/dest/bench/client_flows/data_extractor.d.ts +1 -1
- package/dest/bench/client_flows/data_extractor.js +8 -30
- package/dest/bench/utils.d.ts +4 -13
- package/dest/bench/utils.d.ts.map +1 -1
- package/dest/bench/utils.js +10 -34
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +8 -8
- 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 +42 -42
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +12 -9
- 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 +35 -35
- package/dest/e2e_deploy_contract/deploy_test.d.ts +12 -6
- package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
- package/dest/e2e_deploy_contract/deploy_test.js +9 -18
- package/dest/e2e_epochs/epochs_test.d.ts +19 -12
- package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
- package/dest/e2e_epochs/epochs_test.js +30 -22
- package/dest/e2e_fees/bridging_race.notest.d.ts +1 -1
- package/dest/e2e_fees/bridging_race.notest.js +14 -11
- package/dest/e2e_fees/fees_test.d.ts +10 -8
- package/dest/e2e_fees/fees_test.d.ts.map +1 -1
- package/dest/e2e_fees/fees_test.js +35 -38
- package/dest/e2e_l1_publisher/write_json.d.ts +4 -2
- package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
- package/dest/e2e_l1_publisher/write_json.js +9 -8
- package/dest/e2e_multi_validator/utils.d.ts +2 -2
- package/dest/e2e_multi_validator/utils.d.ts.map +1 -1
- package/dest/e2e_multi_validator/utils.js +4 -10
- package/dest/e2e_nested_contract/nested_contract_test.d.ts +7 -4
- package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
- package/dest/e2e_nested_contract/nested_contract_test.js +11 -12
- package/dest/e2e_p2p/inactivity_slash_test.d.ts +31 -0
- package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -0
- package/dest/e2e_p2p/inactivity_slash_test.js +139 -0
- package/dest/e2e_p2p/p2p_network.d.ts +238 -17
- package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
- package/dest/e2e_p2p/p2p_network.js +46 -19
- package/dest/e2e_p2p/shared.d.ts +16 -17
- package/dest/e2e_p2p/shared.d.ts.map +1 -1
- package/dest/e2e_p2p/shared.js +56 -55
- package/dest/e2e_token_contract/token_contract_test.d.ts +6 -5
- package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
- package/dest/e2e_token_contract/token_contract_test.js +14 -17
- package/dest/fixtures/e2e_prover_test.d.ts +12 -8
- package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
- package/dest/fixtures/e2e_prover_test.js +53 -58
- package/dest/fixtures/fixtures.d.ts +1 -1
- package/dest/fixtures/fixtures.d.ts.map +1 -1
- package/dest/fixtures/fixtures.js +1 -1
- package/dest/fixtures/get_acvm_config.d.ts +2 -2
- package/dest/fixtures/get_acvm_config.d.ts.map +1 -1
- package/dest/fixtures/get_acvm_config.js +1 -1
- package/dest/fixtures/get_bb_config.d.ts +2 -2
- package/dest/fixtures/get_bb_config.d.ts.map +1 -1
- package/dest/fixtures/get_bb_config.js +2 -2
- package/dest/fixtures/index.d.ts +1 -1
- package/dest/fixtures/l1_to_l2_messaging.d.ts +4 -3
- package/dest/fixtures/l1_to_l2_messaging.d.ts.map +1 -1
- package/dest/fixtures/l1_to_l2_messaging.js +2 -2
- package/dest/fixtures/logging.d.ts +1 -1
- package/dest/fixtures/setup_l1_contracts.d.ts +476 -5
- package/dest/fixtures/setup_l1_contracts.d.ts.map +1 -1
- package/dest/fixtures/setup_l1_contracts.js +3 -3
- package/dest/fixtures/setup_p2p_test.d.ts +12 -11
- package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
- package/dest/fixtures/setup_p2p_test.js +50 -24
- package/dest/fixtures/snapshot_manager.d.ts +13 -10
- package/dest/fixtures/snapshot_manager.d.ts.map +1 -1
- package/dest/fixtures/snapshot_manager.js +66 -51
- package/dest/fixtures/token_utils.d.ts +10 -5
- package/dest/fixtures/token_utils.d.ts.map +1 -1
- package/dest/fixtures/token_utils.js +17 -18
- package/dest/fixtures/utils.d.ts +479 -35
- package/dest/fixtures/utils.d.ts.map +1 -1
- package/dest/fixtures/utils.js +106 -125
- package/dest/fixtures/web3signer.d.ts +5 -0
- package/dest/fixtures/web3signer.d.ts.map +1 -0
- package/dest/fixtures/web3signer.js +53 -0
- package/dest/fixtures/with_telemetry_utils.d.ts +2 -2
- package/dest/fixtures/with_telemetry_utils.d.ts.map +1 -1
- package/dest/fixtures/with_telemetry_utils.js +2 -2
- package/dest/index.d.ts +1 -1
- package/dest/quality_of_service/alert_checker.d.ts +2 -2
- package/dest/quality_of_service/alert_checker.d.ts.map +1 -1
- package/dest/shared/cross_chain_test_harness.d.ts +20 -23
- package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
- package/dest/shared/cross_chain_test_harness.js +14 -16
- package/dest/shared/gas_portal_test_harness.d.ts +10 -17
- package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
- package/dest/shared/gas_portal_test_harness.js +11 -8
- package/dest/shared/index.d.ts +1 -1
- package/dest/shared/jest_setup.d.ts +1 -1
- package/dest/shared/jest_setup.js +1 -1
- package/dest/shared/submit-transactions.d.ts +6 -4
- package/dest/shared/submit-transactions.d.ts.map +1 -1
- package/dest/shared/submit-transactions.js +8 -7
- package/dest/shared/uniswap_l1_l2.d.ts +12 -8
- package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
- package/dest/shared/uniswap_l1_l2.js +44 -58
- package/dest/simulators/index.d.ts +1 -1
- package/dest/simulators/lending_simulator.d.ts +4 -7
- package/dest/simulators/lending_simulator.d.ts.map +1 -1
- package/dest/simulators/lending_simulator.js +8 -5
- package/dest/simulators/token_simulator.d.ts +4 -2
- package/dest/simulators/token_simulator.d.ts.map +1 -1
- package/dest/simulators/token_simulator.js +2 -2
- package/dest/spartan/setup_test_wallets.d.ts +22 -14
- package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
- package/dest/spartan/setup_test_wallets.js +144 -86
- package/dest/spartan/tx_metrics.d.ts +39 -0
- package/dest/spartan/tx_metrics.d.ts.map +1 -0
- package/dest/spartan/tx_metrics.js +95 -0
- package/dest/spartan/utils.d.ts +92 -17
- package/dest/spartan/utils.d.ts.map +1 -1
- package/dest/spartan/utils.js +386 -63
- package/package.json +43 -40
- package/src/bench/client_flows/benchmark.ts +8 -8
- package/src/bench/client_flows/client_flows_benchmark.ts +141 -114
- package/src/bench/client_flows/data_extractor.ts +9 -31
- package/src/bench/utils.ts +9 -37
- package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +46 -63
- package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +38 -51
- package/src/e2e_deploy_contract/deploy_test.ts +18 -36
- package/src/e2e_epochs/epochs_test.ts +41 -35
- package/src/e2e_fees/bridging_race.notest.ts +16 -11
- package/src/e2e_fees/fees_test.ts +42 -47
- package/src/e2e_l1_publisher/write_json.ts +12 -9
- package/src/e2e_multi_validator/utils.ts +5 -11
- package/src/e2e_nested_contract/nested_contract_test.ts +15 -13
- package/src/e2e_p2p/inactivity_slash_test.ts +184 -0
- package/src/e2e_p2p/p2p_network.ts +124 -82
- package/src/e2e_p2p/shared.ts +66 -58
- package/src/e2e_token_contract/token_contract_test.ts +17 -17
- package/src/fixtures/e2e_prover_test.ts +60 -97
- package/src/fixtures/fixtures.ts +1 -2
- package/src/fixtures/get_acvm_config.ts +2 -2
- package/src/fixtures/get_bb_config.ts +3 -2
- package/src/fixtures/l1_to_l2_messaging.ts +4 -2
- package/src/fixtures/setup_l1_contracts.ts +5 -4
- package/src/fixtures/setup_p2p_test.ts +79 -32
- package/src/fixtures/snapshot_manager.ts +87 -82
- package/src/fixtures/token_utils.ts +16 -24
- package/src/fixtures/utils.ts +142 -172
- package/src/fixtures/web3signer.ts +63 -0
- package/src/fixtures/with_telemetry_utils.ts +2 -2
- package/src/guides/up_quick_start.sh +3 -11
- package/src/quality_of_service/alert_checker.ts +1 -1
- package/src/shared/cross_chain_test_harness.ts +23 -31
- package/src/shared/gas_portal_test_harness.ts +14 -21
- package/src/shared/jest_setup.ts +1 -1
- package/src/shared/submit-transactions.ts +12 -8
- package/src/shared/uniswap_l1_l2.ts +77 -86
- package/src/simulators/lending_simulator.ts +9 -6
- package/src/simulators/token_simulator.ts +5 -2
- package/src/spartan/DEVELOP.md +15 -3
- package/src/spartan/setup_test_wallets.ts +171 -127
- package/src/spartan/tx_metrics.ts +130 -0
- package/src/spartan/utils.ts +463 -64
package/dest/bench/utils.d.ts
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import { type
|
|
1
|
+
import { type SentTx, type WaitOpts } from '@aztec/aztec.js/contracts';
|
|
2
2
|
import { BenchmarkingContract } from '@aztec/noir-test-contracts.js/Benchmarking';
|
|
3
|
-
import { type PXEService } from '@aztec/pxe/server';
|
|
4
3
|
import type { MetricsType } from '@aztec/telemetry-client';
|
|
5
4
|
import type { BenchmarkTelemetryClient } from '@aztec/telemetry-client/bench';
|
|
6
5
|
import { type EndToEndContext, type SetupOptions } from '../fixtures/utils.js';
|
|
@@ -15,7 +14,7 @@ export declare function benchmarkSetup(opts: Partial<SetupOptions> & {
|
|
|
15
14
|
telemetry: BenchmarkTelemetryClient;
|
|
16
15
|
context: EndToEndContext;
|
|
17
16
|
contract: BenchmarkingContract;
|
|
18
|
-
sequencer: import("
|
|
17
|
+
sequencer: import("../../../sequencer-client/dest/index.js").SequencerClient;
|
|
19
18
|
}>;
|
|
20
19
|
type MetricFilter = {
|
|
21
20
|
source: MetricsType;
|
|
@@ -39,15 +38,7 @@ export type GithubActionBenchmarkResult = {
|
|
|
39
38
|
* @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
|
|
40
39
|
* @returns Array of sent txs.
|
|
41
40
|
*/
|
|
42
|
-
export declare function sendTxs(txCount: number, context: EndToEndContext, contract: BenchmarkingContract, heavyPublicCompute?: boolean):
|
|
41
|
+
export declare function sendTxs(txCount: number, context: EndToEndContext, contract: BenchmarkingContract, heavyPublicCompute?: boolean): SentTx[];
|
|
43
42
|
export declare function waitTxs(txs: SentTx[], context: EndToEndContext, txWaitOpts?: WaitOpts): Promise<void>;
|
|
44
|
-
/**
|
|
45
|
-
* Creates a new PXE
|
|
46
|
-
* @param node - Node to connect the pxe to.
|
|
47
|
-
* @param contract - Benchmark contract to add to the pxe.
|
|
48
|
-
* @param startingBlock - First l2 block to process.
|
|
49
|
-
* @returns The new PXE.
|
|
50
|
-
*/
|
|
51
|
-
export declare function createNewPXE(node: AztecNode, contract: BenchmarkingContract): Promise<PXEService>;
|
|
52
43
|
export {};
|
|
53
|
-
//# sourceMappingURL=
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iZW5jaC91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQWEsS0FBSyxNQUFNLEVBQUUsS0FBSyxRQUFRLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUVsRixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUNsRixPQUFPLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMzRCxPQUFPLEtBQUssRUFBNEMsd0JBQXdCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUt4SCxPQUFPLEVBQUUsS0FBSyxlQUFlLEVBQUUsS0FBSyxZQUFZLEVBQVMsTUFBTSxzQkFBc0IsQ0FBQztBQUV0Rjs7R0FFRztBQUNILHdCQUFzQixjQUFjLENBQ2xDLElBQUksRUFBRSxPQUFPLENBQUMsWUFBWSxDQUFDLEdBQUc7SUFDNUIsNkJBQTZCLENBQUMsT0FBTyxFQUFFLENBQUMsV0FBVyxHQUFHLFlBQVksQ0FBQyxFQUFFLENBQUM7SUFDdEUsa0ZBQWtGO0lBQ2xGLFdBQVcsQ0FBQyxFQUFFLE1BQU0sQ0FBQztDQUN0Qjs7Ozs7R0F5QkY7QUFFRCxLQUFLLFlBQVksR0FBRztJQUNsQixNQUFNLEVBQUUsV0FBVyxDQUFDO0lBQ3BCLFNBQVMsRUFBRSxDQUFDLEtBQUssRUFBRSxNQUFNLEtBQUssTUFBTSxDQUFDO0lBQ3JDLElBQUksRUFBRSxNQUFNLENBQUM7SUFDYixJQUFJLENBQUMsRUFBRSxNQUFNLENBQUM7Q0FDZixDQUFDO0FBR0YsTUFBTSxNQUFNLDJCQUEyQixHQUFHO0lBQ3hDLElBQUksRUFBRSxNQUFNLENBQUM7SUFDYixLQUFLLEVBQUUsTUFBTSxDQUFDO0lBQ2QsS0FBSyxDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQ2YsSUFBSSxFQUFFLE1BQU0sQ0FBQztJQUNiLEtBQUssQ0FBQyxFQUFFLE1BQU0sQ0FBQztDQUNoQixDQUFDO0FBNkRGOzs7Ozs7OztHQVFHO0FBQ0gsd0JBQWdCLE9BQU8sQ0FDckIsT0FBTyxFQUFFLE1BQU0sRUFDZixPQUFPLEVBQUUsZUFBZSxFQUN4QixRQUFRLEVBQUUsb0JBQW9CLEVBQzlCLGtCQUFrQixHQUFFLE9BQWUsR0FDbEMsTUFBTSxFQUFFLENBTVY7QUFFRCx3QkFBc0IsT0FBTyxDQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFLFVBQVUsQ0FBQyxFQUFFLFFBQVEsaUJBSTNGIn0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/bench/utils.ts"],"names":[],"mappings":"AACA,OAAO,
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/bench/utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAa,KAAK,MAAM,EAAE,KAAK,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAElF,OAAO,EAAE,oBAAoB,EAAE,MAAM,4CAA4C,CAAC;AAClF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,KAAK,EAA4C,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAKxH,OAAO,EAAE,KAAK,eAAe,EAAE,KAAK,YAAY,EAAS,MAAM,sBAAsB,CAAC;AAEtF;;GAEG;AACH,wBAAsB,cAAc,CAClC,IAAI,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG;IAC5B,6BAA6B,CAAC,OAAO,EAAE,CAAC,WAAW,GAAG,YAAY,CAAC,EAAE,CAAC;IACtE,kFAAkF;IAClF,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;;;;;GAyBF;AAED,KAAK,YAAY,GAAG;IAClB,MAAM,EAAE,WAAW,CAAC;IACpB,SAAS,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IACrC,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;CACf,CAAC;AAGF,MAAM,MAAM,2BAA2B,GAAG;IACxC,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AA6DF;;;;;;;;GAQG;AACH,wBAAgB,OAAO,CACrB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,oBAAoB,EAC9B,kBAAkB,GAAE,OAAe,GAClC,MAAM,EAAE,CAMV;AAED,wBAAsB,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,eAAe,EAAE,UAAU,CAAC,EAAE,QAAQ,iBAI3F"}
|
package/dest/bench/utils.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import { BatchCall } from '@aztec/aztec.js';
|
|
1
|
+
import { BatchCall } from '@aztec/aztec.js/contracts';
|
|
2
2
|
import { mean, stdDev, times } from '@aztec/foundation/collection';
|
|
3
3
|
import { BenchmarkingContract } from '@aztec/noir-test-contracts.js/Benchmarking';
|
|
4
|
-
import { createPXEService } from '@aztec/pxe/server';
|
|
5
4
|
import { mkdirSync, writeFileSync } from 'fs';
|
|
6
5
|
import path from 'path';
|
|
7
6
|
import { setup } from '../fixtures/utils.js';
|
|
@@ -14,8 +13,9 @@ import { setup } from '../fixtures/utils.js';
|
|
|
14
13
|
benchmark: true
|
|
15
14
|
}
|
|
16
15
|
});
|
|
16
|
+
const defaultAccountAddress = context.accounts[0];
|
|
17
17
|
const contract = await BenchmarkingContract.deploy(context.wallet).send({
|
|
18
|
-
from:
|
|
18
|
+
from: defaultAccountAddress
|
|
19
19
|
}).deployed();
|
|
20
20
|
context.logger.info(`Deployed benchmarking contract at ${contract.address}`);
|
|
21
21
|
const sequencer = context.aztecNode.getSequencer();
|
|
@@ -92,10 +92,10 @@ function getMetricValues(points) {
|
|
|
92
92
|
* @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
|
|
93
93
|
* @returns A BatchCall instance.
|
|
94
94
|
*/ function makeCall(index, context, contract, heavyPublicCompute) {
|
|
95
|
-
const owner = context.
|
|
95
|
+
const [owner] = context.accounts;
|
|
96
96
|
if (heavyPublicCompute) {
|
|
97
97
|
return new BatchCall(context.wallet, [
|
|
98
|
-
contract.methods.
|
|
98
|
+
contract.methods.sha256_hash_1024(randomBytesAsBigInts(1024))
|
|
99
99
|
]);
|
|
100
100
|
} else {
|
|
101
101
|
return new BatchCall(context.wallet, [
|
|
@@ -112,44 +112,20 @@ function getMetricValues(points) {
|
|
|
112
112
|
* @param contract - Target contract.
|
|
113
113
|
* @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
|
|
114
114
|
* @returns Array of sent txs.
|
|
115
|
-
*/ export
|
|
115
|
+
*/ export function sendTxs(txCount, context, contract, heavyPublicCompute = false) {
|
|
116
116
|
const calls = times(txCount, (index)=>makeCall(index, context, contract, heavyPublicCompute));
|
|
117
117
|
context.logger.info(`Creating ${txCount} txs`);
|
|
118
|
-
const
|
|
119
|
-
from: context.wallet.getAddress()
|
|
120
|
-
})));
|
|
118
|
+
const [from] = context.accounts;
|
|
121
119
|
context.logger.info(`Sending ${txCount} txs`);
|
|
122
|
-
return
|
|
120
|
+
return calls.map((call)=>call.send({
|
|
121
|
+
from
|
|
122
|
+
}));
|
|
123
123
|
}
|
|
124
124
|
export async function waitTxs(txs, context, txWaitOpts) {
|
|
125
125
|
context.logger.info(`Awaiting ${txs.length} txs to be mined`);
|
|
126
126
|
await Promise.all(txs.map((tx)=>tx.wait(txWaitOpts)));
|
|
127
127
|
context.logger.info(`All ${txs.length} txs have been mined`);
|
|
128
128
|
}
|
|
129
|
-
/**
|
|
130
|
-
* Creates a new PXE
|
|
131
|
-
* @param node - Node to connect the pxe to.
|
|
132
|
-
* @param contract - Benchmark contract to add to the pxe.
|
|
133
|
-
* @param startingBlock - First l2 block to process.
|
|
134
|
-
* @returns The new PXE.
|
|
135
|
-
*/ export async function createNewPXE(node, contract) {
|
|
136
|
-
const l1Contracts = await node.getL1ContractAddresses();
|
|
137
|
-
const { l1ChainId, rollupVersion } = await node.getNodeInfo();
|
|
138
|
-
const pxeConfig = {
|
|
139
|
-
l2BlockBatchSize: 50,
|
|
140
|
-
l2BlockPollingIntervalMS: 100,
|
|
141
|
-
dataDirectory: undefined,
|
|
142
|
-
dataStoreMapSizeKB: 1024 * 1024,
|
|
143
|
-
l1Contracts,
|
|
144
|
-
l1ChainId,
|
|
145
|
-
rollupVersion
|
|
146
|
-
};
|
|
147
|
-
// docs:start:PXEcreate
|
|
148
|
-
const pxe = await createPXEService(node, pxeConfig);
|
|
149
|
-
// docs:end:PXEcreate
|
|
150
|
-
await pxe.registerContract(contract);
|
|
151
|
-
return pxe;
|
|
152
|
-
}
|
|
153
129
|
function randomBytesAsBigInts(length) {
|
|
154
130
|
return [
|
|
155
131
|
...Array(length)
|
|
@@ -1,8 +1,13 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
2
|
+
import { Fr } from '@aztec/aztec.js/fields';
|
|
3
|
+
import { type Logger } from '@aztec/aztec.js/log';
|
|
4
|
+
import type { AztecNode } from '@aztec/aztec.js/node';
|
|
5
|
+
import type { TxHash } from '@aztec/aztec.js/tx';
|
|
2
6
|
import type { CheatCodes } from '@aztec/aztec/testing';
|
|
3
7
|
import { TokenBlacklistContract } from '@aztec/noir-contracts.js/TokenBlacklist';
|
|
4
8
|
import { InvalidAccountContract } from '@aztec/noir-test-contracts.js/InvalidAccount';
|
|
5
9
|
import type { SequencerClient } from '@aztec/sequencer-client';
|
|
10
|
+
import type { TestWallet } from '@aztec/test-wallet/server';
|
|
6
11
|
import { type SubsystemsContext } from '../fixtures/snapshot_manager.js';
|
|
7
12
|
import { TokenSimulator } from '../simulators/token_simulator.js';
|
|
8
13
|
export declare class Role {
|
|
@@ -22,20 +27,15 @@ export declare class BlacklistTokenContractTest {
|
|
|
22
27
|
static CHANGE_ROLES_DELAY: number;
|
|
23
28
|
private snapshotManager;
|
|
24
29
|
logger: Logger;
|
|
25
|
-
|
|
26
|
-
pxe: PXE;
|
|
27
|
-
accounts: CompleteAddress[];
|
|
30
|
+
wallet: TestWallet;
|
|
28
31
|
asset: TokenBlacklistContract;
|
|
29
32
|
tokenSim: TokenSimulator;
|
|
30
33
|
badAccount: InvalidAccountContract;
|
|
31
34
|
cheatCodes: CheatCodes;
|
|
32
35
|
sequencer: SequencerClient;
|
|
33
36
|
aztecNode: AztecNode;
|
|
34
|
-
admin: AccountWallet;
|
|
35
37
|
adminAddress: AztecAddress;
|
|
36
|
-
other: AccountWallet;
|
|
37
38
|
otherAddress: AztecAddress;
|
|
38
|
-
blacklisted: AccountWallet;
|
|
39
39
|
blacklistedAddress: AztecAddress;
|
|
40
40
|
constructor(testName: string);
|
|
41
41
|
crossTimestampOfChange(): Promise<void>;
|
|
@@ -51,4 +51,4 @@ export declare class BlacklistTokenContractTest {
|
|
|
51
51
|
addPendingShieldNoteToPXE(contract: TokenBlacklistContract, recipient: AztecAddress, amount: bigint, secretHash: Fr, txHash: TxHash): Promise<void>;
|
|
52
52
|
applyMintSnapshot(): Promise<void>;
|
|
53
53
|
}
|
|
54
|
-
//# sourceMappingURL=
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxhY2tsaXN0X3Rva2VuX2NvbnRyYWN0X3Rlc3QuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lMmVfYmxhY2tsaXN0X3Rva2VuX2NvbnRyYWN0L2JsYWNrbGlzdF90b2tlbl9jb250cmFjdF90ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUV6RCxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUMsT0FBTyxFQUFFLEtBQUssTUFBTSxFQUFnQixNQUFNLHFCQUFxQixDQUFDO0FBQ2hFLE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3RELE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2pELE9BQU8sS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXZELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQ3RGLE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQy9ELE9BQU8sS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBSTVELE9BQU8sRUFFTCxLQUFLLGlCQUFpQixFQUl2QixNQUFNLGlDQUFpQyxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUlsRSxxQkFBYSxJQUFJO0lBQ2YsT0FBTyxDQUFDLE9BQU8sQ0FBUztJQUN4QixPQUFPLENBQUMsUUFBUSxDQUFTO0lBQ3pCLE9BQU8sQ0FBQyxhQUFhLENBQVM7SUFFOUIsU0FBUyxTQUdSO0lBRUQsVUFBVSxTQUdUO0lBRUQsZUFBZSxTQUdkO0lBRUQsWUFBWTs7OztNQUlYO0NBQ0Y7QUFFRCxxQkFBYSwwQkFBMEI7SUFFckMsTUFBTSxDQUFDLGtCQUFrQixTQUFTO0lBRWxDLE9BQU8sQ0FBQyxlQUFlLENBQW1CO0lBQzFDLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFDZixNQUFNLEVBQUcsVUFBVSxDQUFDO0lBQ3BCLEtBQUssRUFBRyxzQkFBc0IsQ0FBQztJQUMvQixRQUFRLEVBQUcsY0FBYyxDQUFDO0lBQzFCLFVBQVUsRUFBRyxzQkFBc0IsQ0FBQztJQUNwQyxVQUFVLEVBQUcsVUFBVSxDQUFDO0lBQ3hCLFNBQVMsRUFBRyxlQUFlLENBQUM7SUFDNUIsU0FBUyxFQUFHLFNBQVMsQ0FBQztJQUV0QixZQUFZLEVBQUcsWUFBWSxDQUFDO0lBQzVCLFlBQVksRUFBRyxZQUFZLENBQUM7SUFDNUIsa0JBQWtCLEVBQUcsWUFBWSxDQUFDO0lBRWxDLFlBQVksUUFBUSxFQUFFLE1BQU0sRUFHM0I7SUFFSyxzQkFBc0Isa0JBTTNCO0lBRUQ7Ozs7T0FJRztJQUNHLGtCQUFrQixrQkE4RHZCO0lBRUssS0FBSyxrQkFFVjtJQUVELFFBQVEsR0FBSSxDQUFDLDhKQUkyRDtJQUVsRSxRQUFRLGtCQUViO0lBRUsseUJBQXlCLENBQzdCLFFBQVEsRUFBRSxzQkFBc0IsRUFDaEMsU0FBUyxFQUFFLFlBQVksRUFDdkIsTUFBTSxFQUFFLE1BQU0sRUFDZCxVQUFVLEVBQUUsRUFBRSxFQUNkLE1BQU0sRUFBRSxNQUFNLGlCQWNmO0lBRUssaUJBQWlCLGtCQWtFdEI7Q0FDRiJ9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"blacklist_token_contract_test.d.ts","sourceRoot":"","sources":["../../src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"blacklist_token_contract_test.d.ts","sourceRoot":"","sources":["../../src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAEzD,OAAO,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAC5C,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,qBAAqB,CAAC;AAChE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAEvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAC;AACjF,OAAO,EAAE,sBAAsB,EAAE,MAAM,8CAA8C,CAAC;AACtF,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAI5D,OAAO,EAEL,KAAK,iBAAiB,EAIvB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAIlE,qBAAa,IAAI;IACf,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,aAAa,CAAS;IAE9B,SAAS,SAGR;IAED,UAAU,SAGT;IAED,eAAe,SAGd;IAED,YAAY;;;;MAIX;CACF;AAED,qBAAa,0BAA0B;IAErC,MAAM,CAAC,kBAAkB,SAAS;IAElC,OAAO,CAAC,eAAe,CAAmB;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAG,UAAU,CAAC;IACpB,KAAK,EAAG,sBAAsB,CAAC;IAC/B,QAAQ,EAAG,cAAc,CAAC;IAC1B,UAAU,EAAG,sBAAsB,CAAC;IACpC,UAAU,EAAG,UAAU,CAAC;IACxB,SAAS,EAAG,eAAe,CAAC;IAC5B,SAAS,EAAG,SAAS,CAAC;IAEtB,YAAY,EAAG,YAAY,CAAC;IAC5B,YAAY,EAAG,YAAY,CAAC;IAC5B,kBAAkB,EAAG,YAAY,CAAC;IAElC,YAAY,QAAQ,EAAE,MAAM,EAG3B;IAEK,sBAAsB,kBAM3B;IAED;;;;OAIG;IACG,kBAAkB,kBA8DvB;IAEK,KAAK,kBAEV;IAED,QAAQ,GAAI,CAAC,8JAI2D;IAElE,QAAQ,kBAEb;IAEK,yBAAyB,CAC7B,QAAQ,EAAE,sBAAsB,EAChC,SAAS,EAAE,YAAY,EACvB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,EAAE,EACd,MAAM,EAAE,MAAM,iBAcf;IAEK,iBAAiB,kBAkEtB;CACF"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Fr
|
|
1
|
+
import { computeSecretHash } from '@aztec/aztec.js/crypto';
|
|
2
|
+
import { Fr } from '@aztec/aztec.js/fields';
|
|
3
|
+
import { createLogger } from '@aztec/aztec.js/log';
|
|
3
4
|
import { TokenBlacklistContract } from '@aztec/noir-contracts.js/TokenBlacklist';
|
|
4
5
|
import { InvalidAccountContract } from '@aztec/noir-test-contracts.js/InvalidAccount';
|
|
5
6
|
import { jest } from '@jest/globals';
|
|
@@ -37,20 +38,15 @@ export class BlacklistTokenContractTest {
|
|
|
37
38
|
static CHANGE_ROLES_DELAY = 86400;
|
|
38
39
|
snapshotManager;
|
|
39
40
|
logger;
|
|
40
|
-
|
|
41
|
-
pxe;
|
|
42
|
-
accounts = [];
|
|
41
|
+
wallet;
|
|
43
42
|
asset;
|
|
44
43
|
tokenSim;
|
|
45
44
|
badAccount;
|
|
46
45
|
cheatCodes;
|
|
47
46
|
sequencer;
|
|
48
47
|
aztecNode;
|
|
49
|
-
admin;
|
|
50
48
|
adminAddress;
|
|
51
|
-
other;
|
|
52
49
|
otherAddress;
|
|
53
|
-
blacklisted;
|
|
54
50
|
blacklistedAddress;
|
|
55
51
|
constructor(testName){
|
|
56
52
|
this.logger = createLogger(`e2e:e2e_blacklist_token_contract:${testName}`);
|
|
@@ -66,32 +62,32 @@ export class BlacklistTokenContractTest {
|
|
|
66
62
|
*/ async applyBaseSnapshots() {
|
|
67
63
|
// Adding a timeout of 2 minutes in here such that it is propagated to the underlying tests
|
|
68
64
|
jest.setTimeout(120_000);
|
|
69
|
-
await this.snapshotManager.snapshot('3_accounts', deployAccounts(3, this.logger),
|
|
70
|
-
this.pxe = pxe;
|
|
65
|
+
await this.snapshotManager.snapshot('3_accounts', deployAccounts(3, this.logger), ({ deployedAccounts }, { cheatCodes, aztecNode, sequencer, wallet })=>{
|
|
71
66
|
this.cheatCodes = cheatCodes;
|
|
72
67
|
this.aztecNode = aztecNode;
|
|
73
68
|
this.sequencer = sequencer;
|
|
74
|
-
this.
|
|
75
|
-
this.
|
|
76
|
-
this.
|
|
77
|
-
this.
|
|
78
|
-
|
|
79
|
-
this.blacklisted = this.wallets[2];
|
|
80
|
-
this.blacklistedAddress = this.blacklisted.getAddress();
|
|
81
|
-
this.accounts = this.wallets.map((w)=>w.getCompleteAddress());
|
|
69
|
+
this.wallet = wallet;
|
|
70
|
+
this.adminAddress = deployedAccounts[0].address;
|
|
71
|
+
this.otherAddress = deployedAccounts[1].address;
|
|
72
|
+
this.blacklistedAddress = deployedAccounts[2].address;
|
|
73
|
+
return Promise.resolve();
|
|
82
74
|
});
|
|
83
75
|
await this.snapshotManager.snapshot('e2e_blacklist_token_contract', async ()=>{
|
|
84
76
|
// Create the token contract state.
|
|
85
77
|
// Move this account thing to addAccounts above?
|
|
86
78
|
this.logger.verbose(`Public deploy accounts...`);
|
|
87
|
-
await publicDeployAccounts(this.
|
|
79
|
+
await publicDeployAccounts(this.wallet, [
|
|
80
|
+
this.adminAddress,
|
|
81
|
+
this.otherAddress,
|
|
82
|
+
this.blacklistedAddress
|
|
83
|
+
]);
|
|
88
84
|
this.logger.verbose(`Deploying TokenContract...`);
|
|
89
|
-
this.asset = await TokenBlacklistContract.deploy(this.
|
|
85
|
+
this.asset = await TokenBlacklistContract.deploy(this.wallet, this.adminAddress).send({
|
|
90
86
|
from: this.adminAddress
|
|
91
87
|
}).deployed();
|
|
92
88
|
this.logger.verbose(`Token deployed to ${this.asset.address}`);
|
|
93
89
|
this.logger.verbose(`Deploying bad account...`);
|
|
94
|
-
this.badAccount = await InvalidAccountContract.deploy(this.
|
|
90
|
+
this.badAccount = await InvalidAccountContract.deploy(this.wallet).send({
|
|
95
91
|
from: this.adminAddress
|
|
96
92
|
}).deployed();
|
|
97
93
|
this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
|
|
@@ -102,10 +98,14 @@ export class BlacklistTokenContractTest {
|
|
|
102
98
|
};
|
|
103
99
|
}, async ({ tokenContractAddress, badAccountAddress })=>{
|
|
104
100
|
// Restore the token contract state.
|
|
105
|
-
this.asset =
|
|
101
|
+
this.asset = TokenBlacklistContract.at(tokenContractAddress, this.wallet);
|
|
106
102
|
this.logger.verbose(`Token contract address: ${this.asset.address}`);
|
|
107
|
-
this.tokenSim = new TokenSimulator(this.asset, this.
|
|
108
|
-
|
|
103
|
+
this.tokenSim = new TokenSimulator(this.asset, this.wallet, this.adminAddress, this.logger, [
|
|
104
|
+
this.adminAddress,
|
|
105
|
+
this.otherAddress,
|
|
106
|
+
this.blacklistedAddress
|
|
107
|
+
]);
|
|
108
|
+
this.badAccount = InvalidAccountContract.at(badAccountAddress, this.wallet);
|
|
109
109
|
this.logger.verbose(`Bad account address: ${this.badAccount.address}`);
|
|
110
110
|
expect(await this.asset.methods.get_roles(this.adminAddress).simulate({
|
|
111
111
|
from: this.adminAddress
|
|
@@ -120,29 +120,29 @@ export class BlacklistTokenContractTest {
|
|
|
120
120
|
await this.snapshotManager.teardown();
|
|
121
121
|
}
|
|
122
122
|
async addPendingShieldNoteToPXE(contract, recipient, amount, secretHash, txHash) {
|
|
123
|
-
const txEffects = await this.
|
|
123
|
+
const txEffects = await this.aztecNode.getTxEffect(txHash);
|
|
124
124
|
await contract.methods.deliver_transparent_note(contract.address, amount, secretHash, txHash.hash, txEffects.data.noteHashes, txEffects.data.nullifiers[0], recipient).simulate({
|
|
125
125
|
from: recipient
|
|
126
126
|
});
|
|
127
127
|
}
|
|
128
128
|
async applyMintSnapshot() {
|
|
129
129
|
await this.snapshotManager.snapshot('mint', async ()=>{
|
|
130
|
-
const { asset
|
|
130
|
+
const { asset } = this;
|
|
131
131
|
const amount = 10000n;
|
|
132
132
|
const adminMinterRole = new Role().withAdmin().withMinter();
|
|
133
|
-
await this.asset.
|
|
133
|
+
await this.asset.methods.update_roles(this.adminAddress, adminMinterRole.toNoirStruct()).send({
|
|
134
134
|
from: this.adminAddress
|
|
135
135
|
}).wait();
|
|
136
136
|
const blacklistRole = new Role().withBlacklisted();
|
|
137
|
-
await this.asset.
|
|
137
|
+
await this.asset.methods.update_roles(this.blacklistedAddress, blacklistRole.toNoirStruct()).send({
|
|
138
138
|
from: this.adminAddress
|
|
139
139
|
}).wait();
|
|
140
140
|
await this.crossTimestampOfChange();
|
|
141
|
-
expect(await this.asset.methods.get_roles(this.
|
|
141
|
+
expect(await this.asset.methods.get_roles(this.adminAddress).simulate({
|
|
142
142
|
from: this.adminAddress
|
|
143
143
|
})).toEqual(adminMinterRole.toNoirStruct());
|
|
144
144
|
this.logger.verbose(`Minting ${amount} publicly...`);
|
|
145
|
-
await asset.methods.mint_public(
|
|
145
|
+
await asset.methods.mint_public(this.adminAddress, amount).send({
|
|
146
146
|
from: this.adminAddress
|
|
147
147
|
}).wait();
|
|
148
148
|
this.logger.verbose(`Minting ${amount} privately...`);
|
|
@@ -151,8 +151,8 @@ export class BlacklistTokenContractTest {
|
|
|
151
151
|
const receipt = await asset.methods.mint_private(amount, secretHash).send({
|
|
152
152
|
from: this.adminAddress
|
|
153
153
|
}).wait();
|
|
154
|
-
await this.addPendingShieldNoteToPXE(asset,
|
|
155
|
-
const txClaim = asset.methods.redeem_shield(
|
|
154
|
+
await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
|
|
155
|
+
const txClaim = asset.methods.redeem_shield(this.adminAddress, amount, secret).send({
|
|
156
156
|
from: this.adminAddress
|
|
157
157
|
});
|
|
158
158
|
await txClaim.wait();
|
|
@@ -161,21 +161,21 @@ export class BlacklistTokenContractTest {
|
|
|
161
161
|
amount
|
|
162
162
|
};
|
|
163
163
|
}, async ({ amount })=>{
|
|
164
|
-
const { asset,
|
|
165
|
-
tokenSim.mintPublic(
|
|
166
|
-
const publicBalance = await asset.methods.balance_of_public(
|
|
167
|
-
from:
|
|
164
|
+
const { asset, tokenSim } = this;
|
|
165
|
+
tokenSim.mintPublic(this.adminAddress, amount);
|
|
166
|
+
const publicBalance = await asset.methods.balance_of_public(this.adminAddress).simulate({
|
|
167
|
+
from: this.adminAddress
|
|
168
168
|
});
|
|
169
169
|
this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
|
|
170
|
-
expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(
|
|
171
|
-
tokenSim.mintPrivate(
|
|
172
|
-
const privateBalance = await asset.methods.balance_of_private(
|
|
173
|
-
from:
|
|
170
|
+
expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(this.adminAddress));
|
|
171
|
+
tokenSim.mintPrivate(this.adminAddress, amount);
|
|
172
|
+
const privateBalance = await asset.methods.balance_of_private(this.adminAddress).simulate({
|
|
173
|
+
from: this.adminAddress
|
|
174
174
|
});
|
|
175
175
|
this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
|
|
176
|
-
expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(
|
|
176
|
+
expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
|
|
177
177
|
const totalSupply = await asset.methods.total_supply().simulate({
|
|
178
|
-
from:
|
|
178
|
+
from: this.adminAddress
|
|
179
179
|
});
|
|
180
180
|
this.logger.verbose(`Total supply: ${totalSupply}`);
|
|
181
181
|
expect(totalSupply).toEqual(tokenSim.totalSupply);
|
|
@@ -1,39 +1,42 @@
|
|
|
1
1
|
import type { AztecNodeConfig } from '@aztec/aztec-node';
|
|
2
|
-
import {
|
|
2
|
+
import { AztecAddress, EthAddress } from '@aztec/aztec.js/addresses';
|
|
3
|
+
import { type Logger } from '@aztec/aztec.js/log';
|
|
4
|
+
import type { AztecNode } from '@aztec/aztec.js/node';
|
|
3
5
|
import { CheatCodes } from '@aztec/aztec/testing';
|
|
4
|
-
import { type
|
|
6
|
+
import { type DeployL1ContractsArgs, type DeployL1ContractsReturnType } from '@aztec/ethereum/deploy-l1-contracts';
|
|
7
|
+
import type { ExtendedViemWalletClient } from '@aztec/ethereum/types';
|
|
5
8
|
import { TokenContract } from '@aztec/noir-contracts.js/Token';
|
|
6
9
|
import { TokenBridgeContract } from '@aztec/noir-contracts.js/TokenBridge';
|
|
7
10
|
import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
|
|
11
|
+
import type { TestWallet } from '@aztec/test-wallet/server';
|
|
8
12
|
import { type SubsystemsContext } from '../fixtures/snapshot_manager.js';
|
|
13
|
+
import type { SetupOptions } from '../fixtures/utils.js';
|
|
9
14
|
import { CrossChainTestHarness } from '../shared/cross_chain_test_harness.js';
|
|
10
15
|
export declare class CrossChainMessagingTest {
|
|
11
16
|
private snapshotManager;
|
|
12
17
|
logger: Logger;
|
|
13
|
-
accounts: CompleteAddress[];
|
|
14
18
|
aztecNode: AztecNode;
|
|
15
|
-
pxe: PXE;
|
|
16
19
|
aztecNodeConfig: AztecNodeConfig;
|
|
17
20
|
aztecNodeAdmin: AztecNodeAdmin;
|
|
21
|
+
ctx: SubsystemsContext;
|
|
18
22
|
l1Client: ExtendedViemWalletClient | undefined;
|
|
19
|
-
|
|
23
|
+
wallet: TestWallet;
|
|
24
|
+
ownerAddress: AztecAddress;
|
|
20
25
|
user1Address: AztecAddress;
|
|
21
|
-
user2Wallet: AccountWallet;
|
|
22
26
|
user2Address: AztecAddress;
|
|
23
27
|
crossChainTestHarness: CrossChainTestHarness;
|
|
24
28
|
ethAccount: EthAddress;
|
|
25
|
-
ownerAddress: AztecAddress;
|
|
26
29
|
l2Token: TokenContract;
|
|
27
30
|
l2Bridge: TokenBridgeContract;
|
|
28
31
|
inbox: any;
|
|
29
32
|
outbox: any;
|
|
30
33
|
cheatCodes: CheatCodes;
|
|
31
34
|
deployL1ContractsValues: DeployL1ContractsReturnType;
|
|
32
|
-
constructor(testName: string);
|
|
35
|
+
constructor(testName: string, opts?: SetupOptions, deployL1ContractsArgs?: Partial<DeployL1ContractsArgs>);
|
|
33
36
|
assumeProven(): Promise<void>;
|
|
34
37
|
setup(): Promise<void>;
|
|
35
38
|
snapshot: <T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>) => Promise<void>;
|
|
36
39
|
teardown(): Promise<void>;
|
|
37
40
|
applyBaseSnapshots(): Promise<void>;
|
|
38
41
|
}
|
|
39
|
-
//# sourceMappingURL=
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3Jvc3NfY2hhaW5fbWVzc2FnaW5nX3Rlc3QuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lMmVfY3Jvc3NfY2hhaW5fbWVzc2FnaW5nL2Nyb3NzX2NoYWluX21lc3NhZ2luZ190ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDckUsT0FBTyxFQUFFLEtBQUssTUFBTSxFQUFnQixNQUFNLHFCQUFxQixDQUFDO0FBQ2hFLE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUVsRCxPQUFPLEVBQ0wsS0FBSyxxQkFBcUIsRUFDMUIsS0FBSywyQkFBMkIsRUFFakMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM3QyxPQUFPLEtBQUssRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRXRFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUMvRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUMzRSxPQUFPLEtBQUssRUFBRSxjQUFjLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUN0RSxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUs1RCxPQUFPLEVBRUwsS0FBSyxpQkFBaUIsRUFJdkIsTUFBTSxpQ0FBaUMsQ0FBQztBQUN6QyxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUk5RSxxQkFBYSx1QkFBdUI7SUFDbEMsT0FBTyxDQUFDLGVBQWUsQ0FBbUI7SUFDMUMsTUFBTSxFQUFFLE1BQU0sQ0FBQztJQUNmLFNBQVMsRUFBRyxTQUFTLENBQUM7SUFDdEIsZUFBZSxFQUFHLGVBQWUsQ0FBQztJQUNsQyxjQUFjLEVBQUcsY0FBYyxDQUFDO0lBQ2hDLEdBQUcsRUFBRyxpQkFBaUIsQ0FBQztJQUV4QixRQUFRLEVBQUcsd0JBQXdCLEdBQUcsU0FBUyxDQUFDO0lBRWhELE1BQU0sRUFBRyxVQUFVLENBQUM7SUFDcEIsWUFBWSxFQUFHLFlBQVksQ0FBQztJQUM1QixZQUFZLEVBQUcsWUFBWSxDQUFDO0lBQzVCLFlBQVksRUFBRyxZQUFZLENBQUM7SUFDNUIscUJBQXFCLEVBQUcscUJBQXFCLENBQUM7SUFDOUMsVUFBVSxFQUFHLFVBQVUsQ0FBQztJQUN4QixPQUFPLEVBQUcsYUFBYSxDQUFDO0lBQ3hCLFFBQVEsRUFBRyxtQkFBbUIsQ0FBQztJQUUvQixLQUFLLEVBQUcsR0FBRyxDQUFDO0lBQ1osTUFBTSxFQUFHLEdBQUcsQ0FBQztJQUNiLFVBQVUsRUFBRyxVQUFVLENBQUM7SUFFeEIsdUJBQXVCLEVBQUcsMkJBQTJCLENBQUM7SUFFdEQsWUFBWSxRQUFRLEVBQUUsTUFBTSxFQUFFLElBQUksR0FBRSxZQUFpQixFQUFFLHFCQUFxQixHQUFFLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBTSxFQU1oSDtJQUVLLFlBQVksa0JBRWpCO0lBRUssS0FBSyxrQkFRVjtJQUVELFFBQVEsR0FBSSxDQUFDLDhKQUkyRDtJQUVsRSxRQUFRLGtCQUViO0lBRUssa0JBQWtCLGtCQXVGdkI7Q0FDRiJ9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cross_chain_messaging_test.d.ts","sourceRoot":"","sources":["../../src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"cross_chain_messaging_test.d.ts","sourceRoot":"","sources":["../../src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,qBAAqB,CAAC;AAChE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAElD,OAAO,EACL,KAAK,qBAAqB,EAC1B,KAAK,2BAA2B,EAEjC,MAAM,qCAAqC,CAAC;AAC7C,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEtE,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACtE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAK5D,OAAO,EAEL,KAAK,iBAAiB,EAIvB,MAAM,iCAAiC,CAAC;AACzC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAI9E,qBAAa,uBAAuB;IAClC,OAAO,CAAC,eAAe,CAAmB;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAG,SAAS,CAAC;IACtB,eAAe,EAAG,eAAe,CAAC;IAClC,cAAc,EAAG,cAAc,CAAC;IAChC,GAAG,EAAG,iBAAiB,CAAC;IAExB,QAAQ,EAAG,wBAAwB,GAAG,SAAS,CAAC;IAEhD,MAAM,EAAG,UAAU,CAAC;IACpB,YAAY,EAAG,YAAY,CAAC;IAC5B,YAAY,EAAG,YAAY,CAAC;IAC5B,YAAY,EAAG,YAAY,CAAC;IAC5B,qBAAqB,EAAG,qBAAqB,CAAC;IAC9C,UAAU,EAAG,UAAU,CAAC;IACxB,OAAO,EAAG,aAAa,CAAC;IACxB,QAAQ,EAAG,mBAAmB,CAAC;IAE/B,KAAK,EAAG,GAAG,CAAC;IACZ,MAAM,EAAG,GAAG,CAAC;IACb,UAAU,EAAG,UAAU,CAAC;IAExB,uBAAuB,EAAG,2BAA2B,CAAC;IAEtD,YAAY,QAAQ,EAAE,MAAM,EAAE,IAAI,GAAE,YAAiB,EAAE,qBAAqB,GAAE,OAAO,CAAC,qBAAqB,CAAM,EAMhH;IAEK,YAAY,kBAEjB;IAEK,KAAK,kBAQV;IAED,QAAQ,GAAI,CAAC,8JAI2D;IAElE,QAAQ,kBAEb;IAEK,kBAAkB,kBAuFvB;CACF"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
1
|
+
import { EthAddress } from '@aztec/aztec.js/addresses';
|
|
2
|
+
import { createLogger } from '@aztec/aztec.js/log';
|
|
3
|
+
import { createExtendedL1Client } from '@aztec/ethereum/client';
|
|
4
|
+
import { deployL1Contract } from '@aztec/ethereum/deploy-l1-contracts';
|
|
5
5
|
import { InboxAbi, OutboxAbi, TestERC20Abi, TestERC20Bytecode } from '@aztec/l1-artifacts';
|
|
6
6
|
import { TokenContract } from '@aztec/noir-contracts.js/Token';
|
|
7
7
|
import { TokenBridgeContract } from '@aztec/noir-contracts.js/TokenBridge';
|
|
@@ -13,65 +13,65 @@ const { E2E_DATA_PATH: dataPath } = process.env;
|
|
|
13
13
|
export class CrossChainMessagingTest {
|
|
14
14
|
snapshotManager;
|
|
15
15
|
logger;
|
|
16
|
-
accounts = [];
|
|
17
16
|
aztecNode;
|
|
18
|
-
pxe;
|
|
19
17
|
aztecNodeConfig;
|
|
20
18
|
aztecNodeAdmin;
|
|
19
|
+
ctx;
|
|
21
20
|
l1Client;
|
|
22
|
-
|
|
21
|
+
wallet;
|
|
22
|
+
ownerAddress;
|
|
23
23
|
user1Address;
|
|
24
|
-
user2Wallet;
|
|
25
24
|
user2Address;
|
|
26
25
|
crossChainTestHarness;
|
|
27
26
|
ethAccount;
|
|
28
|
-
ownerAddress;
|
|
29
27
|
l2Token;
|
|
30
28
|
l2Bridge;
|
|
31
29
|
inbox;
|
|
32
30
|
outbox;
|
|
33
31
|
cheatCodes;
|
|
34
32
|
deployL1ContractsValues;
|
|
35
|
-
constructor(testName){
|
|
33
|
+
constructor(testName, opts = {}, deployL1ContractsArgs = {}){
|
|
36
34
|
this.logger = createLogger(`e2e:e2e_cross_chain_messaging:${testName}`);
|
|
37
|
-
this.snapshotManager = createSnapshotManager(`e2e_cross_chain_messaging/${testName}`, dataPath
|
|
35
|
+
this.snapshotManager = createSnapshotManager(`e2e_cross_chain_messaging/${testName}`, dataPath, opts, {
|
|
36
|
+
initialValidators: [],
|
|
37
|
+
...deployL1ContractsArgs
|
|
38
|
+
});
|
|
38
39
|
}
|
|
39
40
|
async assumeProven() {
|
|
40
41
|
await this.cheatCodes.rollup.markAsProven();
|
|
41
42
|
}
|
|
42
43
|
async setup() {
|
|
43
|
-
|
|
44
|
-
this.aztecNode = aztecNode;
|
|
45
|
-
this.
|
|
46
|
-
this.aztecNodeConfig = aztecNodeConfig;
|
|
47
|
-
this.cheatCodes =
|
|
48
|
-
this.deployL1ContractsValues = deployL1ContractsValues;
|
|
49
|
-
this.aztecNodeAdmin = aztecNode;
|
|
44
|
+
this.ctx = await this.snapshotManager.setup();
|
|
45
|
+
this.aztecNode = this.ctx.aztecNode;
|
|
46
|
+
this.wallet = this.ctx.wallet;
|
|
47
|
+
this.aztecNodeConfig = this.ctx.aztecNodeConfig;
|
|
48
|
+
this.cheatCodes = this.ctx.cheatCodes;
|
|
49
|
+
this.deployL1ContractsValues = this.ctx.deployL1ContractsValues;
|
|
50
|
+
this.aztecNodeAdmin = this.ctx.aztecNode;
|
|
50
51
|
}
|
|
51
52
|
snapshot = (name, apply, restore = ()=>Promise.resolve())=>this.snapshotManager.snapshot(name, apply, restore);
|
|
52
53
|
async teardown() {
|
|
53
54
|
await this.snapshotManager.teardown();
|
|
54
55
|
}
|
|
55
56
|
async applyBaseSnapshots() {
|
|
56
|
-
// Note that we are using the same `
|
|
57
|
+
// Note that we are using the same `wallet`, `aztecNodeConfig` and `aztecNode` across all snapshots.
|
|
57
58
|
// This is to not have issues with different networks.
|
|
58
|
-
await this.snapshotManager.snapshot('3_accounts', deployAccounts(3, this.logger),
|
|
59
|
-
|
|
60
|
-
this.
|
|
61
|
-
wallets.forEach((w, i)=>this.logger.verbose(`Wallet ${i} address: ${w.getAddress()}`));
|
|
62
|
-
this.user1Wallet = wallets[0];
|
|
63
|
-
this.user1Address = this.user1Wallet.getAddress();
|
|
64
|
-
this.user2Wallet = wallets[1];
|
|
65
|
-
this.user2Address = this.user2Wallet.getAddress();
|
|
66
|
-
this.pxe = pxe;
|
|
59
|
+
await this.snapshotManager.snapshot('3_accounts', deployAccounts(3, this.logger), ({ deployedAccounts }, { wallet, aztecNodeConfig, aztecNode })=>{
|
|
60
|
+
[this.ownerAddress, this.user1Address, this.user2Address] = deployedAccounts.map((a)=>a.address);
|
|
61
|
+
this.wallet = wallet;
|
|
67
62
|
this.aztecNode = aztecNode;
|
|
68
63
|
this.aztecNodeConfig = aztecNodeConfig;
|
|
64
|
+
return Promise.resolve();
|
|
69
65
|
});
|
|
70
66
|
await this.snapshotManager.snapshot('e2e_cross_chain_messaging', async ()=>{
|
|
71
67
|
// Create the token contract state.
|
|
72
68
|
// Move this account thing to addAccounts above?
|
|
73
69
|
this.logger.verbose(`Public deploy accounts...`);
|
|
74
|
-
await publicDeployAccounts(this.
|
|
70
|
+
await publicDeployAccounts(this.wallet, [
|
|
71
|
+
this.ownerAddress,
|
|
72
|
+
this.user1Address,
|
|
73
|
+
this.user2Address
|
|
74
|
+
]);
|
|
75
75
|
this.l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
|
|
76
76
|
const underlyingERC20Address = await deployL1Contract(this.l1Client, TestERC20Abi, TestERC20Bytecode, [
|
|
77
77
|
'Underlying',
|
|
@@ -79,15 +79,14 @@ export class CrossChainMessagingTest {
|
|
|
79
79
|
this.l1Client.account.address
|
|
80
80
|
]).then(({ address })=>address);
|
|
81
81
|
this.logger.verbose(`Setting up cross chain harness...`);
|
|
82
|
-
this.crossChainTestHarness = await CrossChainTestHarness.new(this.aztecNode, this.
|
|
82
|
+
this.crossChainTestHarness = await CrossChainTestHarness.new(this.aztecNode, this.l1Client, this.wallet, this.ownerAddress, this.logger, underlyingERC20Address);
|
|
83
83
|
this.logger.verbose(`L2 token deployed to: ${this.crossChainTestHarness.l2Token.address}`);
|
|
84
84
|
return this.crossChainTestHarness.toCrossChainContext();
|
|
85
|
-
},
|
|
86
|
-
this.l2Token =
|
|
87
|
-
this.l2Bridge =
|
|
85
|
+
}, (crossChainContext)=>{
|
|
86
|
+
this.l2Token = TokenContract.at(crossChainContext.l2Token, this.wallet);
|
|
87
|
+
this.l2Bridge = TokenBridgeContract.at(crossChainContext.l2Bridge, this.wallet);
|
|
88
88
|
// There is an issue with the reviver so we are getting strings sometimes. Working around it here.
|
|
89
89
|
this.ethAccount = EthAddress.fromString(crossChainContext.ethAccount.toString());
|
|
90
|
-
this.ownerAddress = AztecAddress.fromString(crossChainContext.ownerAddress.toString());
|
|
91
90
|
const tokenPortalAddress = EthAddress.fromString(crossChainContext.tokenPortal.toString());
|
|
92
91
|
const l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
|
|
93
92
|
const inbox = getContract({
|
|
@@ -100,10 +99,11 @@ export class CrossChainMessagingTest {
|
|
|
100
99
|
abi: OutboxAbi,
|
|
101
100
|
client: l1Client
|
|
102
101
|
});
|
|
103
|
-
this.crossChainTestHarness = new CrossChainTestHarness(this.aztecNode, this.
|
|
102
|
+
this.crossChainTestHarness = new CrossChainTestHarness(this.aztecNode, this.logger, this.l2Token, this.l2Bridge, this.ethAccount, tokenPortalAddress, crossChainContext.underlying, l1Client, this.aztecNodeConfig.l1Contracts, this.wallet, this.ownerAddress);
|
|
104
103
|
this.l1Client = l1Client;
|
|
105
104
|
this.inbox = inbox;
|
|
106
105
|
this.outbox = outbox;
|
|
106
|
+
return Promise.resolve();
|
|
107
107
|
});
|
|
108
108
|
}
|
|
109
109
|
}
|
|
@@ -1,11 +1,18 @@
|
|
|
1
|
-
import
|
|
1
|
+
import type { ContractArtifact } from '@aztec/aztec.js/abi';
|
|
2
|
+
import type { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
3
|
+
import { type ContractBase } from '@aztec/aztec.js/contracts';
|
|
4
|
+
import { Fr } from '@aztec/aztec.js/fields';
|
|
5
|
+
import type { PublicKeys } from '@aztec/aztec.js/keys';
|
|
6
|
+
import { type Logger } from '@aztec/aztec.js/log';
|
|
7
|
+
import type { AztecNode } from '@aztec/aztec.js/node';
|
|
8
|
+
import type { Wallet } from '@aztec/aztec.js/wallet';
|
|
2
9
|
import type { StatefulTestContract } from '@aztec/noir-test-contracts.js/StatefulTest';
|
|
3
10
|
import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
|
|
11
|
+
import type { TestWallet } from '@aztec/test-wallet/server';
|
|
4
12
|
export declare class DeployTest {
|
|
5
13
|
private snapshotManager;
|
|
6
14
|
logger: Logger;
|
|
7
|
-
|
|
8
|
-
wallet: AccountWallet;
|
|
15
|
+
wallet: TestWallet;
|
|
9
16
|
defaultAccountAddress: AztecAddress;
|
|
10
17
|
aztecNode: AztecNode;
|
|
11
18
|
aztecNodeAdmin: AztecNodeAdmin;
|
|
@@ -20,11 +27,10 @@ export declare class DeployTest {
|
|
|
20
27
|
constructorName?: string;
|
|
21
28
|
deployer?: AztecAddress;
|
|
22
29
|
}): Promise<T>;
|
|
23
|
-
registerRandomAccount(): Promise<AztecAddress>;
|
|
24
30
|
}
|
|
25
31
|
export type StatefulContractCtorArgs = Parameters<StatefulTestContract['methods']['constructor']>;
|
|
26
32
|
export type ContractArtifactClass<T extends ContractBase> = {
|
|
27
|
-
at(address: AztecAddress, wallet: Wallet):
|
|
33
|
+
at(address: AztecAddress, wallet: Wallet): T;
|
|
28
34
|
artifact: ContractArtifact;
|
|
29
35
|
};
|
|
30
|
-
//# sourceMappingURL=
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVwbG95X3Rlc3QuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lMmVfZGVwbG95X2NvbnRyYWN0L2RlcGxveV90ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDNUQsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDOUQsT0FBTyxFQUFFLEtBQUssWUFBWSxFQUE4QyxNQUFNLDJCQUEyQixDQUFDO0FBQzFHLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1QyxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsS0FBSyxNQUFNLEVBQWdCLE1BQU0scUJBQXFCLENBQUM7QUFDaEUsT0FBTyxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDckQsT0FBTyxLQUFLLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUN2RixPQUFPLEtBQUssRUFBRSxjQUFjLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUN0RSxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQU01RCxxQkFBYSxVQUFVO0lBQ3JCLE9BQU8sQ0FBQyxlQUFlLENBQW1CO0lBQ25DLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFDZixNQUFNLEVBQUcsVUFBVSxDQUFDO0lBQ3BCLHFCQUFxQixFQUFHLFlBQVksQ0FBQztJQUNyQyxTQUFTLEVBQUcsU0FBUyxDQUFDO0lBQ3RCLGNBQWMsRUFBRyxjQUFjLENBQUM7SUFFdkMsWUFBWSxRQUFRLEVBQUUsTUFBTSxFQUczQjtJQUVLLEtBQUssa0JBTVY7SUFFSyxRQUFRLGtCQUViO1lBRWEsMkJBQTJCO0lBT25DLGdCQUFnQixDQUFDLENBQUMsU0FBUyxZQUFZLEVBQzNDLE1BQU0sRUFBRSxNQUFNLEVBQ2QsZ0JBQWdCLEVBQUUscUJBQXFCLENBQUMsQ0FBQyxDQUFDLEVBQzFDLElBQUksR0FBRTtRQUNKLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUNWLFVBQVUsQ0FBQyxFQUFFLFVBQVUsQ0FBQztRQUN4QixRQUFRLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQztRQUNqQixlQUFlLENBQUMsRUFBRSxNQUFNLENBQUM7UUFDekIsUUFBUSxDQUFDLEVBQUUsWUFBWSxDQUFDO0tBQ3BCLEdBQ0wsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQVdaO0NBQ0Y7QUFFRCxNQUFNLE1BQU0sd0JBQXdCLEdBQUcsVUFBVSxDQUFDLG9CQUFvQixDQUFDLFNBQVMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUM7QUFFbEcsTUFBTSxNQUFNLHFCQUFxQixDQUFDLENBQUMsU0FBUyxZQUFZLElBQUk7SUFDMUQsRUFBRSxDQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sR0FBRyxDQUFDLENBQUM7SUFDN0MsUUFBUSxFQUFFLGdCQUFnQixDQUFDO0NBQzVCLENBQUMifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"deploy_test.d.ts","sourceRoot":"","sources":["../../src/e2e_deploy_contract/deploy_test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"deploy_test.d.ts","sourceRoot":"","sources":["../../src/e2e_deploy_contract/deploy_test.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,KAAK,YAAY,EAA8C,MAAM,2BAA2B,CAAC;AAC1G,OAAO,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAC5C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,qBAAqB,CAAC;AAChE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,4CAA4C,CAAC;AACvF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACtE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAM5D,qBAAa,UAAU;IACrB,OAAO,CAAC,eAAe,CAAmB;IACnC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAG,UAAU,CAAC;IACpB,qBAAqB,EAAG,YAAY,CAAC;IACrC,SAAS,EAAG,SAAS,CAAC;IACtB,cAAc,EAAG,cAAc,CAAC;IAEvC,YAAY,QAAQ,EAAE,MAAM,EAG3B;IAEK,KAAK,kBAMV;IAEK,QAAQ,kBAEb;YAEa,2BAA2B;IAOnC,gBAAgB,CAAC,CAAC,SAAS,YAAY,EAC3C,MAAM,EAAE,MAAM,EACd,gBAAgB,EAAE,qBAAqB,CAAC,CAAC,CAAC,EAC1C,IAAI,GAAE;QACJ,IAAI,CAAC,EAAE,EAAE,CAAC;QACV,UAAU,CAAC,EAAE,UAAU,CAAC;QACxB,QAAQ,CAAC,EAAE,GAAG,EAAE,CAAC;QACjB,eAAe,CAAC,EAAE,MAAM,CAAC;QACzB,QAAQ,CAAC,EAAE,YAAY,CAAC;KACpB,GACL,OAAO,CAAC,CAAC,CAAC,CAWZ;CACF;AAED,MAAM,MAAM,wBAAwB,GAAG,UAAU,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;AAElG,MAAM,MAAM,qBAAqB,CAAC,CAAC,SAAS,YAAY,IAAI;IAC1D,EAAE,CAAC,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC;IAC7C,QAAQ,EAAE,gBAAgB,CAAC;CAC5B,CAAC"}
|