[INFO] cloning repository https://github.com/agiletec-inc/airis-workspace [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/agiletec-inc/airis-workspace" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fagiletec-inc%2Fairis-workspace", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fagiletec-inc%2Fairis-workspace'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 3d25932c2759b29114485af61f4d1214accacf4f [INFO] testing agiletec-inc/airis-workspace against 1.95.0 for beta-1.96-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fagiletec-inc%2Fairis-workspace" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'... [INFO] [stderr] done. [INFO] removed /workspace/builds/worker-0-tc1/source/.cargo/config.toml [INFO] started tweaking git repo https://github.com/agiletec-inc/airis-workspace [INFO] finished tweaking git repo https://github.com/agiletec-inc/airis-workspace [INFO] tweaked toml for git repo https://github.com/agiletec-inc/airis-workspace written to /workspace/builds/worker-0-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/agiletec-inc/airis-workspace on toolchain 1.95.0 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/agiletec-inc/airis-workspace already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded utf8-zero v0.8.1 [INFO] [stderr] Downloaded cookie_store v0.22.1 [INFO] [stderr] Downloaded unit-prefix v0.5.2 [INFO] [stderr] Downloaded predicates-tree v1.0.13 [INFO] [stderr] Downloaded supports-hyperlinks v3.2.0 [INFO] [stderr] Downloaded dialoguer v0.12.0 [INFO] [stderr] Downloaded assert_cmd v2.2.0 [INFO] [stderr] Downloaded colored v3.1.1 [INFO] [stderr] Downloaded clap_complete v4.6.2 [INFO] [stderr] Downloaded indicatif v0.18.4 [INFO] [stderr] Downloaded miette v7.6.0 [INFO] [stderr] Downloaded serde_yml v0.0.12 [INFO] [stderr] Downloaded libyml v0.0.5 [INFO] [stderr] Downloaded ureq v3.3.0 [INFO] [stderr] Downloaded textwrap v0.16.2 [INFO] [stderr] Downloaded blake3 v1.8.4 [INFO] [stderr] Downloaded ureq-proto v0.6.0 [INFO] [stderr] Downloaded console v0.16.3 [INFO] [stderr] Downloaded owo-colors v4.3.0 [INFO] [stderr] Downloaded predicates v3.1.4 [INFO] [stderr] Downloaded miette-derive v7.6.0 [INFO] [stderr] Downloaded fastrand v2.4.0 [INFO] [stderr] Downloaded backtrace-ext v0.2.1 [INFO] [stderr] Downloaded float-cmp v0.10.0 [INFO] [stderr] Downloaded supports-unicode v3.0.0 [INFO] [stderr] Downloaded terminal_size v0.4.4 [INFO] [stderr] Downloaded difflib v0.4.0 [INFO] [stderr] Downloaded predicates-core v1.0.10 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 87a64c90a1d05151401bbf70de0890c7cf6aa4dbd314416ae533feda5cf4b6c8 [INFO] running `Command { std: "docker" "start" "-a" "87a64c90a1d05151401bbf70de0890c7cf6aa4dbd314416ae533feda5cf4b6c8", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "87a64c90a1d05151401bbf70de0890c7cf6aa4dbd314416ae533feda5cf4b6c8", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "87a64c90a1d05151401bbf70de0890c7cf6aa4dbd314416ae533feda5cf4b6c8", kill_on_drop: false }` [INFO] [stdout] 87a64c90a1d05151401bbf70de0890c7cf6aa4dbd314416ae533feda5cf4b6c8 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 597500305fd429146fe9680b103baf4d3145d1cc864d112ed6a0e675740f4ee4 [INFO] running `Command { std: "docker" "start" "-a" "597500305fd429146fe9680b103baf4d3145d1cc864d112ed6a0e675740f4ee4", kill_on_drop: false }` [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling find-msvc-tools v0.1.9 [INFO] [stderr] Compiling rustix v1.1.4 [INFO] [stderr] Compiling adler2 v2.0.1 [INFO] [stderr] Compiling simd-adler32 v0.3.9 [INFO] [stderr] Compiling zeroize v1.8.2 [INFO] [stderr] Compiling linux-raw-sys v0.12.1 [INFO] [stderr] Compiling itoa v1.0.18 [INFO] [stderr] Compiling unicode-width v0.2.2 [INFO] [stderr] Compiling log v0.4.29 [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling object v0.37.3 [INFO] [stderr] Compiling indexmap v2.13.1 [INFO] [stderr] Compiling anstyle-parse v1.0.0 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling cc v1.2.59 [INFO] [stderr] Compiling rustls-pki-types v1.14.0 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling gimli v0.32.3 [INFO] [stderr] Compiling colorchoice v1.0.5 [INFO] [stderr] Compiling regex-syntax v0.8.10 [INFO] [stderr] Compiling anstyle v1.0.14 [INFO] [stderr] Compiling untrusted v0.9.0 [INFO] [stderr] Compiling httparse v1.10.1 [INFO] [stderr] Compiling getrandom v0.4.2 [INFO] [stderr] Compiling zmij v1.0.21 [INFO] [stderr] Compiling once_cell v1.21.4 [INFO] [stderr] Compiling anstream v1.0.0 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling rustls v0.23.37 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling rustc-demangle v0.1.27 [INFO] [stderr] Compiling clap_lex v1.1.0 [INFO] [stderr] Compiling owo-colors v4.3.0 [INFO] [stderr] Compiling portable-atomic v1.13.1 [INFO] [stderr] Compiling serde_yml v0.0.12 [INFO] [stderr] Compiling clap_builder v4.6.0 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling bstr v1.12.1 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling console v0.16.3 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling fastrand v2.4.0 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling unicode-linebreak v0.1.5 [INFO] [stderr] Compiling winnow v1.0.1 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling blake3 v1.8.4 [INFO] [stderr] Compiling textwrap v0.16.2 [INFO] [stderr] Compiling walkdir v2.5.0 [INFO] [stderr] Compiling ureq-proto v0.6.0 [INFO] [stderr] Compiling toml_parser v1.1.2+spec-1.1.0 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling libyml v0.0.5 [INFO] [stderr] Compiling flate2 v1.1.9 [INFO] [stderr] Compiling crossbeam-deque v0.8.6 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling terminal_size v0.4.4 [INFO] [stderr] Compiling tempfile v3.27.0 [INFO] [stderr] Compiling webpki-roots v1.0.6 [INFO] [stderr] Compiling toml_datetime v1.1.1+spec-1.1.0 [INFO] [stderr] Compiling serde_spanned v1.1.1 [INFO] [stderr] Compiling airis-workspace v3.3.3 (/opt/rustwide/workdir) [INFO] [stderr] Compiling toml_writer v1.1.1+spec-1.1.0 [INFO] [stderr] Compiling utf8-zero v0.8.1 [INFO] [stderr] Compiling shell-words v1.1.1 [INFO] [stderr] Compiling supports-hyperlinks v3.2.0 [INFO] [stderr] Compiling cpufeatures v0.3.0 [INFO] [stderr] Compiling arrayvec v0.7.6 [INFO] [stderr] Compiling unicode-width v0.1.14 [INFO] [stderr] Compiling unit-prefix v0.5.2 [INFO] [stderr] Compiling supports-unicode v3.0.0 [INFO] [stderr] Compiling constant_time_eq v0.4.2 [INFO] [stderr] Compiling iana-time-zone v0.1.65 [INFO] [stderr] Compiling ryu v1.0.23 [INFO] [stderr] Compiling arrayref v0.3.9 [INFO] [stderr] Compiling chrono v0.4.44 [INFO] [stderr] Compiling indicatif v0.18.4 [INFO] [stderr] Compiling dialoguer v0.12.0 [INFO] [stderr] Compiling toml v1.1.2+spec-1.1.0 [INFO] [stderr] Compiling dirs v6.0.0 [INFO] [stderr] Compiling colored v3.1.1 [INFO] [stderr] Compiling glob v0.3.3 [INFO] [stderr] Compiling addr2line v0.25.1 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling clap_derive v4.6.0 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling miette-derive v7.6.0 [INFO] [stderr] Compiling tokio-macros v2.7.0 [INFO] [stderr] Compiling globset v0.4.18 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling backtrace v0.3.76 [INFO] [stderr] Compiling tokio v1.51.0 [INFO] [stderr] Compiling ignore v0.4.25 [INFO] [stderr] Compiling rustls-webpki v0.103.10 [INFO] [stderr] Compiling backtrace-ext v0.2.1 [INFO] [stderr] Compiling miette v7.6.0 [INFO] [stderr] Compiling clap v4.6.0 [INFO] [stderr] Compiling clap_complete v4.6.2 [INFO] [stderr] Compiling ureq v3.3.0 [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 22s [INFO] running `Command { std: "docker" "inspect" "597500305fd429146fe9680b103baf4d3145d1cc864d112ed6a0e675740f4ee4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "597500305fd429146fe9680b103baf4d3145d1cc864d112ed6a0e675740f4ee4", kill_on_drop: false }` [INFO] [stdout] 597500305fd429146fe9680b103baf4d3145d1cc864d112ed6a0e675740f4ee4 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] ab7f848762251f1a9d03d1ca9246f9b0e24ab4e1281958a8711b851eb7062c9e [INFO] running `Command { std: "docker" "start" "-a" "ab7f848762251f1a9d03d1ca9246f9b0e24ab4e1281958a8711b851eb7062c9e", kill_on_drop: false }` [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling predicates-core v1.0.10 [INFO] [stderr] Compiling float-cmp v0.10.0 [INFO] [stderr] Compiling difflib v0.4.0 [INFO] [stderr] Compiling normalize-line-endings v0.3.0 [INFO] [stderr] Compiling assert_cmd v2.2.0 [INFO] [stderr] Compiling termtree v0.5.1 [INFO] [stderr] Compiling wait-timeout v0.2.1 [INFO] [stderr] Compiling predicates-tree v1.0.13 [INFO] [stderr] Compiling bstr v1.12.1 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling predicates v3.1.4 [INFO] [stderr] Compiling globset v0.4.18 [INFO] [stderr] Compiling ignore v0.4.25 [INFO] [stderr] Compiling airis-workspace v3.3.3 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `super::*` [INFO] [stdout] --> src/commands/guards/tests.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use super::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs` [INFO] [stdout] --> src/commands/guards/tests.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::fs; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 44.96s [INFO] running `Command { std: "docker" "inspect" "ab7f848762251f1a9d03d1ca9246f9b0e24ab4e1281958a8711b851eb7062c9e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ab7f848762251f1a9d03d1ca9246f9b0e24ab4e1281958a8711b851eb7062c9e", kill_on_drop: false }` [INFO] [stdout] ab7f848762251f1a9d03d1ca9246f9b0e24ab4e1281958a8711b851eb7062c9e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 7816052ca8b262708303544ccab69809d5fff69601d7105cbc13ec6019decfc5 [INFO] running `Command { std: "docker" "start" "-a" "7816052ca8b262708303544ccab69809d5fff69601d7105cbc13ec6019decfc5", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `super::*` [INFO] [stderr] --> src/commands/guards/tests.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use super::*; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fs` [INFO] [stderr] --> src/commands/guards/tests.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::fs; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `airis-workspace` (lib test) generated 2 warnings (run `cargo fix --lib -p airis-workspace --tests` to apply 2 suggestions) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.35s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/airis_workspace-661c41bccb51905d) [INFO] [stdout] [INFO] [stdout] running 314 tests [INFO] [stdout] test commands::bump_version::tests::test_breaking_marker_only_matches_subject ... ok [INFO] [stdout] test commands::bump_version::tests::test_bump_version_string ... ok [INFO] [stdout] test commands::affected::tests::test_get_package_from_path ... ok [INFO] [stdout] test channel::tests::test_parse_channel ... ok [INFO] [stdout] test commands::bump_version::tests::test_scoped_breaking_marker ... ok [INFO] [stdout] test commands::bundle::tests::test_bundle_metadata_serialization ... ok [INFO] [stdout] test commands::bump_version::tests::test_strip_commit_comments ... ok [INFO] [stdout] test commands::bundle::tests::test_generate_deployment_yaml ... ok [INFO] [stdout] test commands::bundle::tests::test_generate_deployment_yaml_defaults ... ok [INFO] [stdout] test commands::bundle::tests::test_generate_service_yaml ... ok [INFO] [stdout] test commands::bundle::tests::test_generate_service_yaml_default_port ... ok [INFO] [stdout] test commands::claude_setup::tests::test_initialize_source_dir ... ok [INFO] [stdout] test commands::claude_setup::tests::test_check_plugin_installed_detects_presence ... ok [INFO] [stdout] test commands::bump_version::tests::test_conventional_commits_detection ... ok [INFO] [stdout] test commands::bundle::tests::test_format_size ... ok [INFO] [stdout] test commands::bundle::tests::test_detect_artifact_dirs_with_dist ... ok [INFO] [stdout] test commands::bundle::tests::test_detect_artifact_dirs_empty ... ok [INFO] [stdout] test commands::claude_setup::tests::test_is_legacy_airis_entry ... ok [INFO] [stdout] test commands::claude_setup::tests::test_remove_legacy_airis_entries_preserves_others ... ok [INFO] [stdout] test commands::claude_setup::tests::test_registry_load_save_roundtrip ... ok [INFO] [stdout] test commands::claude_setup::tests::test_sync_managed_dir_creates_files ... ok [INFO] [stdout] test commands::claude_setup::tests::test_sync_from_source_preserves_non_airis_files ... ok [INFO] [stdout] test commands::claude_setup::tests::test_sync_from_source_basic ... ok [INFO] [stdout] test commands::claude_setup::tests::test_sync_managed_dir_skips_unchanged ... ok [INFO] [stdout] test commands::clean::tests::project_root_rejected_when_no_marker_present ... ok [INFO] [stdout] test commands::clean::tests::test_protected_paths ... ok [INFO] [stdout] test commands::deps::tests::test_detect_cycles_no_cycle ... ok [INFO] [stdout] test commands::deps::tests::test_detect_cycles_with_cycle ... ok [INFO] [stdout] test commands::deps::tests::test_check_architecture_violation ... ok [INFO] [stdout] test commands::clean::tests::project_root_detected_for_each_marker ... ok [INFO] [stdout] test commands::diff::tests::test_compute_unified_diff_no_changes ... ok [INFO] [stdout] test commands::claude_setup::tests::test_sync_single_file_creates_and_overwrites ... ok [INFO] [stdout] test commands::diff::tests::test_compute_unified_diff_with_changes ... ok [INFO] [stdout] test commands::diff::tests::test_file_status_serialize ... ok [INFO] [stdout] test commands::deps::tests::test_build_dependents_map ... ok [INFO] [stdout] test commands::diff::tests::test_format_new_file_diff ... ok [INFO] [stdout] test commands::deps::tests::test_check_architecture_valid ... ok [INFO] [stdout] test commands::discover::tests::test_detect_framework_hono ... ok [INFO] [stdout] test commands::claude_setup::tests::test_sync_managed_dir_deletes_orphans ... ok [INFO] [stdout] test commands::discover::tests::test_detect_framework_python ... ok [INFO] [stdout] test commands::discover::tests::test_detect_framework_rust ... ok [INFO] [stdout] test commands::claude_setup::tests::test_sync_from_source_orphan_removal ... ok [INFO] [stdout] test commands::discover::tests::test_extract_package_info_basic ... ok [INFO] [stdout] test commands::discover::tests::test_detect_framework_unknown ... ok [INFO] [stdout] test commands::discover::tests::test_extract_package_info_skips_workspace_refs ... ok [INFO] [stdout] test commands::discover::tests::test_extract_catalog ... ok [INFO] [stdout] test commands::discover::tests::test_discover_from_workspaces_excludes_negated ... ok [INFO] [stdout] test commands::discover::tests::test_discover_from_workspaces_basic ... ok [INFO] [stdout] test commands::discover::tests::test_discover_from_workspaces_nested_products ... ok [INFO] [stdout] test commands::discover::tests::test_detect_framework_node_fallback ... ok [INFO] [stdout] test commands::clean::tests::default_manifest_provides_canonical_clean_lists ... ok [INFO] [stdout] test commands::docs::tests::render_gemini_uses_imports ... ok [INFO] [stdout] test commands::discover::tests::test_detect_framework_vite ... ok [INFO] [stdout] test commands::discover::tests::test_extract_package_info_with_catalog_conversion ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_forbidden_renders_mock_rule ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_empty_when_all_defaults_with_allowed ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_injected_into_agents_md ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_injected_into_claude_md ... ok [INFO] [stdout] test commands::discover::tests::test_detect_framework_nextjs ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_injected_into_gemini_md ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_not_in_claude_md_when_all_defaults_allowed ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_renders_coverage_targets ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_renders_custom_ai_rules ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_renders_forbidden_patterns ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_renders_type_enforcement ... ok [INFO] [stdout] test commands::docs::tests::testing_policy_unit_only_renders_mock_rule ... ok [INFO] [stdout] test commands::doctor::tests::test_artifact_severity_build_outputs_are_warnings ... ok [INFO] [stdout] test commands::doctor::tests::test_artifact_severity_dependencies_are_errors ... ok [INFO] [stdout] test commands::doctor::tests::test_issue_severity ... ok [INFO] [stdout] test commands::generate::tests::test_matches_wildcard_catalog_hit ... ok [INFO] [stdout] test commands::generate::tests::test_matches_wildcard_catalog_miss ... ok [INFO] [stdout] test commands::generate::tests::test_load_generation_registry ... ok [INFO] [stdout] test commands::generate::tests::test_load_generation_registry_missing_file ... ok [INFO] [stdout] test commands::generate::tests::test_detect_ts_major_default ... ok [INFO] [stdout] test commands::generate::tests::test_matches_wildcard_catalog_empty ... ok [INFO] [stdout] test commands::generate::tests::test_wildcard_matches_exact ... ok [INFO] [stdout] test commands::generate::tests::test_wildcard_matches_prefix ... ok [INFO] [stdout] test commands::generate::tests::test_detect_ts_major_from_catalog_tilde ... ok [INFO] [stdout] test commands::generate::tests::test_detect_ts_major_from_catalog ... ok [INFO] [stdout] test commands::generate::tests::test_wildcard_matches_star_only ... ok [INFO] [stdout] test commands::guards::tests::test_global_config_default ... ok [INFO] [stdout] test commands::guards::tests::test_global_config_paths ... ok [INFO] [stdout] test commands::generate::tests::test_detect_ts_major_explicit_override ... ok [INFO] [stdout] test commands::guards::tests::test_global_config_serialization ... ok [INFO] [stdout] test commands::discover::tests::test_get_package_name ... ok [INFO] [stdout] test commands::generate::tests::test_save_generation_registry_deduplicates_and_sorts ... ok [INFO] [stdout] test commands::manifest_cmd::tests::test_workspace_truth_compose_files ... ok [INFO] [stdout] test commands::migrate::tests::test_dry_run_does_not_create_files ... ok [INFO] [stdout] test commands::migrate::tests::test_execute_creates_manifest ... ok [INFO] [stdout] test commands::manifest_cmd::tests::test_workspace_truth_recommended_commands ... ok [INFO] [stdout] test commands::migrate::tests::test_generate_manifest_content ... ok [INFO] [stdout] test commands::migrate::tests::test_plan_always_includes_generate_manifest ... ok [INFO] [stdout] test commands::manifest_cmd::tests::test_workspace_truth_serialization ... ok [INFO] [stdout] test commands::migrate::tests::test_plan_does_not_move_root_compose ... ok [INFO] [stdout] test commands::network::tests::test_default_networks ... ok [INFO] [stdout] test commands::new_cmd::tests::test_empty_name_rejected ... ok [INFO] [stdout] test commands::new_cmd::tests::test_generate_lib_project ... ok [INFO] [stdout] test commands::new_cmd::tests::test_generate_py_lib ... ok [INFO] [stdout] test commands::new_cmd::tests::test_generate_py_api ... ok [INFO] [stdout] test commands::new_cmd::tests::test_generate_rust_service ... ok [INFO] [stdout] test commands::new_cmd::tests::test_get_base_dir ... ok [INFO] [stdout] test commands::new_cmd::tests::test_invalid_name_rejected ... ok [INFO] [stdout] test commands::policy::tests::test_banned_env_vars_clean_code_passes ... ok [INFO] [stdout] test commands::policy::tests::test_banned_env_vars_detects_violation ... ok [INFO] [stdout] test commands::policy::tests::test_banned_env_vars_skips_allowed_paths ... ok [INFO] [stdout] test commands::policy::tests::test_forbidden_files_check ... ok [INFO] [stdout] test commands::policy::tests::test_mock_pattern_clean_test_passes ... ok [INFO] [stdout] test commands::policy::tests::test_policy_config_default ... ok [INFO] [stdout] test commands::policy::tests::test_mock_pattern_detects_violation ... ok [INFO] [stdout] test commands::new_cmd::tests::test_generate_api_project ... ok [INFO] [stdout] test commands::policy::tests::test_mock_pattern_ignores_non_test_files ... ok [INFO] [stdout] test commands::policy::tests::test_required_env_missing ... ok [INFO] [stdout] test commands::run::tests::test_build_clean_command_filters_unsafe ... ok [INFO] [stdout] test commands::policy::tests::test_policy_template ... ok [INFO] [stdout] test commands::run::tests::test_build_compose_command_no_compose_file_errors ... ok [INFO] [stdout] test commands::run::tests::test_condense_status_hours ... ok [INFO] [stdout] test commands::run::tests::test_build_compose_command_with_compose_file_succeeds ... ok [INFO] [stdout] test commands::run::tests::test_condense_status_minutes ... ok [INFO] [stdout] test commands::run::tests::test_condense_status_other ... ok [INFO] [stdout] test commands::run::tests::test_build_compose_command_with_orchestration_succeeds ... ok [INFO] [stdout] test commands::policy::tests::test_type_enforcement_skips_non_db_tests ... ok [INFO] [stdout] test commands::run::tests::test_condense_status_passthrough ... ok [INFO] [stdout] test commands::policy::tests::test_type_enforcement_passes_with_import ... ok [INFO] [stdout] test commands::run::tests::test_default_commands_uses_package_manager ... ok [INFO] [stdout] test commands::run::tests::test_dev_section_post_up_default_empty ... ok [INFO] [stdout] test commands::policy::tests::test_severity_enum ... ok [INFO] [stdout] test commands::run::tests::test_extract_host_port_env_var_default ... ok [INFO] [stdout] test commands::run::tests::test_ensure_env_file_copies_example ... ok [INFO] [stdout] test commands::run::tests::test_extract_host_port_fallback_to_port_field ... ok [INFO] [stdout] test commands::run::tests::test_extract_host_port_no_ports ... ok [INFO] [stdout] test commands::run::tests::test_ensure_env_file_noop_when_env_exists ... ok [INFO] [stdout] test commands::run::tests::test_get_package_manager_bun ... ok [INFO] [stdout] test commands::run::tests::test_extract_host_port_plain_number ... ok [INFO] [stdout] test commands::docs::tests::sync_generates_configured_vendor_adapters ... ok [INFO] [stdout] test commands::run::tests::test_dev_section_post_up_with_hooks ... ok [INFO] [stdout] test commands::run::tests::test_ensure_env_file_noop_when_no_example ... ok [INFO] [stdout] test commands::run::tests::test_get_package_manager_default ... ok [INFO] [stdout] test commands::run::tests::test_get_package_manager_npm ... ok [INFO] [stdout] test commands::run::tests::test_get_package_manager_yarn ... ok [INFO] [stdout] test commands::run::tests::test_extra_args_blocks_command_substitution ... ok [INFO] [stdout] test commands::run::tests::test_hooks_section_parses_from_toml ... ok [INFO] [stdout] test commands::policy::tests::test_type_enforcement_detects_missing_import ... ok [INFO] [stdout] test commands::run::tests::test_manifest_commands_override_defaults ... ok [INFO] [stdout] test commands::run::tests::test_hash_file_deterministic ... ok [INFO] [stdout] test commands::run::tests::test_extra_args_blocks_shell_injection_pipe ... ok [INFO] [stdout] test commands::run::tests::test_extra_args_blocks_shell_injection_semicolon ... ok [INFO] [stdout] test commands::run::tests::test_manifest_can_add_custom_commands ... ok [INFO] [stdout] test commands::run::tests::test_manifest_dev_urls_parsing ... ok [INFO] [stdout] test commands::run::tests::test_parse_service_ports_no_ports ... ok [INFO] [stdout] test commands::run::tests::test_hash_file_changes_with_content ... ok [INFO] [stdout] test commands::run::tests::test_parse_service_ports_object_format ... ok [INFO] [stdout] test commands::run::tests::test_parse_service_ports_empty_services ... ok [INFO] [stdout] test commands::run::tests::test_get_package_manager_pnpm ... ok [INFO] [stdout] test commands::run::tests::test_pre_command_hooks_default_is_none ... ok [INFO] [stdout] test commands::run::tests::test_remap_case_insensitive ... ok [INFO] [stdout] test commands::run::tests::test_remap_empty_table ... ok [INFO] [stdout] test commands::run::tests::test_remap_no_partial_word_match ... ok [INFO] [stdout] test commands::run::tests::test_remap_no_match ... ok [INFO] [stdout] test commands::run::tests::test_remap_prefix_match ... ok [INFO] [stdout] test commands::run::tests::test_validate_clean_path_rejects_absolute ... ok [INFO] [stdout] test commands::policy::tests::test_mock_pattern_multiple_patterns ... ok [INFO] [stdout] test commands::run::tests::test_run_missing_command ... ok [INFO] [stdout] test commands::run::tests::test_remap_exact_match ... ok [INFO] [stdout] test commands::run::tests::test_parse_service_ports_string_format ... ok [INFO] [stdout] test commands::run::tests::test_run_missing_manifest_and_compose ... ok [INFO] [stdout] test commands::run::tests::test_parse_service_ports_skips_zero_port ... ok [INFO] [stdout] test commands::run::tests::test_validate_clean_path_rejects_shell_chars ... ok [INFO] [stdout] test commands::run::tests::test_validate_clean_path_rejects_traversal ... ok [INFO] [stdout] test commands::run::tests::test_validate_clean_path_safe_paths ... ok [INFO] [stdout] test commands::run::tests::test_validate_clean_pattern_rejects_paths ... ok [INFO] [stdout] test commands::run::tests::test_validate_clean_pattern_rejects_shell_injection ... ok [INFO] [stdout] test commands::upgrade::tests::test_detect_platform ... ok [INFO] [stdout] test commands::upgrade::tests::test_version_gt ... ok [INFO] [stdout] test conventions::tests::test_name_from_path ... ok [INFO] [stdout] test conventions::tests::test_hono_defaults ... ok [INFO] [stdout] test conventions::tests::test_nextjs_defaults ... ok [INFO] [stdout] test conventions::tests::test_cloudflare_worker_defaults ... ok [INFO] [stdout] test conventions::tests::test_nextjs_has_watchpack_polling ... ok [INFO] [stdout] test conventions::tests::test_parse_node_version_from_image ... ok [INFO] [stdout] test conventions::tests::test_python_defaults ... ok [INFO] [stdout] test conventions::tests::test_node_version_to_es_target ... ok [INFO] [stdout] test conventions::tests::test_unknown_framework_has_sensible_defaults ... ok [INFO] [stdout] test commands::run::tests::test_validate_clean_pattern_safe_patterns ... ok [INFO] [stdout] test dag::tests::test_topo_order ... ok [INFO] [stdout] test conventions::tests::test_vite_has_chokidar_polling ... ok [INFO] [stdout] test docker_build::tests::test_cache_dir_structure ... ok [INFO] [stdout] test docker_build::tests::test_detect_nextjs_no_package_json ... ok [INFO] [stdout] test docker_build::tests::test_cache_hit_miss ... ok [INFO] [stdout] test docker_build::tests::test_build_config_default ... ok [INFO] [stdout] test docker_build::tests::test_compute_hash_deterministic ... ok [INFO] [stdout] test docker_build::tests::test_compute_hash_changes_with_content ... ok [INFO] [stdout] test docker_build::tests::test_generate_nextjs_dockerfile ... ok [INFO] [stdout] test docker_build::tests::test_cache_store_and_hit ... ok [INFO] [stdout] test commands::run::tests::test_validate_clean_path_rejects_dangerous ... ok [INFO] [stdout] test conventions::tests::test_node_has_no_polling_env ... ok [INFO] [stdout] test docker_build::tests::test_detect_nextjs_without_next ... ok [INFO] [stdout] test executor::tests::test_default_parallelism ... ok [INFO] [stdout] test docker_build::tests::test_generate_python_dockerfile ... ok [INFO] [stdout] test docker_build::tests::test_generate_bun_dockerfile ... ok [INFO] [stdout] test executor::tests::test_executor_empty ... ok [INFO] [stdout] test docker_build::tests::test_generate_deno_dockerfile ... ok [INFO] [stdout] test docker_build::tests::test_generate_rust_dockerfile ... ok [INFO] [stdout] test import_scanner::tests::test_extract_package_name_scoped ... ok [INFO] [stdout] test import_scanner::tests::test_extract_package_name_unscoped ... ok [INFO] [stdout] test import_scanner::tests::test_real_agiletec_pricing_no_self_ref ... ok [INFO] [stdout] test docker_build::tests::test_detect_nextjs_with_next_devdep ... ok [INFO] [stdout] test executor::tests::test_task_state ... ok [INFO] [stdout] test import_scanner::tests::test_real_agiletec_ui_has_react_hook_form ... ok [INFO] [stdout] test docker_build::tests::test_detect_nextjs_with_next_dep ... ok [INFO] [stdout] test import_scanner::tests::test_real_agiletec_notification_no_self_ref ... ok [INFO] [stdout] test executor::tests::test_executor_single_task ... ok [INFO] [stdout] test import_scanner::tests::test_scan_real_agiletec_voice_gateway ... ok [INFO] [stdout] test docker_build::tests::test_dockerfile_with_build_args ... ok [INFO] [stdout] test executor::tests::test_executor_with_dependencies ... ok [INFO] [stdout] test import_scanner::tests::test_scan_real_agiletec_corporate ... ok [INFO] [stdout] test import_scanner::tests::test_scan_reexports ... ok [INFO] [stdout] test import_scanner::tests::test_scan_dynamic_imports ... ok [INFO] [stdout] test import_scanner::tests::test_scan_subpath_imports ... ok [INFO] [stdout] test import_scanner::tests::test_scan_mixed_quotes ... ok [INFO] [stdout] test import_scanner::tests::test_scan_standard_imports ... ok [INFO] [stdout] test import_scanner::tests::test_scan_multiline_imports ... ok [INFO] [stdout] test import_scanner::tests::test_inline_block_comment_on_same_line ... ok [INFO] [stdout] test import_scanner::tests::test_skip_node_builtins ... ok [INFO] [stdout] test import_scanner::tests::test_skip_relative_and_alias_imports ... ok [INFO] [stdout] test import_scanner::tests::test_skip_block_comments ... ok [INFO] [stdout] test import_scanner::tests::test_skip_jsdoc_continuation_lines ... ok [INFO] [stdout] test import_scanner::tests::test_skip_line_comments ... ok [INFO] [stdout] test import_scanner::tests::test_skip_jsdoc_imports ... ok [INFO] [stdout] test manifest::tests::test_levenshtein_distance ... ok [INFO] [stdout] test manifest::tests::test_resolve_name_from_path ... ok [INFO] [stdout] test manifest::tests::test_resolve_deploy_explicit_not_overridden ... ok [INFO] [stdout] test manifest::tests::test_policy_security_config ... ok [INFO] [stdout] test manifest::tests::test_policy_security_invalid_glob_rejected ... ok [INFO] [stdout] test manifest::tests::test_policy_testing_full_config ... ok [INFO] [stdout] test manifest::tests::test_resolve_scope_from_workspace ... ok [INFO] [stdout] test manifest::tests::test_policy_section_defaults_when_absent ... ok [INFO] [stdout] test manifest::tests::test_policy_testing_takes_precedence_over_testing ... ok [INFO] [stdout] test manifest::tests::test_resolve_scope_not_overridden ... ok [INFO] [stdout] test manifest::tests::test_testing_invalid_regex_rejected ... ok [INFO] [stdout] test manifest::tests::test_testing_invalid_required_imports_regex_rejected ... ok [INFO] [stdout] test manifest::tests::test_resolve_deploy_defaults_from_framework ... ok [INFO] [stdout] test manifest::tests::test_resolve_port_from_framework ... ok [INFO] [stdout] test manifest::tests::test_testing_fallback_to_policy_testing ... ok [INFO] [stdout] test manifest::tests::test_testing_smoke_default_timeout ... ok [INFO] [stdout] test manifest::tests::test_testing_section_mock_policy_allowed ... ok [INFO] [stdout] test manifest::tests::test_testing_section_defaults_when_absent ... ok [INFO] [stdout] test manifest::tests::test_testing_section_mock_policy_forbidden ... ok [INFO] [stdout] test manifest::tests::test_testing_section_full_config ... ok [INFO] [stdout] test manifest::tests::test_validate_catalog_follow_missing_reference ... ok [INFO] [stdout] test manifest::tests::test_validate_catalog_follow_cycle_indirect ... ok [INFO] [stdout] test manifest::tests::test_validate_allows_named_volumes ... ok [INFO] [stdout] test manifest::tests::test_validate_catalog_typo_warning_lates ... ok [INFO] [stdout] test manifest::tests::test_validate_duplicate_ports ... ok [INFO] [stdout] test manifest::tests::test_validate_catalog_follow_chain_no_cycle ... ok [INFO] [stdout] test manifest::tests::test_validate_dev_dep_group_missing_reference ... ok [INFO] [stdout] test manifest::tests::test_validate_env_group_missing_reference ... ok [INFO] [stdout] test manifest::tests::test_validate_catalog_no_false_positive_semver ... ok [INFO] [stdout] test manifest::tests::test_validate_catalog_follow_valid_reference ... ok [INFO] [stdout] test manifest::tests::test_validate_env_validation_all_declared ... ok [INFO] [stdout] test manifest::tests::test_validate_guard_deny_invalid_command_name ... ok [INFO] [stdout] test manifest::tests::test_validate_dep_group_valid_reference ... ok [INFO] [stdout] test manifest::tests::test_validate_guard_deny_with_message_invalid_name ... ok [INFO] [stdout] test manifest::tests::test_validate_guard_wrap_dangerous_wrapper_value ... ok [INFO] [stdout] test manifest::tests::test_validate_guard_deny_wrap_conflict ... ok [INFO] [stdout] test manifest::tests::test_validate_guard_wrap_invalid_command_name ... ok [INFO] [stdout] test manifest::tests::test_validate_catalog_follow_cycle_direct ... ok [INFO] [stdout] test manifest::tests::test_testing_valid_regex_accepted ... ok [INFO] [stdout] test manifest::tests::test_validate_guard_no_conflict ... ok [INFO] [stdout] test manifest::tests::test_validate_rejects_workspace_bind_mounts ... ok [INFO] [stdout] test channel::tests::test_resolve_edge ... ok [INFO] [stdout] test ownership::tests::test_default_is_user ... ok [INFO] [stdout] test ownership::tests::test_tool_owned_files ... ok [INFO] [stdout] test ownership::tests::test_user_owned_files ... ok [INFO] [stdout] test pnpm::tests::test_resolve_workspace_link ... ok [INFO] [stdout] test preset::tests::test_app_overrides_preset ... ok [INFO] [stdout] test preset::tests::test_dep_groups_expansion ... ok [INFO] [stdout] test preset::tests::test_missing_dep_group_errors ... ok [INFO] [stdout] test preset::tests::test_missing_preset_errors ... ok [INFO] [stdout] test channel::tests::test_fetch_image_digest_nonexistent ... ok [INFO] [stdout] test commands::run::tests::test_run_missing_manifest_but_has_compose ... ok [INFO] [stdout] test preset::tests::test_multiple_presets ... ok [INFO] [stdout] test preset::tests::test_preset_dep_groups ... ok [INFO] [stdout] test manifest::tests::test_validate_env_validation_orphan ... ok [INFO] [stdout] test manifest::tests::test_validate_passes_for_minimal_manifest ... ok [INFO] [stdout] test manifest::tests::test_validate_preset_dep_group_missing_reference ... ok [INFO] [stdout] test manifest::tests::test_validate_multiple_errors_collected ... ok [INFO] [stdout] test manifest::tests::test_validate_dep_group_missing_reference ... ok [INFO] [stdout] test manifest::tests::test_validate_env_group_valid_reference ... ok [INFO] [stdout] test manifest::tests::test_validate_skip_none_ports ... ok [INFO] [stdout] test manifest::tests::test_validate_no_duplicate_when_ports_differ ... ok [INFO] [stdout] test preset::tests::test_resolve_single_preset ... ok [INFO] [stdout] test remote_cache::tests::test_parse_oci_url ... ok [INFO] [stdout] test remote_cache::tests::test_parse_s3_url ... ok [INFO] [stdout] test remote_cache::tests::test_s3_key ... ok [INFO] [stdout] test channel::tests::test_resolve_bun ... ok [INFO] [stdout] test preset::tests::test_resolve_profile_vars ... ok [INFO] [stdout] test remote_cache::tests::test_oci_tag ... ok [INFO] [stdout] test safe_fs::tests::test_safefs_dry_run ... ok [INFO] [stdout] test safe_fs::tests::test_safefs_allows_inside_workspace ... ok [INFO] [stdout] test safe_fs::tests::test_safefs_clean_artifact_protects_critical ... ok [INFO] [stdout] test channel::tests::test_resolve_channel_returns_digest_when_available ... ok [INFO] [stdout] test safe_fs::tests::test_safefs_respects_user_ownership ... ok [INFO] [stdout] test remote_cache::tests::test_parse_invalid_url ... ok [INFO] [stdout] test safe_fs::tests::test_safefs_rejects_outside_workspace ... ok [INFO] [stdout] test safe_fs::tests::test_safefs_clean_artifact_allows_build_dirs ... ok [INFO] [stdout] test manifest::tests::test_validate_rejects_service_bind_mounts ... ok [INFO] [stdout] test templates::tests::test_profile_effective_role ... ok [INFO] [stdout] test version_resolver::tests::test_resolve_version_passthrough ... ok [INFO] [stdout] test remote_cache::tests::test_parse_s3_url_no_prefix ... ok [INFO] [stdout] test safe_fs::tests::test_safefs_clean_artifact_allows_node_modules_in_protected_paths ... ok [INFO] [stdout] test channel::tests::test_resolve_lts ... ok [INFO] [stdout] test templates::tests::test_glob_expansion_adds_products_workspaces ... ok [INFO] [stdout] test templates::tests::test_glob_expansion_skips_exclude_patterns ... ok [INFO] [stdout] test safe_fs::tests::test_safefs_write_creates_backup ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 314 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.24s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/airis-e9eae7bba80f70e1) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/cli_test.rs (/opt/rustwide/target/debug/deps/cli_test-51d49c18c0e0d7e2) [INFO] [stdout] [INFO] [stdout] running 20 tests [INFO] [stdout] test test_build_no_cache_option ... ok [INFO] [stdout] test test_affected_help ... ok [INFO] [stdout] test test_cache_directory_structure ... ok [INFO] [stdout] test test_build_parallel_option ... ok [INFO] [stdout] test test_build_help ... ok [INFO] [stdout] test test_build_push_option ... ok [INFO] [stdout] test test_build_context_out_option ... ok [INFO] [stdout] test test_help_flag ... ok [INFO] [stdout] test test_build_remote_cache_option ... ok [INFO] [stdout] test test_bundle_help ... ok [INFO] [stdout] test test_build_targets_option ... ok [INFO] [stdout] test test_version_flag ... ok [INFO] [stdout] test test_build_image_option ... ok [INFO] [stdout] test test_policy_check_no_config ... ok [INFO] [stdout] test test_policy_help ... ok [INFO] [stdout] test test_clean_dry_run ... ok [INFO] [stdout] test test_affected_command ... ok [INFO] [stdout] test test_build_docker_requires_project ... ok [INFO] [stdout] test test_bundle_requires_project ... ok [INFO] [stdout] test test_invalid_channel ... ok [INFO] [stderr] Doc-tests airis_workspace [INFO] [stdout] [INFO] [stdout] test result: ok. 20 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.13s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 2 tests [INFO] [stdout] test src/channel.rs - channel (line 8) ... ignored [INFO] [stdout] test src/remote_cache.rs - remote_cache (line 7) ... ignored [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 2 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stdout] all doctests ran in 0.44s; merged doctests compilation took 0.44s [INFO] running `Command { std: "docker" "inspect" "7816052ca8b262708303544ccab69809d5fff69601d7105cbc13ec6019decfc5", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7816052ca8b262708303544ccab69809d5fff69601d7105cbc13ec6019decfc5", kill_on_drop: false }` [INFO] [stdout] 7816052ca8b262708303544ccab69809d5fff69601d7105cbc13ec6019decfc5