diff --git a/Cargo.lock b/Cargo.lock index d5bc54d8..512a3f78 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -418,6 +418,21 @@ dependencies = [ "nom", ] +[[package]] +name = "assert_cmd" +version = "2.0.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ed72493ac66d5804837f480ab3766c72bdfab91a65e565fc54fa9e42db0073a8" +dependencies = [ + "anstyle", + "bstr", + "doc-comment", + "predicates", + "predicates-core", + "predicates-tree", + "wait-timeout", +] + [[package]] name = "ast_node" version = "0.9.5" @@ -1057,6 +1072,17 @@ dependencies = [ "tinyvec", ] +[[package]] +name = "bstr" +version = "1.9.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "05efc5cfd9110c8416e471df0e96702d58690178e206e61b7173706673c93706" +dependencies = [ + "memchr", + "regex-automata 0.4.6", + "serde", +] + [[package]] name = "bumpalo" version = "3.15.4" @@ -2190,6 +2216,12 @@ dependencies = [ "syn 1.0.109", ] +[[package]] +name = "difflib" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6184e33543162437515c2e2b48714794e37845ec9851711914eec9d308f6ebe8" + [[package]] name = "digest" version = "0.8.1" @@ -2264,6 +2296,12 @@ dependencies = [ "syn 2.0.52", ] +[[package]] +name = "doc-comment" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fea41bba32d969b513997752735605054bc0dfa92b4c56bf1189f2e174be7a10" + [[package]] name = "docify" version = "0.2.7" @@ -2673,6 +2711,15 @@ dependencies = [ "miniz_oxide", ] +[[package]] +name = "float-cmp" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "98de4bbd547a563b716d8dfa9aad1cb19bfab00f4fa09a6a4ed21dbcf44ce9c4" +dependencies = [ + "num-traits", +] + [[package]] name = "fnv" version = "1.0.7" @@ -4649,6 +4696,12 @@ dependencies = [ "nom", ] +[[package]] +name = "normalize-line-endings" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "61807f77802ff30975e01f4f071c8ba10c022052f98b3294119f3e615d13e5be" + [[package]] name = "nu-ansi-term" version = "0.46.0" @@ -5365,6 +5418,7 @@ dependencies = [ "ansi_term", "anyhow", "askama", + "assert_cmd", "clap", "cliclack", "console", @@ -5376,6 +5430,7 @@ dependencies = [ "indexmap 2.2.5", "ink_env", "log", + "predicates", "reqwest", "serde", "serde_json", @@ -5414,6 +5469,36 @@ version = "0.2.17" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5b40af805b3121feab8a3c29f04d8ad262fa8e0561883e7653e024ae4479e6de" +[[package]] +name = "predicates" +version = "3.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "68b87bfd4605926cdfefc1c3b5f8fe560e3feca9d5552cf68c466d3d8236c7e8" +dependencies = [ + "anstyle", + "difflib", + "float-cmp", + "normalize-line-endings", + "predicates-core", + "regex", +] + +[[package]] +name = "predicates-core" +version = "1.0.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b794032607612e7abeb4db69adb4e33590fa6cf1149e95fd7cb00e634b92f174" + +[[package]] +name = "predicates-tree" +version = "1.0.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "368ba315fb8c5052ab692e68a0eefec6ec57b23a36959c14496f0b0df2c0cecf" +dependencies = [ + "predicates-core", + "termtree", +] + [[package]] name = "prettier-please" version = "0.2.0" @@ -8499,6 +8584,12 @@ dependencies = [ "winapi-util", ] +[[package]] +name = "termtree" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3369f5ac52d5eb6ab48c6b4ffdc8efbcad6b89c765749064ba298f2c68a16a76" + [[package]] name = "text_lines" version = "0.6.0" @@ -9359,6 +9450,15 @@ dependencies = [ "zeroize", ] +[[package]] +name = "wait-timeout" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9f200f5b12eb75f8c1ed65abd4b2db8a6e1b138a20de009dacee265a2498f3f6" +dependencies = [ + "libc", +] + [[package]] name = "waker-fn" version = "1.1.1" diff --git a/Cargo.toml b/Cargo.toml index 241cdb5c..211269c4 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -47,6 +47,10 @@ tracing-subscriber = { version = "0.3", optional = true } zombienet-sdk = { git = "https://github.com/r0gue-io/zombienet-sdk", branch = "pop", optional = true } zombienet-support = { git = "https://github.com/r0gue-io/zombienet-sdk", branch = "pop", optional = true } +[dev-dependencies] +assert_cmd = "2.0.14" +predicates = "3.1.0" + [features] default = ["contract", "parachain"] contract = [ diff --git a/src/commands/new/contract.rs b/src/commands/new/contract.rs index 4f08d5f4..1039817a 100644 --- a/src/commands/new/contract.rs +++ b/src/commands/new/contract.rs @@ -60,19 +60,26 @@ impl NewContractCommand { #[cfg(test)] mod tests { use super::*; - use std::fs; + use anyhow::Result; #[test] - fn test_new_contract_command_execute() -> anyhow::Result<()> { + fn test_new_contract_command_execute_success() -> Result<()> { + let temp_contract_dir = tempfile::tempdir().expect("Could not create temp dir"); let command = - NewContractCommand { name: "test_contract".to_string(), path: Some(PathBuf::new()) }; + NewContractCommand { name: "test_contract".to_string(), path: Some(PathBuf::from(temp_contract_dir.path())) }; let result = command.execute(); assert!(result.is_ok()); - // Clean up - if let Err(err) = fs::remove_dir_all("test_contract") { - eprintln!("Failed to delete directory: {}", err); - } + Ok(()) + } + + #[test] + fn test_new_contract_command_execute_fails_path_no_exist() -> Result<()> { + let temp_contract_dir = tempfile::tempdir().expect("Could not create temp dir"); + let command = + NewContractCommand { name: "test_contract".to_string(), path: Some(temp_contract_dir.path().join("new_contract")) }; + let result_error = command.execute(); + assert!(result_error.is_err()); Ok(()) } } diff --git a/src/engines/contract_engine.rs b/src/engines/contract_engine.rs index 0f20bbe2..d6f53ba2 100644 --- a/src/engines/contract_engine.rs +++ b/src/engines/contract_engine.rs @@ -203,6 +203,23 @@ mod tests { Ok(()) } + #[test] + fn test_contract_build() -> Result<(), Error> { + let temp_contract_dir = setup_test_environment()?; + + let build = build_smart_contract(&Some(temp_contract_dir.path().join("test_contract"))); + assert!(build.is_ok(), "Result should be Ok"); + + // Verify that the folder target has been created + assert!(temp_contract_dir.path().join("test_contract/target").exists()); + // Verify that all the artifacts has been generated + assert!(temp_contract_dir.path().join("test_contract/target/ink/test_contract.contract").exists()); + assert!(temp_contract_dir.path().join("test_contract/target/ink/test_contract.wasm").exists()); + assert!(temp_contract_dir.path().join("test_contract/target/ink/test_contract.json").exists()); + + Ok(()) + } + #[test] fn test_contract_test() -> Result<(), Error> { let temp_contract_dir = setup_test_environment()?; diff --git a/tests/build_contract.rs b/tests/build_contract.rs new file mode 100644 index 00000000..8e34dcca --- /dev/null +++ b/tests/build_contract.rs @@ -0,0 +1,74 @@ +use assert_cmd::Command; +use predicates::prelude::*; +use anyhow::{Result, Error}; + +fn setup_test_environment() -> Result { + let temp_contract_dir = tempfile::tempdir().unwrap(); + // pop new contract test_contract + Command::cargo_bin("pop") + .unwrap() + .current_dir(&temp_contract_dir) + .args(&["new", "contract", "test_contract"]) + .assert() + .success(); + + Ok(temp_contract_dir) +} + +#[test] +fn test_contract_build() -> Result<(), Error> { + let temp_contract_dir = setup_test_environment()?; + + // pop build contract + Command::cargo_bin("pop") + .unwrap() + .current_dir(&temp_contract_dir.path().join("test_contract")) + .args(&["build", "contract"]) + .assert() + .success(); + + // Verify that the folder target has been created + assert!(temp_contract_dir.path().join("test_contract/target").exists()); + // Verify that all the artifacts has been generated + assert!(temp_contract_dir.path().join("test_contract/target/ink/test_contract.contract").exists()); + assert!(temp_contract_dir.path().join("test_contract/target/ink/test_contract.wasm").exists()); + assert!(temp_contract_dir.path().join("test_contract/target/ink/test_contract.json").exists()); + + Ok(()) +} + +#[test] +fn test_contract_build_specify_path() -> Result<(), Error> { + let temp_contract_dir = setup_test_environment()?; + + // pop build contract --path ./test_contract + Command::cargo_bin("pop") + .unwrap() + .current_dir(&temp_contract_dir.path()) + .args(&["build", "contract", "--path", "./test_contract"]) + .assert() + .success(); + + // Verify that the folder target has been created + assert!(temp_contract_dir.path().join("test_contract/target").exists()); + // Verify that all the artifacts has been generated + assert!(temp_contract_dir.path().join("test_contract/target/ink/test_contract.contract").exists()); + assert!(temp_contract_dir.path().join("test_contract/target/ink/test_contract.wasm").exists()); + assert!(temp_contract_dir.path().join("test_contract/target/ink/test_contract.json").exists()); + + Ok(()) +} + +#[test] +fn test_contract_build_fails_if_no_contract_exists() -> Result<(), Error> { + + // pop build contract + Command::cargo_bin("pop") + .unwrap() + .args(&["build", "contract",]) + .assert() + .failure() + .stderr(predicate::str::contains("Error: No 'ink' dependency found")); + + Ok(()) +}