From 04d07e1ffa384f64e521b3b2cefa255bf25c737c Mon Sep 17 00:00:00 2001 From: Dariusz Doktorski Date: Wed, 11 Dec 2024 21:43:34 +0100 Subject: [PATCH 1/3] Fix creating package with snfoundry test runner --- scarb/src/ops/new.rs | 10 +++++----- scarb/tests/snforge_init.rs | 18 +++++++++++++++--- 2 files changed, 20 insertions(+), 8 deletions(-) diff --git a/scarb/src/ops/new.rs b/scarb/src/ops/new.rs index 5aaa404ea..8589bf67b 100644 --- a/scarb/src/ops/new.rs +++ b/scarb/src/ops/new.rs @@ -217,12 +217,12 @@ fn mk( Ok(()) } -fn init_snforge(name: PackageName, target_dir: Utf8PathBuf, config: &Config) -> Result<()> { - let target_dir = target_dir.parent().context("package must have a parent")?; +fn init_snforge(name: PackageName, root_dir: Utf8PathBuf, config: &Config) -> Result<()> { let mut process = Command::new("snforge") - .arg("init") - .arg(name.as_str()) - .current_dir(target_dir) + .arg("new") + .args(["--name", name.as_str()]) + .arg("--overwrite") + .arg(root_dir.as_str()) .envs(get_env_vars(config, None)?) .stderr(Stdio::inherit()) .stdout(Stdio::inherit()) diff --git a/scarb/tests/snforge_init.rs b/scarb/tests/snforge_init.rs index 8e19310a3..5cf93b117 100644 --- a/scarb/tests/snforge_init.rs +++ b/scarb/tests/snforge_init.rs @@ -3,14 +3,23 @@ use assert_fs::TempDir; use scarb::core::TomlManifest; use scarb_test_support::command::Scarb; use scarb_test_support::fsx::AssertFsUtf8Ext; +use test_case::test_case; -#[test] +#[test_case(None)] +#[test_case(Some("simple_project"))] #[ignore = "run this test by name"] -fn new_simple() { +fn new_simple(package_name: Option<&str>) { let pt = TempDir::new().unwrap(); + let name_args = if let Some(package_name) = package_name { + vec!["--name", package_name] + } else { + vec![] + }; + Scarb::quick_snapbox() .arg("new") + .args(name_args) .arg("hello") .args(["--test-runner", "starknet-foundry"]) .current_dir(&pt) @@ -27,7 +36,10 @@ fn new_simple() { assert!(t.child(".git").is_dir()); let toml_manifest = TomlManifest::read_from_path(t.child("Scarb.toml").utf8_path()).unwrap(); - assert_eq!(toml_manifest.package.unwrap().name.as_str(), "hello"); + assert_eq!( + toml_manifest.package.unwrap().name.as_str(), + package_name.unwrap_or("hello") + ); let deps = toml_manifest.dependencies.unwrap(); assert_eq!(deps.len(), 1); assert!(deps.contains_key("starknet")); From d07f85e39a4f4372b4fa1665d31e62b9b63cefcd Mon Sep 17 00:00:00 2001 From: Dariusz Doktorski Date: Tue, 17 Dec 2024 12:59:00 +0100 Subject: [PATCH 2/3] Add snforge init test to CI workflow --- .github/workflows/ci.yml | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 5ed2eeab0..4c56b436a 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -108,3 +108,18 @@ jobs: cache-dependency-path: website/package-lock.json - run: npm ci - run: npm run fmt:check + + snforge-init: + runs-on: ${{ matrix.platform.os }} + strategy: + matrix: + platform: + - name: linux x86-64 + os: ubuntu-latest + - name: windows x86-64 + os: windows-latest + steps: + - uses: actions/checkout@v4 + - uses: dtolnay/rust-toolchain@stable + - uses: foundry-rs/setup-snfoundry@v3 + - run: cargo test --profile=ci --package scarb --test snforge_init new_simple -- --ignored From 8ced8d92ab5b62b4f0ce0b8097f5dba13a33ce6e Mon Sep 17 00:00:00 2001 From: Dariusz Doktorski Date: Tue, 17 Dec 2024 13:23:46 +0100 Subject: [PATCH 3/3] Run CI check only on ubuntu --- .github/workflows/ci.yml | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 4c56b436a..4e68a9f7d 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -110,14 +110,7 @@ jobs: - run: npm run fmt:check snforge-init: - runs-on: ${{ matrix.platform.os }} - strategy: - matrix: - platform: - - name: linux x86-64 - os: ubuntu-latest - - name: windows x86-64 - os: windows-latest + runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: dtolnay/rust-toolchain@stable