@aztec/end-to-end 0.0.1-commit.7d4e6cd → 0.0.1-commit.8afd444
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 +12 -13
- package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
- package/dest/bench/client_flows/client_flows_benchmark.js +117 -132
- package/dest/bench/utils.d.ts +6 -5
- package/dest/bench/utils.d.ts.map +1 -1
- package/dest/bench/utils.js +9 -7
- package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +6 -7
- 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 +96 -112
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +6 -7
- 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 +65 -62
- package/dest/e2e_deploy_contract/deploy_test.d.ts +4 -3
- package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
- package/dest/e2e_deploy_contract/deploy_test.js +18 -13
- package/dest/e2e_epochs/epochs_test.d.ts +7 -1
- package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
- package/dest/e2e_epochs/epochs_test.js +30 -8
- package/dest/e2e_fees/bridging_race.notest.js +3 -5
- package/dest/e2e_fees/fees_test.d.ts +13 -13
- package/dest/e2e_fees/fees_test.d.ts.map +1 -1
- package/dest/e2e_fees/fees_test.js +122 -140
- 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 -13
- 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 +3 -3
- package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -1
- package/dest/e2e_p2p/inactivity_slash_test.js +3 -3
- package/dest/e2e_p2p/p2p_network.d.ts +7 -6
- package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
- package/dest/e2e_p2p/p2p_network.js +110 -103
- 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 +153 -0
- package/dest/e2e_p2p/shared.d.ts +6 -6
- package/dest/e2e_p2p/shared.d.ts.map +1 -1
- package/dest/e2e_p2p/shared.js +9 -16
- package/dest/e2e_token_contract/token_contract_test.d.ts +16 -9
- package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
- package/dest/e2e_token_contract/token_contract_test.js +89 -91
- package/dest/fixtures/e2e_prover_test.d.ts +8 -14
- package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
- package/dest/fixtures/e2e_prover_test.js +85 -93
- 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 +114 -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/setup.d.ts +218 -0
- package/dest/fixtures/setup.d.ts.map +1 -0
- package/dest/fixtures/setup.js +695 -0
- package/dest/fixtures/setup_p2p_test.d.ts +4 -5
- package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
- package/dest/fixtures/setup_p2p_test.js +24 -19
- package/dest/fixtures/token_utils.d.ts +1 -1
- package/dest/fixtures/token_utils.d.ts.map +1 -1
- package/dest/fixtures/token_utils.js +7 -4
- package/dest/fixtures/utils.d.ts +5 -191
- package/dest/fixtures/utils.d.ts.map +1 -1
- package/dest/fixtures/utils.js +4 -615
- 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 +14 -4
- package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
- package/dest/shared/cross_chain_test_harness.js +11 -11
- package/dest/shared/gas_portal_test_harness.d.ts +11 -1
- 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/submit-transactions.d.ts +3 -3
- 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 +1 -1
- package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
- package/dest/shared/uniswap_l1_l2.js +12 -12
- package/dest/simulators/lending_simulator.d.ts +5 -1
- package/dest/simulators/lending_simulator.d.ts.map +1 -1
- package/dest/simulators/lending_simulator.js +2 -2
- package/dest/spartan/setup_test_wallets.d.ts +1 -1
- package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
- package/dest/spartan/setup_test_wallets.js +61 -34
- package/dest/spartan/tx_metrics.d.ts +51 -2
- package/dest/spartan/tx_metrics.d.ts.map +1 -1
- package/dest/spartan/tx_metrics.js +333 -6
- package/dest/spartan/utils/bot.d.ts +27 -0
- package/dest/spartan/utils/bot.d.ts.map +1 -0
- package/dest/spartan/utils/bot.js +141 -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 +126 -0
- package/dest/spartan/utils/k8s.d.ts.map +1 -0
- package/dest/spartan/utils/k8s.js +375 -0
- package/dest/spartan/utils/nodes.d.ts +41 -0
- package/dest/spartan/utils/nodes.d.ts.map +1 -0
- package/dest/spartan/utils/nodes.js +461 -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 -253
- package/dest/spartan/utils.d.ts.map +1 -1
- package/dest/spartan/utils.js +1 -892
- package/package.json +43 -39
- package/src/bench/client_flows/benchmark.ts +24 -2
- package/src/bench/client_flows/client_flows_benchmark.ts +137 -203
- package/src/bench/utils.ts +9 -7
- package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +104 -142
- package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +99 -106
- package/src/e2e_deploy_contract/deploy_test.ts +21 -14
- package/src/e2e_epochs/epochs_test.ts +59 -33
- package/src/e2e_fees/bridging_race.notest.ts +3 -9
- package/src/e2e_fees/fees_test.ts +171 -217
- package/src/e2e_l1_publisher/write_json.ts +16 -13
- package/src/e2e_nested_contract/nested_contract_test.ts +33 -56
- package/src/e2e_p2p/inactivity_slash_test.ts +5 -5
- package/src/e2e_p2p/p2p_network.ts +171 -167
- package/src/e2e_p2p/reqresp/utils.ts +207 -0
- package/src/e2e_p2p/shared.ts +20 -22
- package/src/e2e_token_contract/token_contract_test.ts +103 -118
- package/src/fixtures/dumps/epoch_proof_result.json +1 -1
- package/src/fixtures/e2e_prover_test.ts +99 -133
- package/src/fixtures/ha_setup.ts +184 -0
- package/src/fixtures/index.ts +1 -0
- package/src/fixtures/setup.ts +1017 -0
- package/src/fixtures/setup_p2p_test.ts +15 -20
- package/src/fixtures/token_utils.ts +6 -5
- package/src/fixtures/utils.ts +27 -901
- package/src/quality_of_service/prometheus_client.ts +113 -0
- package/src/shared/cross_chain_test_harness.ts +13 -27
- package/src/shared/gas_portal_test_harness.ts +1 -1
- package/src/shared/submit-transactions.ts +9 -15
- package/src/shared/uniswap_l1_l2.ts +12 -19
- package/src/simulators/lending_simulator.ts +2 -2
- package/src/spartan/setup_test_wallets.ts +72 -24
- package/src/spartan/tx_metrics.ts +255 -9
- package/src/spartan/utils/bot.ts +185 -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 +64 -0
- package/src/spartan/utils/k8s.ts +527 -0
- package/src/spartan/utils/nodes.ts +538 -0
- package/src/spartan/utils/scripts.ts +99 -0
- package/src/spartan/utils.ts +1 -1158
- package/dest/fixtures/snapshot_manager.d.ts +0 -93
- package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
- package/dest/fixtures/snapshot_manager.js +0 -488
- package/src/fixtures/snapshot_manager.ts +0 -646
package/src/bench/utils.ts
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import type { AztecNodeService } from '@aztec/aztec-node';
|
|
2
2
|
import { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
3
|
-
import { BatchCall,
|
|
3
|
+
import { BatchCall, NO_WAIT, type WaitOpts } from '@aztec/aztec.js/contracts';
|
|
4
|
+
import { waitForTx } from '@aztec/aztec.js/node';
|
|
4
5
|
import { mean, stdDev, times } from '@aztec/foundation/collection';
|
|
5
6
|
import { BenchmarkingContract } from '@aztec/noir-test-contracts.js/Benchmarking';
|
|
7
|
+
import type { TxHash } from '@aztec/stdlib/tx';
|
|
6
8
|
import type { MetricDefinition } from '@aztec/telemetry-client';
|
|
7
9
|
import type { BenchmarkDataPoint, BenchmarkMetricsType, BenchmarkTelemetryClient } from '@aztec/telemetry-client/bench';
|
|
8
10
|
|
|
@@ -23,7 +25,7 @@ export async function benchmarkSetup(
|
|
|
23
25
|
) {
|
|
24
26
|
const context = await setup(1, { ...opts, telemetryConfig: { benchmark: true } });
|
|
25
27
|
const defaultAccountAddress = context.accounts[0];
|
|
26
|
-
const contract = await BenchmarkingContract.deploy(context.wallet).send({ from: defaultAccountAddress })
|
|
28
|
+
const contract = await BenchmarkingContract.deploy(context.wallet).send({ from: defaultAccountAddress });
|
|
27
29
|
context.logger.info(`Deployed benchmarking contract at ${contract.address}`);
|
|
28
30
|
const sequencer = (context.aztecNode as AztecNodeService).getSequencer()!;
|
|
29
31
|
const telemetry = context.telemetryClient! as BenchmarkTelemetryClient;
|
|
@@ -142,18 +144,18 @@ export async function sendTxs(
|
|
|
142
144
|
context: EndToEndContext,
|
|
143
145
|
contract: BenchmarkingContract,
|
|
144
146
|
heavyPublicCompute: boolean = false,
|
|
145
|
-
): Promise<
|
|
147
|
+
): Promise<TxHash[]> {
|
|
146
148
|
const calls = await Promise.all(times(txCount, index => makeCall(index, context, contract, heavyPublicCompute)));
|
|
147
149
|
context.logger.info(`Creating ${txCount} txs`);
|
|
148
150
|
const [from] = context.accounts;
|
|
149
151
|
context.logger.info(`Sending ${txCount} txs`);
|
|
150
|
-
return calls.map(call => call.send({ from }));
|
|
152
|
+
return Promise.all(calls.map(call => call.send({ from, wait: NO_WAIT })));
|
|
151
153
|
}
|
|
152
154
|
|
|
153
|
-
export async function waitTxs(txs:
|
|
155
|
+
export async function waitTxs(txs: TxHash[], context: EndToEndContext, txWaitOpts?: WaitOpts) {
|
|
154
156
|
context.logger.info(`Awaiting ${txs.length} txs to be mined`);
|
|
155
|
-
await Promise.all(txs.map(
|
|
156
|
-
context.logger.info(
|
|
157
|
+
await Promise.all(txs.map(txHash => waitForTx(context.aztecNode, txHash, txWaitOpts)));
|
|
158
|
+
context.logger.info(`${txs.length} txs have been mined`);
|
|
157
159
|
}
|
|
158
160
|
|
|
159
161
|
function randomBytesAsBigInts(length: number): bigint[] {
|
|
@@ -13,17 +13,9 @@ 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
18
|
|
|
25
|
-
const { E2E_DATA_PATH: dataPath } = process.env;
|
|
26
|
-
|
|
27
19
|
export class Role {
|
|
28
20
|
private isAdmin = false;
|
|
29
21
|
private isMinter = false;
|
|
@@ -55,7 +47,7 @@ export class BlacklistTokenContractTest {
|
|
|
55
47
|
// This value MUST match the same value that we have in the contract
|
|
56
48
|
static CHANGE_ROLES_DELAY = 86400;
|
|
57
49
|
|
|
58
|
-
|
|
50
|
+
context!: EndToEndContext;
|
|
59
51
|
logger: Logger;
|
|
60
52
|
wallet!: TestWallet;
|
|
61
53
|
asset!: TokenBlacklistContract;
|
|
@@ -71,7 +63,6 @@ export class BlacklistTokenContractTest {
|
|
|
71
63
|
|
|
72
64
|
constructor(testName: string) {
|
|
73
65
|
this.logger = createLogger(`e2e:e2e_blacklist_token_contract:${testName}`);
|
|
74
|
-
this.snapshotManager = createSnapshotManager(`e2e_blacklist_token_contract/${testName}`, dataPath);
|
|
75
66
|
}
|
|
76
67
|
|
|
77
68
|
async crossTimestampOfChange() {
|
|
@@ -83,86 +74,72 @@ export class BlacklistTokenContractTest {
|
|
|
83
74
|
}
|
|
84
75
|
|
|
85
76
|
/**
|
|
86
|
-
*
|
|
77
|
+
* Applies base setup:
|
|
87
78
|
* 1. Add 3 accounts.
|
|
88
79
|
* 2. Publicly deploy accounts, deploy token contract and a "bad account".
|
|
89
80
|
*/
|
|
90
|
-
async
|
|
81
|
+
async applyBaseSetup() {
|
|
91
82
|
// Adding a timeout of 2 minutes in here such that it is propagated to the underlying tests
|
|
92
83
|
jest.setTimeout(120_000);
|
|
93
84
|
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
85
|
+
this.logger.info('Deploying 3 accounts');
|
|
86
|
+
const { deployedAccounts } = await deployAccounts(
|
|
87
|
+
3,
|
|
88
|
+
this.logger,
|
|
89
|
+
)({
|
|
90
|
+
wallet: this.context.wallet,
|
|
91
|
+
initialFundedAccounts: this.context.initialFundedAccounts,
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
this.cheatCodes = this.context.cheatCodes;
|
|
95
|
+
this.aztecNode = this.context.aztecNodeService!;
|
|
96
|
+
this.sequencer = this.context.sequencer!;
|
|
97
|
+
this.wallet = this.context.wallet;
|
|
98
|
+
this.adminAddress = deployedAccounts[0].address;
|
|
99
|
+
this.otherAddress = deployedAccounts[1].address;
|
|
100
|
+
this.blacklistedAddress = deployedAccounts[2].address;
|
|
101
|
+
|
|
102
|
+
this.logger.info('Setting up blacklist token contract');
|
|
103
|
+
// Create the token contract state.
|
|
104
|
+
this.logger.verbose(`Public deploy accounts...`);
|
|
105
|
+
await publicDeployAccounts(this.wallet, [this.adminAddress, this.otherAddress, this.blacklistedAddress]);
|
|
106
|
+
|
|
107
|
+
this.logger.verbose(`Deploying TokenContract...`);
|
|
108
|
+
this.asset = await TokenBlacklistContract.deploy(this.wallet, this.adminAddress).send({
|
|
109
|
+
from: this.adminAddress,
|
|
110
|
+
});
|
|
111
|
+
this.logger.verbose(`Token deployed to ${this.asset.address}`);
|
|
112
|
+
|
|
113
|
+
this.logger.verbose(`Deploying bad account...`);
|
|
114
|
+
this.badAccount = await InvalidAccountContract.deploy(this.wallet).send({ from: this.adminAddress });
|
|
115
|
+
this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
|
|
116
|
+
|
|
117
|
+
await this.crossTimestampOfChange();
|
|
118
|
+
|
|
119
|
+
this.tokenSim = new TokenSimulator(
|
|
120
|
+
this.asset as unknown as TokenContract,
|
|
121
|
+
this.wallet,
|
|
122
|
+
this.adminAddress,
|
|
123
|
+
this.logger,
|
|
124
|
+
[this.adminAddress, this.otherAddress, this.blacklistedAddress],
|
|
107
125
|
);
|
|
108
126
|
|
|
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
|
-
},
|
|
127
|
+
expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
|
|
128
|
+
new Role().withAdmin().toNoirStruct(),
|
|
151
129
|
);
|
|
152
130
|
}
|
|
153
131
|
|
|
154
132
|
async setup() {
|
|
155
|
-
|
|
133
|
+
this.logger.info('Setting up fresh context');
|
|
134
|
+
this.context = await setup(0, {
|
|
135
|
+
fundSponsoredFPC: true,
|
|
136
|
+
skipAccountDeployment: true,
|
|
137
|
+
});
|
|
138
|
+
await this.applyBaseSetup();
|
|
156
139
|
}
|
|
157
140
|
|
|
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
141
|
async teardown() {
|
|
165
|
-
await this.
|
|
142
|
+
await teardown(this.context);
|
|
166
143
|
}
|
|
167
144
|
|
|
168
145
|
async addPendingShieldNoteToPXE(
|
|
@@ -174,7 +151,7 @@ export class BlacklistTokenContractTest {
|
|
|
174
151
|
) {
|
|
175
152
|
const txEffects = await this.aztecNode.getTxEffect(txHash);
|
|
176
153
|
await contract.methods
|
|
177
|
-
.
|
|
154
|
+
.process_transparent_note(
|
|
178
155
|
contract.address,
|
|
179
156
|
amount,
|
|
180
157
|
secretHash,
|
|
@@ -186,71 +163,56 @@ export class BlacklistTokenContractTest {
|
|
|
186
163
|
.simulate({ from: recipient });
|
|
187
164
|
}
|
|
188
165
|
|
|
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
|
-
},
|
|
166
|
+
async applyMint() {
|
|
167
|
+
this.logger.info('Applying mint setup');
|
|
168
|
+
const { asset, tokenSim } = this;
|
|
169
|
+
const amount = 10000n;
|
|
170
|
+
|
|
171
|
+
const adminMinterRole = new Role().withAdmin().withMinter();
|
|
172
|
+
await this.asset.methods
|
|
173
|
+
.update_roles(this.adminAddress, adminMinterRole.toNoirStruct())
|
|
174
|
+
.send({ from: this.adminAddress });
|
|
175
|
+
|
|
176
|
+
const blacklistRole = new Role().withBlacklisted();
|
|
177
|
+
await this.asset.methods
|
|
178
|
+
.update_roles(this.blacklistedAddress, blacklistRole.toNoirStruct())
|
|
179
|
+
.send({ from: this.adminAddress });
|
|
180
|
+
|
|
181
|
+
await this.crossTimestampOfChange();
|
|
182
|
+
|
|
183
|
+
expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
|
|
184
|
+
adminMinterRole.toNoirStruct(),
|
|
254
185
|
);
|
|
186
|
+
|
|
187
|
+
this.logger.verbose(`Minting ${amount} publicly...`);
|
|
188
|
+
await asset.methods.mint_public(this.adminAddress, amount).send({ from: this.adminAddress });
|
|
189
|
+
|
|
190
|
+
this.logger.verbose(`Minting ${amount} privately...`);
|
|
191
|
+
const secret = Fr.random();
|
|
192
|
+
const secretHash = await computeSecretHash(secret);
|
|
193
|
+
const receipt = await asset.methods.mint_private(amount, secretHash).send({ from: this.adminAddress });
|
|
194
|
+
|
|
195
|
+
await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
|
|
196
|
+
await asset.methods.redeem_shield(this.adminAddress, amount, secret).send({ from: this.adminAddress });
|
|
197
|
+
this.logger.verbose(`Minting complete.`);
|
|
198
|
+
|
|
199
|
+
tokenSim.mintPublic(this.adminAddress, amount);
|
|
200
|
+
|
|
201
|
+
const publicBalance = await asset.methods
|
|
202
|
+
.balance_of_public(this.adminAddress)
|
|
203
|
+
.simulate({ from: this.adminAddress });
|
|
204
|
+
this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
|
|
205
|
+
expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(this.adminAddress));
|
|
206
|
+
|
|
207
|
+
tokenSim.mintPrivate(this.adminAddress, amount);
|
|
208
|
+
const privateBalance = await asset.methods
|
|
209
|
+
.balance_of_private(this.adminAddress)
|
|
210
|
+
.simulate({ from: this.adminAddress });
|
|
211
|
+
this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
|
|
212
|
+
expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
|
|
213
|
+
|
|
214
|
+
const totalSupply = await asset.methods.total_supply().simulate({ from: this.adminAddress });
|
|
215
|
+
this.logger.verbose(`Total supply: ${totalSupply}`);
|
|
216
|
+
expect(totalSupply).toEqual(tokenSim.totalSupply);
|
|
255
217
|
}
|
|
256
218
|
}
|
|
@@ -23,25 +23,24 @@ import type { TestWallet } from '@aztec/test-wallet/server';
|
|
|
23
23
|
|
|
24
24
|
import { MNEMONIC } from '../fixtures/fixtures.js';
|
|
25
25
|
import {
|
|
26
|
-
type
|
|
27
|
-
type
|
|
28
|
-
createSnapshotManager,
|
|
26
|
+
type EndToEndContext,
|
|
27
|
+
type SetupOptions,
|
|
29
28
|
deployAccounts,
|
|
30
29
|
publicDeployAccounts,
|
|
31
|
-
|
|
32
|
-
|
|
30
|
+
setup,
|
|
31
|
+
teardown,
|
|
32
|
+
} from '../fixtures/setup.js';
|
|
33
33
|
import { CrossChainTestHarness } from '../shared/cross_chain_test_harness.js';
|
|
34
34
|
|
|
35
|
-
const { E2E_DATA_PATH: dataPath } = process.env;
|
|
36
|
-
|
|
37
35
|
export class CrossChainMessagingTest {
|
|
38
|
-
private snapshotManager: ISnapshotManager;
|
|
39
36
|
private requireEpochProven: boolean;
|
|
37
|
+
private setupOptions: SetupOptions;
|
|
38
|
+
private deployL1ContractsArgs: Partial<DeployAztecL1ContractsArgs>;
|
|
40
39
|
logger: Logger;
|
|
40
|
+
context!: EndToEndContext;
|
|
41
41
|
aztecNode!: AztecNode;
|
|
42
42
|
aztecNodeConfig!: AztecNodeConfig;
|
|
43
43
|
aztecNodeAdmin!: AztecNodeAdmin;
|
|
44
|
-
ctx!: SubsystemsContext;
|
|
45
44
|
|
|
46
45
|
l1Client!: ExtendedViemWalletClient | undefined;
|
|
47
46
|
|
|
@@ -67,26 +66,23 @@ export class CrossChainMessagingTest {
|
|
|
67
66
|
deployL1ContractsArgs: Partial<DeployAztecL1ContractsArgs> = {},
|
|
68
67
|
) {
|
|
69
68
|
this.logger = createLogger(`e2e:e2e_cross_chain_messaging:${testName}`);
|
|
70
|
-
this.
|
|
69
|
+
this.setupOptions = opts;
|
|
70
|
+
this.deployL1ContractsArgs = {
|
|
71
71
|
initialValidators: [],
|
|
72
72
|
...deployL1ContractsArgs,
|
|
73
|
-
}
|
|
73
|
+
};
|
|
74
74
|
this.requireEpochProven = opts.startProverNode ?? false;
|
|
75
75
|
}
|
|
76
76
|
|
|
77
77
|
async setup() {
|
|
78
|
-
this.
|
|
79
|
-
this.
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
if (this.requireEpochProven) {
|
|
87
|
-
// Turn off the watcher to prevent it from keep marking blocks as proven.
|
|
88
|
-
this.ctx.watcher.setIsMarkingAsProven(false);
|
|
89
|
-
}
|
|
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();
|
|
90
86
|
}
|
|
91
87
|
|
|
92
88
|
async advanceToEpochProven(l2TxReceipt: TxReceipt): Promise<EpochNumber> {
|
|
@@ -108,94 +104,91 @@ export class CrossChainMessagingTest {
|
|
|
108
104
|
}
|
|
109
105
|
}
|
|
110
106
|
|
|
111
|
-
snapshot = <T>(
|
|
112
|
-
name: string,
|
|
113
|
-
apply: (context: SubsystemsContext) => Promise<T>,
|
|
114
|
-
restore: (snapshotData: T, context: SubsystemsContext) => Promise<void> = () => Promise.resolve(),
|
|
115
|
-
): Promise<void> => this.snapshotManager.snapshot(name, apply, restore);
|
|
116
|
-
|
|
117
107
|
async teardown() {
|
|
118
|
-
await this.
|
|
108
|
+
await teardown(this.context);
|
|
119
109
|
}
|
|
120
110
|
|
|
121
|
-
async
|
|
122
|
-
//
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
111
|
+
async applyBaseSetup() {
|
|
112
|
+
// Set up base context fields
|
|
113
|
+
this.aztecNode = this.context.aztecNodeService!;
|
|
114
|
+
this.wallet = this.context.wallet;
|
|
115
|
+
this.aztecNodeConfig = this.context.config;
|
|
116
|
+
this.cheatCodes = this.context.cheatCodes;
|
|
117
|
+
this.deployL1ContractsValues = this.context.deployL1ContractsValues;
|
|
118
|
+
this.aztecNodeAdmin = this.context.aztecNodeService!;
|
|
119
|
+
|
|
120
|
+
if (this.requireEpochProven) {
|
|
121
|
+
// Turn off the watcher to prevent it from keep marking blocks as proven.
|
|
122
|
+
this.context.watcher!.setIsMarkingAsProven(false);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
// Deploy 3 accounts
|
|
126
|
+
this.logger.info('Applying 3_accounts setup');
|
|
127
|
+
const { deployedAccounts } = await deployAccounts(
|
|
128
|
+
3,
|
|
129
|
+
this.logger,
|
|
130
|
+
)({
|
|
131
|
+
wallet: this.context.wallet,
|
|
132
|
+
initialFundedAccounts: this.context.initialFundedAccounts,
|
|
133
|
+
});
|
|
134
|
+
[this.ownerAddress, this.user1Address, this.user2Address] = deployedAccounts.map(a => a.address);
|
|
135
|
+
|
|
136
|
+
// Set up cross chain messaging
|
|
137
|
+
this.logger.info('Applying e2e_cross_chain_messaging setup');
|
|
138
|
+
|
|
139
|
+
// Create the token contract state.
|
|
140
|
+
this.logger.verbose(`Public deploy accounts...`);
|
|
141
|
+
await publicDeployAccounts(this.wallet, [this.ownerAddress, this.user1Address, this.user2Address]);
|
|
142
|
+
|
|
143
|
+
this.l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
|
|
144
|
+
|
|
145
|
+
const underlyingERC20Address = await deployL1Contract(this.l1Client, TestERC20Abi, TestERC20Bytecode, [
|
|
146
|
+
'Underlying',
|
|
147
|
+
'UND',
|
|
148
|
+
this.l1Client.account.address,
|
|
149
|
+
]).then(({ address }) => address);
|
|
150
|
+
|
|
151
|
+
this.logger.verbose(`Setting up cross chain harness...`);
|
|
152
|
+
this.crossChainTestHarness = await CrossChainTestHarness.new(
|
|
153
|
+
this.aztecNode,
|
|
154
|
+
this.l1Client,
|
|
155
|
+
this.wallet,
|
|
156
|
+
this.ownerAddress,
|
|
157
|
+
this.logger,
|
|
158
|
+
underlyingERC20Address,
|
|
135
159
|
);
|
|
136
160
|
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
this.l2Token = TokenContract.at(crossChainContext.l2Token, this.wallet);
|
|
169
|
-
this.l2Bridge = TokenBridgeContract.at(crossChainContext.l2Bridge, this.wallet);
|
|
170
|
-
|
|
171
|
-
// There is an issue with the reviver so we are getting strings sometimes. Working around it here.
|
|
172
|
-
this.ethAccount = EthAddress.fromString(crossChainContext.ethAccount.toString());
|
|
173
|
-
const tokenPortalAddress = EthAddress.fromString(crossChainContext.tokenPortal.toString());
|
|
174
|
-
|
|
175
|
-
const l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
|
|
176
|
-
this.l1Client = l1Client;
|
|
177
|
-
|
|
178
|
-
const l1Contracts = this.aztecNodeConfig.l1Contracts;
|
|
179
|
-
this.rollup = new RollupContract(l1Client, l1Contracts.rollupAddress.toString());
|
|
180
|
-
this.inbox = new InboxContract(l1Client, l1Contracts.inboxAddress.toString());
|
|
181
|
-
this.outbox = new OutboxContract(l1Client, l1Contracts.outboxAddress.toString());
|
|
182
|
-
|
|
183
|
-
this.crossChainTestHarness = new CrossChainTestHarness(
|
|
184
|
-
this.aztecNode,
|
|
185
|
-
this.logger,
|
|
186
|
-
this.l2Token,
|
|
187
|
-
this.l2Bridge,
|
|
188
|
-
this.ethAccount,
|
|
189
|
-
tokenPortalAddress,
|
|
190
|
-
crossChainContext.underlying,
|
|
191
|
-
l1Client,
|
|
192
|
-
this.aztecNodeConfig.l1Contracts,
|
|
193
|
-
this.wallet,
|
|
194
|
-
this.ownerAddress,
|
|
195
|
-
);
|
|
196
|
-
|
|
197
|
-
return Promise.resolve();
|
|
198
|
-
},
|
|
161
|
+
this.logger.verbose(`L2 token deployed to: ${this.crossChainTestHarness.l2Token.address}`);
|
|
162
|
+
|
|
163
|
+
const crossChainContext = this.crossChainTestHarness.toCrossChainContext();
|
|
164
|
+
|
|
165
|
+
this.l2Token = TokenContract.at(crossChainContext.l2Token, this.wallet);
|
|
166
|
+
this.l2Bridge = TokenBridgeContract.at(crossChainContext.l2Bridge, this.wallet);
|
|
167
|
+
|
|
168
|
+
// There is an issue with the reviver so we are getting strings sometimes. Working around it here.
|
|
169
|
+
this.ethAccount = EthAddress.fromString(crossChainContext.ethAccount.toString());
|
|
170
|
+
const tokenPortalAddress = EthAddress.fromString(crossChainContext.tokenPortal.toString());
|
|
171
|
+
|
|
172
|
+
const l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
|
|
173
|
+
this.l1Client = l1Client;
|
|
174
|
+
|
|
175
|
+
const l1Contracts = this.aztecNodeConfig.l1Contracts;
|
|
176
|
+
this.rollup = new RollupContract(l1Client, l1Contracts.rollupAddress.toString());
|
|
177
|
+
this.inbox = new InboxContract(l1Client, l1Contracts.inboxAddress.toString());
|
|
178
|
+
this.outbox = new OutboxContract(l1Client, l1Contracts.outboxAddress.toString());
|
|
179
|
+
|
|
180
|
+
this.crossChainTestHarness = new CrossChainTestHarness(
|
|
181
|
+
this.aztecNode,
|
|
182
|
+
this.logger,
|
|
183
|
+
this.l2Token,
|
|
184
|
+
this.l2Bridge,
|
|
185
|
+
this.ethAccount,
|
|
186
|
+
tokenPortalAddress,
|
|
187
|
+
crossChainContext.underlying,
|
|
188
|
+
l1Client,
|
|
189
|
+
this.aztecNodeConfig.l1Contracts,
|
|
190
|
+
this.wallet,
|
|
191
|
+
this.ownerAddress,
|
|
199
192
|
);
|
|
200
193
|
}
|
|
201
194
|
}
|
|
@@ -10,12 +10,10 @@ import type { StatefulTestContract } from '@aztec/noir-test-contracts.js/Statefu
|
|
|
10
10
|
import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
|
|
11
11
|
import type { TestWallet } from '@aztec/test-wallet/server';
|
|
12
12
|
|
|
13
|
-
import { type
|
|
14
|
-
|
|
15
|
-
const { E2E_DATA_PATH: dataPath } = process.env;
|
|
13
|
+
import { type EndToEndContext, deployAccounts, setup, teardown } from '../fixtures/setup.js';
|
|
16
14
|
|
|
17
15
|
export class DeployTest {
|
|
18
|
-
|
|
16
|
+
public context!: EndToEndContext;
|
|
19
17
|
public logger: Logger;
|
|
20
18
|
public wallet!: TestWallet;
|
|
21
19
|
public defaultAccountAddress!: AztecAddress;
|
|
@@ -24,26 +22,35 @@ export class DeployTest {
|
|
|
24
22
|
|
|
25
23
|
constructor(testName: string) {
|
|
26
24
|
this.logger = createLogger(`e2e:e2e_deploy_contract:${testName}`);
|
|
27
|
-
this.snapshotManager = createSnapshotManager(`e2e_deploy_contract/${testName}`, dataPath);
|
|
28
25
|
}
|
|
29
26
|
|
|
30
27
|
async setup() {
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
28
|
+
this.logger.info('Setting up test environment');
|
|
29
|
+
this.context = await setup(0, {
|
|
30
|
+
fundSponsoredFPC: true,
|
|
31
|
+
skipAccountDeployment: true,
|
|
32
|
+
});
|
|
33
|
+
this.aztecNode = this.context.aztecNodeService!;
|
|
34
|
+
this.wallet = this.context.wallet;
|
|
35
|
+
this.aztecNodeAdmin = this.context.aztecNodeService!;
|
|
36
|
+
await this.applyInitialAccount();
|
|
35
37
|
return this;
|
|
36
38
|
}
|
|
37
39
|
|
|
38
40
|
async teardown() {
|
|
39
|
-
await this.
|
|
41
|
+
await teardown(this.context);
|
|
40
42
|
}
|
|
41
43
|
|
|
42
|
-
private async
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
44
|
+
private async applyInitialAccount() {
|
|
45
|
+
this.logger.info('Applying initial account setup');
|
|
46
|
+
const { deployedAccounts } = await deployAccounts(
|
|
47
|
+
1,
|
|
48
|
+
this.logger,
|
|
49
|
+
)({
|
|
50
|
+
wallet: this.context.wallet,
|
|
51
|
+
initialFundedAccounts: this.context.initialFundedAccounts,
|
|
46
52
|
});
|
|
53
|
+
this.defaultAccountAddress = deployedAccounts[0].address;
|
|
47
54
|
}
|
|
48
55
|
|
|
49
56
|
async registerContract<T extends ContractBase>(
|