aboutsummaryrefslogtreecommitdiffhomepage
path: root/crates/mozart/tests/cli_show.rs
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2026-02-21 20:54:29 +0900
committernsfisis <nsfisis@gmail.com>2026-02-21 20:54:29 +0900
commite40ae3649d62a933211e81d8ac773fdd86ff1dfb (patch)
tree22713882537531c2b0f0a55248045d9f280ce3fe /crates/mozart/tests/cli_show.rs
parent3c8ce2b72daccccc88278b8dfbff1a1acc39096c (diff)
downloadphp-mozart-e40ae3649d62a933211e81d8ac773fdd86ff1dfb.tar.gz
php-mozart-e40ae3649d62a933211e81d8ac773fdd86ff1dfb.tar.zst
php-mozart-e40ae3649d62a933211e81d8ac773fdd86ff1dfb.zip
test(cli): add end-to-end integration tests for CLI commands
Add 23 integration tests using assert_cmd and predicates covering about, validate, show, licenses, install, config, init, and dump-autoload commands with shared test helpers and fixture projects. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
Diffstat (limited to 'crates/mozart/tests/cli_show.rs')
-rw-r--r--crates/mozart/tests/cli_show.rs65
1 files changed, 65 insertions, 0 deletions
diff --git a/crates/mozart/tests/cli_show.rs b/crates/mozart/tests/cli_show.rs
new file mode 100644
index 0000000..0ecb588
--- /dev/null
+++ b/crates/mozart/tests/cli_show.rs
@@ -0,0 +1,65 @@
+mod common;
+
+use predicates::str::contains;
+
+#[test]
+fn test_show_locked_packages() {
+ let project = common::copy_fixture_to_temp("with_lock");
+ common::mozart_cmd()
+ .arg("show")
+ .arg("--locked")
+ .arg("--working-dir")
+ .arg(project.path())
+ .assert()
+ .success()
+ .stdout(contains("psr/log"));
+}
+
+#[test]
+fn test_show_self() {
+ let project = common::copy_fixture_to_temp("with_lock");
+ common::mozart_cmd()
+ .arg("show")
+ .arg("--self-info")
+ .arg("--working-dir")
+ .arg(project.path())
+ .assert()
+ .success()
+ .stdout(contains("test/locked-project"));
+}
+
+#[test]
+fn test_show_name_only() {
+ let project = common::copy_fixture_to_temp("with_lock");
+ common::mozart_cmd()
+ .arg("show")
+ .arg("--name-only")
+ .arg("--locked")
+ .arg("--working-dir")
+ .arg(project.path())
+ .assert()
+ .success()
+ .stdout(contains("psr/log"));
+}
+
+#[test]
+fn test_show_format_json() {
+ let project = common::copy_fixture_to_temp("with_lock");
+ let output = common::mozart_cmd()
+ .arg("show")
+ .arg("--format=json")
+ .arg("--locked")
+ .arg("--working-dir")
+ .arg(project.path())
+ .assert()
+ .success()
+ .get_output()
+ .stdout
+ .clone();
+
+ let stdout = String::from_utf8_lossy(&output);
+ // Output should be parseable JSON
+ let parsed: serde_json::Value =
+ serde_json::from_str(&stdout).expect("show --format=json output should be valid JSON");
+ assert!(parsed.is_array() || parsed.is_object());
+}