[INFO] cloning repository https://github.com/personal-ai-system/pais [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/personal-ai-system/pais" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpersonal-ai-system%2Fpais", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpersonal-ai-system%2Fpais'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 6b881fd5f26d9cc58f62eba28ba661a9cc22a413 [INFO] testing personal-ai-system/pais against master#d933cf483edf1605142ac6899ff32536c0ad8b22 for pr-150933 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpersonal-ai-system%2Fpais" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/personal-ai-system/pais [INFO] finished tweaking git repo https://github.com/personal-ai-system/pais [INFO] tweaked toml for git repo https://github.com/personal-ai-system/pais written to /workspace/builds/worker-4-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/personal-ai-system/pais on toolchain d933cf483edf1605142ac6899ff32536c0ad8b22 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d933cf483edf1605142ac6899ff32536c0ad8b22" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/personal-ai-system/pais 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" "+d933cf483edf1605142ac6899ff32536c0ad8b22" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating git repository `https://github.com/scottidler/mermaid-rs` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded shellexpand v3.1.1 [INFO] [stderr] Downloaded is-docker v0.2.0 [INFO] [stderr] Downloaded is-wsl v0.4.0 [INFO] [stderr] Downloaded which v7.0.3 [INFO] [stderr] Downloaded open v5.3.3 [INFO] [stderr] Downloaded lazy-regex-proc_macros v3.5.0 [INFO] [stderr] Downloaded lazy-regex v3.5.0 [INFO] [stderr] Downloaded env_filter v0.1.4 [INFO] [stderr] Downloaded ureq-proto v0.5.3 [INFO] [stderr] Downloaded zmij v1.0.6 [INFO] [stderr] Downloaded clap_complete v4.5.64 [INFO] [stderr] Downloaded jiff-static v0.2.17 [INFO] [stderr] Downloaded serde_json v1.0.148 [INFO] [stderr] Downloaded ureq v3.1.4 [INFO] [stderr] Downloaded moxcms v0.7.11 [INFO] [stderr] Downloaded pxfm v0.1.27 [INFO] [stderr] Downloaded jiff v0.2.17 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+d933cf483edf1605142ac6899ff32536c0ad8b22" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] cae830528ece3d18f47040df95b050342e3136dd2fea217768a5db873e4a5fbb [INFO] running `Command { std: "docker" "start" "-a" "cae830528ece3d18f47040df95b050342e3136dd2fea217768a5db873e4a5fbb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "cae830528ece3d18f47040df95b050342e3136dd2fea217768a5db873e4a5fbb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cae830528ece3d18f47040df95b050342e3136dd2fea217768a5db873e4a5fbb", kill_on_drop: false }` [INFO] [stdout] cae830528ece3d18f47040df95b050342e3136dd2fea217768a5db873e4a5fbb [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+d933cf483edf1605142ac6899ff32536c0ad8b22" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] e79b58748082245eee16e187656acead2ee3f215455363401577f57f7a69c7ca [INFO] running `Command { std: "docker" "start" "-a" "e79b58748082245eee16e187656acead2ee3f215455363401577f57f7a69c7ca", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.104 [INFO] [stderr] Compiling quote v1.0.42 [INFO] [stderr] Compiling libc v0.2.178 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling bytes v1.11.0 [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling find-msvc-tools v0.1.6 [INFO] [stderr] Compiling memchr v2.7.6 [INFO] [stderr] Compiling rustix v1.1.3 [INFO] [stderr] Compiling rustls-pki-types v1.13.2 [INFO] [stderr] Compiling simd-adler32 v0.3.8 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling crc32fast v1.5.0 [INFO] [stderr] Compiling linux-raw-sys v0.11.0 [INFO] [stderr] Compiling regex-syntax v0.8.8 [INFO] [stderr] Compiling adler2 v2.0.1 [INFO] [stderr] Compiling cc v1.2.51 [INFO] [stderr] Compiling rustls v0.23.35 [INFO] [stderr] Compiling anstyle-parse v0.2.7 [INFO] [stderr] Compiling colorchoice v1.0.4 [INFO] [stderr] Compiling is_terminal_polyfill v1.70.2 [INFO] [stderr] Compiling anstyle-query v1.1.5 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling anstyle v1.0.13 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling zmij v1.0.6 [INFO] [stderr] Compiling fdeflate v0.3.7 [INFO] [stderr] Compiling anstream v0.6.21 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling flate2 v1.1.5 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling webpki-roots v1.0.4 [INFO] [stderr] Compiling serde_json v1.0.148 [INFO] [stderr] Compiling ipnet v2.11.0 [INFO] [stderr] Compiling clap_lex v0.7.6 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling pxfm v0.1.27 [INFO] [stderr] Compiling is-docker v0.2.0 [INFO] [stderr] Compiling option-ext v0.2.0 [INFO] [stderr] Compiling anyhow v1.0.100 [INFO] [stderr] Compiling clap_builder v4.5.53 [INFO] [stderr] Compiling syn v2.0.112 [INFO] [stderr] Compiling png v0.18.0 [INFO] [stderr] Compiling owo-colors v4.2.3 [INFO] [stderr] Compiling byteorder-lite v0.1.0 [INFO] [stderr] Compiling thiserror v2.0.17 [INFO] [stderr] Compiling socket2 v0.6.1 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling getrandom v0.2.16 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling iri-string v0.7.10 [INFO] [stderr] Compiling x11rb-protocol v0.13.2 [INFO] [stderr] Compiling bytemuck v1.24.0 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling is-wsl v0.4.0 [INFO] [stderr] Compiling mermaid-rs v0.2.6 (https://github.com/scottidler/mermaid-rs?tag=v0.2.6#4687e617) [INFO] [stderr] Compiling jiff v0.2.17 [INFO] [stderr] Compiling unsafe-libyaml v0.2.11 [INFO] [stderr] Compiling eyre v0.6.12 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling ureq-proto v0.5.3 [INFO] [stderr] Compiling open v5.3.3 [INFO] [stderr] Compiling dirs v6.0.0 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling urlencoding v2.1.3 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Compiling indenter v0.3.4 [INFO] [stderr] Compiling pais v0.2.7 (/opt/rustwide/workdir) [INFO] [stderr] Compiling iana-time-zone v0.1.64 [INFO] [stderr] Compiling env_home v0.1.0 [INFO] [stderr] Compiling shellexpand v3.1.1 [INFO] [stderr] Compiling colored v3.0.0 [INFO] [stderr] Compiling indexmap v2.12.1 [INFO] [stderr] Compiling moxcms v0.7.11 [INFO] [stderr] Compiling gethostname v1.1.0 [INFO] [stderr] Compiling which v7.0.3 [INFO] [stderr] Compiling tempfile v3.24.0 [INFO] [stderr] Compiling terminal_size v0.4.3 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling regex v1.12.2 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling clap_derive v4.5.49 [INFO] [stderr] Compiling thiserror-impl v2.0.17 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling env_filter v0.1.4 [INFO] [stderr] Compiling rustls-webpki v0.103.8 [INFO] [stderr] Compiling x11rb v0.13.2 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling clap v4.5.53 [INFO] [stderr] Compiling clap_complete v4.5.64 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling env_logger v0.11.8 [INFO] [stderr] Compiling lazy-regex-proc_macros v3.5.0 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling lazy-regex v3.5.0 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling serde_yaml v0.9.34+deprecated [INFO] [stderr] Compiling chrono v0.4.42 [INFO] [stderr] Compiling toml_edit v0.22.27 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling image v0.25.9 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling ureq v3.1.4 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling tower v0.5.2 [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling arboard v3.6.1 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling hyper-util v0.1.19 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 11s [INFO] running `Command { std: "docker" "inspect" "e79b58748082245eee16e187656acead2ee3f215455363401577f57f7a69c7ca", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e79b58748082245eee16e187656acead2ee3f215455363401577f57f7a69c7ca", kill_on_drop: false }` [INFO] [stdout] e79b58748082245eee16e187656acead2ee3f215455363401577f57f7a69c7ca [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+d933cf483edf1605142ac6899ff32536c0ad8b22" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 8bcbb8f5bcf5810b54fc77270a6b60b9f2863af8029aafdee7da6bba5d7077f6 [INFO] running `Command { std: "docker" "start" "-a" "8bcbb8f5bcf5810b54fc77270a6b60b9f2863af8029aafdee7da6bba5d7077f6", kill_on_drop: false }` [INFO] [stderr] Compiling pais v0.2.7 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 10.98s [INFO] running `Command { std: "docker" "inspect" "8bcbb8f5bcf5810b54fc77270a6b60b9f2863af8029aafdee7da6bba5d7077f6", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8bcbb8f5bcf5810b54fc77270a6b60b9f2863af8029aafdee7da6bba5d7077f6", kill_on_drop: false }` [INFO] [stdout] 8bcbb8f5bcf5810b54fc77270a6b60b9f2863af8029aafdee7da6bba5d7077f6 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+d933cf483edf1605142ac6899ff32536c0ad8b22" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 267667386eb148ed510117a4e29bd2fbaa50849d2d9dd21b1074d88bd2ee2749 [INFO] running `Command { std: "docker" "start" "-a" "267667386eb148ed510117a4e29bd2fbaa50849d2d9dd21b1074d88bd2ee2749", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.34s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/pais-87507e174462f5c6) [INFO] [stdout] [INFO] [stdout] running 216 tests [INFO] [stdout] test agent::traits::tests::test_trait_display ... ok [INFO] [stdout] test agent::traits::tests::test_trait_from_str ... ok [INFO] [stdout] test agent::loader::tests::test_agent_deserialize ... ok [INFO] [stdout] test architecture::tests::test_truncate_multiline ... ok [INFO] [stdout] test architecture::tests::test_truncate ... ok [INFO] [stdout] test agent::loader::tests::test_agent_generate_prompt_custom_prefix ... ok [INFO] [stdout] test agent::traits::tests::test_trait_category ... ok [INFO] [stdout] test agent::loader::tests::test_agent_generate_prompt_from_traits ... ok [INFO] [stdout] test bundle::manifest::tests::test_optional_plugins ... ok [INFO] [stdout] test bundle::manifest::tests::test_parse_full_bundle ... ok [INFO] [stdout] test bundle::manifest::tests::test_parse_minimal_bundle ... ok [INFO] [stdout] test commands::context::tests::test_extract_skill_body_empty_body ... ok [INFO] [stdout] test commands::context::tests::test_extract_skill_body_no_frontmatter ... ok [INFO] [stdout] test commands::context::tests::test_extract_skill_body_valid ... ok [INFO] [stdout] test commands::context::tests::test_should_include_skill_no_filter ... ok [INFO] [stdout] test bundle::manifest::tests::test_plugin_order_preserved ... ok [INFO] [stdout] test commands::context::tests::test_should_include_skill_with_filter_positive ... ok [INFO] [stdout] test commands::session::tests::test_expand_names_deduplicates ... ok [INFO] [stdout] test commands::session::tests::test_expand_names_direct ... ok [INFO] [stdout] test commands::session::tests::test_expand_names_mixed ... ok [INFO] [stdout] test bundle::manifest::tests::test_required_plugins ... ok [INFO] [stdout] test commands::session::tests::test_expand_names_empty_input ... ok [INFO] [stdout] test commands::context::tests::test_should_include_skill_empty_filter ... ok [INFO] [stdout] test commands::context::tests::test_should_include_skill_with_filter_negative ... ok [INFO] [stdout] test commands::bundle::tests::test_generate_bundle_manifest ... ok [INFO] [stdout] test commands::session::tests::test_expand_names_preserves_order ... ok [INFO] [stdout] test commands::session::tests::test_expand_names_profile_order_preserved ... ok [INFO] [stdout] test commands::session::tests::test_expand_names_profile_with_overlapping_items ... ok [INFO] [stdout] test commands::session::tests::test_expand_names_unknown_profile_treated_as_literal ... ok [INFO] [stdout] test commands::session::tests::test_expand_names_with_profile ... ok [INFO] [stdout] test commands::session::tests::test_find_skill_source_not_found ... ok [INFO] [stdout] test commands::session::tests::test_find_skill_source_in_skills_dir ... ok [INFO] [stdout] test bundle::manager::tests::test_discover_bundles ... ok [INFO] [stdout] test commands::session::tests::test_find_skill_source_requires_skill_md ... ok [INFO] [stdout] test commands::session::tests::test_get_current_symlinks_ignores_regular_files ... ok [INFO] [stdout] test commands::session::tests::test_get_default_empty_first_profile ... ok [INFO] [stdout] test bundle::manager::tests::test_discover_empty_directory ... ok [INFO] [stdout] test commands::context::tests::test_get_local_timestamp ... ok [INFO] [stdout] test commands::session::tests::test_find_skill_source_prefers_skills_over_plugins ... ok [INFO] [stdout] test commands::session::tests::test_find_skill_source_in_plugins_dir ... ok [INFO] [stdout] test commands::session::tests::test_get_all_skill_names_empty ... ok [INFO] [stdout] test commands::session::tests::test_get_default_first_profile ... ok [INFO] [stdout] test commands::session::tests::test_get_current_symlinks_nonexistent_directory ... ok [INFO] [stdout] test commands::session::tests::test_get_all_skill_names_deduplicates ... ok [INFO] [stdout] test commands::session::tests::test_get_all_skill_names_from_plugins_dir ... ok [INFO] [stdout] test commands::session::tests::test_get_current_symlinks_empty_directory ... ok [INFO] [stdout] test commands::session::tests::test_get_all_skill_names_combined ... ok [INFO] [stdout] test commands::session::tests::test_get_current_symlinks_with_symlinks ... ok [INFO] [stdout] test commands::session::tests::test_get_default_empty ... ok [INFO] [stdout] test commands::session::tests::test_get_default_respects_insertion_order ... ok [INFO] [stdout] test commands::session::tests::test_mcp_default_is_first_profile ... ok [INFO] [stdout] test commands::session::tests::test_get_all_skill_names_from_skills_dir ... ok [INFO] [stdout] test commands::session::tests::test_mcp_json_deserialize ... ok [INFO] [stdout] test commands::session::tests::test_mcp_mixed_profile_and_direct ... ok [INFO] [stdout] test commands::session::tests::test_mcp_profile_expansion ... ok [INFO] [stdout] test commands::session::tests::test_resolve_list_none_with_empty_first_profile ... ok [INFO] [stdout] test commands::session::tests::test_resolve_list_empty_vec_input ... ok [INFO] [stdout] test commands::session::tests::test_expand_names_multiple_profiles ... ok [INFO] [stdout] test commands::session::tests::test_resolve_list_expands_profile_in_input ... ok [INFO] [stdout] test commands::session::tests::test_resolve_list_without_input ... ok [INFO] [stdout] test commands::session::tests::test_sync_symlinks_creates_directory_if_needed ... ok [INFO] [stdout] test commands::session::tests::test_sync_symlinks_add_new_skills ... ok [INFO] [stdout] test commands::session::tests::test_sync_symlinks_handles_not_found ... ok [INFO] [stdout] test commands::session::tests::test_sync_symlinks_mixed_add_remove_unchanged ... ok [INFO] [stdout] test commands::session::tests::test_sync_symlinks_results_are_sorted ... ok [INFO] [stdout] test commands::sync::tests::test_get_claude_skills_dir ... ok [INFO] [stdout] test commands::session::tests::test_resolve_list_with_input ... ok [INFO] [stdout] test commands::session::tests::test_sync_symlinks_preserves_regular_files ... ok [INFO] [stdout] test commands::sync::tests::test_sync_skill_creates_symlink ... ok [INFO] [stdout] test commands::sync::tests::test_sync_skill_dry_run ... ok [INFO] [stdout] test commands::sync::tests::test_sync_skill_skips_existing_correct_link ... ok [INFO] [stdout] test config::tests::test_config_serialization_roundtrip ... ok [INFO] [stdout] test commands::session::tests::test_sync_symlinks_leaves_unchanged ... ok [INFO] [stdout] test config::tests::test_default_hooks_config ... ok [INFO] [stdout] test config::tests::test_expand_path_no_expansion ... ok [INFO] [stdout] test config::tests::test_expand_path_with_env_var ... ok [INFO] [stdout] test config::tests::test_expand_path_with_tilde ... ok [INFO] [stdout] test config::tests::test_pais_dir_default ... ok [INFO] [stdout] test config::tests::test_pais_dir_from_env ... ok [INFO] [stdout] test config::tests::test_log_level_parsing ... ok [INFO] [stdout] test config::tests::test_parse_kebab_case_observability_config ... ok [INFO] [stdout] test config::tests::test_parse_kebab_case_environment_config ... ok [INFO] [stdout] test config::tests::test_parse_realistic_config_file ... ok [INFO] [stdout] test config::tests::test_load_returns_config ... ok [INFO] [stdout] test config::tests::test_parse_kebab_case_hooks_config ... ok [INFO] [stdout] test commands::session::tests::test_sync_symlinks_empty_list_loads_all ... ok [INFO] [stdout] test config::tests::test_default_config ... ok [INFO] [stdout] test history::capture::tests::test_event_capture_disabled ... ok [INFO] [stdout] test history::capture::tests::test_captured_event_creation ... ok [INFO] [stdout] test history::capture::tests::test_event_capture_enabled ... ok [INFO] [stdout] test hook::history::tests::test_build_session_summary ... ok [INFO] [stdout] test hook::history::tests::test_empty_payload_produces_session_completed ... ok [INFO] [stdout] test hook::history::tests::test_determine_category_content_based ... ok [INFO] [stdout] test hook::history::tests::test_determine_category_fallback_when_agent_not_found ... ok [INFO] [stdout] test commands::session::tests::test_sync_symlinks_remove_unwanted_skills ... ok [INFO] [stdout] test history::capture::tests::test_init_history_dirs ... ok [INFO] [stdout] test history::tests::test_generate_id ... ok [INFO] [stdout] test history::categorize::tests::test_categorize_decision ... ok [INFO] [stdout] test history::categorize::tests::test_categorize_learning ... ok [INFO] [stdout] test history::categorize::tests::test_categorize_research ... ok [INFO] [stdout] test history::categorize::tests::test_extract_summary_no_title ... ok [INFO] [stdout] test history::categorize::tests::test_categorize_session ... ok [INFO] [stdout] test history::categorize::tests::test_extract_summary_with_title ... ok [INFO] [stdout] test history::categorize::tests::test_extract_tags ... ok [INFO] [stdout] test history::tests::test_entry_to_markdown ... ok [INFO] [stdout] test hook::history::tests::test_extract_text_from_content_array ... ok [INFO] [stdout] test hook::history::tests::test_empty_transcript_file ... ok [INFO] [stdout] test hook::history::tests::test_extract_text_from_content_string ... ok [INFO] [stdout] test hook::history::tests::test_handles_subagent_stop ... ok [INFO] [stdout] test hook::history::tests::test_malformed_jsonl_gracefully_fails ... ok [INFO] [stdout] test hook::history::tests::test_nonexistent_transcript_path_gracefully_fails ... ok [INFO] [stdout] test hook::history::tests::test_payload_with_only_session_id_is_empty ... ok [INFO] [stdout] test hook::history::tests::test_real_claude_code_transcript_format ... ok [INFO] [stdout] test hook::history::tests::test_response_field_takes_precedence_over_transcript ... ok [INFO] [stdout] test hook::history::tests::test_response_is_truncated_at_5000_chars ... ok [INFO] [stdout] test hook::history::tests::test_short_response_is_skipped ... ok [INFO] [stdout] test hook::history::tests::test_stop_handler_creates_learning_entry_from_transcript ... ok [INFO] [stdout] test hook::history::tests::test_transcript_path_is_read_when_response_missing ... ok [INFO] [stdout] test hook::history::tests::test_stop_handler_creates_session_entry_from_transcript ... ok [INFO] [stdout] test hook::history::tests::test_transcript_with_only_user_messages ... ok [INFO] [stdout] test hook::history::tests::test_transcript_with_thinking_blocks_extracts_text_only ... ok [INFO] [stdout] test hook::research::tests::test_allows_non_research_paths ... ok [INFO] [stdout] test hook::research::tests::test_blocks_missing_topic ... ok [INFO] [stdout] test hook::research::tests::test_blocks_underscore_in_topic ... ok [INFO] [stdout] test hook::research::tests::test_blocks_uppercase_category ... ok [INFO] [stdout] test hook::research::tests::test_disabled_validator_allows_all ... ok [INFO] [stdout] test hook::research::tests::test_blocks_wrong_filename_format ... ok [INFO] [stdout] test hook::research::tests::test_allows_valid_research_path ... ok [INFO] [stdout] test hook::research::tests::test_allows_valid_research_path_absolute ... ok [INFO] [stdout] test hook::research::tests::test_ignores_non_write_tools ... ok [INFO] [stdout] test hook::research::tests::test_only_handles_pre_tool_use ... ok [INFO] [stdout] test hook::security::tests::test_blocks_rm_rf_root ... ok [INFO] [stdout] test hook::tests::test_hook_event_all_variants ... ok [INFO] [stdout] test hook::tests::test_hook_event_from_str_lowercase ... ok [INFO] [stdout] test hook::tests::test_hook_event_from_str_pascal_case ... ok [INFO] [stdout] test hook::security::tests::test_blocks_fork_bomb ... ok [INFO] [stdout] test hook::tests::test_hook_event_from_str_unknown ... ok [INFO] [stdout] test hook::tests::test_hook_event_from_str_with_separators ... ok [INFO] [stdout] test hook::tests::test_hook_event_serialization ... ok [INFO] [stdout] test hook::tests::test_hook_result_exit_codes ... ok [INFO] [stdout] test hook::ui::tests::test_extract_task_summary_capitalizes ... ok [INFO] [stdout] test hook::ui::tests::test_disabled_handler ... ok [INFO] [stdout] test hook::ui::tests::test_extract_task_summary_multiline ... ok [INFO] [stdout] test hook::ui::tests::test_extract_task_summary_simple ... ok [INFO] [stdout] test hook::ui::tests::test_extract_task_summary_strips_prefix ... ok [INFO] [stdout] test hook::ui::tests::test_extract_task_summary_truncates ... ok [INFO] [stdout] test hook::ui::tests::test_handles_user_prompt_submit ... ok [INFO] [stdout] test migrate::tests::test_migration_v0_to_v1 ... ok [INFO] [stdout] test migrate::tests::test_parse_version_tag ... ok [INFO] [stdout] test observability::emitter::tests::test_emitter_disabled ... ok [INFO] [stdout] test observability::emitter::tests::test_event_format_display ... ok [INFO] [stdout] test observability::emitter::tests::test_event_with_payload ... ok [INFO] [stdout] test observability::emitter::tests::test_event_from_hook ... ok [INFO] [stdout] test hook::security::tests::test_blocks_reverse_shell ... ok [INFO] [stdout] test plugin::executor::tests::test_hook_result_conversion ... ok [INFO] [stdout] test hook::security::tests::test_blocks_nc_reverse_shell ... ok [INFO] [stdout] test plugin::manifest::tests::test_consume_spec_optional ... ok [INFO] [stdout] test hook::security::tests::test_blocks_curl_pipe_bash ... ok [INFO] [stdout] test plugin::manifest::tests::test_default_build_type ... ok [INFO] [stdout] test plugin::manifest::tests::test_default_hooks_spec ... ok [INFO] [stdout] test plugin::manifest::tests::test_default_plugin_language ... ok [INFO] [stdout] test plugin::tests::test_discover_empty_directory ... ok [INFO] [stdout] test plugin::manifest::tests::test_manifest_serialization_roundtrip ... ok [INFO] [stdout] test plugin::manifest::tests::test_parse_full_manifest ... ok [INFO] [stdout] test plugin::manifest::tests::test_parse_minimal_manifest ... ok [INFO] [stdout] test plugin::tests::test_discover_plugins ... ok [INFO] [stdout] test plugin::tests::test_remove_plugin ... ok [INFO] [stdout] test plugin::verify::tests::test_has_checks ... ok [INFO] [stdout] test skill::indexer::tests::test_extract_triggers_empty ... ok [INFO] [stdout] test skill::indexer::tests::test_extract_triggers_key_words ... ok [INFO] [stdout] test skill::indexer::tests::test_extract_triggers_use_when ... ok [INFO] [stdout] test skill::loader::tests::test_discover_empty_directory ... ok [INFO] [stdout] test skill::loader::tests::test_discover_nonexistent_directory ... ok [INFO] [stdout] test skill::loader::tests::test_discover_simple_skills ... ok [INFO] [stdout] test plugin::verify::tests::test_command_check_exit_code ... ok [INFO] [stdout] test skill::loader::tests::test_load_plugin_skill ... ok [INFO] [stdout] test skill::loader::tests::test_load_simple_skill ... ok [INFO] [stdout] test skill::parser::tests::test_parse_frontmatter_minimal ... ok [INFO] [stdout] test skill::parser::tests::test_parse_frontmatter_no_closing ... ok [INFO] [stdout] test skill::parser::tests::test_parse_frontmatter_no_delimiter ... ok [INFO] [stdout] test plugin::verify::tests::test_file_check_fails_when_file_missing ... ok [INFO] [stdout] test plugin::verify::tests::test_file_check_passes_when_file_exists ... ok [INFO] [stdout] test skill::parser::tests::test_parse_frontmatter_valid ... ok [INFO] [stdout] test skill::scanner::tests::test_scan_finds_pais_skill ... ok [INFO] [stdout] test skill::parser::tests::test_parse_frontmatter_missing_name ... ok [INFO] [stdout] test skill::scanner::tests::test_scan_finds_multiple_skills ... ok [INFO] [stdout] test plugin::verify::tests::test_command_check_output_contains ... ok [INFO] [stdout] test skill::scanner::tests::test_scan_ignores_node_modules ... ok [INFO] [stdout] test skill::scanner::tests::test_scan_ignores_hidden_dirs ... ok [INFO] [stdout] test skill::scanner::tests::test_scan_nonexistent_directory ... ok [INFO] [stdout] test skill::template::tests::test_generate_template_hyphenated_name ... ok [INFO] [stdout] test skill::template::tests::test_generate_template_simple_name ... ok [INFO] [stdout] test skill::template::tests::test_generate_template_underscored_name ... ok [INFO] [stdout] test skill::template::tests::test_template_has_frontmatter ... ok [INFO] [stdout] test skill::tests::test_discovered_skill ... ok [INFO] [stdout] test skill::tests::test_plugin_skill ... ok [INFO] [stdout] test skill::workflow::tests::test_find_workflow_case_insensitive ... ok [INFO] [stdout] test skill::workflow::tests::test_find_workflow_exact ... ok [INFO] [stdout] test skill::workflow::tests::test_find_workflow_partial ... ok [INFO] [stdout] test skill::scanner::tests::test_scan_respects_max_depth ... ok [INFO] [stdout] test skill::tests::test_new_simple_skill ... ok [INFO] [stdout] test skill::workflow::tests::test_parse_workflows_no_table ... ok [INFO] [stdout] test skill::workflow::tests::test_parse_workflows_case_insensitive_header ... ok [INFO] [stdout] test hook::security::tests::test_blocks_prompt_injection ... ok [INFO] [stdout] test skill::workflow::tests::test_parse_workflows_basic ... ok [INFO] [stdout] test skill::scanner::tests::test_should_enter ... ok [INFO] [stdout] test hook::security::tests::test_blocks_credential_theft ... ok [INFO] [stdout] test hook::security::tests::test_blocks_aws_credentials ... ok [INFO] [stdout] test hook::security::tests::test_blocks_env_key_access ... ok [INFO] [stdout] test hook::security::tests::test_warns_git_force_push ... ok [INFO] [stdout] test hook::security::tests::test_warns_sudo ... ok [INFO] [stdout] test plugin::executor::tests::test_execute_hook_block ... ok [INFO] [stdout] test hook::security::tests::test_logs_ssh ... ok [INFO] [stdout] test plugin::executor::tests::test_execute_hook_allow ... ok [INFO] [stdout] test hook::security::tests::test_blocks_data_exfiltration ... ok [INFO] [stdout] test hook::security::tests::test_allows_safe_command ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 216 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.21s [INFO] [stdout] [INFO] [stderr] Running tests/plugin_integration.rs (/opt/rustwide/target/debug/deps/plugin_integration-7913bfa83801331d) [INFO] [stdout] [INFO] [stdout] running 11 tests [INFO] [stdout] test test_pais_run_rust_plugin ... ignored [INFO] [stdout] test test_plugin_install_from_local_path ... ok [INFO] [stdout] test test_plugin_install_dev_mode ... ok [INFO] [stdout] test test_plugin_verify ... ok [INFO] [stdout] test test_plugin_remove ... ok [INFO] [stdout] test test_plugin_info ... ok [INFO] [stdout] test test_status_shows_plugins ... ok [INFO] [stdout] test test_plugin_list_shows_installed ... ok [INFO] [stdout] test test_pais_run_with_multiple_args ... ok [INFO] [stdout] test test_pais_run_unknown_action_fails ... ok [INFO] [stdout] test test_pais_run_python_plugin ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 10 passed; 0 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.21s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "267667386eb148ed510117a4e29bd2fbaa50849d2d9dd21b1074d88bd2ee2749", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "267667386eb148ed510117a4e29bd2fbaa50849d2d9dd21b1074d88bd2ee2749", kill_on_drop: false }` [INFO] [stdout] 267667386eb148ed510117a4e29bd2fbaa50849d2d9dd21b1074d88bd2ee2749