@aztec/end-to-end 0.0.0-test.1 → 0.0.1-commit.1142ef1
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 +61 -0
- package/dest/bench/client_flows/benchmark.d.ts.map +1 -0
- package/dest/bench/client_flows/benchmark.js +261 -0
- package/dest/bench/client_flows/client_flows_benchmark.d.ts +80 -0
- package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -0
- package/dest/bench/client_flows/client_flows_benchmark.js +336 -0
- package/dest/bench/client_flows/config.d.ts +14 -0
- package/dest/bench/client_flows/config.d.ts.map +1 -0
- package/dest/bench/client_flows/config.js +106 -0
- package/dest/bench/client_flows/data_extractor.d.ts +2 -0
- package/dest/bench/client_flows/data_extractor.d.ts.map +1 -0
- package/dest/bench/client_flows/data_extractor.js +79 -0
- package/dest/bench/utils.d.ts +14 -40
- package/dest/bench/utils.d.ts.map +1 -1
- package/dest/bench/utils.js +37 -70
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +21 -13
- 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 +85 -57
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +29 -28
- 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 +79 -82
- package/dest/e2e_deploy_contract/deploy_test.d.ts +16 -8
- package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
- package/dest/e2e_deploy_contract/deploy_test.js +13 -19
- package/dest/e2e_epochs/epochs_test.d.ts +65 -22
- package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
- package/dest/e2e_epochs/epochs_test.js +233 -49
- package/dest/e2e_fees/bridging_race.notest.d.ts +2 -0
- package/dest/e2e_fees/bridging_race.notest.d.ts.map +1 -0
- package/dest/e2e_fees/bridging_race.notest.js +63 -0
- package/dest/e2e_fees/fees_test.d.ts +27 -12
- package/dest/e2e_fees/fees_test.d.ts.map +1 -1
- package/dest/e2e_fees/fees_test.js +107 -110
- package/dest/e2e_l1_publisher/write_json.d.ts +10 -0
- package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -0
- package/dest/e2e_l1_publisher/write_json.js +55 -0
- package/dest/e2e_multi_validator/utils.d.ts +12 -0
- package/dest/e2e_multi_validator/utils.d.ts.map +1 -0
- package/dest/e2e_multi_validator/utils.js +214 -0
- package/dest/e2e_nested_contract/nested_contract_test.d.ts +10 -7
- package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
- package/dest/e2e_nested_contract/nested_contract_test.js +24 -20
- 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 +136 -0
- package/dest/e2e_p2p/p2p_network.d.ts +276 -23
- package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
- package/dest/e2e_p2p/p2p_network.js +188 -133
- package/dest/e2e_p2p/shared.d.ts +43 -7
- package/dest/e2e_p2p/shared.d.ts.map +1 -1
- package/dest/e2e_p2p/shared.js +164 -19
- package/dest/e2e_token_contract/token_contract_test.d.ts +12 -6
- package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
- package/dest/e2e_token_contract/token_contract_test.js +50 -26
- package/dest/fixtures/e2e_prover_test.d.ts +61 -0
- package/dest/fixtures/e2e_prover_test.d.ts.map +1 -0
- package/dest/{e2e_prover → fixtures}/e2e_prover_test.js +108 -113
- package/dest/fixtures/fixtures.d.ts +6 -8
- package/dest/fixtures/fixtures.d.ts.map +1 -1
- package/dest/fixtures/fixtures.js +5 -5
- 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 +3 -15
- 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 +10 -17
- package/dest/fixtures/index.d.ts +1 -1
- package/dest/fixtures/l1_to_l2_messaging.d.ts +11 -7
- package/dest/fixtures/l1_to_l2_messaging.d.ts.map +1 -1
- package/dest/fixtures/l1_to_l2_messaging.js +45 -19
- package/dest/fixtures/logging.d.ts +1 -1
- package/dest/fixtures/setup_p2p_test.d.ts +15 -14
- package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
- package/dest/fixtures/setup_p2p_test.js +82 -22
- package/dest/fixtures/snapshot_manager.d.ts +20 -14
- package/dest/fixtures/snapshot_manager.d.ts.map +1 -1
- package/dest/fixtures/snapshot_manager.js +147 -138
- package/dest/fixtures/token_utils.d.ts +10 -4
- package/dest/fixtures/token_utils.d.ts.map +1 -1
- package/dest/fixtures/token_utils.js +28 -12
- package/dest/fixtures/utils.d.ts +92 -54
- package/dest/fixtures/utils.d.ts.map +1 -1
- package/dest/fixtures/utils.js +452 -389
- 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/grafana_client.d.ts +41 -0
- package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
- package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
- package/dest/shared/cross_chain_test_harness.d.ts +42 -35
- package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
- package/dest/shared/cross_chain_test_harness.js +106 -52
- package/dest/shared/gas_portal_test_harness.d.ts +29 -31
- package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
- package/dest/shared/gas_portal_test_harness.js +51 -30
- package/dest/shared/index.d.ts +2 -2
- package/dest/shared/index.d.ts.map +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 +3 -25
- package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
- package/dest/shared/uniswap_l1_l2.js +170 -120
- package/dest/simulators/index.d.ts +1 -1
- package/dest/simulators/lending_simulator.d.ts +7 -11
- package/dest/simulators/lending_simulator.d.ts.map +1 -1
- package/dest/simulators/lending_simulator.js +16 -17
- package/dest/simulators/token_simulator.d.ts +6 -3
- package/dest/simulators/token_simulator.d.ts.map +1 -1
- package/dest/simulators/token_simulator.js +16 -13
- package/dest/spartan/setup_test_wallets.d.ts +27 -11
- package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
- package/dest/spartan/setup_test_wallets.js +202 -58
- 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 +151 -313
- package/dest/spartan/utils.d.ts.map +1 -1
- package/dest/spartan/utils.js +598 -151
- package/package.json +65 -58
- package/src/bench/client_flows/benchmark.ts +341 -0
- package/src/bench/client_flows/client_flows_benchmark.ts +450 -0
- package/src/bench/client_flows/config.ts +61 -0
- package/src/bench/client_flows/data_extractor.ts +89 -0
- package/src/bench/utils.ts +35 -81
- package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +80 -77
- package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +103 -122
- package/src/e2e_deploy_contract/deploy_test.ts +24 -39
- package/src/e2e_epochs/epochs_test.ts +299 -65
- package/src/e2e_fees/bridging_race.notest.ts +80 -0
- package/src/e2e_fees/fees_test.ts +150 -142
- package/src/e2e_l1_publisher/write_json.ts +74 -0
- package/src/e2e_multi_validator/utils.ts +258 -0
- package/src/e2e_nested_contract/nested_contract_test.ts +29 -19
- package/src/e2e_p2p/inactivity_slash_test.ts +179 -0
- package/src/e2e_p2p/p2p_network.ts +274 -171
- package/src/e2e_p2p/shared.ts +252 -29
- package/src/e2e_token_contract/token_contract_test.ts +43 -39
- package/src/fixtures/dumps/epoch_proof_result.json +1 -1
- package/src/{e2e_prover → fixtures}/e2e_prover_test.ts +112 -160
- package/src/fixtures/fixtures.ts +5 -7
- package/src/fixtures/get_acvm_config.ts +4 -12
- package/src/fixtures/get_bb_config.ts +18 -13
- package/src/fixtures/l1_to_l2_messaging.ts +56 -24
- package/src/fixtures/setup_p2p_test.ts +127 -39
- package/src/fixtures/snapshot_manager.ts +189 -160
- package/src/fixtures/token_utils.ts +32 -15
- package/src/fixtures/utils.ts +556 -475
- package/src/fixtures/web3signer.ts +63 -0
- package/src/fixtures/with_telemetry_utils.ts +2 -2
- package/src/guides/up_quick_start.sh +7 -15
- package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +2 -2
- package/src/shared/cross_chain_test_harness.ts +113 -87
- package/src/shared/gas_portal_test_harness.ts +59 -50
- package/src/shared/index.ts +1 -1
- package/src/shared/jest_setup.ts +1 -1
- package/src/shared/submit-transactions.ts +12 -8
- package/src/shared/uniswap_l1_l2.ts +194 -211
- package/src/simulators/lending_simulator.ts +15 -16
- package/src/simulators/token_simulator.ts +21 -13
- package/src/spartan/DEVELOP.md +128 -0
- package/src/spartan/setup_test_wallets.ts +258 -93
- package/src/spartan/tx_metrics.ts +130 -0
- package/src/spartan/utils.ts +722 -146
- package/dest/e2e_prover/e2e_prover_test.d.ts +0 -56
- package/dest/e2e_prover/e2e_prover_test.d.ts.map +0 -1
- package/dest/fixtures/setup_l1_contracts.d.ts +0 -6
- package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
- package/dest/fixtures/setup_l1_contracts.js +0 -17
- package/dest/quality_of_service/alert_checker.d.ts +0 -41
- package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
- package/dest/sample-dapp/connect.js +0 -12
- package/dest/sample-dapp/contracts.js +0 -10
- package/dest/sample-dapp/deploy.js +0 -35
- package/dest/sample-dapp/index.js +0 -98
- package/src/fixtures/setup_l1_contracts.ts +0 -27
- package/src/sample-dapp/connect.mjs +0 -16
- package/src/sample-dapp/contracts.mjs +0 -14
- package/src/sample-dapp/deploy.mjs +0 -40
- package/src/sample-dapp/index.mjs +0 -128
package/dest/bench/utils.js
CHANGED
|
@@ -1,12 +1,9 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { BenchmarkingContract } from '@aztec/noir-contracts.js/Benchmarking';
|
|
5
|
-
import {
|
|
6
|
-
import
|
|
7
|
-
import { mkdirpSync } from 'fs-extra';
|
|
8
|
-
import { globSync } from 'glob';
|
|
9
|
-
import { join } from 'path';
|
|
1
|
+
import { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
2
|
+
import { BatchCall } from '@aztec/aztec.js/contracts';
|
|
3
|
+
import { mean, stdDev, times } from '@aztec/foundation/collection';
|
|
4
|
+
import { BenchmarkingContract } from '@aztec/noir-test-contracts.js/Benchmarking';
|
|
5
|
+
import { mkdirSync, writeFileSync } from 'fs';
|
|
6
|
+
import path from 'path';
|
|
10
7
|
import { setup } from '../fixtures/utils.js';
|
|
11
8
|
/**
|
|
12
9
|
* Setup for benchmarks. Initializes a remote node with a single account and deploys a benchmark contract.
|
|
@@ -17,7 +14,10 @@ import { setup } from '../fixtures/utils.js';
|
|
|
17
14
|
benchmark: true
|
|
18
15
|
}
|
|
19
16
|
});
|
|
20
|
-
const
|
|
17
|
+
const defaultAccountAddress = context.accounts[0];
|
|
18
|
+
const contract = await BenchmarkingContract.deploy(context.wallet).send({
|
|
19
|
+
from: defaultAccountAddress
|
|
20
|
+
}).deployed();
|
|
21
21
|
context.logger.info(`Deployed benchmarking contract at ${contract.address}`);
|
|
22
22
|
const sequencer = context.aztecNode.getSequencer();
|
|
23
23
|
const telemetry = context.telemetryClient;
|
|
@@ -28,7 +28,13 @@ import { setup } from '../fixtures/utils.js';
|
|
|
28
28
|
await telemetry.flush();
|
|
29
29
|
const data = telemetry.getMeters();
|
|
30
30
|
const formatted = formatMetricsForGithubBenchmarkAction(data, opts.metrics);
|
|
31
|
+
if (formatted.length === 0) {
|
|
32
|
+
throw new Error(`No benchmark data generated. Please review your test setup.`);
|
|
33
|
+
}
|
|
31
34
|
const benchOutput = opts.benchOutput ?? process.env.BENCH_OUTPUT ?? 'bench.json';
|
|
35
|
+
mkdirSync(path.dirname(benchOutput), {
|
|
36
|
+
recursive: true
|
|
37
|
+
});
|
|
32
38
|
writeFileSync(benchOutput, JSON.stringify(formatted));
|
|
33
39
|
context.logger.info(`Wrote ${data.length} metrics to ${benchOutput}`);
|
|
34
40
|
await origTeardown();
|
|
@@ -40,17 +46,20 @@ import { setup } from '../fixtures/utils.js';
|
|
|
40
46
|
sequencer
|
|
41
47
|
};
|
|
42
48
|
}
|
|
49
|
+
function isMetricDefinition(f) {
|
|
50
|
+
return 'description' in f;
|
|
51
|
+
}
|
|
43
52
|
function formatMetricsForGithubBenchmarkAction(data, filter) {
|
|
44
|
-
const allFilters = filter.map((f)=>
|
|
45
|
-
name: f,
|
|
53
|
+
const allFilters = filter.map((f)=>isMetricDefinition(f) ? {
|
|
54
|
+
name: f.name,
|
|
46
55
|
source: f,
|
|
47
56
|
transform: (x)=>x,
|
|
48
|
-
unit:
|
|
57
|
+
unit: f.unit
|
|
49
58
|
} : f);
|
|
50
59
|
return data.flatMap((meter)=>{
|
|
51
|
-
return meter.metrics.filter((metric)=>allFilters.map((f)=>f.source).includes(metric.name)).map((metric)=>[
|
|
60
|
+
return meter.metrics.filter((metric)=>allFilters.map((f)=>f.source.name).includes(metric.name)).map((metric)=>[
|
|
52
61
|
metric,
|
|
53
|
-
allFilters.find((f)=>f.source === metric.name)
|
|
62
|
+
allFilters.find((f)=>f.source.name === metric.name)
|
|
54
63
|
]).map(([metric, filter])=>({
|
|
55
64
|
name: `${meter.name}/${filter.name}`,
|
|
56
65
|
unit: filter.unit ?? metric.unit ?? 'unknown',
|
|
@@ -76,28 +85,6 @@ function getMetricValues(points) {
|
|
|
76
85
|
};
|
|
77
86
|
}
|
|
78
87
|
}
|
|
79
|
-
/**
|
|
80
|
-
* Creates and returns a directory with the current job name and a random number.
|
|
81
|
-
* @param index - Index to merge into the dir path.
|
|
82
|
-
* @returns A path to a created dir.
|
|
83
|
-
*/ export function makeDataDirectory(index) {
|
|
84
|
-
const testName = expect.getState().currentTestName.split(' ')[0].replaceAll('/', '_');
|
|
85
|
-
const db = join('data', testName, index.toString(), `${randomInt(99)}`);
|
|
86
|
-
mkdirpSync(db);
|
|
87
|
-
return db;
|
|
88
|
-
}
|
|
89
|
-
/**
|
|
90
|
-
* Returns the size in disk of a folder.
|
|
91
|
-
* @param path - Path to the folder.
|
|
92
|
-
* @returns Size in bytes.
|
|
93
|
-
*/ export function getFolderSize(path) {
|
|
94
|
-
return globSync('**', {
|
|
95
|
-
stat: true,
|
|
96
|
-
cwd: path,
|
|
97
|
-
nodir: true,
|
|
98
|
-
withFileTypes: true
|
|
99
|
-
}).reduce((accum, file)=>accum + file.size, 0);
|
|
100
|
-
}
|
|
101
88
|
/**
|
|
102
89
|
* Returns a call to the benchmark contract. Each call has a private execution (account entrypoint),
|
|
103
90
|
* a nested private call (create_note), a public call (increment_balance), and a nested public
|
|
@@ -108,17 +95,19 @@ function getMetricValues(points) {
|
|
|
108
95
|
* @param contract - Benchmarking contract.
|
|
109
96
|
* @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
|
|
110
97
|
* @returns A BatchCall instance.
|
|
111
|
-
*/
|
|
112
|
-
const owner = context.wallet.getAddress();
|
|
113
|
-
const sender = owner;
|
|
98
|
+
*/ async function makeCall(index, context, contract, heavyPublicCompute) {
|
|
114
99
|
if (heavyPublicCompute) {
|
|
115
100
|
return new BatchCall(context.wallet, [
|
|
116
|
-
|
|
101
|
+
contract.methods.sha256_hash_1024(randomBytesAsBigInts(1024))
|
|
117
102
|
]);
|
|
118
103
|
} else {
|
|
104
|
+
// We use random address for the new note owner because we can emit at most UNFINALIZED_TAGGING_INDEXES_WINDOW_LEN
|
|
105
|
+
// logs for a given sender-recipient-contract tuple.
|
|
106
|
+
const ownerOfNewNote = await AztecAddress.random();
|
|
107
|
+
const [ownerOfBalance] = context.accounts;
|
|
119
108
|
return new BatchCall(context.wallet, [
|
|
120
|
-
|
|
121
|
-
|
|
109
|
+
contract.methods.create_note(ownerOfNewNote, index + 1),
|
|
110
|
+
contract.methods.increment_balance(ownerOfBalance, index + 1)
|
|
122
111
|
]);
|
|
123
112
|
}
|
|
124
113
|
}
|
|
@@ -131,41 +120,19 @@ function getMetricValues(points) {
|
|
|
131
120
|
* @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
|
|
132
121
|
* @returns Array of sent txs.
|
|
133
122
|
*/ export async function sendTxs(txCount, context, contract, heavyPublicCompute = false) {
|
|
134
|
-
const calls = await
|
|
123
|
+
const calls = await Promise.all(times(txCount, (index)=>makeCall(index, context, contract, heavyPublicCompute)));
|
|
135
124
|
context.logger.info(`Creating ${txCount} txs`);
|
|
136
|
-
const
|
|
137
|
-
skipPublicSimulation: true
|
|
138
|
-
})));
|
|
125
|
+
const [from] = context.accounts;
|
|
139
126
|
context.logger.info(`Sending ${txCount} txs`);
|
|
140
|
-
return
|
|
127
|
+
return calls.map((call)=>call.send({
|
|
128
|
+
from
|
|
129
|
+
}));
|
|
141
130
|
}
|
|
142
131
|
export async function waitTxs(txs, context, txWaitOpts) {
|
|
143
132
|
context.logger.info(`Awaiting ${txs.length} txs to be mined`);
|
|
144
133
|
await Promise.all(txs.map((tx)=>tx.wait(txWaitOpts)));
|
|
145
134
|
context.logger.info(`All ${txs.length} txs have been mined`);
|
|
146
135
|
}
|
|
147
|
-
/**
|
|
148
|
-
* Creates a new PXE
|
|
149
|
-
* @param node - Node to connect the pxe to.
|
|
150
|
-
* @param contract - Benchmark contract to add to the pxe.
|
|
151
|
-
* @param startingBlock - First l2 block to process.
|
|
152
|
-
* @returns The new PXE.
|
|
153
|
-
*/ export async function createNewPXE(node, contract, startingBlock = INITIAL_L2_BLOCK_NUM) {
|
|
154
|
-
const l1Contracts = await node.getL1ContractAddresses();
|
|
155
|
-
const { l1ChainId, protocolVersion } = await node.getNodeInfo();
|
|
156
|
-
const pxeConfig = {
|
|
157
|
-
l2StartingBlock: startingBlock,
|
|
158
|
-
l2BlockPollingIntervalMS: 100,
|
|
159
|
-
dataDirectory: undefined,
|
|
160
|
-
dataStoreMapSizeKB: 1024 * 1024,
|
|
161
|
-
l1Contracts,
|
|
162
|
-
l1ChainId,
|
|
163
|
-
version: protocolVersion
|
|
164
|
-
};
|
|
165
|
-
const pxe = await createPXEService(node, pxeConfig);
|
|
166
|
-
await pxe.registerContract(contract);
|
|
167
|
-
return pxe;
|
|
168
|
-
}
|
|
169
136
|
function randomBytesAsBigInts(length) {
|
|
170
137
|
return [
|
|
171
138
|
...Array(length)
|
|
@@ -1,6 +1,13 @@
|
|
|
1
|
-
import {
|
|
2
|
-
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';
|
|
6
|
+
import type { CheatCodes } from '@aztec/aztec/testing';
|
|
3
7
|
import { TokenBlacklistContract } from '@aztec/noir-contracts.js/TokenBlacklist';
|
|
8
|
+
import { InvalidAccountContract } from '@aztec/noir-test-contracts.js/InvalidAccount';
|
|
9
|
+
import type { SequencerClient } from '@aztec/sequencer-client';
|
|
10
|
+
import type { TestWallet } from '@aztec/test-wallet/server';
|
|
4
11
|
import { type SubsystemsContext } from '../fixtures/snapshot_manager.js';
|
|
5
12
|
import { TokenSimulator } from '../simulators/token_simulator.js';
|
|
6
13
|
export declare class Role {
|
|
@@ -17,20 +24,21 @@ export declare class Role {
|
|
|
17
24
|
};
|
|
18
25
|
}
|
|
19
26
|
export declare class BlacklistTokenContractTest {
|
|
20
|
-
|
|
21
|
-
static DELAY: number;
|
|
27
|
+
static CHANGE_ROLES_DELAY: number;
|
|
22
28
|
private snapshotManager;
|
|
23
29
|
logger: Logger;
|
|
24
|
-
|
|
25
|
-
accounts: CompleteAddress[];
|
|
30
|
+
wallet: TestWallet;
|
|
26
31
|
asset: TokenBlacklistContract;
|
|
27
32
|
tokenSim: TokenSimulator;
|
|
28
|
-
badAccount:
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
33
|
+
badAccount: InvalidAccountContract;
|
|
34
|
+
cheatCodes: CheatCodes;
|
|
35
|
+
sequencer: SequencerClient;
|
|
36
|
+
aztecNode: AztecNode;
|
|
37
|
+
adminAddress: AztecAddress;
|
|
38
|
+
otherAddress: AztecAddress;
|
|
39
|
+
blacklistedAddress: AztecAddress;
|
|
32
40
|
constructor(testName: string);
|
|
33
|
-
|
|
41
|
+
crossTimestampOfChange(): Promise<void>;
|
|
34
42
|
/**
|
|
35
43
|
* Adds two state shifts to snapshot manager.
|
|
36
44
|
* 1. Add 3 accounts.
|
|
@@ -40,7 +48,7 @@ export declare class BlacklistTokenContractTest {
|
|
|
40
48
|
setup(): Promise<void>;
|
|
41
49
|
snapshot: <T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>) => Promise<void>;
|
|
42
50
|
teardown(): Promise<void>;
|
|
43
|
-
addPendingShieldNoteToPXE(contract: TokenBlacklistContract,
|
|
51
|
+
addPendingShieldNoteToPXE(contract: TokenBlacklistContract, recipient: AztecAddress, amount: bigint, secretHash: Fr, txHash: TxHash): Promise<void>;
|
|
44
52
|
applyMintSnapshot(): Promise<void>;
|
|
45
53
|
}
|
|
46
|
-
//# 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,8 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Fr
|
|
3
|
-
import {
|
|
4
|
-
import { DocsExampleContract } from '@aztec/noir-contracts.js/DocsExample';
|
|
1
|
+
import { computeSecretHash } from '@aztec/aztec.js/crypto';
|
|
2
|
+
import { Fr } from '@aztec/aztec.js/fields';
|
|
3
|
+
import { createLogger } from '@aztec/aztec.js/log';
|
|
5
4
|
import { TokenBlacklistContract } from '@aztec/noir-contracts.js/TokenBlacklist';
|
|
5
|
+
import { InvalidAccountContract } from '@aztec/noir-test-contracts.js/InvalidAccount';
|
|
6
6
|
import { jest } from '@jest/globals';
|
|
7
7
|
import { createSnapshotManager, deployAccounts, publicDeployAccounts } from '../fixtures/snapshot_manager.js';
|
|
8
8
|
import { TokenSimulator } from '../simulators/token_simulator.js';
|
|
@@ -34,27 +34,26 @@ export class Role {
|
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
36
|
export class BlacklistTokenContractTest {
|
|
37
|
-
// A low delay is really poor ux, but we need to keep it low for the tests to run "quickly".
|
|
38
37
|
// This value MUST match the same value that we have in the contract
|
|
39
|
-
static
|
|
38
|
+
static CHANGE_ROLES_DELAY = 86400;
|
|
40
39
|
snapshotManager;
|
|
41
40
|
logger;
|
|
42
|
-
|
|
43
|
-
accounts = [];
|
|
41
|
+
wallet;
|
|
44
42
|
asset;
|
|
45
43
|
tokenSim;
|
|
46
44
|
badAccount;
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
45
|
+
cheatCodes;
|
|
46
|
+
sequencer;
|
|
47
|
+
aztecNode;
|
|
48
|
+
adminAddress;
|
|
49
|
+
otherAddress;
|
|
50
|
+
blacklistedAddress;
|
|
50
51
|
constructor(testName){
|
|
51
52
|
this.logger = createLogger(`e2e:e2e_blacklist_token_contract:${testName}`);
|
|
52
53
|
this.snapshotManager = createSnapshotManager(`e2e_blacklist_token_contract/${testName}`, dataPath);
|
|
53
54
|
}
|
|
54
|
-
async
|
|
55
|
-
|
|
56
|
-
await this.asset.methods.get_roles(this.admin.getAddress()).send().wait();
|
|
57
|
-
}
|
|
55
|
+
async crossTimestampOfChange() {
|
|
56
|
+
await this.cheatCodes.warpL2TimeAtLeastBy(this.sequencer, this.aztecNode, BlacklistTokenContractTest.CHANGE_ROLES_DELAY);
|
|
58
57
|
}
|
|
59
58
|
/**
|
|
60
59
|
* Adds two state shifts to snapshot manager.
|
|
@@ -63,37 +62,54 @@ export class BlacklistTokenContractTest {
|
|
|
63
62
|
*/ async applyBaseSnapshots() {
|
|
64
63
|
// Adding a timeout of 2 minutes in here such that it is propagated to the underlying tests
|
|
65
64
|
jest.setTimeout(120_000);
|
|
66
|
-
await this.snapshotManager.snapshot('3_accounts', deployAccounts(3, this.logger),
|
|
67
|
-
this.
|
|
68
|
-
this.
|
|
69
|
-
this.
|
|
70
|
-
this.
|
|
71
|
-
this.
|
|
65
|
+
await this.snapshotManager.snapshot('3_accounts', deployAccounts(3, this.logger), ({ deployedAccounts }, { cheatCodes, aztecNode, sequencer, wallet })=>{
|
|
66
|
+
this.cheatCodes = cheatCodes;
|
|
67
|
+
this.aztecNode = aztecNode;
|
|
68
|
+
this.sequencer = sequencer;
|
|
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();
|
|
72
74
|
});
|
|
73
75
|
await this.snapshotManager.snapshot('e2e_blacklist_token_contract', async ()=>{
|
|
74
76
|
// Create the token contract state.
|
|
75
77
|
// Move this account thing to addAccounts above?
|
|
76
78
|
this.logger.verbose(`Public deploy accounts...`);
|
|
77
|
-
await publicDeployAccounts(this.
|
|
79
|
+
await publicDeployAccounts(this.wallet, [
|
|
80
|
+
this.adminAddress,
|
|
81
|
+
this.otherAddress,
|
|
82
|
+
this.blacklistedAddress
|
|
83
|
+
]);
|
|
78
84
|
this.logger.verbose(`Deploying TokenContract...`);
|
|
79
|
-
this.asset = await TokenBlacklistContract.deploy(this.
|
|
85
|
+
this.asset = await TokenBlacklistContract.deploy(this.wallet, this.adminAddress).send({
|
|
86
|
+
from: this.adminAddress
|
|
87
|
+
}).deployed();
|
|
80
88
|
this.logger.verbose(`Token deployed to ${this.asset.address}`);
|
|
81
89
|
this.logger.verbose(`Deploying bad account...`);
|
|
82
|
-
this.badAccount = await
|
|
90
|
+
this.badAccount = await InvalidAccountContract.deploy(this.wallet).send({
|
|
91
|
+
from: this.adminAddress
|
|
92
|
+
}).deployed();
|
|
83
93
|
this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
|
|
84
|
-
await this.
|
|
94
|
+
await this.crossTimestampOfChange();
|
|
85
95
|
return {
|
|
86
96
|
tokenContractAddress: this.asset.address,
|
|
87
97
|
badAccountAddress: this.badAccount.address
|
|
88
98
|
};
|
|
89
99
|
}, async ({ tokenContractAddress, badAccountAddress })=>{
|
|
90
100
|
// Restore the token contract state.
|
|
91
|
-
this.asset =
|
|
101
|
+
this.asset = TokenBlacklistContract.at(tokenContractAddress, this.wallet);
|
|
92
102
|
this.logger.verbose(`Token contract address: ${this.asset.address}`);
|
|
93
|
-
this.tokenSim = new TokenSimulator(this.asset, this.
|
|
94
|
-
|
|
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);
|
|
95
109
|
this.logger.verbose(`Bad account address: ${this.badAccount.address}`);
|
|
96
|
-
expect(await this.asset.methods.get_roles(this.
|
|
110
|
+
expect(await this.asset.methods.get_roles(this.adminAddress).simulate({
|
|
111
|
+
from: this.adminAddress
|
|
112
|
+
})).toEqual(new Role().withAdmin().toNoirStruct());
|
|
97
113
|
});
|
|
98
114
|
}
|
|
99
115
|
async setup() {
|
|
@@ -103,52 +119,64 @@ export class BlacklistTokenContractTest {
|
|
|
103
119
|
async teardown() {
|
|
104
120
|
await this.snapshotManager.teardown();
|
|
105
121
|
}
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
};
|
|
111
|
-
}
|
|
112
|
-
async addPendingShieldNoteToPXE(contract, wallet, amount, secretHash, txHash) {
|
|
113
|
-
const txEffects = await wallet.getTxEffect(txHash);
|
|
114
|
-
await contract.methods.deliver_transparent_note(contract.address, amount, secretHash, txHash.hash, this.#toBoundedVec(txEffects.data.noteHashes, MAX_NOTE_HASHES_PER_TX), txEffects.data.nullifiers[0], wallet.getAddress()).simulate();
|
|
122
|
+
async addPendingShieldNoteToPXE(contract, recipient, amount, secretHash, txHash) {
|
|
123
|
+
const txEffects = await this.aztecNode.getTxEffect(txHash);
|
|
124
|
+
await contract.methods.deliver_transparent_note(contract.address, amount, secretHash, txHash.hash, txEffects.data.noteHashes, txEffects.data.nullifiers[0], recipient).simulate({
|
|
125
|
+
from: recipient
|
|
126
|
+
});
|
|
115
127
|
}
|
|
116
128
|
async applyMintSnapshot() {
|
|
117
129
|
await this.snapshotManager.snapshot('mint', async ()=>{
|
|
118
|
-
const { asset
|
|
130
|
+
const { asset } = this;
|
|
119
131
|
const amount = 10000n;
|
|
120
132
|
const adminMinterRole = new Role().withAdmin().withMinter();
|
|
121
|
-
await this.asset.
|
|
133
|
+
await this.asset.methods.update_roles(this.adminAddress, adminMinterRole.toNoirStruct()).send({
|
|
134
|
+
from: this.adminAddress
|
|
135
|
+
}).wait();
|
|
122
136
|
const blacklistRole = new Role().withBlacklisted();
|
|
123
|
-
await this.asset.
|
|
124
|
-
|
|
125
|
-
|
|
137
|
+
await this.asset.methods.update_roles(this.blacklistedAddress, blacklistRole.toNoirStruct()).send({
|
|
138
|
+
from: this.adminAddress
|
|
139
|
+
}).wait();
|
|
140
|
+
await this.crossTimestampOfChange();
|
|
141
|
+
expect(await this.asset.methods.get_roles(this.adminAddress).simulate({
|
|
142
|
+
from: this.adminAddress
|
|
143
|
+
})).toEqual(adminMinterRole.toNoirStruct());
|
|
126
144
|
this.logger.verbose(`Minting ${amount} publicly...`);
|
|
127
|
-
await asset.methods.mint_public(
|
|
145
|
+
await asset.methods.mint_public(this.adminAddress, amount).send({
|
|
146
|
+
from: this.adminAddress
|
|
147
|
+
}).wait();
|
|
128
148
|
this.logger.verbose(`Minting ${amount} privately...`);
|
|
129
149
|
const secret = Fr.random();
|
|
130
150
|
const secretHash = await computeSecretHash(secret);
|
|
131
|
-
const receipt = await asset.methods.mint_private(amount, secretHash).send(
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
await
|
|
135
|
-
|
|
151
|
+
const receipt = await asset.methods.mint_private(amount, secretHash).send({
|
|
152
|
+
from: this.adminAddress
|
|
153
|
+
}).wait();
|
|
154
|
+
await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
|
|
155
|
+
const txClaim = asset.methods.redeem_shield(this.adminAddress, amount, secret).send({
|
|
156
|
+
from: this.adminAddress
|
|
136
157
|
});
|
|
158
|
+
await txClaim.wait();
|
|
137
159
|
this.logger.verbose(`Minting complete.`);
|
|
138
160
|
return {
|
|
139
161
|
amount
|
|
140
162
|
};
|
|
141
163
|
}, async ({ amount })=>{
|
|
142
|
-
const { asset,
|
|
143
|
-
tokenSim.mintPublic(
|
|
144
|
-
const publicBalance = await asset.methods.balance_of_public(
|
|
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
|
+
});
|
|
145
169
|
this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
|
|
146
|
-
expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(
|
|
147
|
-
tokenSim.mintPrivate(
|
|
148
|
-
const privateBalance = await asset.methods.balance_of_private(
|
|
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
|
+
});
|
|
149
175
|
this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
|
|
150
|
-
expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(
|
|
151
|
-
const totalSupply = await asset.methods.total_supply().simulate(
|
|
176
|
+
expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
|
|
177
|
+
const totalSupply = await asset.methods.total_supply().simulate({
|
|
178
|
+
from: this.adminAddress
|
|
179
|
+
});
|
|
152
180
|
this.logger.verbose(`Total supply: ${totalSupply}`);
|
|
153
181
|
expect(totalSupply).toEqual(tokenSim.totalSupply);
|
|
154
182
|
return Promise.resolve();
|
|
@@ -1,47 +1,48 @@
|
|
|
1
1
|
import type { AztecNodeConfig } from '@aztec/aztec-node';
|
|
2
|
-
import {
|
|
3
|
-
import { type
|
|
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';
|
|
5
|
+
import type { TxReceipt } from '@aztec/aztec.js/tx';
|
|
6
|
+
import { CheatCodes } from '@aztec/aztec/testing';
|
|
7
|
+
import { InboxContract, OutboxContract, RollupContract } from '@aztec/ethereum/contracts';
|
|
8
|
+
import type { DeployAztecL1ContractsArgs, DeployAztecL1ContractsReturnType } from '@aztec/ethereum/deploy-aztec-l1-contracts';
|
|
9
|
+
import type { ExtendedViemWalletClient } from '@aztec/ethereum/types';
|
|
10
|
+
import { EpochNumber } from '@aztec/foundation/branded-types';
|
|
4
11
|
import { TokenContract } from '@aztec/noir-contracts.js/Token';
|
|
5
12
|
import { TokenBridgeContract } from '@aztec/noir-contracts.js/TokenBridge';
|
|
13
|
+
import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
|
|
14
|
+
import type { TestWallet } from '@aztec/test-wallet/server';
|
|
6
15
|
import { type SubsystemsContext } from '../fixtures/snapshot_manager.js';
|
|
16
|
+
import type { SetupOptions } from '../fixtures/utils.js';
|
|
7
17
|
import { CrossChainTestHarness } from '../shared/cross_chain_test_harness.js';
|
|
8
18
|
export declare class CrossChainMessagingTest {
|
|
9
19
|
private snapshotManager;
|
|
20
|
+
private requireEpochProven;
|
|
10
21
|
logger: Logger;
|
|
11
|
-
wallets: AccountWallet[];
|
|
12
|
-
accounts: CompleteAddress[];
|
|
13
22
|
aztecNode: AztecNode;
|
|
14
|
-
pxe: PXE;
|
|
15
23
|
aztecNodeConfig: AztecNodeConfig;
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
24
|
+
aztecNodeAdmin: AztecNodeAdmin;
|
|
25
|
+
ctx: SubsystemsContext;
|
|
26
|
+
l1Client: ExtendedViemWalletClient | undefined;
|
|
27
|
+
wallet: TestWallet;
|
|
28
|
+
ownerAddress: AztecAddress;
|
|
29
|
+
user1Address: AztecAddress;
|
|
30
|
+
user2Address: AztecAddress;
|
|
19
31
|
crossChainTestHarness: CrossChainTestHarness;
|
|
20
32
|
ethAccount: EthAddress;
|
|
21
|
-
ownerAddress: AztecAddress;
|
|
22
33
|
l2Token: TokenContract;
|
|
23
34
|
l2Bridge: TokenBridgeContract;
|
|
24
|
-
rollup:
|
|
25
|
-
inbox:
|
|
26
|
-
outbox:
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
35
|
+
rollup: RollupContract;
|
|
36
|
+
inbox: InboxContract;
|
|
37
|
+
outbox: OutboxContract;
|
|
38
|
+
cheatCodes: CheatCodes;
|
|
39
|
+
deployL1ContractsValues: DeployAztecL1ContractsReturnType;
|
|
40
|
+
constructor(testName: string, opts?: SetupOptions, deployL1ContractsArgs?: Partial<DeployAztecL1ContractsArgs>);
|
|
30
41
|
setup(): Promise<void>;
|
|
42
|
+
advanceToEpochProven(l2TxReceipt: TxReceipt): Promise<EpochNumber>;
|
|
43
|
+
catchUpProvenChain(): Promise<void>;
|
|
31
44
|
snapshot: <T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>) => Promise<void>;
|
|
32
45
|
teardown(): Promise<void>;
|
|
33
46
|
applyBaseSnapshots(): Promise<void>;
|
|
34
|
-
toCrossChainContext(): CrossChainContext;
|
|
35
47
|
}
|
|
36
|
-
|
|
37
|
-
l2Token: AztecAddress;
|
|
38
|
-
l2Bridge: AztecAddress;
|
|
39
|
-
tokenPortal: EthAddress;
|
|
40
|
-
underlying: EthAddress;
|
|
41
|
-
ethAccount: EthAddress;
|
|
42
|
-
ownerAddress: AztecAddress;
|
|
43
|
-
inbox: EthAddress;
|
|
44
|
-
outbox: EthAddress;
|
|
45
|
-
};
|
|
46
|
-
export {};
|
|
47
|
-
//# sourceMappingURL=cross_chain_messaging_test.d.ts.map
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3Jvc3NfY2hhaW5fbWVzc2FnaW5nX3Rlc3QuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lMmVfY3Jvc3NfY2hhaW5fbWVzc2FnaW5nL2Nyb3NzX2NoYWluX21lc3NhZ2luZ190ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFckUsT0FBTyxFQUFFLEtBQUssTUFBTSxFQUFnQixNQUFNLHFCQUFxQixDQUFDO0FBQ2hFLE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3RELE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUVsRCxPQUFPLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRixPQUFPLEtBQUssRUFDViwwQkFBMEIsRUFDMUIsZ0NBQWdDLEVBQ2pDLE1BQU0sMkNBQTJDLENBQUM7QUFFbkQsT0FBTyxLQUFLLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RSxPQUFPLEVBQW9CLFdBQVcsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBR2hGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUMvRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUMzRSxPQUFPLEtBQUssRUFBRSxjQUFjLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUN0RSxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUc1RCxPQUFPLEVBRUwsS0FBSyxpQkFBaUIsRUFJdkIsTUFBTSxpQ0FBaUMsQ0FBQztBQUN6QyxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUk5RSxxQkFBYSx1QkFBdUI7SUFDbEMsT0FBTyxDQUFDLGVBQWUsQ0FBbUI7SUFDMUMsT0FBTyxDQUFDLGtCQUFrQixDQUFVO0lBQ3BDLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFDZixTQUFTLEVBQUcsU0FBUyxDQUFDO0lBQ3RCLGVBQWUsRUFBRyxlQUFlLENBQUM7SUFDbEMsY0FBYyxFQUFHLGNBQWMsQ0FBQztJQUNoQyxHQUFHLEVBQUcsaUJBQWlCLENBQUM7SUFFeEIsUUFBUSxFQUFHLHdCQUF3QixHQUFHLFNBQVMsQ0FBQztJQUVoRCxNQUFNLEVBQUcsVUFBVSxDQUFDO0lBQ3BCLFlBQVksRUFBRyxZQUFZLENBQUM7SUFDNUIsWUFBWSxFQUFHLFlBQVksQ0FBQztJQUM1QixZQUFZLEVBQUcsWUFBWSxDQUFDO0lBQzVCLHFCQUFxQixFQUFHLHFCQUFxQixDQUFDO0lBQzlDLFVBQVUsRUFBRyxVQUFVLENBQUM7SUFDeEIsT0FBTyxFQUFHLGFBQWEsQ0FBQztJQUN4QixRQUFRLEVBQUcsbUJBQW1CLENBQUM7SUFFL0IsTUFBTSxFQUFHLGNBQWMsQ0FBQztJQUN4QixLQUFLLEVBQUcsYUFBYSxDQUFDO0lBQ3RCLE1BQU0sRUFBRyxjQUFjLENBQUM7SUFDeEIsVUFBVSxFQUFHLFVBQVUsQ0FBQztJQUV4Qix1QkFBdUIsRUFBRyxnQ0FBZ0MsQ0FBQztJQUUzRCxZQUNFLFFBQVEsRUFBRSxNQUFNLEVBQ2hCLElBQUksR0FBRSxZQUFpQixFQUN2QixxQkFBcUIsR0FBRSxPQUFPLENBQUMsMEJBQTBCLENBQU0sRUFRaEU7SUFFSyxLQUFLLGtCQWFWO0lBRUssb0JBQW9CLENBQUMsV0FBVyxFQUFFLFNBQVMsR0FBRyxPQUFPLENBQUMsV0FBVyxDQUFDLENBVXZFO0lBRUssa0JBQWtCLGtCQUt2QjtJQUVELFFBQVEsR0FBSSxDQUFDLDhKQUkyRDtJQUVsRSxRQUFRLGtCQUViO0lBRUssa0JBQWtCLGtCQStFdkI7Q0FDRiJ9
|
|
@@ -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;AAErE,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,qBAAqB,CAAC;AAChE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAElD,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC1F,OAAO,KAAK,EACV,0BAA0B,EAC1B,gCAAgC,EACjC,MAAM,2CAA2C,CAAC;AAEnD,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAoB,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAGhF,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;AAG5D,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,OAAO,CAAC,kBAAkB,CAAU;IACpC,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,MAAM,EAAG,cAAc,CAAC;IACxB,KAAK,EAAG,aAAa,CAAC;IACtB,MAAM,EAAG,cAAc,CAAC;IACxB,UAAU,EAAG,UAAU,CAAC;IAExB,uBAAuB,EAAG,gCAAgC,CAAC;IAE3D,YACE,QAAQ,EAAE,MAAM,EAChB,IAAI,GAAE,YAAiB,EACvB,qBAAqB,GAAE,OAAO,CAAC,0BAA0B,CAAM,EAQhE;IAEK,KAAK,kBAaV;IAEK,oBAAoB,CAAC,WAAW,EAAE,SAAS,GAAG,OAAO,CAAC,WAAW,CAAC,CAUvE;IAEK,kBAAkB,kBAKvB;IAED,QAAQ,GAAI,CAAC,8JAI2D;IAElE,QAAQ,kBAEb;IAEK,kBAAkB,kBA+EvB;CACF"}
|