@aztec/end-to-end 0.0.1-commit.b655e406 → 0.0.1-commit.b6e433891
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 +22 -16
- package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
- package/dest/bench/client_flows/client_flows_benchmark.js +142 -124
- 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.d.ts +1 -1
- package/dest/bench/client_flows/data_extractor.js +7 -27
- package/dest/bench/utils.d.ts +8 -7
- package/dest/bench/utils.d.ts.map +1 -1
- package/dest/bench/utils.js +31 -19
- 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 +107 -113
- 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 -70
- package/dest/e2e_deploy_contract/deploy_test.d.ts +6 -5
- 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 +27 -15
- package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
- package/dest/e2e_epochs/epochs_test.js +107 -54
- package/dest/e2e_fees/bridging_race.notest.d.ts +1 -1
- package/dest/e2e_fees/bridging_race.notest.js +5 -7
- 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 +138 -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 +18 -19
- package/dest/e2e_multi_validator/utils.d.ts +1 -1
- 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 +30 -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 +7 -6
- package/dest/e2e_p2p/p2p_network.d.ts +229 -21
- package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
- package/dest/e2e_p2p/p2p_network.js +142 -114
- 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 +190 -0
- package/dest/e2e_p2p/shared.d.ts +31 -11
- package/dest/e2e_p2p/shared.d.ts.map +1 -1
- package/dest/e2e_p2p/shared.js +51 -22
- 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 +100 -92
- 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 +15 -21
- package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
- package/dest/fixtures/e2e_prover_test.js +123 -138
- package/dest/fixtures/elu_monitor.d.ts +21 -0
- package/dest/fixtures/elu_monitor.d.ts.map +1 -0
- package/dest/fixtures/elu_monitor.js +102 -0
- 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.d.ts +1 -1
- package/dest/fixtures/get_acvm_config.js +1 -1
- package/dest/fixtures/get_bb_config.d.ts +1 -1
- package/dest/fixtures/get_bb_config.d.ts.map +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/logging.d.ts +1 -1
- package/dest/fixtures/setup.d.ts +239 -0
- package/dest/fixtures/setup.d.ts.map +1 -0
- package/dest/fixtures/setup.js +606 -0
- package/dest/fixtures/setup_p2p_test.d.ts +17 -10
- package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
- package/dest/fixtures/setup_p2p_test.js +55 -36
- package/dest/fixtures/token_utils.d.ts +6 -3
- package/dest/fixtures/token_utils.d.ts.map +1 -1
- package/dest/fixtures/token_utils.js +17 -10
- package/dest/fixtures/utils.d.ts +5 -192
- package/dest/fixtures/utils.d.ts.map +1 -1
- package/dest/fixtures/utils.js +4 -648
- package/dest/fixtures/web3signer.d.ts +1 -1
- 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/index.d.ts +1 -1
- package/dest/quality_of_service/grafana_client.d.ts +41 -0
- package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
- package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
- package/dest/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 +7 -6
- package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
- package/dest/shared/cross_chain_test_harness.js +27 -27
- package/dest/shared/gas_portal_test_harness.d.ts +2 -2
- package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
- package/dest/shared/gas_portal_test_harness.js +4 -4
- 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/jest_setup.d.ts +1 -1
- package/dest/shared/jest_setup.js +41 -1
- 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 +58 -39
- package/dest/simulators/index.d.ts +1 -1
- package/dest/simulators/lending_simulator.d.ts +2 -2
- package/dest/simulators/lending_simulator.d.ts.map +1 -1
- package/dest/simulators/lending_simulator.js +8 -6
- 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 +3 -24
- package/dest/spartan/setup_test_wallets.d.ts +18 -6
- package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
- package/dest/spartan/setup_test_wallets.js +129 -24
- 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 +45 -0
- package/dest/spartan/utils/config.d.ts.map +1 -0
- package/dest/spartan/utils/config.js +23 -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 +11 -0
- package/dest/spartan/utils/index.d.ts.map +1 -0
- package/dest/spartan/utils/index.js +22 -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 +461 -0
- package/dest/spartan/utils/pod_logs.d.ts +25 -0
- package/dest/spartan/utils/pod_logs.d.ts.map +1 -0
- package/dest/spartan/utils/pod_logs.js +74 -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 +76 -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 +48 -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 +151 -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 +49 -44
- package/src/bench/client_flows/benchmark.ts +24 -2
- package/src/bench/client_flows/client_flows_benchmark.ts +163 -177
- package/src/bench/client_flows/config.ts +9 -1
- package/src/bench/client_flows/data_extractor.ts +6 -28
- package/src/bench/utils.ts +36 -21
- package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +120 -145
- package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +140 -125
- package/src/e2e_deploy_contract/deploy_test.ts +23 -16
- package/src/e2e_epochs/epochs_test.ts +176 -114
- package/src/e2e_fees/bridging_race.notest.ts +6 -12
- package/src/e2e_fees/fees_test.ts +179 -226
- package/src/e2e_l1_publisher/write_json.ts +20 -19
- package/src/e2e_multi_validator/utils.ts +1 -1
- package/src/e2e_nested_contract/nested_contract_test.ts +35 -55
- package/src/e2e_p2p/inactivity_slash_test.ts +8 -7
- package/src/e2e_p2p/p2p_network.ts +205 -178
- package/src/e2e_p2p/reqresp/utils.ts +256 -0
- package/src/e2e_p2p/shared.ts +90 -29
- 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 +121 -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 +144 -186
- package/src/fixtures/elu_monitor.ts +126 -0
- 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 +903 -0
- package/src/fixtures/setup_p2p_test.ts +58 -48
- package/src/fixtures/token_utils.ts +12 -8
- package/src/fixtures/utils.ts +27 -947
- package/src/fixtures/web3signer.ts +1 -1
- package/src/fixtures/with_telemetry_utils.ts +2 -2
- package/src/guides/up_quick_start.sh +4 -4
- 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 +30 -43
- package/src/shared/gas_portal_test_harness.ts +4 -4
- package/src/shared/index.ts +2 -1
- package/src/shared/jest_setup.ts +51 -1
- package/src/shared/mock_state_view.ts +188 -0
- package/src/shared/submit-transactions.ts +11 -16
- package/src/shared/uniswap_l1_l2.ts +86 -102
- package/src/simulators/lending_simulator.ts +11 -7
- package/src/simulators/token_simulator.ts +6 -30
- package/src/spartan/DEVELOP.md +7 -0
- package/src/spartan/setup_test_wallets.ts +205 -29
- 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 +29 -0
- package/src/spartan/utils/health.ts +255 -0
- package/src/spartan/utils/helm.ts +84 -0
- package/src/spartan/utils/index.ts +71 -0
- package/src/spartan/utils/k8s.ts +535 -0
- package/src/spartan/utils/nodes.ts +543 -0
- package/src/spartan/utils/pod_logs.ts +99 -0
- package/src/spartan/utils/scripts.ts +99 -0
- package/src/spartan/utils.ts +1 -942
- package/src/test-wallet/test_wallet.ts +294 -0
- package/src/test-wallet/utils.ts +112 -0
- package/src/test-wallet/wallet_worker_script.ts +60 -0
- package/src/test-wallet/worker_wallet.ts +213 -0
- package/src/test-wallet/worker_wallet_schema.ts +13 -0
- package/dest/fixtures/setup_l1_contracts.d.ts +0 -6
- package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
- package/dest/fixtures/setup_l1_contracts.js +0 -17
- package/dest/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
package/src/bench/utils.ts
CHANGED
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import type { AztecNodeService } from '@aztec/aztec-node';
|
|
2
|
-
import {
|
|
2
|
+
import { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
3
|
+
import { BatchCall, NO_WAIT, type WaitOpts } from '@aztec/aztec.js/contracts';
|
|
4
|
+
import { waitForTx } from '@aztec/aztec.js/node';
|
|
3
5
|
import { mean, stdDev, times } from '@aztec/foundation/collection';
|
|
4
6
|
import { BenchmarkingContract } from '@aztec/noir-test-contracts.js/Benchmarking';
|
|
5
|
-
import type {
|
|
7
|
+
import type { TxHash } from '@aztec/stdlib/tx';
|
|
8
|
+
import type { MetricDefinition } from '@aztec/telemetry-client';
|
|
6
9
|
import type { BenchmarkDataPoint, BenchmarkMetricsType, BenchmarkTelemetryClient } from '@aztec/telemetry-client/bench';
|
|
7
10
|
|
|
8
11
|
import { mkdirSync, writeFileSync } from 'fs';
|
|
@@ -15,17 +18,17 @@ import { type EndToEndContext, type SetupOptions, setup } from '../fixtures/util
|
|
|
15
18
|
*/
|
|
16
19
|
export async function benchmarkSetup(
|
|
17
20
|
opts: Partial<SetupOptions> & {
|
|
18
|
-
/** What metrics to export */ metrics: (
|
|
21
|
+
/** What metrics to export */ metrics: (MetricDefinition | MetricFilter)[];
|
|
19
22
|
/** Where to output the benchmark data (defaults to BENCH_OUTPUT or bench.json) */
|
|
20
23
|
benchOutput?: string;
|
|
21
24
|
},
|
|
22
25
|
) {
|
|
23
26
|
const context = await setup(1, { ...opts, telemetryConfig: { benchmark: true } });
|
|
24
27
|
const defaultAccountAddress = context.accounts[0];
|
|
25
|
-
const contract = await BenchmarkingContract.deploy(context.wallet).send({ from: defaultAccountAddress })
|
|
28
|
+
const { contract } = await BenchmarkingContract.deploy(context.wallet).send({ from: defaultAccountAddress });
|
|
26
29
|
context.logger.info(`Deployed benchmarking contract at ${contract.address}`);
|
|
27
30
|
const sequencer = (context.aztecNode as AztecNodeService).getSequencer()!;
|
|
28
|
-
const telemetry = context.telemetryClient
|
|
31
|
+
const telemetry = context.telemetryClient as BenchmarkTelemetryClient;
|
|
29
32
|
context.logger.warn(`Cleared benchmark data points from setup`);
|
|
30
33
|
telemetry.clear();
|
|
31
34
|
const origTeardown = context.teardown.bind(context);
|
|
@@ -46,7 +49,7 @@ export async function benchmarkSetup(
|
|
|
46
49
|
}
|
|
47
50
|
|
|
48
51
|
type MetricFilter = {
|
|
49
|
-
source:
|
|
52
|
+
source: MetricDefinition;
|
|
50
53
|
transform: (value: number) => number;
|
|
51
54
|
name: string;
|
|
52
55
|
unit?: string;
|
|
@@ -61,17 +64,21 @@ export type GithubActionBenchmarkResult = {
|
|
|
61
64
|
extra?: string;
|
|
62
65
|
};
|
|
63
66
|
|
|
67
|
+
function isMetricDefinition(f: MetricDefinition | MetricFilter): f is MetricDefinition {
|
|
68
|
+
return 'description' in f;
|
|
69
|
+
}
|
|
70
|
+
|
|
64
71
|
function formatMetricsForGithubBenchmarkAction(
|
|
65
72
|
data: BenchmarkMetricsType,
|
|
66
|
-
filter: (
|
|
73
|
+
filter: (MetricDefinition | MetricFilter)[],
|
|
67
74
|
): GithubActionBenchmarkResult[] {
|
|
68
75
|
const allFilters: MetricFilter[] = filter.map(f =>
|
|
69
|
-
|
|
76
|
+
isMetricDefinition(f) ? { name: f.name, source: f, transform: (x: number) => x, unit: f.unit } : f,
|
|
70
77
|
);
|
|
71
78
|
return data.flatMap(meter => {
|
|
72
79
|
return meter.metrics
|
|
73
|
-
.filter(metric => allFilters.map(f => f.source).includes(metric.name
|
|
74
|
-
.map(metric => [metric, allFilters.find(f => f.source === metric.name)!] as const)
|
|
80
|
+
.filter(metric => allFilters.map(f => f.source.name).includes(metric.name))
|
|
81
|
+
.map(metric => [metric, allFilters.find(f => f.source.name === metric.name)!] as const)
|
|
75
82
|
.map(([metric, filter]) => ({
|
|
76
83
|
name: `${meter.name}/${filter.name}`,
|
|
77
84
|
unit: filter.unit ?? metric.unit ?? 'unknown',
|
|
@@ -103,19 +110,22 @@ function getMetricValues(points: BenchmarkDataPoint[]) {
|
|
|
103
110
|
* @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
|
|
104
111
|
* @returns A BatchCall instance.
|
|
105
112
|
*/
|
|
106
|
-
function makeCall(
|
|
113
|
+
async function makeCall(
|
|
107
114
|
index: number,
|
|
108
115
|
context: EndToEndContext,
|
|
109
116
|
contract: BenchmarkingContract,
|
|
110
117
|
heavyPublicCompute: boolean,
|
|
111
118
|
) {
|
|
112
|
-
const [owner] = context.accounts;
|
|
113
119
|
if (heavyPublicCompute) {
|
|
114
120
|
return new BatchCall(context.wallet, [contract.methods.sha256_hash_1024(randomBytesAsBigInts(1024))]);
|
|
115
121
|
} else {
|
|
122
|
+
// We use random address for the new note owner because we can emit at most UNFINALIZED_TAGGING_INDEXES_WINDOW_LEN
|
|
123
|
+
// logs for a given sender-recipient-contract tuple.
|
|
124
|
+
const ownerOfNewNote = await AztecAddress.random();
|
|
125
|
+
const [ownerOfBalance] = context.accounts;
|
|
116
126
|
return new BatchCall(context.wallet, [
|
|
117
|
-
contract.methods.create_note(
|
|
118
|
-
contract.methods.increment_balance(
|
|
127
|
+
contract.methods.create_note(ownerOfNewNote, index + 1),
|
|
128
|
+
contract.methods.increment_balance(ownerOfBalance, index + 1),
|
|
119
129
|
]);
|
|
120
130
|
}
|
|
121
131
|
}
|
|
@@ -129,23 +139,28 @@ function makeCall(
|
|
|
129
139
|
* @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
|
|
130
140
|
* @returns Array of sent txs.
|
|
131
141
|
*/
|
|
132
|
-
export function sendTxs(
|
|
142
|
+
export async function sendTxs(
|
|
133
143
|
txCount: number,
|
|
134
144
|
context: EndToEndContext,
|
|
135
145
|
contract: BenchmarkingContract,
|
|
136
146
|
heavyPublicCompute: boolean = false,
|
|
137
|
-
):
|
|
138
|
-
const calls = times(txCount, index => makeCall(index, context, contract, heavyPublicCompute));
|
|
147
|
+
): Promise<TxHash[]> {
|
|
148
|
+
const calls = await Promise.all(times(txCount, index => makeCall(index, context, contract, heavyPublicCompute)));
|
|
139
149
|
context.logger.info(`Creating ${txCount} txs`);
|
|
140
150
|
const [from] = context.accounts;
|
|
141
151
|
context.logger.info(`Sending ${txCount} txs`);
|
|
142
|
-
return
|
|
152
|
+
return Promise.all(
|
|
153
|
+
calls.map(async call => {
|
|
154
|
+
const { txHash } = await call.send({ from, wait: NO_WAIT });
|
|
155
|
+
return txHash;
|
|
156
|
+
}),
|
|
157
|
+
);
|
|
143
158
|
}
|
|
144
159
|
|
|
145
|
-
export async function waitTxs(txs:
|
|
160
|
+
export async function waitTxs(txs: TxHash[], context: EndToEndContext, txWaitOpts?: WaitOpts) {
|
|
146
161
|
context.logger.info(`Awaiting ${txs.length} txs to be mined`);
|
|
147
|
-
await Promise.all(txs.map(
|
|
148
|
-
context.logger.info(
|
|
162
|
+
await Promise.all(txs.map(txHash => waitForTx(context.aztecNode, txHash, txWaitOpts)));
|
|
163
|
+
context.logger.info(`${txs.length} txs have been mined`);
|
|
149
164
|
}
|
|
150
165
|
|
|
151
166
|
function randomBytesAsBigInts(length: number): bigint[] {
|
|
@@ -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,83 @@ 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
|
+
({ contract: 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
|
+
({ contract: this.badAccount } = await InvalidAccountContract.deploy(this.wallet).send({
|
|
117
|
+
from: this.adminAddress,
|
|
118
|
+
}));
|
|
119
|
+
this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
|
|
120
|
+
|
|
121
|
+
// Deploy a proxy contract for "on behalf of other" tests. The note owner must be the tx sender
|
|
122
|
+
// (so their notes are in scope), but msg_sender in the target must differ from the note owner
|
|
123
|
+
// to trigger authwit validation. The proxy forwards calls so that msg_sender != tx sender.
|
|
124
|
+
this.logger.verbose(`Deploying generic proxy...`);
|
|
125
|
+
({ contract: this.authwitProxy } = await GenericProxyContract.deploy(this.wallet).send({
|
|
126
|
+
from: this.adminAddress,
|
|
127
|
+
}));
|
|
128
|
+
this.logger.verbose(`Deployed to ${this.authwitProxy.address}.`);
|
|
129
|
+
|
|
130
|
+
await this.crossTimestampOfChange();
|
|
131
|
+
|
|
132
|
+
this.tokenSim = new TokenSimulator(
|
|
133
|
+
this.asset as unknown as TokenContract,
|
|
134
|
+
this.wallet,
|
|
135
|
+
this.adminAddress,
|
|
136
|
+
this.logger,
|
|
137
|
+
[this.adminAddress, this.otherAddress, this.blacklistedAddress],
|
|
107
138
|
);
|
|
108
139
|
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
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 = await 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 = await 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
|
-
},
|
|
151
|
-
);
|
|
140
|
+
expect(
|
|
141
|
+
(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).result,
|
|
142
|
+
).toEqual(new Role().withAdmin().toNoirStruct());
|
|
152
143
|
}
|
|
153
144
|
|
|
154
145
|
async setup() {
|
|
155
|
-
|
|
146
|
+
this.logger.info('Setting up fresh context');
|
|
147
|
+
this.context = await setup(0, {
|
|
148
|
+
fundSponsoredFPC: true,
|
|
149
|
+
skipAccountDeployment: true,
|
|
150
|
+
});
|
|
151
|
+
await this.applyBaseSetup();
|
|
156
152
|
}
|
|
157
153
|
|
|
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
154
|
async teardown() {
|
|
165
|
-
await this.
|
|
155
|
+
await teardown(this.context);
|
|
166
156
|
}
|
|
167
157
|
|
|
168
158
|
async addPendingShieldNoteToPXE(
|
|
@@ -174,7 +164,7 @@ export class BlacklistTokenContractTest {
|
|
|
174
164
|
) {
|
|
175
165
|
const txEffects = await this.aztecNode.getTxEffect(txHash);
|
|
176
166
|
await contract.methods
|
|
177
|
-
.
|
|
167
|
+
.process_transparent_note(
|
|
178
168
|
contract.address,
|
|
179
169
|
amount,
|
|
180
170
|
secretHash,
|
|
@@ -186,71 +176,56 @@ export class BlacklistTokenContractTest {
|
|
|
186
176
|
.simulate({ from: recipient });
|
|
187
177
|
}
|
|
188
178
|
|
|
189
|
-
async
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
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
|
-
},
|
|
254
|
-
);
|
|
179
|
+
async applyMint() {
|
|
180
|
+
this.logger.info('Applying mint setup');
|
|
181
|
+
const { asset, tokenSim } = this;
|
|
182
|
+
const amount = 10000n;
|
|
183
|
+
|
|
184
|
+
const adminMinterRole = new Role().withAdmin().withMinter();
|
|
185
|
+
await this.asset.methods
|
|
186
|
+
.update_roles(this.adminAddress, adminMinterRole.toNoirStruct())
|
|
187
|
+
.send({ from: this.adminAddress });
|
|
188
|
+
|
|
189
|
+
const blacklistRole = new Role().withBlacklisted();
|
|
190
|
+
await this.asset.methods
|
|
191
|
+
.update_roles(this.blacklistedAddress, blacklistRole.toNoirStruct())
|
|
192
|
+
.send({ from: this.adminAddress });
|
|
193
|
+
|
|
194
|
+
await this.crossTimestampOfChange();
|
|
195
|
+
|
|
196
|
+
expect(
|
|
197
|
+
(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).result,
|
|
198
|
+
).toEqual(adminMinterRole.toNoirStruct());
|
|
199
|
+
|
|
200
|
+
this.logger.verbose(`Minting ${amount} publicly...`);
|
|
201
|
+
await asset.methods.mint_public(this.adminAddress, amount).send({ from: this.adminAddress });
|
|
202
|
+
|
|
203
|
+
this.logger.verbose(`Minting ${amount} privately...`);
|
|
204
|
+
const secret = Fr.random();
|
|
205
|
+
const secretHash = await computeSecretHash(secret);
|
|
206
|
+
const { receipt } = await asset.methods.mint_private(amount, secretHash).send({ from: this.adminAddress });
|
|
207
|
+
|
|
208
|
+
await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
|
|
209
|
+
await asset.methods.redeem_shield(this.adminAddress, amount, secret).send({ from: this.adminAddress });
|
|
210
|
+
this.logger.verbose(`Minting complete.`);
|
|
211
|
+
|
|
212
|
+
tokenSim.mintPublic(this.adminAddress, amount);
|
|
213
|
+
|
|
214
|
+
const { result: publicBalance } = await asset.methods
|
|
215
|
+
.balance_of_public(this.adminAddress)
|
|
216
|
+
.simulate({ from: this.adminAddress });
|
|
217
|
+
this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
|
|
218
|
+
expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(this.adminAddress));
|
|
219
|
+
|
|
220
|
+
tokenSim.mintPrivate(this.adminAddress, amount);
|
|
221
|
+
const { result: privateBalance } = await asset.methods
|
|
222
|
+
.balance_of_private(this.adminAddress)
|
|
223
|
+
.simulate({ from: this.adminAddress });
|
|
224
|
+
this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
|
|
225
|
+
expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
|
|
226
|
+
|
|
227
|
+
const { result: totalSupply } = await asset.methods.total_supply().simulate({ from: this.adminAddress });
|
|
228
|
+
this.logger.verbose(`Total supply: ${totalSupply}`);
|
|
229
|
+
expect(totalSupply).toEqual(tokenSim.totalSupply);
|
|
255
230
|
}
|
|
256
231
|
}
|