@aztec/end-to-end 0.0.1-commit.c7c42ec → 0.0.1-commit.f295ac2
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 +105 -135
- package/dest/bench/client_flows/data_extractor.js +3 -1
- package/dest/bench/utils.d.ts +5 -5
- package/dest/bench/utils.d.ts.map +1 -1
- package/dest/bench/utils.js +8 -5
- 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 +98 -113
- package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +15 -10
- 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 +89 -70
- 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.js +2 -2
- package/dest/e2e_fees/bridging_race.notest.js +2 -4
- 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 +123 -141
- package/dest/e2e_l1_publisher/write_json.d.ts +3 -3
- package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
- package/dest/e2e_l1_publisher/write_json.js +19 -15
- 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 +32 -40
- 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 +107 -104
- package/dest/e2e_p2p/shared.d.ts +1 -1
- package/dest/e2e_p2p/shared.d.ts.map +1 -1
- package/dest/e2e_p2p/shared.js +4 -4
- 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 +90 -92
- 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 +83 -95
- package/dest/fixtures/setup.d.ts +216 -0
- package/dest/fixtures/setup.d.ts.map +1 -0
- package/dest/fixtures/setup.js +684 -0
- package/dest/fixtures/utils.d.ts +5 -194
- package/dest/fixtures/utils.d.ts.map +1 -1
- package/dest/fixtures/utils.js +4 -619
- 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 +14 -3
- package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
- package/dest/shared/cross_chain_test_harness.js +2 -2
- 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/index.d.ts +2 -2
- package/dest/shared/index.d.ts.map +1 -1
- package/dest/shared/uniswap_l1_l2.d.ts +3 -28
- package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
- package/dest/shared/uniswap_l1_l2.js +39 -21
- package/dest/simulators/lending_simulator.d.ts +5 -1
- package/dest/simulators/lending_simulator.d.ts.map +1 -1
- package/dest/spartan/setup_test_wallets.d.ts +4 -3
- package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
- package/dest/spartan/tx_metrics.d.ts +4 -1
- package/dest/spartan/tx_metrics.d.ts.map +1 -1
- package/dest/spartan/tx_metrics.js +24 -1
- package/dest/spartan/utils.d.ts +12 -5
- package/dest/spartan/utils.d.ts.map +1 -1
- package/dest/spartan/utils.js +123 -73
- package/package.json +40 -39
- package/src/bench/client_flows/benchmark.ts +24 -2
- package/src/bench/client_flows/client_flows_benchmark.ts +143 -196
- package/src/bench/client_flows/data_extractor.ts +1 -1
- package/src/bench/utils.ts +11 -7
- package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +107 -142
- package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +127 -116
- package/src/e2e_deploy_contract/deploy_test.ts +21 -14
- package/src/e2e_epochs/epochs_test.ts +2 -2
- package/src/e2e_fees/bridging_race.notest.ts +2 -5
- package/src/e2e_fees/fees_test.ts +172 -216
- package/src/e2e_l1_publisher/write_json.ts +22 -17
- package/src/e2e_nested_contract/nested_contract_test.ts +35 -56
- package/src/e2e_p2p/inactivity_slash_test.ts +5 -5
- package/src/e2e_p2p/p2p_network.ts +166 -168
- package/src/e2e_p2p/shared.ts +6 -5
- package/src/e2e_token_contract/token_contract_test.ts +105 -118
- package/src/fixtures/e2e_prover_test.ts +107 -137
- package/src/fixtures/setup.ts +1010 -0
- package/src/fixtures/utils.ts +27 -907
- 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 +3 -9
- package/src/shared/index.ts +1 -1
- package/src/shared/uniswap_l1_l2.ts +46 -58
- package/src/spartan/setup_test_wallets.ts +7 -1
- package/src/spartan/tx_metrics.ts +27 -4
- package/src/spartan/utils.ts +112 -24
- 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 -493
- 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/snapshot_manager.ts +0 -651
|
@@ -6,17 +6,15 @@ import { ChildContract } from '@aztec/noir-test-contracts.js/Child';
|
|
|
6
6
|
import { ParentContract } from '@aztec/noir-test-contracts.js/Parent';
|
|
7
7
|
|
|
8
8
|
import {
|
|
9
|
-
type
|
|
10
|
-
type SubsystemsContext,
|
|
11
|
-
createSnapshotManager,
|
|
9
|
+
type EndToEndContext,
|
|
12
10
|
deployAccounts,
|
|
13
11
|
publicDeployAccounts,
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
12
|
+
setup,
|
|
13
|
+
teardown as teardownSubsystems,
|
|
14
|
+
} from '../fixtures/setup.js';
|
|
17
15
|
|
|
18
16
|
export class NestedContractTest {
|
|
19
|
-
|
|
17
|
+
context!: EndToEndContext;
|
|
20
18
|
logger: Logger;
|
|
21
19
|
wallet!: Wallet;
|
|
22
20
|
defaultAccountAddress!: AztecAddress;
|
|
@@ -30,67 +28,48 @@ export class NestedContractTest {
|
|
|
30
28
|
private numberOfAccounts = 1,
|
|
31
29
|
) {
|
|
32
30
|
this.logger = createLogger(`e2e:e2e_nested_contract:${testName}`);
|
|
33
|
-
this.snapshotManager = createSnapshotManager(`e2e_nested_contract/${testName}-${numberOfAccounts}`, dataPath);
|
|
34
31
|
}
|
|
35
32
|
|
|
36
33
|
/**
|
|
37
|
-
*
|
|
38
|
-
* 1. Add 3 accounts.
|
|
39
|
-
* 2. Publicly deploy accounts
|
|
34
|
+
* Applies base setup by deploying accounts and publicly deploying them.
|
|
40
35
|
*/
|
|
41
|
-
async
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
36
|
+
async applyBaseSetup() {
|
|
37
|
+
this.logger.info('Deploying accounts');
|
|
38
|
+
const { deployedAccounts } = await deployAccounts(
|
|
39
|
+
this.numberOfAccounts,
|
|
40
|
+
this.logger,
|
|
41
|
+
)({
|
|
42
|
+
wallet: this.context.wallet,
|
|
43
|
+
initialFundedAccounts: this.context.initialFundedAccounts,
|
|
44
|
+
});
|
|
45
|
+
this.wallet = this.context.wallet;
|
|
46
|
+
[{ address: this.defaultAccountAddress }] = deployedAccounts;
|
|
47
|
+
this.aztecNode = this.context.aztecNodeService!;
|
|
52
48
|
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
async () => {},
|
|
56
|
-
async () => {
|
|
57
|
-
this.logger.verbose(`Public deploy accounts...`);
|
|
58
|
-
await publicDeployAccounts(this.wallet, [this.defaultAccountAddress]);
|
|
59
|
-
},
|
|
60
|
-
);
|
|
49
|
+
this.logger.info('Public deploy accounts');
|
|
50
|
+
await publicDeployAccounts(this.wallet, [this.defaultAccountAddress]);
|
|
61
51
|
}
|
|
62
52
|
|
|
63
53
|
async setup() {
|
|
64
|
-
|
|
54
|
+
this.logger.info('Setting up fresh subsystems');
|
|
55
|
+
this.context = await setup(0, {
|
|
56
|
+
fundSponsoredFPC: true,
|
|
57
|
+
skipAccountDeployment: true,
|
|
58
|
+
});
|
|
59
|
+
await this.applyBaseSetup();
|
|
65
60
|
}
|
|
66
61
|
|
|
67
62
|
async teardown() {
|
|
68
|
-
await this.
|
|
63
|
+
await teardownSubsystems(this.context);
|
|
69
64
|
}
|
|
70
65
|
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
'manual',
|
|
80
|
-
async () => {
|
|
81
|
-
const parentContract = await ParentContract.deploy(this.wallet)
|
|
82
|
-
.send({ from: this.defaultAccountAddress })
|
|
83
|
-
.deployed();
|
|
84
|
-
const childContract = await ChildContract.deploy(this.wallet)
|
|
85
|
-
.send({ from: this.defaultAccountAddress })
|
|
86
|
-
.deployed();
|
|
87
|
-
return { parentContractAddress: parentContract.address, childContractAddress: childContract.address };
|
|
88
|
-
},
|
|
89
|
-
({ parentContractAddress, childContractAddress }) => {
|
|
90
|
-
this.parentContract = ParentContract.at(parentContractAddress, this.wallet);
|
|
91
|
-
this.childContract = ChildContract.at(childContractAddress, this.wallet);
|
|
92
|
-
return Promise.resolve();
|
|
93
|
-
},
|
|
94
|
-
);
|
|
66
|
+
async applyManual() {
|
|
67
|
+
this.logger.info('Deploying parent and child contracts');
|
|
68
|
+
const parentContract = await ParentContract.deploy(this.wallet)
|
|
69
|
+
.send({ from: this.defaultAccountAddress })
|
|
70
|
+
.deployed();
|
|
71
|
+
const childContract = await ChildContract.deploy(this.wallet).send({ from: this.defaultAccountAddress }).deployed();
|
|
72
|
+
this.parentContract = parentContract;
|
|
73
|
+
this.childContract = childContract;
|
|
95
74
|
}
|
|
96
75
|
}
|
|
@@ -82,8 +82,8 @@ export class P2PInactivityTest {
|
|
|
82
82
|
}
|
|
83
83
|
|
|
84
84
|
public async setup() {
|
|
85
|
-
await this.test.applyBaseSnapshots();
|
|
86
85
|
await this.test.setup();
|
|
86
|
+
await this.test.applyBaseSetup();
|
|
87
87
|
|
|
88
88
|
// Set slashing penalties for inactivity
|
|
89
89
|
const { rollup } = await this.test.getContracts();
|
|
@@ -98,13 +98,13 @@ export class P2PInactivityTest {
|
|
|
98
98
|
this.rollup = rollup;
|
|
99
99
|
|
|
100
100
|
if (!this.keepInitialNode) {
|
|
101
|
-
await this.test.ctx.
|
|
101
|
+
await this.test.ctx.aztecNodeService!.stop();
|
|
102
102
|
}
|
|
103
103
|
|
|
104
104
|
// Create all active nodes
|
|
105
105
|
this.activeNodes = await createNodes(
|
|
106
106
|
this.test.ctx.aztecNodeConfig,
|
|
107
|
-
this.test.ctx.dateProvider
|
|
107
|
+
this.test.ctx.dateProvider!,
|
|
108
108
|
this.test.bootstrapNodeEnr,
|
|
109
109
|
NUM_NODES - this.inactiveNodeCount - Number(this.keepInitialNode),
|
|
110
110
|
BOOT_NODE_UDP_PORT,
|
|
@@ -118,7 +118,7 @@ export class P2PInactivityTest {
|
|
|
118
118
|
const inactiveConfig = { ...this.test.ctx.aztecNodeConfig, dontStartSequencer: true };
|
|
119
119
|
this.inactiveNodes = await createNodes(
|
|
120
120
|
inactiveConfig,
|
|
121
|
-
this.test.ctx.dateProvider
|
|
121
|
+
this.test.ctx.dateProvider!,
|
|
122
122
|
this.test.bootstrapNodeEnr,
|
|
123
123
|
this.inactiveNodeCount,
|
|
124
124
|
BOOT_NODE_UDP_PORT,
|
|
@@ -129,7 +129,7 @@ export class P2PInactivityTest {
|
|
|
129
129
|
);
|
|
130
130
|
|
|
131
131
|
this.nodes = [
|
|
132
|
-
...(this.keepInitialNode ? [this.test.ctx.
|
|
132
|
+
...(this.keepInitialNode ? [this.test.ctx.aztecNodeService!] : []),
|
|
133
133
|
...this.activeNodes,
|
|
134
134
|
...this.inactiveNodes,
|
|
135
135
|
];
|
|
@@ -34,18 +34,20 @@ import getPort from 'get-port';
|
|
|
34
34
|
import { type GetContractReturnType, getAddress, getContract } from 'viem';
|
|
35
35
|
import { privateKeyToAccount } from 'viem/accounts';
|
|
36
36
|
|
|
37
|
+
import {
|
|
38
|
+
type EndToEndContext,
|
|
39
|
+
type SetupOptions,
|
|
40
|
+
deployAccounts,
|
|
41
|
+
getPrivateKeyFromIndex,
|
|
42
|
+
getSponsoredFPCAddress,
|
|
43
|
+
setup,
|
|
44
|
+
teardown,
|
|
45
|
+
} from '../fixtures/setup.js';
|
|
37
46
|
import {
|
|
38
47
|
ATTESTER_PRIVATE_KEYS_START_INDEX,
|
|
39
48
|
createValidatorConfig,
|
|
40
49
|
generatePrivateKeys,
|
|
41
50
|
} from '../fixtures/setup_p2p_test.js';
|
|
42
|
-
import {
|
|
43
|
-
type ISnapshotManager,
|
|
44
|
-
type SubsystemsContext,
|
|
45
|
-
createSnapshotManager,
|
|
46
|
-
deployAccounts,
|
|
47
|
-
} from '../fixtures/snapshot_manager.js';
|
|
48
|
-
import { type SetupOptions, getPrivateKeyFromIndex, getSponsoredFPCAddress } from '../fixtures/utils.js';
|
|
49
51
|
import { getEndToEndTestTelemetryClient } from '../fixtures/with_telemetry_utils.js';
|
|
50
52
|
|
|
51
53
|
// Use a fixed bootstrap node private key so that we can re-use the same snapshot and the nodes can find each other
|
|
@@ -60,14 +62,14 @@ export const SHORTENED_BLOCK_TIME_CONFIG_NO_PRUNES = {
|
|
|
60
62
|
};
|
|
61
63
|
|
|
62
64
|
export class P2PNetworkTest {
|
|
63
|
-
|
|
65
|
+
public context!: EndToEndContext;
|
|
64
66
|
public baseAccountPrivateKey: `0x${string}`;
|
|
65
67
|
public baseAccount;
|
|
66
68
|
|
|
67
69
|
public logger: Logger;
|
|
68
70
|
public monitor!: ChainMonitor;
|
|
69
71
|
|
|
70
|
-
public ctx!:
|
|
72
|
+
public ctx!: EndToEndContext;
|
|
71
73
|
public attesterPrivateKeys: `0x${string}`[] = [];
|
|
72
74
|
public attesterPublicKeys: string[] = [];
|
|
73
75
|
public peerIdPrivateKeys: string[] = [];
|
|
@@ -83,6 +85,10 @@ export class P2PNetworkTest {
|
|
|
83
85
|
|
|
84
86
|
public bootstrapNode?: BootstrapNode;
|
|
85
87
|
|
|
88
|
+
// Store setup options for use in setup()
|
|
89
|
+
private setupOptions: SetupOptions;
|
|
90
|
+
private deployL1ContractsArgs: any;
|
|
91
|
+
|
|
86
92
|
constructor(
|
|
87
93
|
public readonly testName: string,
|
|
88
94
|
public bootstrapNodeEnr: string,
|
|
@@ -107,43 +113,41 @@ export class P2PNetworkTest {
|
|
|
107
113
|
|
|
108
114
|
const zkPassportParams = ZkPassportProofParams.random();
|
|
109
115
|
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
slashingRoundSizeInEpochs
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
aztecProofSubmissionEpochs
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
zkPassportScope: zkPassportParams.scope,
|
|
144
|
-
},
|
|
116
|
+
// Store setup options for later use
|
|
117
|
+
this.setupOptions = {
|
|
118
|
+
...initialValidatorConfig,
|
|
119
|
+
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
120
|
+
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
121
|
+
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
122
|
+
aztecProofSubmissionEpochs:
|
|
123
|
+
initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
|
|
124
|
+
slashingRoundSizeInEpochs:
|
|
125
|
+
initialValidatorConfig.slashingRoundSizeInEpochs ?? l1ContractsConfig.slashingRoundSizeInEpochs,
|
|
126
|
+
slasherFlavor: initialValidatorConfig.slasherFlavor ?? 'tally',
|
|
127
|
+
aztecTargetCommitteeSize: numberOfValidators,
|
|
128
|
+
metricsPort: metricsPort,
|
|
129
|
+
numberOfInitialFundedAccounts: 2,
|
|
130
|
+
startProverNode,
|
|
131
|
+
};
|
|
132
|
+
|
|
133
|
+
this.deployL1ContractsArgs = {
|
|
134
|
+
...initialValidatorConfig,
|
|
135
|
+
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
136
|
+
slashingRoundSizeInEpochs:
|
|
137
|
+
initialValidatorConfig.slashingRoundSizeInEpochs ?? l1ContractsConfig.slashingRoundSizeInEpochs,
|
|
138
|
+
slasherFlavor: initialValidatorConfig.slasherFlavor ?? 'tally',
|
|
139
|
+
|
|
140
|
+
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
141
|
+
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
142
|
+
aztecProofSubmissionEpochs:
|
|
143
|
+
initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
|
|
144
|
+
aztecTargetCommitteeSize: numberOfValidators,
|
|
145
|
+
initialValidators: [],
|
|
146
|
+
zkPassportArgs: {
|
|
147
|
+
zkPassportDomain: zkPassportParams.domain,
|
|
148
|
+
zkPassportScope: zkPassportParams.scope,
|
|
145
149
|
},
|
|
146
|
-
|
|
150
|
+
};
|
|
147
151
|
}
|
|
148
152
|
|
|
149
153
|
static async create({
|
|
@@ -187,23 +191,22 @@ export class P2PNetworkTest {
|
|
|
187
191
|
|
|
188
192
|
get fundedAccount() {
|
|
189
193
|
if (!this.deployedAccounts[0]) {
|
|
190
|
-
throw new Error('Call
|
|
194
|
+
throw new Error('Call setupAccount to create a funded account.');
|
|
191
195
|
}
|
|
192
196
|
return this.deployedAccounts[0];
|
|
193
197
|
}
|
|
194
198
|
|
|
195
199
|
async addBootstrapNode() {
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
});
|
|
200
|
+
this.logger.info('Adding bootstrap node');
|
|
201
|
+
const telemetry = await getEndToEndTestTelemetryClient(this.metricsPort);
|
|
202
|
+
this.bootstrapNode = await createBootstrapNodeFromPrivateKey(
|
|
203
|
+
BOOTSTRAP_NODE_PRIVATE_KEY,
|
|
204
|
+
this.bootNodePort,
|
|
205
|
+
telemetry,
|
|
206
|
+
this.context.config,
|
|
207
|
+
);
|
|
208
|
+
// Overwrite enr with updated info
|
|
209
|
+
this.bootstrapNodeEnr = this.bootstrapNode.getENR().encodeTxt();
|
|
207
210
|
}
|
|
208
211
|
|
|
209
212
|
getValidators() {
|
|
@@ -224,128 +227,114 @@ export class P2PNetworkTest {
|
|
|
224
227
|
return { validators };
|
|
225
228
|
}
|
|
226
229
|
|
|
227
|
-
async
|
|
230
|
+
async applyBaseSetup() {
|
|
228
231
|
await this.addBootstrapNode();
|
|
229
|
-
await this.snapshotManager.snapshot('add-validators', async ({ deployL1ContractsValues, cheatCodes }) => {
|
|
230
|
-
const rollup = getContract({
|
|
231
|
-
address: deployL1ContractsValues.l1ContractAddresses.rollupAddress.toString(),
|
|
232
|
-
abi: RollupAbi,
|
|
233
|
-
client: deployL1ContractsValues.l1Client,
|
|
234
|
-
});
|
|
235
232
|
|
|
236
|
-
|
|
233
|
+
this.logger.info('Adding validators');
|
|
234
|
+
const rollup = getContract({
|
|
235
|
+
address: this.context.deployL1ContractsValues.l1ContractAddresses.rollupAddress.toString(),
|
|
236
|
+
abi: RollupAbi,
|
|
237
|
+
client: this.context.deployL1ContractsValues.l1Client,
|
|
238
|
+
});
|
|
237
239
|
|
|
238
|
-
|
|
239
|
-
address: deployL1ContractsValues.l1ContractAddresses.stakingAssetAddress.toString(),
|
|
240
|
-
abi: TestERC20Abi,
|
|
241
|
-
client: deployL1ContractsValues.l1Client,
|
|
242
|
-
});
|
|
240
|
+
this.logger.info(`Adding ${this.numberOfValidators} validators`);
|
|
243
241
|
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
);
|
|
250
|
-
|
|
251
|
-
const multiAdder = getContract({
|
|
252
|
-
address: multiAdderAddress.toString(),
|
|
253
|
-
abi: MultiAdderArtifact.contractAbi,
|
|
254
|
-
client: deployL1ContractsValues.l1Client,
|
|
255
|
-
});
|
|
242
|
+
const stakingAsset = getContract({
|
|
243
|
+
address: this.context.deployL1ContractsValues.l1ContractAddresses.stakingAssetAddress.toString(),
|
|
244
|
+
abi: TestERC20Abi,
|
|
245
|
+
client: this.context.deployL1ContractsValues.l1Client,
|
|
246
|
+
});
|
|
256
247
|
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
const { validators } = this.getValidators();
|
|
265
|
-
this.validators = validators;
|
|
266
|
-
|
|
267
|
-
const gseAddress = deployL1ContractsValues.l1ContractAddresses.gseAddress!;
|
|
268
|
-
if (!gseAddress) {
|
|
269
|
-
throw new Error('GSE contract not deployed');
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
const gseContract = new GSEContract(deployL1ContractsValues.l1Client, gseAddress.toString());
|
|
273
|
-
|
|
274
|
-
const makeValidatorTuples = async (validator: Operator) => {
|
|
275
|
-
const registrationTuple = await gseContract.makeRegistrationTuple(validator.bn254SecretKey.getValue());
|
|
276
|
-
return {
|
|
277
|
-
attester: validator.attester.toString() as `0x${string}`,
|
|
278
|
-
withdrawer: validator.withdrawer.toString() as `0x${string}`,
|
|
279
|
-
...registrationTuple,
|
|
280
|
-
};
|
|
281
|
-
};
|
|
282
|
-
const validatorTuples = await Promise.all(validators.map(makeValidatorTuples));
|
|
248
|
+
const { address: multiAdderAddress } = await deployL1Contract(
|
|
249
|
+
this.context.deployL1ContractsValues.l1Client,
|
|
250
|
+
MultiAdderArtifact.contractAbi,
|
|
251
|
+
MultiAdderArtifact.contractBytecode,
|
|
252
|
+
[rollup.address, this.context.deployL1ContractsValues.l1Client.account.address],
|
|
253
|
+
);
|
|
283
254
|
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
255
|
+
const multiAdder = getContract({
|
|
256
|
+
address: multiAdderAddress.toString(),
|
|
257
|
+
abi: MultiAdderArtifact.contractAbi,
|
|
258
|
+
client: this.context.deployL1ContractsValues.l1Client,
|
|
259
|
+
});
|
|
260
|
+
|
|
261
|
+
const stakeNeeded = (await rollup.read.getActivationThreshold()) * BigInt(this.numberOfValidators);
|
|
262
|
+
await Promise.all(
|
|
263
|
+
[await stakingAsset.write.mint([multiAdder.address, stakeNeeded], {} as any)].map(txHash =>
|
|
264
|
+
this.context.deployL1ContractsValues.l1Client.waitForTransactionReceipt({ hash: txHash }),
|
|
265
|
+
),
|
|
266
|
+
);
|
|
287
267
|
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
BigInt(await cheatCodes.rollup.getEpoch()) + (await rollup.read.getLagInEpochsForValidatorSet()) + 1n,
|
|
291
|
-
),
|
|
292
|
-
);
|
|
268
|
+
const { validators } = this.getValidators();
|
|
269
|
+
this.validators = validators;
|
|
293
270
|
|
|
294
|
-
|
|
295
|
-
|
|
271
|
+
const gseAddress = this.context.deployL1ContractsValues.l1ContractAddresses.gseAddress!;
|
|
272
|
+
if (!gseAddress) {
|
|
273
|
+
throw new Error('GSE contract not deployed');
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
const gseContract = new GSEContract(this.context.deployL1ContractsValues.l1Client, gseAddress.toString());
|
|
277
|
+
|
|
278
|
+
const makeValidatorTuples = async (validator: Operator) => {
|
|
279
|
+
const registrationTuple = await gseContract.makeRegistrationTuple(validator.bn254SecretKey.getValue());
|
|
280
|
+
return {
|
|
281
|
+
attester: validator.attester.toString() as `0x${string}`,
|
|
282
|
+
withdrawer: validator.withdrawer.toString() as `0x${string}`,
|
|
283
|
+
...registrationTuple,
|
|
284
|
+
};
|
|
285
|
+
};
|
|
286
|
+
const validatorTuples = await Promise.all(validators.map(makeValidatorTuples));
|
|
287
|
+
|
|
288
|
+
await this.context.deployL1ContractsValues.l1Client.waitForTransactionReceipt({
|
|
289
|
+
hash: await multiAdder.write.addValidators([validatorTuples]),
|
|
296
290
|
});
|
|
291
|
+
|
|
292
|
+
await this.context.cheatCodes.rollup.advanceToEpoch(
|
|
293
|
+
EpochNumber.fromBigInt(
|
|
294
|
+
BigInt(await this.context.cheatCodes.rollup.getEpoch()) +
|
|
295
|
+
(await rollup.read.getLagInEpochsForValidatorSet()) +
|
|
296
|
+
1n,
|
|
297
|
+
),
|
|
298
|
+
);
|
|
299
|
+
|
|
300
|
+
// Send and await a tx to make sure we mine a block for the warp to correctly progress.
|
|
301
|
+
await this._sendDummyTx(this.context.deployL1ContractsValues.l1Client);
|
|
297
302
|
}
|
|
298
303
|
|
|
299
304
|
async setupAccount() {
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
305
|
+
this.logger.info('Setting up account');
|
|
306
|
+
const { deployedAccounts } = await deployAccounts(
|
|
307
|
+
1,
|
|
308
|
+
this.logger,
|
|
309
|
+
)({
|
|
310
|
+
wallet: this.context.wallet,
|
|
311
|
+
initialFundedAccounts: this.context.initialFundedAccounts,
|
|
312
|
+
});
|
|
313
|
+
this.deployedAccounts = deployedAccounts;
|
|
314
|
+
[{ address: this.defaultAccountAddress }] = deployedAccounts;
|
|
315
|
+
this.wallet = this.context.wallet;
|
|
310
316
|
}
|
|
311
317
|
|
|
312
318
|
async deploySpamContract() {
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
const spamContract = await SpamContract.deploy(this.wallet)
|
|
321
|
-
.send({ from: this.defaultAccountAddress! })
|
|
322
|
-
.deployed();
|
|
323
|
-
return { contractAddress: spamContract.address };
|
|
324
|
-
},
|
|
325
|
-
({ contractAddress }) => {
|
|
326
|
-
if (!this.wallet) {
|
|
327
|
-
throw new Error('Call snapshot t.setupAccount before deploying account contract');
|
|
328
|
-
}
|
|
329
|
-
this.spamContract = SpamContract.at(contractAddress, this.wallet);
|
|
330
|
-
return Promise.resolve();
|
|
331
|
-
},
|
|
332
|
-
);
|
|
319
|
+
this.logger.info('Deploying spam contract');
|
|
320
|
+
if (!this.wallet) {
|
|
321
|
+
throw new Error('Call setupAccount before deploying spam contract');
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
const spamContract = await SpamContract.deploy(this.wallet).send({ from: this.defaultAccountAddress! }).deployed();
|
|
325
|
+
this.spamContract = spamContract;
|
|
333
326
|
}
|
|
334
327
|
|
|
335
328
|
async removeInitialNode() {
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
await aztecNode.stop();
|
|
347
|
-
},
|
|
348
|
-
);
|
|
329
|
+
this.logger.info('Removing initial node');
|
|
330
|
+
// Send and await a tx to make sure we mine a block for the warp to correctly progress.
|
|
331
|
+
const { receipt } = await this._sendDummyTx(this.context.deployL1ContractsValues.l1Client);
|
|
332
|
+
const block = await this.context.deployL1ContractsValues.l1Client.getBlock({
|
|
333
|
+
blockNumber: receipt.blockNumber,
|
|
334
|
+
});
|
|
335
|
+
this.context.dateProvider!.setTime(Number(block.timestamp) * 1000);
|
|
336
|
+
|
|
337
|
+
await this.context.aztecNodeService!.stop();
|
|
349
338
|
}
|
|
350
339
|
|
|
351
340
|
async sendDummyTx() {
|
|
@@ -361,17 +350,26 @@ export class P2PNetworkTest {
|
|
|
361
350
|
}
|
|
362
351
|
|
|
363
352
|
async setup() {
|
|
364
|
-
this.
|
|
353
|
+
this.logger.info('Setting up subsystems from fresh');
|
|
354
|
+
this.context = await setup(0, {
|
|
355
|
+
...this.setupOptions,
|
|
356
|
+
fundSponsoredFPC: true,
|
|
357
|
+
skipAccountDeployment: true,
|
|
358
|
+
slasherFlavor: this.setupOptions.slasherFlavor ?? this.deployL1ContractsArgs.slasherFlavor ?? 'none',
|
|
359
|
+
aztecTargetCommitteeSize: 0,
|
|
360
|
+
l1ContractsArgs: this.deployL1ContractsArgs,
|
|
361
|
+
});
|
|
362
|
+
this.ctx = this.context;
|
|
365
363
|
|
|
366
364
|
const sponsoredFPCAddress = await getSponsoredFPCAddress();
|
|
367
|
-
const initialFundedAccounts = [...this.
|
|
365
|
+
const initialFundedAccounts = [...this.context.initialFundedAccounts.map(a => a.address), sponsoredFPCAddress];
|
|
368
366
|
|
|
369
367
|
const { prefilledPublicData } = await getGenesisValues(initialFundedAccounts);
|
|
370
368
|
this.prefilledPublicData = prefilledPublicData;
|
|
371
369
|
|
|
372
|
-
const rollupContract = RollupContract.getFromL1ContractsValues(this.
|
|
373
|
-
this.monitor = new ChainMonitor(rollupContract, this.
|
|
374
|
-
this.monitor.on('l1-block', ({ timestamp }) => this.
|
|
370
|
+
const rollupContract = RollupContract.getFromL1ContractsValues(this.context.deployL1ContractsValues);
|
|
371
|
+
this.monitor = new ChainMonitor(rollupContract, this.context.dateProvider!).start();
|
|
372
|
+
this.monitor.on('l1-block', ({ timestamp }) => this.context.dateProvider!.setTime(Number(timestamp) * 1000));
|
|
375
373
|
}
|
|
376
374
|
|
|
377
375
|
async stopNodes(nodes: AztecNodeService[]) {
|
|
@@ -432,7 +430,7 @@ export class P2PNetworkTest {
|
|
|
432
430
|
async teardown() {
|
|
433
431
|
await this.monitor.stop();
|
|
434
432
|
await tryStop(this.bootstrapNode, this.logger);
|
|
435
|
-
await this.
|
|
433
|
+
await teardown(this.context);
|
|
436
434
|
}
|
|
437
435
|
|
|
438
436
|
async getContracts(): Promise<{
|
|
@@ -451,7 +449,7 @@ export class P2PNetworkTest {
|
|
|
451
449
|
);
|
|
452
450
|
|
|
453
451
|
const slasherContract = getContract({
|
|
454
|
-
address: getAddress(await rollup.getSlasherAddress()),
|
|
452
|
+
address: getAddress((await rollup.getSlasherAddress()).toString()),
|
|
455
453
|
abi: SlasherAbi,
|
|
456
454
|
client: this.ctx.deployL1ContractsValues.l1Client,
|
|
457
455
|
});
|
package/src/e2e_p2p/shared.ts
CHANGED
|
@@ -13,6 +13,7 @@ import type {
|
|
|
13
13
|
} from '@aztec/ethereum/contracts';
|
|
14
14
|
import { EpochNumber } from '@aztec/foundation/branded-types';
|
|
15
15
|
import { timesAsync, unique } from '@aztec/foundation/collection';
|
|
16
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
16
17
|
import { retryUntil } from '@aztec/foundation/retry';
|
|
17
18
|
import { pluralize } from '@aztec/foundation/string';
|
|
18
19
|
import type { SpamContract } from '@aztec/noir-test-contracts.js/Spam';
|
|
@@ -137,7 +138,7 @@ export async function awaitCommitteeExists({
|
|
|
137
138
|
logger: Logger;
|
|
138
139
|
}): Promise<readonly `0x${string}`[]> {
|
|
139
140
|
logger.info(`Waiting for committee to be set`);
|
|
140
|
-
let committee:
|
|
141
|
+
let committee: EthAddress[] | undefined;
|
|
141
142
|
await retryUntil(
|
|
142
143
|
async () => {
|
|
143
144
|
committee = await rollup.getCurrentEpochCommittee();
|
|
@@ -146,7 +147,7 @@ export async function awaitCommitteeExists({
|
|
|
146
147
|
'non-empty committee',
|
|
147
148
|
60,
|
|
148
149
|
);
|
|
149
|
-
return committee
|
|
150
|
+
return committee!.map(c => c.toString() as `0x${string}`);
|
|
150
151
|
}
|
|
151
152
|
|
|
152
153
|
export async function awaitOffenseDetected({
|
|
@@ -218,9 +219,9 @@ export async function awaitCommitteeKicked({
|
|
|
218
219
|
|
|
219
220
|
if (slashingProposer.type === 'empire') {
|
|
220
221
|
// Await for the slash payload to be created if empire (no payload is created on tally until execution time)
|
|
221
|
-
const targetEpoch =
|
|
222
|
+
const targetEpoch = EpochNumber((await cheatCodes.getEpoch()) + (await rollup.getLagInEpochsForValidatorSet()) + 1);
|
|
222
223
|
logger.info(`Advancing to epoch ${targetEpoch} so we start slashing`);
|
|
223
|
-
await cheatCodes.advanceToEpoch(
|
|
224
|
+
await cheatCodes.advanceToEpoch(targetEpoch);
|
|
224
225
|
|
|
225
226
|
const slashPayloadEvents = await retryUntil(
|
|
226
227
|
async () => {
|
|
@@ -275,7 +276,7 @@ export async function awaitCommitteeKicked({
|
|
|
275
276
|
logger.info(`Advancing to check current committee`);
|
|
276
277
|
await cheatCodes.debugRollup();
|
|
277
278
|
await cheatCodes.advanceToEpoch(
|
|
278
|
-
EpochNumber
|
|
279
|
+
EpochNumber((await cheatCodes.getEpoch()) + (await rollup.getLagInEpochsForValidatorSet()) + 1),
|
|
279
280
|
);
|
|
280
281
|
await cheatCodes.debugRollup();
|
|
281
282
|
|