Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(zk_toolbox): Migrate CI unit tests to zk_toolbox #2759

Merged
merged 40 commits into from
Sep 4, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
2d1eb2e
Migrate unit tests
matias-gonz Aug 28, 2024
1b24aed
Add options to RustArgs
matias-gonz Aug 28, 2024
a315e67
Add help messages
matias-gonz Aug 28, 2024
b736c36
Add options to ci
matias-gonz Aug 28, 2024
86fbf90
Fix options
matias-gonz Aug 28, 2024
8d0bbd7
Remove `get_dals`
matias-gonz Aug 28, 2024
5a1923e
Increase tries
matias-gonz Aug 28, 2024
6f8250f
Activate db before tests
matias-gonz Aug 28, 2024
80dcb2b
Add dbg msg
matias-gonz Aug 28, 2024
6a11e4b
Update db url
matias-gonz Aug 28, 2024
9ac2c64
Merge branch 'main' of github.com:matter-labs/zksync-era into matias-…
matias-gonz Aug 30, 2024
396e51c
fmt
matias-gonz Aug 30, 2024
93b0175
Update db host
matias-gonz Aug 30, 2024
5ac80de
Merge branch 'main' into matias-ci-migrate-unit-tests
matias-gonz Aug 30, 2024
6102996
Update genesis
matias-gonz Aug 30, 2024
a8be678
Undo genesis
matias-gonz Aug 30, 2024
8d5b51f
Use defaults
matias-gonz Aug 30, 2024
c499942
Fix chain not initialized
matias-gonz Aug 30, 2024
de90c3c
Fix default dbs
matias-gonz Aug 30, 2024
1f161fe
Merge branch 'main' into matias-ci-migrate-unit-tests
matias-gonz Aug 30, 2024
c19545f
Remove zk from benchmark test
matias-gonz Aug 30, 2024
7591720
Remove zk installation
matias-gonz Aug 30, 2024
798d3f1
Remove Contracts unit tests
matias-gonz Aug 30, 2024
4aee393
Compile contracts
matias-gonz Aug 30, 2024
e85121f
fmt
matias-gonz Aug 30, 2024
af98f97
Add ci_run
matias-gonz Aug 30, 2024
49e0c0a
Add zks contracts
matias-gonz Sep 2, 2024
8bc88ff
fmt
matias-gonz Sep 2, 2024
512668f
Add readme
matias-gonz Sep 2, 2024
2af07dd
Add Contracts Args
matias-gonz Sep 2, 2024
fcca579
Merge branch 'main' into matias-zks-contracts
matias-gonz Sep 2, 2024
276aff7
Replace vec with option bools
matias-gonz Sep 3, 2024
452f8ae
Merge branch 'main' into matias-zks-contracts
matias-gonz Sep 3, 2024
34c1f94
Add alias
matias-gonz Sep 3, 2024
ca47272
Merge branch 'matias-zks-contracts' of github.com:matter-labs/zksync-…
matias-gonz Sep 3, 2024
f8f1101
Integrate zks contracts
matias-gonz Sep 3, 2024
bb07b1d
Use full command
matias-gonz Sep 3, 2024
581ccb0
Merge branch 'main' into matias-ci-migrate-unit-tests
matias-gonz Sep 3, 2024
e78130d
Add zks contracts --test
matias-gonz Sep 3, 2024
17ca5c0
Compile all contracts
matias-gonz Sep 3, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 4 additions & 7 deletions .github/workflows/ci-core-reusable.yml
Original file line number Diff line number Diff line change
Expand Up @@ -52,22 +52,19 @@ jobs:

- name: Init
run: |
ci_run zk
ci_run run_retried rustup show
ci_run zk run yarn
ci_run zk db setup
ci_run zk compiler all
ci_run zk contract build
ci_run ./bin/zkt
ci_run zk_supervisor contracts

- name: Contracts unit tests
run: ci_run yarn l1-contracts test

- name: Rust unit tests
run: |
ci_run zk test rust
ci_run zk_supervisor test rust
# Benchmarks are not tested by `cargo nextest` unless specified explicitly, and even then `criterion` harness is incompatible
# with how `cargo nextest` runs tests. Thus, we run criterion-based benchmark tests manually.
ci_run zk f cargo test --release -p vm-benchmark --bench oneshot --bench batch
ci_run cargo test --release -p vm-benchmark --bench oneshot --bench batch

loadtest:
runs-on: [ matterlabs-ci-runner-high-performance ]
Expand Down
6 changes: 4 additions & 2 deletions infrastructure/zk/src/prover_setup.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,8 @@ export async function setupProver(proverType: ProverType) {
} else {
env.modify(
'FRI_PROVER_SETUP_DATA_PATH',
`${process.env.ZKSYNC_HOME}/etc/hyperchains/prover-keys/${process.env.ZKSYNC_ENV}/${proverType === ProverType.GPU ? 'gpu' : 'cpu'
`${process.env.ZKSYNC_HOME}/etc/hyperchains/prover-keys/${process.env.ZKSYNC_ENV}/${
proverType === ProverType.GPU ? 'gpu' : 'cpu'
}/`,
process.env.ENV_FILE!
);
Expand Down Expand Up @@ -97,7 +98,8 @@ async function setupProverKeys(proverType: ProverType) {

env.modify(
'FRI_PROVER_SETUP_DATA_PATH',
`${process.env.ZKSYNC_HOME}/etc/hyperchains/prover-keys/${process.env.ZKSYNC_ENV}/${proverType === ProverType.GPU ? 'gpu' : 'cpu'
`${process.env.ZKSYNC_HOME}/etc/hyperchains/prover-keys/${process.env.ZKSYNC_ENV}/${
proverType === ProverType.GPU ? 'gpu' : 'cpu'
}/`,
process.env.ENV_FILE!
);
Expand Down
24 changes: 18 additions & 6 deletions zk_toolbox/crates/zk_supervisor/src/commands/contracts.rs
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
use std::path::PathBuf;

use clap::{Parser, ValueEnum};
use clap::Parser;
use common::{cmd::Cmd, logger, spinner::Spinner};
use config::EcosystemConfig;
use strum::EnumIter;
use xshell::{cmd, Shell};

use crate::messages::{
MSG_BUILDING_CONTRACTS, MSG_BUILDING_CONTRACTS_SUCCESS, MSG_BUILDING_L1_CONTRACTS_SPINNER,
MSG_BUILDING_L2_CONTRACTS_SPINNER, MSG_BUILDING_SYSTEM_CONTRACTS_SPINNER,
MSG_BUILD_L1_CONTRACTS_HELP, MSG_BUILD_L2_CONTRACTS_HELP, MSG_BUILD_SYSTEM_CONTRACTS_HELP,
MSG_CONTRACTS_DEPS_SPINNER, MSG_NOTHING_TO_BUILD_MSG,
MSG_BUILDING_TEST_CONTRACTS_SPINNER, MSG_BUILD_L1_CONTRACTS_HELP, MSG_BUILD_L2_CONTRACTS_HELP,
MSG_BUILD_SYSTEM_CONTRACTS_HELP, MSG_BUILD_TEST_CONTRACTS_HELP, MSG_CONTRACTS_DEPS_SPINNER,
MSG_NOTHING_TO_BUILD_MSG,
};

#[derive(Debug, Parser)]
Expand All @@ -21,18 +21,22 @@ pub struct ContractsArgs {
pub l2_contracts: Option<bool>,
#[clap(long, alias = "sc", help = MSG_BUILD_SYSTEM_CONTRACTS_HELP, default_missing_value = "true", num_args = 0..=1)]
pub system_contracts: Option<bool>,
#[clap(long, alias = "test", help = MSG_BUILD_TEST_CONTRACTS_HELP, default_missing_value = "true", num_args = 0..=1)]
pub test_contracts: Option<bool>,
}

impl ContractsArgs {
fn contracts(&self) -> Vec<ContractType> {
if self.l1_contracts.is_none()
&& self.l2_contracts.is_none()
&& self.system_contracts.is_none()
&& self.test_contracts.is_none()
{
return vec![
ContractType::L1,
ContractType::L2,
ContractType::SystemContracts,
ContractType::TestContracts,
];
}

Expand All @@ -47,17 +51,20 @@ impl ContractsArgs {
if self.system_contracts.unwrap_or(false) {
contracts.push(ContractType::SystemContracts);
}
if self.test_contracts.unwrap_or(false) {
contracts.push(ContractType::TestContracts);
}

contracts
}
}

#[derive(Debug, ValueEnum, EnumIter, strum::Display, PartialEq, Eq, Clone, Copy)]
#[strum(serialize_all = "lowercase")]
#[derive(Debug, PartialEq, Eq, Clone, Copy)]
pub enum ContractType {
L1,
L2,
SystemContracts,
TestContracts,
}

#[derive(Debug)]
Expand Down Expand Up @@ -85,6 +92,11 @@ impl ContractBuilder {
cmd: "yarn sc build".to_string(),
msg: MSG_BUILDING_SYSTEM_CONTRACTS_SPINNER.to_string(),
},
ContractType::TestContracts => Self {
dir: ecosystem.link_to_code.join("etc/contracts-test-data"),
cmd: "yarn build".to_string(),
msg: MSG_BUILDING_TEST_CONTRACTS_SPINNER.to_string(),
},
}
}

Expand Down
76 changes: 51 additions & 25 deletions zk_toolbox/crates/zk_supervisor/src/commands/test/rust.rs
Original file line number Diff line number Diff line change
@@ -1,12 +1,16 @@
use std::{path::Path, str::FromStr};

use anyhow::Context;
use common::{cmd::Cmd, config::global_config, db::wait_for_db, logger};
use common::{cmd::Cmd, db::wait_for_db, logger};
use config::EcosystemConfig;
use url::Url;
use xshell::{cmd, Shell};

use super::args::rust::RustArgs;
use crate::{
commands::database,
dals::get_test_dals,
dals::{Dal, CORE_DAL_PATH, PROVER_DAL_PATH},
defaults::{TEST_DATABASE_PROVER_URL, TEST_DATABASE_SERVER_URL},
messages::{
MSG_CARGO_NEXTEST_MISSING_ERR, MSG_CHAIN_NOT_FOUND_ERR, MSG_POSTGRES_CONFIG_NOT_FOUND_ERR,
MSG_RESETTING_TEST_DATABASES, MSG_UNIT_TESTS_RUN_SUCCESS, MSG_USING_CARGO_NEXTEST,
Expand All @@ -17,16 +21,45 @@ pub async fn run(shell: &Shell, args: RustArgs) -> anyhow::Result<()> {
let ecosystem = EcosystemConfig::from_file(shell)?;
let chain = ecosystem
.clone()
.load_chain(global_config().chain_name.clone())
.load_chain(Some(ecosystem.default_chain))
.context(MSG_CHAIN_NOT_FOUND_ERR)?;
let general_config = chain.get_general_config()?;
let postgres = general_config
.postgres_config
.context(MSG_POSTGRES_CONFIG_NOT_FOUND_ERR)?;
let general_config = chain.get_general_config();
let link_to_code = ecosystem.link_to_code;

let (test_server_url, test_prover_url) = if let Ok(general_config) = general_config {
let postgres = general_config
.postgres_config
.context(MSG_POSTGRES_CONFIG_NOT_FOUND_ERR)?;

(
postgres
.test_server_url
.context(MSG_POSTGRES_CONFIG_NOT_FOUND_ERR)?,
postgres
.test_prover_url
.context(MSG_POSTGRES_CONFIG_NOT_FOUND_ERR)?,
)
} else {
(
TEST_DATABASE_SERVER_URL.to_string(),
TEST_DATABASE_PROVER_URL.to_string(),
)
};

let dals = vec![
Dal {
url: Url::from_str(&test_server_url.clone())?,
path: CORE_DAL_PATH.to_string(),
},
Dal {
url: Url::from_str(&test_prover_url.clone())?,
path: PROVER_DAL_PATH.to_string(),
},
];

reset_test_databases(shell).await?;
reset_test_databases(shell, &link_to_code, dals).await?;

let _dir_guard = shell.push_dir(&ecosystem.link_to_code);
let _dir_guard = shell.push_dir(&link_to_code);

let cmd = if nextest_is_installed(shell)? {
logger::info(MSG_USING_CARGO_NEXTEST);
Expand All @@ -43,18 +76,8 @@ pub async fn run(shell: &Shell, args: RustArgs) -> anyhow::Result<()> {
};

let cmd = cmd
.env(
"TEST_DATABASE_URL",
postgres
.test_server_url
.context(MSG_POSTGRES_CONFIG_NOT_FOUND_ERR)?,
)
.env(
"TEST_PROVER_DATABASE_URL",
postgres
.test_prover_url
.context(MSG_POSTGRES_CONFIG_NOT_FOUND_ERR)?,
);
.env("TEST_DATABASE_URL", test_server_url)
.env("TEST_PROVER_DATABASE_URL", test_prover_url);
cmd.run()?;

logger::outro(MSG_UNIT_TESTS_RUN_SUCCESS);
Expand All @@ -70,9 +93,12 @@ fn nextest_is_installed(shell: &Shell) -> anyhow::Result<bool> {
Ok(out.contains("cargo-nextest"))
}

async fn reset_test_databases(shell: &Shell) -> anyhow::Result<()> {
async fn reset_test_databases(
shell: &Shell,
link_to_code: &Path,
dals: Vec<Dal>,
) -> anyhow::Result<()> {
logger::info(MSG_RESETTING_TEST_DATABASES);
let ecosystem = EcosystemConfig::from_file(shell)?;

Cmd::new(cmd!(
shell,
Expand All @@ -85,11 +111,11 @@ async fn reset_test_databases(shell: &Shell) -> anyhow::Result<()> {
))
.run()?;

for dal in get_test_dals(shell)? {
for dal in dals {
let mut url = dal.url.clone();
url.set_path("");
wait_for_db(&url, 3).await?;
database::reset::reset_database(shell, ecosystem.link_to_code.clone(), dal.clone()).await?;
database::reset::reset_database(shell, link_to_code, dal.clone()).await?;
}

Ok(())
Expand Down
55 changes: 2 additions & 53 deletions zk_toolbox/crates/zk_supervisor/src/dals.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
use std::str::FromStr;

use anyhow::{anyhow, Context};
use common::config::global_config;
use config::{EcosystemConfig, SecretsConfig};
Expand All @@ -11,8 +9,8 @@ use crate::{
messages::{MSG_CHAIN_NOT_FOUND_ERR, MSG_DATABASE_MUST_BE_PRESENTED},
};

const CORE_DAL_PATH: &str = "core/lib/dal";
const PROVER_DAL_PATH: &str = "prover/crates/lib/prover_dal";
pub const CORE_DAL_PATH: &str = "core/lib/dal";
pub const PROVER_DAL_PATH: &str = "prover/crates/lib/prover_dal";

#[derive(Debug, Clone)]
pub struct SelectedDals {
Expand Down Expand Up @@ -50,10 +48,6 @@ pub fn get_dals(
Ok(dals)
}

pub fn get_test_dals(shell: &Shell) -> anyhow::Result<Vec<Dal>> {
Ok(vec![get_test_prover_dal(shell)?, get_test_core_dal(shell)?])
}

pub fn get_prover_dal(shell: &Shell, url: Option<String>) -> anyhow::Result<Dal> {
let url = if let Some(url) = url {
Url::parse(&url)?
Expand Down Expand Up @@ -94,51 +88,6 @@ pub fn get_core_dal(shell: &Shell, url: Option<String>) -> anyhow::Result<Dal> {
})
}

pub fn get_test_core_dal(shell: &Shell) -> anyhow::Result<Dal> {
let general_config = get_general_config(shell)?;
let postgres = general_config
.postgres_config
.context(MSG_DATABASE_MUST_BE_PRESENTED)?;

let url = Url::from_str(
&postgres
.test_server_url
.clone()
.context(MSG_DATABASE_MUST_BE_PRESENTED)?,
)?;
Ok(Dal {
path: CORE_DAL_PATH.to_string(),
url,
})
}

pub fn get_test_prover_dal(shell: &Shell) -> anyhow::Result<Dal> {
let general_config = get_general_config(shell)?;
let postgres = general_config
.postgres_config
.context(MSG_DATABASE_MUST_BE_PRESENTED)?;

let url = Url::from_str(
&postgres
.test_prover_url
.clone()
.context(MSG_DATABASE_MUST_BE_PRESENTED)?,
)?;

Ok(Dal {
path: PROVER_DAL_PATH.to_string(),
url,
})
}

fn get_general_config(shell: &Shell) -> anyhow::Result<config::GeneralConfig> {
let ecosystem_config = EcosystemConfig::from_file(shell)?;
let chain_config = ecosystem_config
.load_chain(global_config().chain_name.clone())
.context(MSG_CHAIN_NOT_FOUND_ERR)?;
chain_config.get_general_config()
}

fn get_secrets(shell: &Shell) -> anyhow::Result<SecretsConfig> {
let ecosystem_config = EcosystemConfig::from_file(shell)?;
let chain_config = ecosystem_config
Expand Down
4 changes: 4 additions & 0 deletions zk_toolbox/crates/zk_supervisor/src/defaults.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
pub const TEST_DATABASE_SERVER_URL: &str =
"postgres://postgres:notsecurepassword@localhost:5433/zksync_local_test";
pub const TEST_DATABASE_PROVER_URL: &str =
"postgres://postgres:notsecurepassword@localhost:5433/prover_local_test";
1 change: 1 addition & 0 deletions zk_toolbox/crates/zk_supervisor/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ use crate::commands::{clean::CleanCommands, fmt::FmtArgs};

mod commands;
mod dals;
mod defaults;
mod messages;

#[derive(Parser, Debug)]
Expand Down
2 changes: 2 additions & 0 deletions zk_toolbox/crates/zk_supervisor/src/messages.rs
Original file line number Diff line number Diff line change
Expand Up @@ -112,10 +112,12 @@ pub(super) const MSG_CONTRACTS_DEPS_SPINNER: &str = "Installing dependencies..";
pub(super) const MSG_BUILDING_L2_CONTRACTS_SPINNER: &str = "Building L2 contracts..";
pub(super) const MSG_BUILDING_L1_CONTRACTS_SPINNER: &str = "Building L1 contracts..";
pub(super) const MSG_BUILDING_SYSTEM_CONTRACTS_SPINNER: &str = "Building system contracts..";
pub(super) const MSG_BUILDING_TEST_CONTRACTS_SPINNER: &str = "Building test contracts..";
pub(super) const MSG_BUILDING_CONTRACTS_SUCCESS: &str = "Contracts built successfully";
pub(super) const MSG_BUILD_L1_CONTRACTS_HELP: &str = "Build L1 contracts";
pub(super) const MSG_BUILD_L2_CONTRACTS_HELP: &str = "Build L2 contracts";
pub(super) const MSG_BUILD_SYSTEM_CONTRACTS_HELP: &str = "Build system contracts";
pub(super) const MSG_BUILD_TEST_CONTRACTS_HELP: &str = "Build test contracts";

// Integration tests related messages
pub(super) fn msg_integration_tests_run(external_node: bool) -> String {
Expand Down
Loading