@aztec/end-to-end 0.0.1-commit.fce3e4f → 0.0.1-commit.ff7989d6c
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 +3 -2
- package/dest/bench/client_flows/benchmark.d.ts.map +1 -1
- package/dest/bench/client_flows/benchmark.js +21 -1
- package/dest/bench/client_flows/client_flows_benchmark.d.ts +15 -16
- package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
- package/dest/bench/client_flows/client_flows_benchmark.js +126 -139
- package/dest/bench/client_flows/config.d.ts +2 -2
- package/dest/bench/client_flows/config.d.ts.map +1 -1
- package/dest/bench/client_flows/config.js +18 -0
- package/dest/bench/client_flows/data_extractor.js +3 -1
- package/dest/bench/utils.d.ts +9 -8
- package/dest/bench/utils.d.ts.map +1 -1
- package/dest/bench/utils.js +27 -18
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +9 -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 +106 -112
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +20 -14
- 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 +92 -71
- package/dest/e2e_deploy_contract/deploy_test.d.ts +5 -4
- package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
- package/dest/e2e_deploy_contract/deploy_test.js +18 -13
- package/dest/e2e_epochs/epochs_test.d.ts +25 -15
- package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
- package/dest/e2e_epochs/epochs_test.js +100 -51
- package/dest/e2e_fees/bridging_race.notest.js +4 -6
- package/dest/e2e_fees/fees_test.d.ts +21 -17
- package/dest/e2e_fees/fees_test.d.ts.map +1 -1
- package/dest/e2e_fees/fees_test.js +128 -143
- package/dest/e2e_l1_publisher/write_json.d.ts +4 -3
- package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
- package/dest/e2e_l1_publisher/write_json.js +14 -16
- package/dest/e2e_multi_validator/utils.js +1 -1
- package/dest/e2e_nested_contract/nested_contract_test.d.ts +6 -9
- package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
- package/dest/e2e_nested_contract/nested_contract_test.js +31 -39
- package/dest/e2e_p2p/inactivity_slash_test.d.ts +4 -4
- package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -1
- package/dest/e2e_p2p/inactivity_slash_test.js +6 -9
- package/dest/e2e_p2p/p2p_network.d.ts +14 -12
- package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
- package/dest/e2e_p2p/p2p_network.js +135 -112
- package/dest/e2e_p2p/reqresp/utils.d.ts +22 -0
- package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -0
- package/dest/e2e_p2p/reqresp/utils.js +177 -0
- package/dest/e2e_p2p/shared.d.ts +7 -7
- package/dest/e2e_p2p/shared.d.ts.map +1 -1
- package/dest/e2e_p2p/shared.js +18 -21
- package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
- package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
- package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
- package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
- package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
- package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
- package/dest/e2e_token_contract/token_contract_test.d.ts +19 -10
- package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
- package/dest/e2e_token_contract/token_contract_test.js +99 -91
- package/dest/fixtures/authwit_proxy.d.ts +15 -0
- package/dest/fixtures/authwit_proxy.d.ts.map +1 -0
- package/dest/fixtures/authwit_proxy.js +30 -0
- package/dest/fixtures/e2e_prover_test.d.ts +13 -21
- package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
- package/dest/fixtures/e2e_prover_test.js +114 -133
- package/dest/fixtures/fixtures.d.ts +6 -3
- package/dest/fixtures/fixtures.d.ts.map +1 -1
- package/dest/fixtures/fixtures.js +8 -3
- package/dest/fixtures/get_acvm_config.js +1 -1
- package/dest/fixtures/ha_setup.d.ts +71 -0
- package/dest/fixtures/ha_setup.d.ts.map +1 -0
- package/dest/fixtures/ha_setup.js +116 -0
- package/dest/fixtures/index.d.ts +2 -1
- package/dest/fixtures/index.d.ts.map +1 -1
- package/dest/fixtures/index.js +1 -0
- 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/setup.d.ts +235 -0
- package/dest/fixtures/setup.d.ts.map +1 -0
- package/dest/fixtures/setup.js +605 -0
- package/dest/fixtures/setup_p2p_test.d.ts +16 -9
- package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
- package/dest/fixtures/setup_p2p_test.js +43 -32
- package/dest/fixtures/token_utils.d.ts +2 -2
- package/dest/fixtures/token_utils.d.ts.map +1 -1
- package/dest/fixtures/token_utils.js +10 -6
- package/dest/fixtures/utils.d.ts +5 -637
- package/dest/fixtures/utils.d.ts.map +1 -1
- package/dest/fixtures/utils.js +4 -647
- package/dest/fixtures/web3signer.js +1 -1
- 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/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/quality_of_service/prometheus_client.d.ts +38 -0
- package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
- package/dest/quality_of_service/prometheus_client.js +67 -0
- package/dest/shared/cross_chain_test_harness.d.ts +18 -6
- package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
- package/dest/shared/cross_chain_test_harness.js +14 -14
- package/dest/shared/gas_portal_test_harness.d.ts +12 -2
- package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
- package/dest/shared/gas_portal_test_harness.js +1 -1
- package/dest/shared/index.d.ts +3 -2
- package/dest/shared/index.d.ts.map +1 -1
- package/dest/shared/index.js +1 -0
- package/dest/shared/mock_state_view.d.ts +86 -0
- package/dest/shared/mock_state_view.d.ts.map +1 -0
- package/dest/shared/mock_state_view.js +186 -0
- package/dest/shared/submit-transactions.d.ts +4 -4
- package/dest/shared/submit-transactions.d.ts.map +1 -1
- package/dest/shared/submit-transactions.js +9 -11
- package/dest/shared/uniswap_l1_l2.d.ts +3 -27
- package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
- package/dest/shared/uniswap_l1_l2.js +57 -35
- package/dest/simulators/lending_simulator.d.ts +6 -2
- package/dest/simulators/lending_simulator.d.ts.map +1 -1
- package/dest/simulators/lending_simulator.js +2 -2
- package/dest/simulators/token_simulator.d.ts +1 -1
- package/dest/simulators/token_simulator.d.ts.map +1 -1
- package/dest/simulators/token_simulator.js +2 -23
- package/dest/spartan/setup_test_wallets.d.ts +12 -4
- package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
- package/dest/spartan/setup_test_wallets.js +94 -36
- package/dest/spartan/tx_metrics.d.ts +88 -0
- package/dest/spartan/tx_metrics.d.ts.map +1 -0
- package/dest/spartan/tx_metrics.js +422 -0
- package/dest/spartan/utils/bot.d.ts +28 -0
- package/dest/spartan/utils/bot.d.ts.map +1 -0
- package/dest/spartan/utils/bot.js +142 -0
- package/dest/spartan/utils/chaos.d.ts +79 -0
- package/dest/spartan/utils/chaos.d.ts.map +1 -0
- package/dest/spartan/utils/chaos.js +142 -0
- package/dest/spartan/utils/clients.d.ts +39 -0
- package/dest/spartan/utils/clients.d.ts.map +1 -0
- package/dest/spartan/utils/clients.js +90 -0
- package/dest/spartan/utils/config.d.ts +39 -0
- package/dest/spartan/utils/config.d.ts.map +1 -0
- package/dest/spartan/utils/config.js +21 -0
- package/dest/spartan/utils/health.d.ts +63 -0
- package/dest/spartan/utils/health.d.ts.map +1 -0
- package/dest/spartan/utils/health.js +202 -0
- package/dest/spartan/utils/helm.d.ts +15 -0
- package/dest/spartan/utils/helm.d.ts.map +1 -0
- package/dest/spartan/utils/helm.js +47 -0
- package/dest/spartan/utils/index.d.ts +9 -0
- package/dest/spartan/utils/index.d.ts.map +1 -0
- package/dest/spartan/utils/index.js +18 -0
- package/dest/spartan/utils/k8s.d.ts +128 -0
- package/dest/spartan/utils/k8s.d.ts.map +1 -0
- package/dest/spartan/utils/k8s.js +381 -0
- package/dest/spartan/utils/nodes.d.ts +40 -0
- package/dest/spartan/utils/nodes.d.ts.map +1 -0
- package/dest/spartan/utils/nodes.js +460 -0
- package/dest/spartan/utils/scripts.d.ts +30 -0
- package/dest/spartan/utils/scripts.d.ts.map +1 -0
- package/dest/spartan/utils/scripts.js +81 -0
- package/dest/spartan/utils.d.ts +2 -218
- package/dest/spartan/utils.d.ts.map +1 -1
- package/dest/spartan/utils.js +1 -749
- package/dest/test-wallet/test_wallet.d.ts +83 -0
- package/dest/test-wallet/test_wallet.d.ts.map +1 -0
- package/dest/test-wallet/test_wallet.js +214 -0
- package/dest/test-wallet/utils.d.ts +41 -0
- package/dest/test-wallet/utils.d.ts.map +1 -0
- package/dest/test-wallet/utils.js +71 -0
- package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
- package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
- package/dest/test-wallet/wallet_worker_script.js +40 -0
- package/dest/test-wallet/worker_wallet.d.ts +52 -0
- package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
- package/dest/test-wallet/worker_wallet.js +103 -0
- package/dest/test-wallet/worker_wallet_schema.d.ts +274 -0
- package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
- package/dest/test-wallet/worker_wallet_schema.js +10 -0
- package/package.json +46 -41
- package/src/bench/client_flows/benchmark.ts +24 -2
- package/src/bench/client_flows/client_flows_benchmark.ts +148 -215
- package/src/bench/client_flows/config.ts +9 -1
- package/src/bench/client_flows/data_extractor.ts +1 -1
- package/src/bench/utils.ts +31 -21
- package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +114 -143
- package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +140 -126
- package/src/e2e_deploy_contract/deploy_test.ts +22 -15
- package/src/e2e_epochs/epochs_test.ts +162 -113
- package/src/e2e_fees/bridging_race.notest.ts +5 -11
- package/src/e2e_fees/fees_test.ts +171 -228
- package/src/e2e_l1_publisher/write_json.ts +16 -16
- package/src/e2e_multi_validator/utils.ts +1 -1
- package/src/e2e_nested_contract/nested_contract_test.ts +33 -56
- package/src/e2e_p2p/inactivity_slash_test.ts +7 -10
- package/src/e2e_p2p/p2p_network.ts +204 -185
- package/src/e2e_p2p/reqresp/utils.ts +235 -0
- package/src/e2e_p2p/shared.ts +33 -28
- package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
- package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
- package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
- package/src/e2e_token_contract/token_contract_test.ts +113 -119
- package/src/fixtures/authwit_proxy.ts +50 -0
- package/src/fixtures/dumps/epoch_proof_result.json +1 -1
- package/src/fixtures/e2e_prover_test.ts +130 -177
- package/src/fixtures/fixtures.ts +12 -5
- package/src/fixtures/get_acvm_config.ts +1 -1
- package/src/fixtures/ha_setup.ts +186 -0
- package/src/fixtures/index.ts +1 -0
- package/src/fixtures/l1_to_l2_messaging.ts +4 -2
- package/src/fixtures/setup.ts +896 -0
- package/src/fixtures/setup_p2p_test.ts +43 -47
- package/src/fixtures/token_utils.ts +7 -5
- package/src/fixtures/utils.ts +27 -966
- package/src/fixtures/web3signer.ts +1 -1
- package/src/fixtures/with_telemetry_utils.ts +2 -2
- package/src/guides/up_quick_start.sh +3 -3
- package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +1 -1
- package/src/quality_of_service/prometheus_client.ts +113 -0
- package/src/shared/cross_chain_test_harness.ts +19 -36
- package/src/shared/gas_portal_test_harness.ts +2 -2
- package/src/shared/index.ts +2 -1
- package/src/shared/mock_state_view.ts +188 -0
- package/src/shared/submit-transactions.ts +14 -16
- package/src/shared/uniswap_l1_l2.ts +66 -89
- package/src/simulators/lending_simulator.ts +3 -3
- package/src/simulators/token_simulator.ts +1 -29
- package/src/spartan/DEVELOP.md +7 -0
- package/src/spartan/setup_test_wallets.ts +136 -27
- package/src/spartan/tx_metrics.ts +376 -0
- package/src/spartan/utils/bot.ts +188 -0
- package/src/spartan/utils/chaos.ts +253 -0
- package/src/spartan/utils/clients.ts +100 -0
- package/src/spartan/utils/config.ts +27 -0
- package/src/spartan/utils/health.ts +255 -0
- package/src/spartan/utils/helm.ts +84 -0
- package/src/spartan/utils/index.ts +65 -0
- package/src/spartan/utils/k8s.ts +535 -0
- package/src/spartan/utils/nodes.ts +535 -0
- package/src/spartan/utils/scripts.ts +99 -0
- package/src/spartan/utils.ts +1 -942
- package/src/test-wallet/test_wallet.ts +306 -0
- package/src/test-wallet/utils.ts +112 -0
- package/src/test-wallet/wallet_worker_script.ts +43 -0
- package/src/test-wallet/worker_wallet.ts +165 -0
- package/src/test-wallet/worker_wallet_schema.ts +13 -0
- package/dest/fixtures/setup_l1_contracts.d.ts +0 -477
- package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
- package/dest/fixtures/setup_l1_contracts.js +0 -17
- package/dest/fixtures/snapshot_manager.d.ts +0 -95
- package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
- package/dest/fixtures/snapshot_manager.js +0 -505
- package/dest/quality_of_service/alert_checker.d.ts +0 -41
- package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
- package/src/fixtures/setup_l1_contracts.ts +0 -26
- package/src/fixtures/snapshot_manager.ts +0 -665
|
@@ -7,22 +7,15 @@ import type { TxHash } from '@aztec/aztec.js/tx';
|
|
|
7
7
|
import type { CheatCodes } from '@aztec/aztec/testing';
|
|
8
8
|
import type { TokenContract } from '@aztec/noir-contracts.js/Token';
|
|
9
9
|
import { TokenBlacklistContract } from '@aztec/noir-contracts.js/TokenBlacklist';
|
|
10
|
+
import { GenericProxyContract } from '@aztec/noir-test-contracts.js/GenericProxy';
|
|
10
11
|
import { InvalidAccountContract } from '@aztec/noir-test-contracts.js/InvalidAccount';
|
|
11
12
|
import type { SequencerClient } from '@aztec/sequencer-client';
|
|
12
|
-
import type { TestWallet } from '@aztec/test-wallet/server';
|
|
13
13
|
|
|
14
14
|
import { jest } from '@jest/globals';
|
|
15
15
|
|
|
16
|
-
import {
|
|
17
|
-
type ISnapshotManager,
|
|
18
|
-
type SubsystemsContext,
|
|
19
|
-
createSnapshotManager,
|
|
20
|
-
deployAccounts,
|
|
21
|
-
publicDeployAccounts,
|
|
22
|
-
} from '../fixtures/snapshot_manager.js';
|
|
16
|
+
import { type EndToEndContext, deployAccounts, publicDeployAccounts, setup, teardown } from '../fixtures/setup.js';
|
|
23
17
|
import { TokenSimulator } from '../simulators/token_simulator.js';
|
|
24
|
-
|
|
25
|
-
const { E2E_DATA_PATH: dataPath } = process.env;
|
|
18
|
+
import type { TestWallet } from '../test-wallet/test_wallet.js';
|
|
26
19
|
|
|
27
20
|
export class Role {
|
|
28
21
|
private isAdmin = false;
|
|
@@ -55,12 +48,13 @@ export class BlacklistTokenContractTest {
|
|
|
55
48
|
// This value MUST match the same value that we have in the contract
|
|
56
49
|
static CHANGE_ROLES_DELAY = 86400;
|
|
57
50
|
|
|
58
|
-
|
|
51
|
+
context!: EndToEndContext;
|
|
59
52
|
logger: Logger;
|
|
60
53
|
wallet!: TestWallet;
|
|
61
54
|
asset!: TokenBlacklistContract;
|
|
62
55
|
tokenSim!: TokenSimulator;
|
|
63
56
|
badAccount!: InvalidAccountContract;
|
|
57
|
+
authwitProxy!: GenericProxyContract;
|
|
64
58
|
cheatCodes!: CheatCodes;
|
|
65
59
|
sequencer!: SequencerClient;
|
|
66
60
|
aztecNode!: AztecNode;
|
|
@@ -71,7 +65,6 @@ export class BlacklistTokenContractTest {
|
|
|
71
65
|
|
|
72
66
|
constructor(testName: string) {
|
|
73
67
|
this.logger = createLogger(`e2e:e2e_blacklist_token_contract:${testName}`);
|
|
74
|
-
this.snapshotManager = createSnapshotManager(`e2e_blacklist_token_contract/${testName}`, dataPath);
|
|
75
68
|
}
|
|
76
69
|
|
|
77
70
|
async crossTimestampOfChange() {
|
|
@@ -83,86 +76,79 @@ export class BlacklistTokenContractTest {
|
|
|
83
76
|
}
|
|
84
77
|
|
|
85
78
|
/**
|
|
86
|
-
*
|
|
79
|
+
* Applies base setup:
|
|
87
80
|
* 1. Add 3 accounts.
|
|
88
81
|
* 2. Publicly deploy accounts, deploy token contract and a "bad account".
|
|
89
82
|
*/
|
|
90
|
-
async
|
|
83
|
+
async applyBaseSetup() {
|
|
91
84
|
// Adding a timeout of 2 minutes in here such that it is propagated to the underlying tests
|
|
92
85
|
jest.setTimeout(120_000);
|
|
93
86
|
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
87
|
+
this.logger.info('Deploying 3 accounts');
|
|
88
|
+
const { deployedAccounts } = await deployAccounts(
|
|
89
|
+
3,
|
|
90
|
+
this.logger,
|
|
91
|
+
)({
|
|
92
|
+
wallet: this.context.wallet,
|
|
93
|
+
initialFundedAccounts: this.context.initialFundedAccounts,
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
this.cheatCodes = this.context.cheatCodes;
|
|
97
|
+
this.aztecNode = this.context.aztecNodeService;
|
|
98
|
+
this.sequencer = this.context.sequencer!;
|
|
99
|
+
this.wallet = this.context.wallet;
|
|
100
|
+
this.adminAddress = deployedAccounts[0].address;
|
|
101
|
+
this.otherAddress = deployedAccounts[1].address;
|
|
102
|
+
this.blacklistedAddress = deployedAccounts[2].address;
|
|
103
|
+
|
|
104
|
+
this.logger.info('Setting up blacklist token contract');
|
|
105
|
+
// Create the token contract state.
|
|
106
|
+
this.logger.verbose(`Public deploy accounts...`);
|
|
107
|
+
await publicDeployAccounts(this.wallet, [this.adminAddress, this.otherAddress, this.blacklistedAddress]);
|
|
108
|
+
|
|
109
|
+
this.logger.verbose(`Deploying TokenContract...`);
|
|
110
|
+
this.asset = await TokenBlacklistContract.deploy(this.wallet, this.adminAddress).send({
|
|
111
|
+
from: this.adminAddress,
|
|
112
|
+
});
|
|
113
|
+
this.logger.verbose(`Token deployed to ${this.asset.address}`);
|
|
114
|
+
|
|
115
|
+
this.logger.verbose(`Deploying bad account...`);
|
|
116
|
+
this.badAccount = await InvalidAccountContract.deploy(this.wallet).send({ from: this.adminAddress });
|
|
117
|
+
this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
|
|
118
|
+
|
|
119
|
+
// Deploy a proxy contract for "on behalf of other" tests. The note owner must be the tx sender
|
|
120
|
+
// (so their notes are in scope), but msg_sender in the target must differ from the note owner
|
|
121
|
+
// to trigger authwit validation. The proxy forwards calls so that msg_sender != tx sender.
|
|
122
|
+
this.logger.verbose(`Deploying generic proxy...`);
|
|
123
|
+
this.authwitProxy = await GenericProxyContract.deploy(this.wallet).send({ from: this.adminAddress });
|
|
124
|
+
this.logger.verbose(`Deployed to ${this.authwitProxy.address}.`);
|
|
125
|
+
|
|
126
|
+
await this.crossTimestampOfChange();
|
|
127
|
+
|
|
128
|
+
this.tokenSim = new TokenSimulator(
|
|
129
|
+
this.asset as unknown as TokenContract,
|
|
130
|
+
this.wallet,
|
|
131
|
+
this.adminAddress,
|
|
132
|
+
this.logger,
|
|
133
|
+
[this.adminAddress, this.otherAddress, this.blacklistedAddress],
|
|
107
134
|
);
|
|
108
135
|
|
|
109
|
-
await this.
|
|
110
|
-
|
|
111
|
-
async () => {
|
|
112
|
-
// Create the token contract state.
|
|
113
|
-
// Move this account thing to addAccounts above?
|
|
114
|
-
this.logger.verbose(`Public deploy accounts...`);
|
|
115
|
-
await publicDeployAccounts(this.wallet, [this.adminAddress, this.otherAddress, this.blacklistedAddress]);
|
|
116
|
-
|
|
117
|
-
this.logger.verbose(`Deploying TokenContract...`);
|
|
118
|
-
this.asset = await TokenBlacklistContract.deploy(this.wallet, this.adminAddress)
|
|
119
|
-
.send({ from: this.adminAddress })
|
|
120
|
-
.deployed();
|
|
121
|
-
this.logger.verbose(`Token deployed to ${this.asset.address}`);
|
|
122
|
-
|
|
123
|
-
this.logger.verbose(`Deploying bad account...`);
|
|
124
|
-
this.badAccount = await InvalidAccountContract.deploy(this.wallet).send({ from: this.adminAddress }).deployed();
|
|
125
|
-
this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
|
|
126
|
-
|
|
127
|
-
await this.crossTimestampOfChange();
|
|
128
|
-
|
|
129
|
-
return { tokenContractAddress: this.asset.address, badAccountAddress: this.badAccount.address };
|
|
130
|
-
},
|
|
131
|
-
async ({ tokenContractAddress, badAccountAddress }) => {
|
|
132
|
-
// Restore the token contract state.
|
|
133
|
-
this.asset = TokenBlacklistContract.at(tokenContractAddress, this.wallet);
|
|
134
|
-
this.logger.verbose(`Token contract address: ${this.asset.address}`);
|
|
135
|
-
|
|
136
|
-
this.tokenSim = new TokenSimulator(
|
|
137
|
-
this.asset as unknown as TokenContract,
|
|
138
|
-
this.wallet,
|
|
139
|
-
this.adminAddress,
|
|
140
|
-
this.logger,
|
|
141
|
-
[this.adminAddress, this.otherAddress, this.blacklistedAddress],
|
|
142
|
-
);
|
|
143
|
-
|
|
144
|
-
this.badAccount = InvalidAccountContract.at(badAccountAddress, this.wallet);
|
|
145
|
-
this.logger.verbose(`Bad account address: ${this.badAccount.address}`);
|
|
146
|
-
|
|
147
|
-
expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
|
|
148
|
-
new Role().withAdmin().toNoirStruct(),
|
|
149
|
-
);
|
|
150
|
-
},
|
|
136
|
+
expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
|
|
137
|
+
new Role().withAdmin().toNoirStruct(),
|
|
151
138
|
);
|
|
152
139
|
}
|
|
153
140
|
|
|
154
141
|
async setup() {
|
|
155
|
-
|
|
142
|
+
this.logger.info('Setting up fresh context');
|
|
143
|
+
this.context = await setup(0, {
|
|
144
|
+
fundSponsoredFPC: true,
|
|
145
|
+
skipAccountDeployment: true,
|
|
146
|
+
});
|
|
147
|
+
await this.applyBaseSetup();
|
|
156
148
|
}
|
|
157
149
|
|
|
158
|
-
snapshot = <T>(
|
|
159
|
-
name: string,
|
|
160
|
-
apply: (context: SubsystemsContext) => Promise<T>,
|
|
161
|
-
restore: (snapshotData: T, context: SubsystemsContext) => Promise<void> = () => Promise.resolve(),
|
|
162
|
-
): Promise<void> => this.snapshotManager.snapshot(name, apply, restore);
|
|
163
|
-
|
|
164
150
|
async teardown() {
|
|
165
|
-
await this.
|
|
151
|
+
await teardown(this.context);
|
|
166
152
|
}
|
|
167
153
|
|
|
168
154
|
async addPendingShieldNoteToPXE(
|
|
@@ -174,7 +160,7 @@ export class BlacklistTokenContractTest {
|
|
|
174
160
|
) {
|
|
175
161
|
const txEffects = await this.aztecNode.getTxEffect(txHash);
|
|
176
162
|
await contract.methods
|
|
177
|
-
.
|
|
163
|
+
.process_transparent_note(
|
|
178
164
|
contract.address,
|
|
179
165
|
amount,
|
|
180
166
|
secretHash,
|
|
@@ -186,71 +172,56 @@ export class BlacklistTokenContractTest {
|
|
|
186
172
|
.simulate({ from: recipient });
|
|
187
173
|
}
|
|
188
174
|
|
|
189
|
-
async
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
await this.crossTimestampOfChange();
|
|
209
|
-
|
|
210
|
-
expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
|
|
211
|
-
adminMinterRole.toNoirStruct(),
|
|
212
|
-
);
|
|
213
|
-
|
|
214
|
-
this.logger.verbose(`Minting ${amount} publicly...`);
|
|
215
|
-
await asset.methods.mint_public(this.adminAddress, amount).send({ from: this.adminAddress }).wait();
|
|
216
|
-
|
|
217
|
-
this.logger.verbose(`Minting ${amount} privately...`);
|
|
218
|
-
const secret = Fr.random();
|
|
219
|
-
const secretHash = await computeSecretHash(secret);
|
|
220
|
-
const receipt = await asset.methods.mint_private(amount, secretHash).send({ from: this.adminAddress }).wait();
|
|
221
|
-
|
|
222
|
-
await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
|
|
223
|
-
const txClaim = asset.methods
|
|
224
|
-
.redeem_shield(this.adminAddress, amount, secret)
|
|
225
|
-
.send({ from: this.adminAddress });
|
|
226
|
-
await txClaim.wait();
|
|
227
|
-
this.logger.verbose(`Minting complete.`);
|
|
228
|
-
|
|
229
|
-
return { amount };
|
|
230
|
-
},
|
|
231
|
-
async ({ amount }) => {
|
|
232
|
-
const { asset, tokenSim } = this;
|
|
233
|
-
tokenSim.mintPublic(this.adminAddress, amount);
|
|
234
|
-
|
|
235
|
-
const publicBalance = await asset.methods
|
|
236
|
-
.balance_of_public(this.adminAddress)
|
|
237
|
-
.simulate({ from: this.adminAddress });
|
|
238
|
-
this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
|
|
239
|
-
expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(this.adminAddress));
|
|
240
|
-
|
|
241
|
-
tokenSim.mintPrivate(this.adminAddress, amount);
|
|
242
|
-
const privateBalance = await asset.methods
|
|
243
|
-
.balance_of_private(this.adminAddress)
|
|
244
|
-
.simulate({ from: this.adminAddress });
|
|
245
|
-
this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
|
|
246
|
-
expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
|
|
247
|
-
|
|
248
|
-
const totalSupply = await asset.methods.total_supply().simulate({ from: this.adminAddress });
|
|
249
|
-
this.logger.verbose(`Total supply: ${totalSupply}`);
|
|
250
|
-
expect(totalSupply).toEqual(tokenSim.totalSupply);
|
|
251
|
-
|
|
252
|
-
return Promise.resolve();
|
|
253
|
-
},
|
|
175
|
+
async applyMint() {
|
|
176
|
+
this.logger.info('Applying mint setup');
|
|
177
|
+
const { asset, tokenSim } = this;
|
|
178
|
+
const amount = 10000n;
|
|
179
|
+
|
|
180
|
+
const adminMinterRole = new Role().withAdmin().withMinter();
|
|
181
|
+
await this.asset.methods
|
|
182
|
+
.update_roles(this.adminAddress, adminMinterRole.toNoirStruct())
|
|
183
|
+
.send({ from: this.adminAddress });
|
|
184
|
+
|
|
185
|
+
const blacklistRole = new Role().withBlacklisted();
|
|
186
|
+
await this.asset.methods
|
|
187
|
+
.update_roles(this.blacklistedAddress, blacklistRole.toNoirStruct())
|
|
188
|
+
.send({ from: this.adminAddress });
|
|
189
|
+
|
|
190
|
+
await this.crossTimestampOfChange();
|
|
191
|
+
|
|
192
|
+
expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
|
|
193
|
+
adminMinterRole.toNoirStruct(),
|
|
254
194
|
);
|
|
195
|
+
|
|
196
|
+
this.logger.verbose(`Minting ${amount} publicly...`);
|
|
197
|
+
await asset.methods.mint_public(this.adminAddress, amount).send({ from: this.adminAddress });
|
|
198
|
+
|
|
199
|
+
this.logger.verbose(`Minting ${amount} privately...`);
|
|
200
|
+
const secret = Fr.random();
|
|
201
|
+
const secretHash = await computeSecretHash(secret);
|
|
202
|
+
const receipt = await asset.methods.mint_private(amount, secretHash).send({ from: this.adminAddress });
|
|
203
|
+
|
|
204
|
+
await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
|
|
205
|
+
await asset.methods.redeem_shield(this.adminAddress, amount, secret).send({ from: this.adminAddress });
|
|
206
|
+
this.logger.verbose(`Minting complete.`);
|
|
207
|
+
|
|
208
|
+
tokenSim.mintPublic(this.adminAddress, amount);
|
|
209
|
+
|
|
210
|
+
const publicBalance = await asset.methods
|
|
211
|
+
.balance_of_public(this.adminAddress)
|
|
212
|
+
.simulate({ from: this.adminAddress });
|
|
213
|
+
this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
|
|
214
|
+
expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(this.adminAddress));
|
|
215
|
+
|
|
216
|
+
tokenSim.mintPrivate(this.adminAddress, amount);
|
|
217
|
+
const privateBalance = await asset.methods
|
|
218
|
+
.balance_of_private(this.adminAddress)
|
|
219
|
+
.simulate({ from: this.adminAddress });
|
|
220
|
+
this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
|
|
221
|
+
expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
|
|
222
|
+
|
|
223
|
+
const totalSupply = await asset.methods.total_supply().simulate({ from: this.adminAddress });
|
|
224
|
+
this.logger.verbose(`Total supply: ${totalSupply}`);
|
|
225
|
+
expect(totalSupply).toEqual(tokenSim.totalSupply);
|
|
255
226
|
}
|
|
256
227
|
}
|
|
@@ -1,43 +1,46 @@
|
|
|
1
1
|
import type { AztecNodeConfig } from '@aztec/aztec-node';
|
|
2
2
|
import { AztecAddress, EthAddress } from '@aztec/aztec.js/addresses';
|
|
3
|
+
import { waitForProven } from '@aztec/aztec.js/contracts';
|
|
3
4
|
import { type Logger, createLogger } from '@aztec/aztec.js/log';
|
|
4
5
|
import type { AztecNode } from '@aztec/aztec.js/node';
|
|
6
|
+
import type { TxReceipt } from '@aztec/aztec.js/tx';
|
|
5
7
|
import { CheatCodes } from '@aztec/aztec/testing';
|
|
6
|
-
import {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
} from '@aztec/ethereum';
|
|
13
|
-
import {
|
|
8
|
+
import { createExtendedL1Client } from '@aztec/ethereum/client';
|
|
9
|
+
import { InboxContract, OutboxContract, RollupContract } from '@aztec/ethereum/contracts';
|
|
10
|
+
import type {
|
|
11
|
+
DeployAztecL1ContractsArgs,
|
|
12
|
+
DeployAztecL1ContractsReturnType,
|
|
13
|
+
} from '@aztec/ethereum/deploy-aztec-l1-contracts';
|
|
14
|
+
import { deployL1Contract } from '@aztec/ethereum/deploy-l1-contract';
|
|
15
|
+
import type { ExtendedViemWalletClient } from '@aztec/ethereum/types';
|
|
16
|
+
import { EpochNumber } from '@aztec/foundation/branded-types';
|
|
17
|
+
import { sleep } from '@aztec/foundation/sleep';
|
|
18
|
+
import { TestERC20Abi, TestERC20Bytecode } from '@aztec/l1-artifacts';
|
|
14
19
|
import { TokenContract } from '@aztec/noir-contracts.js/Token';
|
|
15
20
|
import { TokenBridgeContract } from '@aztec/noir-contracts.js/TokenBridge';
|
|
16
21
|
import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
|
|
17
|
-
import type { TestWallet } from '@aztec/test-wallet/server';
|
|
18
|
-
|
|
19
|
-
import { getContract } from 'viem';
|
|
20
22
|
|
|
21
23
|
import { MNEMONIC } from '../fixtures/fixtures.js';
|
|
22
24
|
import {
|
|
23
|
-
type
|
|
24
|
-
type
|
|
25
|
-
createSnapshotManager,
|
|
25
|
+
type EndToEndContext,
|
|
26
|
+
type SetupOptions,
|
|
26
27
|
deployAccounts,
|
|
27
28
|
publicDeployAccounts,
|
|
28
|
-
|
|
29
|
-
|
|
29
|
+
setup,
|
|
30
|
+
teardown,
|
|
31
|
+
} from '../fixtures/setup.js';
|
|
30
32
|
import { CrossChainTestHarness } from '../shared/cross_chain_test_harness.js';
|
|
31
|
-
|
|
32
|
-
const { E2E_DATA_PATH: dataPath } = process.env;
|
|
33
|
+
import type { TestWallet } from '../test-wallet/test_wallet.js';
|
|
33
34
|
|
|
34
35
|
export class CrossChainMessagingTest {
|
|
35
|
-
private
|
|
36
|
+
private requireEpochProven: boolean;
|
|
37
|
+
private setupOptions: SetupOptions;
|
|
38
|
+
private deployL1ContractsArgs: Partial<DeployAztecL1ContractsArgs>;
|
|
36
39
|
logger: Logger;
|
|
40
|
+
context!: EndToEndContext;
|
|
37
41
|
aztecNode!: AztecNode;
|
|
38
42
|
aztecNodeConfig!: AztecNodeConfig;
|
|
39
43
|
aztecNodeAdmin!: AztecNodeAdmin;
|
|
40
|
-
ctx!: SubsystemsContext;
|
|
41
44
|
|
|
42
45
|
l1Client!: ExtendedViemWalletClient | undefined;
|
|
43
46
|
|
|
@@ -50,130 +53,141 @@ export class CrossChainMessagingTest {
|
|
|
50
53
|
l2Token!: TokenContract;
|
|
51
54
|
l2Bridge!: TokenBridgeContract;
|
|
52
55
|
|
|
53
|
-
|
|
54
|
-
|
|
56
|
+
rollup!: RollupContract;
|
|
57
|
+
inbox!: InboxContract;
|
|
58
|
+
outbox!: OutboxContract;
|
|
55
59
|
cheatCodes!: CheatCodes;
|
|
56
60
|
|
|
57
|
-
deployL1ContractsValues!:
|
|
61
|
+
deployL1ContractsValues!: DeployAztecL1ContractsReturnType;
|
|
58
62
|
|
|
59
|
-
constructor(
|
|
63
|
+
constructor(
|
|
64
|
+
testName: string,
|
|
65
|
+
opts: SetupOptions = {},
|
|
66
|
+
deployL1ContractsArgs: Partial<DeployAztecL1ContractsArgs> = {},
|
|
67
|
+
) {
|
|
60
68
|
this.logger = createLogger(`e2e:e2e_cross_chain_messaging:${testName}`);
|
|
61
|
-
this.
|
|
69
|
+
this.setupOptions = opts;
|
|
70
|
+
this.deployL1ContractsArgs = {
|
|
62
71
|
initialValidators: [],
|
|
63
72
|
...deployL1ContractsArgs,
|
|
64
|
-
}
|
|
73
|
+
};
|
|
74
|
+
this.requireEpochProven = opts.startProverNode ?? false;
|
|
65
75
|
}
|
|
66
76
|
|
|
67
|
-
async
|
|
68
|
-
|
|
77
|
+
async setup() {
|
|
78
|
+
this.logger.info('Setting up cross chain messaging test');
|
|
79
|
+
this.context = await setup(0, {
|
|
80
|
+
...this.setupOptions,
|
|
81
|
+
fundSponsoredFPC: true,
|
|
82
|
+
skipAccountDeployment: true,
|
|
83
|
+
l1ContractsArgs: this.deployL1ContractsArgs,
|
|
84
|
+
});
|
|
85
|
+
await this.applyBaseSetup();
|
|
69
86
|
}
|
|
70
87
|
|
|
71
|
-
async
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
this.
|
|
76
|
-
|
|
77
|
-
this.
|
|
78
|
-
|
|
88
|
+
async advanceToEpochProven(l2TxReceipt: TxReceipt): Promise<EpochNumber> {
|
|
89
|
+
const block = await this.aztecNode.getBlock(l2TxReceipt.blockNumber!);
|
|
90
|
+
const epoch = await this.rollup.getEpochNumberForCheckpoint(block!.checkpointNumber);
|
|
91
|
+
// Warp to the next epoch.
|
|
92
|
+
await this.cheatCodes.rollup.advanceToEpoch(EpochNumber(epoch + 1));
|
|
93
|
+
// Wait for the tx to be proven.
|
|
94
|
+
await waitForProven(this.aztecNode, l2TxReceipt, { provenTimeout: 300 });
|
|
95
|
+
// Return the epoch the tx is in.
|
|
96
|
+
return epoch;
|
|
79
97
|
}
|
|
80
98
|
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
99
|
+
async catchUpProvenChain() {
|
|
100
|
+
const bn = await this.aztecNode.getBlockNumber();
|
|
101
|
+
while ((await this.aztecNode.getProvenBlockNumber()) < bn) {
|
|
102
|
+
await sleep(1000);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
86
105
|
|
|
87
106
|
async teardown() {
|
|
88
|
-
await this.
|
|
107
|
+
await teardown(this.context);
|
|
89
108
|
}
|
|
90
109
|
|
|
91
|
-
async
|
|
92
|
-
//
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
110
|
+
async applyBaseSetup() {
|
|
111
|
+
// Set up base context fields
|
|
112
|
+
this.aztecNode = this.context.aztecNodeService;
|
|
113
|
+
this.wallet = this.context.wallet;
|
|
114
|
+
this.aztecNodeConfig = this.context.config;
|
|
115
|
+
this.cheatCodes = this.context.cheatCodes;
|
|
116
|
+
this.deployL1ContractsValues = this.context.deployL1ContractsValues;
|
|
117
|
+
this.aztecNodeAdmin = this.context.aztecNodeService;
|
|
118
|
+
|
|
119
|
+
if (this.requireEpochProven) {
|
|
120
|
+
// Turn off the watcher to prevent it from keep marking blocks as proven.
|
|
121
|
+
this.context.watcher.setIsMarkingAsProven(false);
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
// Deploy 3 accounts
|
|
125
|
+
this.logger.info('Applying 3_accounts setup');
|
|
126
|
+
const { deployedAccounts } = await deployAccounts(
|
|
127
|
+
3,
|
|
128
|
+
this.logger,
|
|
129
|
+
)({
|
|
130
|
+
wallet: this.context.wallet,
|
|
131
|
+
initialFundedAccounts: this.context.initialFundedAccounts,
|
|
132
|
+
});
|
|
133
|
+
[this.ownerAddress, this.user1Address, this.user2Address] = deployedAccounts.map(a => a.address);
|
|
134
|
+
|
|
135
|
+
// Set up cross chain messaging
|
|
136
|
+
this.logger.info('Applying e2e_cross_chain_messaging setup');
|
|
137
|
+
|
|
138
|
+
// Create the token contract state.
|
|
139
|
+
this.logger.verbose(`Public deploy accounts...`);
|
|
140
|
+
await publicDeployAccounts(this.wallet, [this.ownerAddress, this.user1Address, this.user2Address]);
|
|
141
|
+
|
|
142
|
+
this.l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
|
|
143
|
+
|
|
144
|
+
const underlyingERC20Address = await deployL1Contract(this.l1Client, TestERC20Abi, TestERC20Bytecode, [
|
|
145
|
+
'Underlying',
|
|
146
|
+
'UND',
|
|
147
|
+
this.l1Client.account.address,
|
|
148
|
+
]).then(({ address }) => address);
|
|
149
|
+
|
|
150
|
+
this.logger.verbose(`Setting up cross chain harness...`);
|
|
151
|
+
this.crossChainTestHarness = await CrossChainTestHarness.new(
|
|
152
|
+
this.aztecNode,
|
|
153
|
+
this.l1Client,
|
|
154
|
+
this.wallet,
|
|
155
|
+
this.ownerAddress,
|
|
156
|
+
this.logger,
|
|
157
|
+
underlyingERC20Address,
|
|
105
158
|
);
|
|
106
159
|
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
this.l2Token = TokenContract.at(crossChainContext.l2Token, this.wallet);
|
|
139
|
-
this.l2Bridge = TokenBridgeContract.at(crossChainContext.l2Bridge, this.wallet);
|
|
140
|
-
|
|
141
|
-
// There is an issue with the reviver so we are getting strings sometimes. Working around it here.
|
|
142
|
-
this.ethAccount = EthAddress.fromString(crossChainContext.ethAccount.toString());
|
|
143
|
-
const tokenPortalAddress = EthAddress.fromString(crossChainContext.tokenPortal.toString());
|
|
144
|
-
|
|
145
|
-
const l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
|
|
146
|
-
|
|
147
|
-
const inbox = getContract({
|
|
148
|
-
address: this.aztecNodeConfig.l1Contracts.inboxAddress.toString(),
|
|
149
|
-
abi: InboxAbi,
|
|
150
|
-
client: l1Client,
|
|
151
|
-
});
|
|
152
|
-
const outbox = getContract({
|
|
153
|
-
address: this.aztecNodeConfig.l1Contracts.outboxAddress.toString(),
|
|
154
|
-
abi: OutboxAbi,
|
|
155
|
-
client: l1Client,
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
this.crossChainTestHarness = new CrossChainTestHarness(
|
|
159
|
-
this.aztecNode,
|
|
160
|
-
this.logger,
|
|
161
|
-
this.l2Token,
|
|
162
|
-
this.l2Bridge,
|
|
163
|
-
this.ethAccount,
|
|
164
|
-
tokenPortalAddress,
|
|
165
|
-
crossChainContext.underlying,
|
|
166
|
-
l1Client,
|
|
167
|
-
this.aztecNodeConfig.l1Contracts,
|
|
168
|
-
this.wallet,
|
|
169
|
-
this.ownerAddress,
|
|
170
|
-
);
|
|
171
|
-
|
|
172
|
-
this.l1Client = l1Client;
|
|
173
|
-
this.inbox = inbox;
|
|
174
|
-
this.outbox = outbox;
|
|
175
|
-
return Promise.resolve();
|
|
176
|
-
},
|
|
160
|
+
this.logger.verbose(`L2 token deployed to: ${this.crossChainTestHarness.l2Token.address}`);
|
|
161
|
+
|
|
162
|
+
const crossChainContext = this.crossChainTestHarness.toCrossChainContext();
|
|
163
|
+
|
|
164
|
+
this.l2Token = TokenContract.at(crossChainContext.l2Token, this.wallet);
|
|
165
|
+
this.l2Bridge = TokenBridgeContract.at(crossChainContext.l2Bridge, this.wallet);
|
|
166
|
+
|
|
167
|
+
// There is an issue with the reviver so we are getting strings sometimes. Working around it here.
|
|
168
|
+
this.ethAccount = EthAddress.fromString(crossChainContext.ethAccount.toString());
|
|
169
|
+
const tokenPortalAddress = EthAddress.fromString(crossChainContext.tokenPortal.toString());
|
|
170
|
+
|
|
171
|
+
const l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
|
|
172
|
+
this.l1Client = l1Client;
|
|
173
|
+
|
|
174
|
+
const l1Contracts = this.aztecNodeConfig.l1Contracts;
|
|
175
|
+
this.rollup = new RollupContract(l1Client, l1Contracts.rollupAddress.toString());
|
|
176
|
+
this.inbox = new InboxContract(l1Client, l1Contracts.inboxAddress.toString());
|
|
177
|
+
this.outbox = new OutboxContract(l1Client, l1Contracts.outboxAddress.toString());
|
|
178
|
+
|
|
179
|
+
this.crossChainTestHarness = new CrossChainTestHarness(
|
|
180
|
+
this.aztecNode,
|
|
181
|
+
this.logger,
|
|
182
|
+
this.l2Token,
|
|
183
|
+
this.l2Bridge,
|
|
184
|
+
this.ethAccount,
|
|
185
|
+
tokenPortalAddress,
|
|
186
|
+
crossChainContext.underlying,
|
|
187
|
+
l1Client,
|
|
188
|
+
this.aztecNodeConfig.l1Contracts,
|
|
189
|
+
this.wallet,
|
|
190
|
+
this.ownerAddress,
|
|
177
191
|
);
|
|
178
192
|
}
|
|
179
193
|
}
|