[INFO] cloning repository https://github.com/bn-l/clarg [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/bn-l/clarg" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbn-l%2Fclarg", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbn-l%2Fclarg'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 223148c393426287f7b21e114b18fd19b43de102 [INFO] testing bn-l/clarg against 1.95.0 for beta-1.96-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbn-l%2Fclarg" "/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/bn-l/clarg [INFO] finished tweaking git repo https://github.com/bn-l/clarg [INFO] tweaked toml for git repo https://github.com/bn-l/clarg written to /workspace/builds/worker-4-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/bn-l/clarg 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/bn-l/clarg 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 tempfile v3.24.0 [INFO] [stderr] Downloaded bitflags v2.10.0 [INFO] [stderr] Downloaded once_cell_polyfill v1.70.2 [INFO] [stderr] Downloaded windows-result v0.4.1 [INFO] [stderr] Downloaded anstyle-wincon v3.0.11 [INFO] [stderr] Downloaded anstyle v1.0.13 [INFO] [stderr] Downloaded rustc-demangle v0.1.27 [INFO] [stderr] Downloaded anstream v0.6.21 [INFO] [stderr] Downloaded clap v4.5.57 [INFO] [stderr] Downloaded owo-colors v4.2.3 [INFO] [stderr] Downloaded backtrace v0.3.76 [INFO] [stderr] Downloaded bumpalo v3.19.1 [INFO] [stderr] Downloaded wasip2 v1.0.2+wasi-0.2.9 [INFO] [stderr] Downloaded cc v1.2.56 [INFO] [stderr] Downloaded js-sys v0.3.85 [INFO] [stderr] Downloaded clap_builder v4.5.57 [INFO] [stderr] Downloaded serde_json v1.0.149 [INFO] [stderr] Downloaded wasm-bindgen-macro-support v0.2.108 [INFO] [stderr] Downloaded tracing-subscriber v0.3.22 [INFO] [stderr] Downloaded chrono v0.4.43 [INFO] [stderr] Downloaded gimli v0.32.3 [INFO] [stderr] Downloaded syn v2.0.114 [INFO] [stderr] Downloaded flexi_logger v0.31.8 [INFO] [stderr] Downloaded object v0.37.3 [INFO] [stderr] Downloaded wasm-bindgen v0.2.108 [INFO] [stderr] Downloaded wit-bindgen v0.51.0 [INFO] [stderr] Downloaded addr2line v0.25.1 [INFO] [stderr] Downloaded iana-time-zone v0.1.65 [INFO] [stderr] Downloaded rustix v1.1.3 [INFO] [stderr] Downloaded gix-path v0.11.2 [INFO] [stderr] Downloaded clap_derive v4.5.55 [INFO] [stderr] Downloaded windows-core v0.62.2 [INFO] [stderr] Downloaded gix-features v0.46.2 [INFO] [stderr] Downloaded pty-process v0.5.3 [INFO] [stderr] Downloaded zmij v1.0.19 [INFO] [stderr] Downloaded ryu v1.0.22 [INFO] [stderr] Downloaded nu-ansi-term v0.50.3 [INFO] [stderr] Downloaded gix-glob v0.24.0 [INFO] [stderr] Downloaded gix-trace v0.1.18 [INFO] [stderr] Downloaded gix-ignore v0.19.1 [INFO] [stderr] Downloaded itoa v1.0.17 [INFO] [stderr] Downloaded clap_lex v0.7.7 [INFO] [stderr] Downloaded wasm-bindgen-macro v0.2.108 [INFO] [stderr] Downloaded wasm-bindgen-shared v0.2.108 [INFO] [stderr] Downloaded windows-implement v0.60.2 [INFO] [stderr] Downloaded windows-interface v0.59.3 [INFO] [stderr] Downloaded windows-strings v0.5.1 [INFO] [stderr] Downloaded libc v0.2.184 [INFO] [stderr] Downloaded gix-validate v0.11.0 [INFO] [stderr] Downloaded unicode-bom v2.0.3 [INFO] [stderr] Downloaded linux-raw-sys v0.11.0 [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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 73dc281e9d3839e747bfda294f3c4f1cb66068fbe992e29a3a9f4af33f48a231 [INFO] running `Command { std: "docker" "start" "-a" "73dc281e9d3839e747bfda294f3c4f1cb66068fbe992e29a3a9f4af33f48a231", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "73dc281e9d3839e747bfda294f3c4f1cb66068fbe992e29a3a9f4af33f48a231", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "73dc281e9d3839e747bfda294f3c4f1cb66068fbe992e29a3a9f4af33f48a231", kill_on_drop: false }` [INFO] [stdout] 73dc281e9d3839e747bfda294f3c4f1cb66068fbe992e29a3a9f4af33f48a231 [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=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] 893aec76bcac15a5bb8e434bcc4a38018deafb7d4d43d4d31cb16e4c81a33bd4 [INFO] running `Command { std: "docker" "start" "-a" "893aec76bcac15a5bb8e434bcc4a38018deafb7d4d43d4d31cb16e4c81a33bd4", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.106 [INFO] [stderr] Compiling quote v1.0.44 [INFO] [stderr] Compiling unicode-ident v1.0.22 [INFO] [stderr] Compiling memchr v2.7.6 [INFO] [stderr] Compiling regex-syntax v0.8.9 [INFO] [stderr] Compiling libc v0.2.184 [INFO] [stderr] Compiling once_cell v1.21.3 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling cfg-if v1.0.4 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling autocfg v1.5.0 [INFO] [stderr] Compiling lazy_static v1.5.0 [INFO] [stderr] Compiling gix-trace v0.1.18 [INFO] [stderr] Compiling owo-colors v4.2.3 [INFO] [stderr] Compiling object v0.37.3 [INFO] [stderr] Compiling utf8parse v0.2.2 [INFO] [stderr] Compiling sharded-slab v0.1.7 [INFO] [stderr] Compiling pin-project-lite v0.2.16 [INFO] [stderr] Compiling thread_local v1.1.9 [INFO] [stderr] Compiling anstyle-parse v0.2.7 [INFO] [stderr] Compiling adler2 v2.0.1 [INFO] [stderr] Compiling colorchoice v1.0.4 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling anstyle v1.0.13 [INFO] [stderr] Compiling eyre v0.6.12 [INFO] [stderr] Compiling is_terminal_polyfill v1.70.2 [INFO] [stderr] Compiling gimli v0.32.3 [INFO] [stderr] Compiling zmij v1.0.19 [INFO] [stderr] Compiling anstyle-query v1.1.5 [INFO] [stderr] Compiling color-spantrace v0.3.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling anstream v0.6.21 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling strsim v0.11.1 [INFO] [stderr] Compiling indenter v0.3.4 [INFO] [stderr] Compiling itoa v1.0.17 [INFO] [stderr] Compiling iana-time-zone v0.1.65 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling equivalent v1.0.2 [INFO] [stderr] Compiling heck v0.5.0 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling rustc-demangle v0.1.27 [INFO] [stderr] Compiling clap_lex v0.7.7 [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling hashbrown v0.16.1 [INFO] [stderr] Compiling clap_builder v4.5.57 [INFO] [stderr] Compiling chrono v0.4.43 [INFO] [stderr] Compiling syn v2.0.114 [INFO] [stderr] Compiling gix-features v0.46.2 [INFO] [stderr] Compiling unsafe-libyaml v0.2.11 [INFO] [stderr] Compiling log v0.4.29 [INFO] [stderr] Compiling ryu v1.0.22 [INFO] [stderr] Compiling unicode-bom v2.0.3 [INFO] [stderr] Compiling nu-ansi-term v0.50.3 [INFO] [stderr] Compiling shlex v1.3.0 [INFO] [stderr] Compiling indexmap v2.13.0 [INFO] [stderr] Compiling tracing-error v0.2.1 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling addr2line v0.25.1 [INFO] [stderr] Compiling backtrace v0.3.76 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling clap_derive v4.5.55 [INFO] [stderr] Compiling color-eyre v0.6.5 [INFO] [stderr] Compiling bstr v1.12.1 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling gix-validate v0.11.0 [INFO] [stderr] Compiling gix-path v0.11.2 [INFO] [stderr] Compiling flexi_logger v0.31.8 [INFO] [stderr] Compiling gix-glob v0.24.0 [INFO] [stderr] Compiling clap v4.5.57 [INFO] [stderr] Compiling gix-ignore v0.19.1 [INFO] [stderr] Compiling serde_yaml v0.9.34+deprecated [INFO] [stderr] Compiling clarg v0.3.2 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 39.83s [INFO] running `Command { std: "docker" "inspect" "893aec76bcac15a5bb8e434bcc4a38018deafb7d4d43d4d31cb16e4c81a33bd4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "893aec76bcac15a5bb8e434bcc4a38018deafb7d4d43d4d31cb16e4c81a33bd4", kill_on_drop: false }` [INFO] [stdout] 893aec76bcac15a5bb8e434bcc4a38018deafb7d4d43d4d31cb16e4c81a33bd4 [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=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] 71aa4e3d6c926e3e77b4055018e8b6c02c3584c0d859361aa15e6536c0011a91 [INFO] running `Command { std: "docker" "start" "-a" "71aa4e3d6c926e3e77b4055018e8b6c02c3584c0d859361aa15e6536c0011a91", kill_on_drop: false }` [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling rustix v1.1.3 [INFO] [stderr] Compiling linux-raw-sys v0.11.0 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling fastrand v2.3.0 [INFO] [stderr] Compiling gix-glob v0.24.0 [INFO] [stderr] Compiling gix-ignore v0.19.1 [INFO] [stderr] Compiling clarg v0.3.2 (/opt/rustwide/workdir) [INFO] [stderr] Compiling pty-process v0.5.3 [INFO] [stderr] Compiling tempfile v3.24.0 [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 12.87s [INFO] running `Command { std: "docker" "inspect" "71aa4e3d6c926e3e77b4055018e8b6c02c3584c0d859361aa15e6536c0011a91", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "71aa4e3d6c926e3e77b4055018e8b6c02c3584c0d859361aa15e6536c0011a91", kill_on_drop: false }` [INFO] [stdout] 71aa4e3d6c926e3e77b4055018e8b6c02c3584c0d859361aa15e6536c0011a91 [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=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] c57f26f53741e54b8903955ac643a9723a0590b7b35cfd9a0b3bf98f7ac3c79b [INFO] running `Command { std: "docker" "start" "-a" "c57f26f53741e54b8903955ac643a9723a0590b7b35cfd9a0b3bf98f7ac3c79b", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.17s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/clarg-818760f3e90e9471) [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 unittests src/main.rs (/opt/rustwide/target/debug/deps/clarg-76dc90a324d94cf1) [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/bash_analyzer_tests.rs (/opt/rustwide/target/debug/deps/bash_analyzer_tests-b3daee8267c04c95) [INFO] [stdout] [INFO] [stdout] running 360 tests [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_cartesian_product ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_empty_brace_parts_preserved ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_double_quoted_braces_not_expanded_in_file_command ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_extract_paths_expands_brace_in_file_command ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_extract_paths_expands_brace_in_redirection_target ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_extract_paths_no_braces_passes_through_untouched ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_nested_braces ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_no_braces_passes_through ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_extract_paths_expands_brace_with_normalization_prep ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_path_with_multiple_expansions ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_escaped_braces_outside_quotes_not_expanded ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_extract_paths_expands_brace_in_unknown_command ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_unmatched_brace_passes_through ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_range_expansion_passes_through ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_single_quoted_braces_not_expanded_in_file_command ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_three_options ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_quoted_set_literal_in_python_c_survives ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_unquoted_braces_still_expand_alongside_quoted_ones ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_simple_brace_expansion ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_quoted_braces_in_redirect_target_not_expanded ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_nested_subdirectory_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_in_and_chain_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_dash_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_absolute_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_in_semicolon_chain_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_etc_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_safe_cd_in_chain_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_home_var_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_sudo_cd_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_parent_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_config_internal_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_parent_parent_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_no_args_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_root_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_config_long_equals_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_tilde_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_with_dotslash_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_with_dot_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_with_parent_escaping_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_config_short_concatenated_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_data_internal_file_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_config_short_separated_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_env_cd_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_subdirectory_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_data_literal_string_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_data_urlencode_at_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_form_at_file_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_form_equals_at_file_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_config_long_separated_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_data_at_file_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_no_output_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_output_tilde_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_data_binary_at_file_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_t_flag_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_long_output_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_output_equals_syntax_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_upload_file_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_multiple_urls_one_output_outside ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_output_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_output_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_t_concatenated_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_input_file_internal_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_input_file_short_separated_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_output_home_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_input_file_long_equals_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_input_file_long_separated_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_long_output_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_output_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_no_output_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_input_file_short_concatenated_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_pipe_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_output_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_output_equals_syntax_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_c_cat_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_deeply_nested_eval_limited ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_dash_c_unsafe_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_c_chain_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_eval_cat_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_eval_empty_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_c_unsafe_cd_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_c_safe_command_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_c_with_long_unicode_command_no_panic ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_eval_nested_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_eval_unsafe_cd_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_eval_with_long_unicode_command_no_panic ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_zsh_c_safe_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_eval_safe_command_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_sh_c_safe_command_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_zsh_c_unsafe_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_script_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_deno_run_outside_blocked ... ignored [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_script_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_deno_not_affected_by_inline_check ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_sh_script_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_dot_script_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_deno_run_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_bun_run_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_dot_script_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_inline_code_deny_reason_mentions_inline_code ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_dash_c_safe_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_sh_c_unsafe_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_node_script_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_node_script_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_node_e_with_external_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python3_script_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_perl_e_with_external_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python_script_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_perl_script_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_node_eval_flag_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_perl_e_pure_code_denied ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python_c_dynamically_constructed_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_d_concatenated_at_file_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python_c_inline_code_denied_under_internal_only ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python_with_flags_then_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python_script_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_ruby_e_pure_code_denied ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python3_c_with_external_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python_script_still_works_after_inline_check ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_source_script_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python_c_with_external_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_source_script_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python_c_relative_traversal_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_ruby_e_with_external_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_cat_with_flags_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_ruby_script_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_ruby_script_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_chmod_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_source_bashrc_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_chmod_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_cp_dest_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_cp_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_cat_multiple_files_one_outside ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_dd_if_tilde_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_dd_no_path_args_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_source_not_affected_by_inline_check ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_cat_absolute_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_head_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_dd_of_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_cp_recursive_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_head_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_cp_source_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_chown_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_dd_if_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_dd_internal_paths_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_mkdir_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_less_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_mkdir_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_ln_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_ln_target_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_more_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_pushd_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_mv_dest_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_rm_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_rmdir_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_mkdir_p_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_mv_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_rm_root_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_mv_source_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_rm_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_rm_recursive_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_touch_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_touch_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_bare_quoted_bare_mixed_delim_resolves_correctly ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_double_less_inside_quotes_is_not_a_heredoc ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_tar_extract_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_escaped_then_bare_mixed_delim_resolves_correctly ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_double_quoted_not_treated_as_path ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_tail_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_extract_paths_skips_heredoc_body_paths ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_find_heredoc_spans_orders_op_and_body ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_bareword_not_treated_as_path ... ok [INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_tilde_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_command_sub_with_inner_quoted_paren ... ok [INFO] [stdout] test bash_analyzer_tests::exec_commands::test_bun_run_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_tar_create_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_double_quoted_with_substitution_inside ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_with_backtick_substitution ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_with_parameter_expansion ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_with_command_substitution_strips_fully ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_backslash_escaped_delim ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_double_quoted_delim ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_inside_bash_c_recursion_strips_body ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_with_command_sub_then_real_redirect ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_inside_eval_recursion_strips_body ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_with_nested_command_substitution ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_single_quoted_delim ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_multiple_heredocs_same_line_strip_in_order ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_tab_stripped_closer_matches ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_mixed_quoted_delim_does_not_hide_trailing_command ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_followed_by_real_redirect_still_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_pipe_in_heredoc_body_does_not_split_command ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_multiple_heredocs_separate_commands ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_real_external_write_inside_bash_c_still_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_tab_stripped_does_not_strip_spaces ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_redirect_inside_heredoc_body_is_not_a_real_redirect ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_root_in_heredoc_body_does_not_trigger_containment ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_strip_heredocs_does_not_strip_triple_less_as_heredoc ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_strip_heredocs_handles_unclosed_input_safely ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_same_line_redirect_after_heredoc_op_still_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::file_commands::test_cat_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_quoted_then_bare_mixed_delim_resolves_correctly ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_single_quoted_not_treated_as_path ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_mixed_quoted_delim_strips_body_normally ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_same_line_redirect_before_heredoc_op_still_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_strip_heredocs_no_op_when_no_doubleless ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_strip_heredocs_preserves_same_line_redirect ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_unbalanced_quote_in_heredoc_body_does_not_corrupt_following_command ... ok [INFO] [stdout] test bash_analyzer_tests::heredocs::test_unclosed_heredoc_strips_to_end_of_input ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_deep_path_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_dot_only_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_dotdot_prefix_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_double_slash_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_absolute_path_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_empty_not_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_env_var_other_not_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_flag_not_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_hidden_directory_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_hidden_file_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_dot_prefix_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_dotdot_only_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_home_var_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_home_var_with_path_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_just_slash_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_number_not_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_simple_word_not_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_tilde_slash_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_tilde_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_trailing_slash_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_url_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_long_flag_not_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_word_with_at_sign_not_path ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_double_quoted_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_double_quoted_tilde_is_literal_and_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_tilde_user_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_escaped_tilde_outside_quotes_is_literal_and_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_escaped_dollar_in_double_quotes_is_literal_and_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_double_quoted_dollar_home_still_expands_and_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_fd_redirect_not_treated_as_file ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_double_quoted_with_space_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_append_outside ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_pattern_not_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_word_containing_dot_not_path ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_relative_path_with_slash_looks_like_path ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_append_inside_project ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_quoted_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_combined_outside ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_parent_dir_outside ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_multiple_redirects_all_inside ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_relative_path_inside ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_single_quoted_dollar_home_is_literal_and_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_single_quoted_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_single_quoted_tilde_is_literal_and_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_stderr_inside_project ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_stderr_outside ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_to_absolute_outside ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_to_dev_null ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_to_dev_zero ... ok [INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_command_not_path ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_data_equals_at_file_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_pipe_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_to_etc ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_to_file_inside_project ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_unquoted_dollar_home_still_expands_and_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_unquoted_tilde_plus_is_literal_and_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_unquoted_tilde_still_expands_and_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_unquoted_tilde_user_expands ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_unseparated_bare_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_with_home_var_outside ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_with_tilde_outside ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_ack_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_ack_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_ag_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_ag_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_fd_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_fd_with_path_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_fd_with_path_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_find_home_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_find_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_find_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_find_root_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_grep_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_grep_with_e_flag_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_rg_glob_flag_not_treated_as_path ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_rg_type_flag_not_treated_as_path ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_expression_looks_like_path_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_rg_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_rg_with_flags_and_outside_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_expression_flag_equals_internal_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_rg_with_path_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_expression_flag_separated_internal_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_grep_recursive_outside_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_grep_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_f_flag_internal_script_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::search_commands::test_rg_with_path_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_f_flag_external_script_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_inplace_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_long_file_flag_separated_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_no_file_args_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_on_external_file_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_brace_without_comma_passes_through ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_short_file_flag_concatenated_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_inplace_backup_internal_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_tilde_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_multiple_files_one_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_with_e_flag_internal_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_with_f_flag_internal_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_inplace_internal_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_and_operator ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_cd_and_ls ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_double_quoted_and ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_double_quoted_semicolon ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_empty_string ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_escaped_ampersand ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_escaped_pipe ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_escaped_semicolon ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_grep_pipe_chain ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_mixed_pipe_and_semicolon ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_mixed_quotes_and_operators ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_mixed_and_or ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_mkdir_and_cd ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_multiple_and_operators ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_multiple_or_operators ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_multiple_pipes ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_multiple_semicolons ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_nested_quotes ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_or_operator ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_pipe ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_semicolon ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_semicolon_no_space ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_simple_command ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_single_ampersand ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_single_quoted_pipe ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_single_quoted_semicolon ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_test_and_exec ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_unmatched_quote_handled ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_whitespace_only ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_absolute_command_path_with_external_arg ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_relative_command_path_with_internal_arg ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_flag_equals_internal_path_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_flag_equals_tilde_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_all_internal_paths_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_flag_equals_external_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_flag_equals_non_path_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_hidden_file_inside_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_short_flag_equals_external_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_with_dotdot_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_with_external_path_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_with_flags_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_with_home_var_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_with_internal_path_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_with_numbers_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_with_tilde_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_with_text_args_allowed ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_all_operators ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_ampersand_at_end ... ok [INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_and_no_spaces ... ok [INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_mixed_args_one_bad_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::redirections::test_multiple_redirects_one_outside ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_long_file_flag_equals_external_blocked ... ok [INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_on_internal_file_allowed ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 359 passed; 0 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.25s [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Running tests/blocked_commands_tests.rs (/opt/rustwide/target/debug/deps/blocked_commands_tests-069b49af31dccb3a) [INFO] [stdout] running 63 tests [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_empty_patterns ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_empty_string_pattern ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_alternation ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_anchored_regex ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_character_class ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_invalid_regex_bad_escape ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_invalid_regex_unclosed_bracket ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_invalid_regex_unclosed_paren ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_end_anchored_regex ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_invalid_quantifier ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_dot_pattern ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_multiple_patterns ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_empty_patterns_never_matches ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_complex_regex ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_first_matching_pattern_in_reason ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_contains_blocked_by_clarg ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_contains_matched ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_regex_pattern ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_empty_command_with_dot_pattern ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_whitespace_pattern ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_invalid_repetition ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_word_boundary ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_contains_forbidden ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_contains_command ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_single_literal_pattern ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_truncates_long_command ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_no_match_returns_none ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_contains_pattern ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_second_pattern_if_first_doesnt_match ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_truncate_long_unicode_command_no_panic ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_truncate_cjk_command_no_panic ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_short_command_not_truncated ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_case_sensitive ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_both_anchored ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_alternation_with_context ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_ampersand ... ok [INFO] [stdout] test blocked_commands_tests::reason_messages::test_truncate_emoji_command_no_panic ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_alternation ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_literal_substring_match ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_multiple_patterns_middle_matches ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_end_anchored ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_multiple_patterns_first_matches ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_literal_no_match ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_curl_pipe_sh_pattern ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_dot_question ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_literal_match ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_custom_class ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_complex_rm_pattern ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_multiple_whitespace ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_negated_class ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_dot_plus ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_multiple_patterns_none_match ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_dd_pattern ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_redirect ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_semicolon ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_dot_star ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_start_anchored ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_word_boundary ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_digit_class ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_whitespace ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_pipe_character ... ok [INFO] [stdout] test blocked_commands_tests::construction::test_new_with_many_patterns ... ok [INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_word_class ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 63 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s [INFO] [stdout] [INFO] [stderr] Running tests/blocked_files_tests.rs (/opt/rustwide/target/debug/deps/blocked_files_tests-8e2f191608875305) [INFO] [stdout] [INFO] [stdout] running 84 tests [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_anchored_project_pattern_still_anchors_inside_project ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_bare_absolute_pattern_does_not_match_unrelated_paths ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_directory_pattern_blocks_outside_project ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_home_pattern_is_not_re_expanded_after_construction ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_dollar_home_pattern_expands_like_tilde ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_bare_tilde_blocks_everything_under_home ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_double_star_pattern_blocks_outside_project ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_absolute_pattern_reason_includes_expanded_pattern_and_path ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_new_with_home_pattern_and_empty_home_errors ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_mixed_pattern_groups_both_fire ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_new_with_only_project_patterns_does_not_check_home ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_emoji_pattern ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_unanchored_basename_pattern_blocks_outside_project ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_anchored_pattern ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_tilde_slash_pattern_blocks_absolute_path_outside_project ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_many_patterns ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_glob_star_pattern ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_absolute_project_root ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_multiple_patterns ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_tilde_pattern_ignores_project_relative_paths ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_relative_project_root ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_mixed_unicode_patterns ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_tilde_doublestar_blocks_any_file_under_home_dir ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_unclosed_bracket_treated_literally ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_bare_absolute_pattern_blocks_filesystem_path ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_negation_pattern ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_question_mark_pattern ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_single_pattern ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_tilde_pattern_does_not_match_different_home_subdir ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_directory_pattern ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_dot_path ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_empty_patterns ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_character_class_pattern ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_doublestar_directory_pattern ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_unclosed_character_class_treated_literally ... ok [INFO] [stdout] test blocked_files_tests::construction::test_new_with_unicode_pattern ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_anchored_pattern_matches_root ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_anchored_pattern_no_match_nested ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_character_class_digits ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_character_class_explicit_chars ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_character_class_letters ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_directory_pattern_matches_contents ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_empty_path ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_multiple_patterns_none_match ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_exact_filename_match ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_filename_in_subdirectory ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_directory_pattern_matches_dir ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_exact_filename_no_match ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_filename_deeply_nested ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_negation_excludes_file ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_doublestar_extension ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_question_mark_single_char ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_hidden_files_pattern ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_negation_order_matters ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_directory_pattern_nested ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_star_extension_no_match ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_multiple_question_marks ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_star_middle_match ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_question_mark_no_match_multiple_chars ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_doublestar_match_any_depth ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_tilde_pattern_does_not_match_outside_home ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_path_outside_project_root_is_checked_against_absolute_patterns ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_star_prefix_match ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_with_spaces_in_path ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_dir_only_pattern_matches_existing_directory_via_fs_probe ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_no_match_returns_none ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_negated_character_class ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_with_special_chars_in_filename ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_anchored_pattern_preserves_leading_slash ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_contains_forbidden ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_contains_matched ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_dir_only_pattern_does_not_match_file_leaf ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_dir_only_pattern_without_hint_on_nonexistent_leaf_still_misses ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_dir_only_pattern_matches_leaf_with_hint ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_contains_blocked_by_clarg ... ok [INFO] [stdout] test blocked_files_tests::absolute_patterns::test_new_with_home_pattern_and_unset_home_errors ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_multiple_patterns_any_match ... ok [INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_star_extension_match ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_empty_patterns_never_matches ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_contains_path ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_contains_pattern ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_directory_pattern_preserves_trailing_slash ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_with_nested_path ... ok [INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_with_complex_pattern ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 84 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s [INFO] [stdout] [INFO] [stderr] Running tests/cli_tests.rs (/opt/rustwide/target/debug/deps/cli_tests-de1611e79ac83882) [INFO] [stdout] [INFO] [stdout] running 157 tests [INFO] [stdout] test cli_tests::combinations::test_all_flags_combined_long ... ok [INFO] [stdout] test cli_tests::combinations::test_b_and_i_combined_only ... ok [INFO] [stdout] test cli_tests::combinations::test_all_flags_combined_multiple_values ... ok [INFO] [stdout] test cli_tests::combinations::test_all_flags_combined_short ... ok [INFO] [stdout] test cli_tests::combinations::test_all_flags_combined_mixed_short_long ... ok [INFO] [stdout] test cli_tests::combinations::test_all_flags_complex_patterns ... ok [INFO] [stdout] test cli_tests::combinations::test_flags_interleaved ... ok [INFO] [stdout] test cli_tests::combinations::test_flags_in_different_order ... ok [INFO] [stdout] test cli_tests::combinations::test_b_and_c_combined_only ... ok [INFO] [stdout] test cli_tests::combinations::test_b_c_and_l_combined_no_i ... ok [INFO] [stdout] test cli_tests::combinations::test_c_and_i_combined_only ... ok [INFO] [stdout] test cli_tests::combinations::test_only_i_flag_with_everything_else_default ... ok [INFO] [stdout] test cli_tests::combinations::test_only_l_flag_with_everything_else_default ... ok [INFO] [stdout] test cli_tests::combinations::test_equals_syntax_for_all_long_flags ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_multiple_dots ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_positional_relative ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_unicode ... ok [INFO] [stdout] test cli_tests::combinations::test_l_and_i_combined_only ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_no_extension ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_positional_absolute ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_with_extension_json ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_with_tilde ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_with_spaces ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_with_extension_yaml ... ok [INFO] [stdout] test cli_tests::combinations::test_mixed_short_and_long_flags ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_all_flags ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_positional_simple ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_very_long ... ok [INFO] [stdout] test cli_tests::config_path::test_config_path_with_extension_yml ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_commands_forbidden ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_internal_access_only ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_no_root ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_b ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_l ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_no_system_dirs ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_multiple_flags_long_form ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_block_access_to ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_comma_separated_with_spaces_around_comma ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_log_dir ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_no_unknown_tools ... ok [INFO] [stdout] test cli_tests::defaults::test_default_args_every_field_is_default ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_c ... ok [INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_i ... ok [INFO] [stdout] test cli_tests::defaults::test_default_args_no_flags ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_and_c_both_empty_strings ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_dot_files ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_double_star_pattern ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_glob_with_square_brackets ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_glob_with_curly_braces ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_numeric_pattern ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_negation_pattern ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_current_directory ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_patterns_with_backslashes ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_pattern_with_dollar ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_glob_with_curly_braces_using_multiple_flags ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_pattern_with_ampersand ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_pattern_with_pipe ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_glob_with_question_mark ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_missing_value ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_parent_directory ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_root_directory ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_pattern_with_semicolon ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_pattern_with_parentheses ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_pattern_with_tab ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_unicode_patterns ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_with_many_comma_separated_items ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_value_with_leading_space ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_with_relative_paths ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_regex_with_anchors ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_value_with_trailing_space ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_regex_with_groups ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_missing_value ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_pattern_with_quotes ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_pattern_with_single_quotes ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_with_home_directory_paths ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_regex_with_character_classes ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_pattern_with_backticks ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_value_with_internal_spaces ... ok [INFO] [stdout] test cli_tests::edge_cases::test_commands_forbidden_missing_value ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_unicode_patterns ... ok [INFO] [stdout] test cli_tests::edge_cases::test_equals_with_comma_in_value ... ok [INFO] [stdout] test cli_tests::edge_cases::test_double_dash_with_flags_before ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_numeric_pattern ... ok [INFO] [stdout] test cli_tests::edge_cases::test_equals_with_equals_in_value ... ok [INFO] [stdout] test cli_tests::edge_cases::test_block_access_to_missing_value ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_regex_with_escape_sequences ... ok [INFO] [stdout] test cli_tests::edge_cases::test_b_flag_with_absolute_paths ... ok [INFO] [stdout] test cli_tests::edge_cases::test_c_flag_with_many_comma_separated_items ... ok [INFO] [stdout] test cli_tests::edge_cases::test_double_dash_before_flag_like_config_path ... ok [INFO] [stdout] test cli_tests::edge_cases::test_double_dash_before_config_path ... ok [INFO] [stdout] test cli_tests::edge_cases::test_extremely_long_pattern_list ... ok [INFO] [stdout] test cli_tests::edge_cases::test_equals_with_empty_value ... ok [INFO] [stdout] test cli_tests::edge_cases::test_trailing_comma ... ok [INFO] [stdout] test cli_tests::edge_cases::test_unknown_long_flag ... ok [INFO] [stdout] test cli_tests::edge_cases::test_very_long_log_path ... ok [INFO] [stdout] test cli_tests::edge_cases::test_unknown_short_flag ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_block_access_to_comma_separated ... ok [INFO] [stdout] test cli_tests::edge_cases::test_leading_comma ... ok [INFO] [stdout] test cli_tests::edge_cases::test_log_dir_missing_value ... ok [INFO] [stdout] test cli_tests::edge_cases::test_l_flag_missing_value ... ok [INFO] [stdout] test cli_tests::edge_cases::test_very_long_single_pattern ... ok [INFO] [stdout] test cli_tests::edge_cases::test_log_path_unicode ... ok [INFO] [stdout] test cli_tests::edge_cases::test_misspelled_long_flag ... ok [INFO] [stdout] test cli_tests::edge_cases::test_multiple_commas ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_block_access_to_equals_syntax ... ok [INFO] [stdout] test cli_tests::edge_cases::test_multiple_positional_arguments_error ... ok [INFO] [stdout] test cli_tests::edge_cases::test_single_comma ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_log_dir_equals_syntax ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_log_dir_simple_path ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_internal_access_only ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_log_dir_path_with_spaces ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_empty_string ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_comma_separated_multiple_items ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_internal_access_only_is_boolean ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_block_access_to_multiple_flags ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_block_access_to_single ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_commands_forbidden_comma_separated ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_commands_forbidden_single ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_commands_forbidden_equals_syntax ... ok [INFO] [stdout] test cli_tests::long_flags::test_long_flag_commands_forbidden_multiple_flags ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_multiple_flags_three_items ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_pattern_with_spaces_quoted ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_single_pattern ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_patterns_with_slashes ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_glob_patterns ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_comma_separated_two_items ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_patterns_with_dots ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_special_characters ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_multiple_flags ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_mixed_comma_and_multiple_flags ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_empty_string ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_multiple_flags ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_patterns_with_special_chars ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_regex_patterns ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_i_alone ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_multiple_flags_three_items ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_mixed_comma_and_multiple_flags ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_l_very_long_path ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_l_path_with_spaces ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_i_is_boolean ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_l_simple_path ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_single_command ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_command_with_spaces_quoted ... ok [INFO] [stdout] test cli_tests::version_help::test_help_and_version_help_wins ... ok [INFO] [stdout] test cli_tests::version_help::test_help_at_end ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_l_path_with_tilde ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_l_relative_path ... ok [INFO] [stdout] test cli_tests::version_help::test_help_flag_long ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_comma_separated_two_items ... ok [INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_comma_separated_multiple_items ... ok [INFO] [stdout] test cli_tests::version_help::test_version_with_other_flags_shows_version ... ok [INFO] [stdout] test cli_tests::version_help::test_version_and_help_version_wins ... ok [INFO] [stdout] test cli_tests::version_help::test_version_at_end ... ok [INFO] [stdout] test cli_tests::version_help::test_version_flag_long ... ok [INFO] [stdout] test cli_tests::version_help::test_help_with_other_flags_shows_help ... ok [INFO] [stdout] test cli_tests::version_help::test_version_flag_short ... ok [INFO] [stderr] Running tests/config_tests.rs (/opt/rustwide/target/debug/deps/config_tests-3770f06db5076036) [INFO] [stdout] test cli_tests::version_help::test_help_flag_short ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 157 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 113 tests [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_boolean_on ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_boolean_variations ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_array_with_single_item ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_config_default_trait ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_boolean_off ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_boolean_no ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_boolean_yes ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_commands_with_pipes_and_redirects ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_case_sensitivity ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_indentation_with_tabs ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_mac_classic_line_endings ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_log_dir_empty_string ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_commands_with_shell_metacharacters ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_mixed_array_and_block_style ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_patterns_with_only_whitespace ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_utf8_bom ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_compact_format ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_windows_line_endings ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_all_flags_populated ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_patterns_with_forward_slashes ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_deeply_nested_patterns ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_document_markers ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_mixed_line_endings ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_only_internal_access_only ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_only_no_root ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_only_no_system_dirs ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_only_no_unknown_tools ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_only_commands_forbidden ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_partial_flags ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_only_log_dir ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_trailing_comma_not_allowed ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_with_config_path_no_unknown_tools ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_with_config_path ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_all_fields ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_extremely_nested_flow_style ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_patterns_with_dots ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_only_internal_access_only_true ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_all_three_special_flags_true ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_empty_arrays ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_only_log_dir ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_special_flags_parses_both_true ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_duplicate_patterns ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_special_flags_alongside_other_fields ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_empty_file ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_only_block_access_to ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_special_flags_defaults_false_when_missing ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_only_commands_forbidden ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_only_block_access_to ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_minimal_valid ... ok [INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_multiple_documents ... ok [INFO] [stdout] test config_tests::from_cli::test_from_cli_no_flags ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_null_commands_forbidden ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_special_flags_no_root_null_errors ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_only_internal_access_only_false ... ok [INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_special_flags_partial_section_defaults_other_flag_false ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_null_log_dir ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_special_flags_no_unknown_tools_null_errors ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_extra_fields_ignored ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_null_internal_access_only ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_special_flags_no_unknown_tools_wrong_type ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_special_flags_no_root_wrong_type ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_file_does_not_exist ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_invalid_yaml_syntax ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_invalid_yaml_syntax_missing_colon ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_null_block_access_to ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_wrong_type_commands_forbidden_string ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_wrong_type_block_access_to_string ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_wrong_type_block_access_to_number ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_log_dir_home_directory ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_log_dir_parent_directory ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_special_flags_unknown_nested_key_errors ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_wrong_type_internal_access_only_number ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_top_level_unknown_keys_still_ignored_alongside_special_flags ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_log_dir_absolute_path ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_complex_regex_patterns ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_wrong_type_commands_forbidden_number ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_wrong_type_log_dir_array ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_gitignore_glob_patterns ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_complex_gitignore_patterns ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_log_dir_current_directory ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_gitignore_negation_patterns ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_log_dir_relative_path ... ok [INFO] [stdout] test config_tests::from_yaml_errors::test_from_yaml_wrong_type_internal_access_only_string ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_log_dir_with_spaces ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_unicode_commands ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_unicode_patterns ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_unicode_log_path ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_many_patterns ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_many_commands ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_regex_patterns_in_commands_forbidden ... ok [INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_very_large_arrays ... ok [INFO] [stdout] test config_tests::from_yaml_strings::test_from_yaml_empty_strings_in_block_access_to ... ok [INFO] [stdout] test config_tests::from_yaml_strings::test_from_yaml_empty_strings_in_commands_forbidden ... ok [INFO] [stdout] test config_tests::from_yaml_strings::test_from_yaml_patterns_with_leading_spaces ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_backslashes_in_patterns ... ok [INFO] [stdout] test config_tests::from_yaml_strings::test_from_yaml_patterns_with_trailing_spaces ... ok [INFO] [stdout] test config_tests::from_yaml_strings::test_from_yaml_patterns_with_tabs ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_escaped_quotes_in_values ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_flow_style_complete ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_multiline_folded_strings ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_mixed_quoted_values ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_newlines_in_patterns ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_multiline_literal_strings ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_double_quoted_values ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_flow_style_arrays ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_with_anchors_and_aliases ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_with_comments ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_very_long_strings ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_special_characters_in_patterns ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_yaml_numbers_as_strings ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_with_only_comments ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_yaml_special_values ... ok [INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_single_quoted_values ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 113 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s [INFO] [stdout] [INFO] [stderr] Running tests/hook_input_tests.rs (/opt/rustwide/target/debug/deps/hook_input_tests-1df49634f2221efc) [INFO] [stdout] [INFO] [stdout] running 136 tests [INFO] [stdout] test hook_input_tests::claude_tools::test_glob_tool_with_path_and_pattern ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_edit_tool_with_replace_all ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_bash_tool_with_timeout ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_glob_tool_with_pattern ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_edit_tool_with_old_and_new_string ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_read_tool_with_file_path ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_grep_tool_with_all_options ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_read_tool_with_offset_and_limit ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_grep_tool_with_pattern ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_task_update_tool ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_webfetch_tool_with_url_and_prompt ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_websearch_tool_with_query ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_websearch_tool_with_domain_filters ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_command_with_pipes_and_redirects ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_write_tool_with_file_path_and_content ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_permission_mode_explicit_null ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_full_hook_input_all_fields ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_session_id_with_special_characters ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_file_path_with_backslashes ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_tool_input_explicit_null ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_tool_input_deeply_nested ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_tool_use_id_explicit_null ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_very_long_strings ... ok [INFO] [stdout] test hook_input_tests::edge_cases::test_debug_format ... ok [INFO] [stdout] test hook_input_tests::edge_cases::test_minimal_valid_json ... ok [INFO] [stdout] test hook_input_tests::edge_cases::test_notebook_edit_tool ... ok [INFO] [stdout] test hook_input_tests::edge_cases::test_strings_with_leading_trailing_whitespace ... ok [INFO] [stdout] test hook_input_tests::edge_cases::test_strings_with_newlines ... ok [INFO] [stdout] test hook_input_tests::edge_cases::test_tool_input_with_prompt ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_task_create_tool ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_transcript_path_explicit_null ... ok [INFO] [stdout] test hook_input_tests::edge_cases::test_skill_tool ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_tool_input_large_array ... ok [INFO] [stdout] test hook_input_tests::complex_scenarios::test_multiple_helper_methods_on_same_input ... ok [INFO] [stdout] test hook_input_tests::edge_cases::test_tool_input_with_query ... ok [INFO] [stdout] test hook_input_tests::edge_cases::test_tool_input_with_url ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_command_returns_none_when_absent ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_command_returns_none_when_command_is_null ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_command_returns_none_when_not_a_string ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_command_returns_some_when_present ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_command_returns_none_when_tool_input_empty ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_file_path_returns_none_when_tool_input_empty ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_file_path_returns_none_when_absent ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_pattern_returns_none_when_not_a_string ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_pattern_returns_none_when_tool_input_empty ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_file_path_returns_none_when_file_path_is_boolean ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_search_path_returns_some_when_present ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_file_path_returns_none_when_file_path_is_object ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_file_path_returns_none_when_file_path_is_array ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_command_with_complex_bash_script ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_file_path_returns_none_when_file_path_is_null ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_file_path_returns_none_when_not_a_string ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_all_optional_fields_missing ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_all_optional_fields_present ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_only_permission_mode_present ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_only_transcript_path_present ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_only_tool_use_id_present ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_permission_mode_and_tool_use_id_present ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_permission_mode_missing ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_permission_mode_present ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_search_path_returns_none_when_tool_input_empty ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_tool_use_id_missing ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_pattern_returns_some_when_present ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_transcript_path_missing ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_transcript_path_and_permission_mode_present ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_pattern_returns_none_when_absent ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_transcript_path_and_tool_use_id_present ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_transcript_path_present ... ok [INFO] [stdout] test hook_input_tests::paths::test_cwd_windows_style_path ... ok [INFO] [stdout] test hook_input_tests::paths::test_cwd_with_dots ... ok [INFO] [stdout] test hook_input_tests::paths::test_cwd_absolute_path ... ok [INFO] [stdout] test hook_input_tests::paths::test_cwd_with_spaces ... ok [INFO] [stdout] test hook_input_tests::paths::test_cwd_relative_path ... ok [INFO] [stdout] test hook_input_tests::optional_fields::test_tool_use_id_present ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_file_path_returns_some_when_present ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_bash_tool_with_simple_command ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_bash_tool_with_run_in_background ... ok [INFO] [stdout] test hook_input_tests::edge_cases::test_strings_with_tabs ... ok [INFO] [stdout] test hook_input_tests::paths::test_cwd_with_special_characters ... ok [INFO] [stdout] test hook_input_tests::permission_and_events::test_hook_event_name_custom_value ... ok [INFO] [stdout] test hook_input_tests::permission_and_events::test_hook_event_name_post_tool_use ... ok [INFO] [stdout] test hook_input_tests::permission_and_events::test_hook_event_name_pre_tool_use ... ok [INFO] [stdout] test hook_input_tests::permission_and_events::test_tool_input_with_mixed_types ... ok [INFO] [stdout] test hook_input_tests::permission_and_events::test_tool_input_with_numbers ... ok [INFO] [stdout] test hook_input_tests::permission_and_events::test_tool_input_with_null_values ... ok [INFO] [stdout] test hook_input_tests::required_fields::test_missing_session_id_fails ... ok [INFO] [stdout] test hook_input_tests::required_fields::test_missing_cwd_fails ... ok [INFO] [stdout] test hook_input_tests::required_fields::test_missing_hook_event_name_fails ... ok [INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_missing_uses_default ... ok [INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_file_path ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_search_path_returns_none_when_absent ... ok [INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_arrays ... ok [INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_path_and_pattern ... ok [INFO] [stdout] test hook_input_tests::helper_methods::test_search_path_returns_none_when_not_a_string ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_cwd_wrong_type_number ... ok [INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_path_only ... ok [INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_nested_objects ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_extra_fields_ignored ... ok [INFO] [stdout] test hook_input_tests::permission_and_events::test_tool_input_with_booleans ... ok [INFO] [stdout] test hook_input_tests::required_fields::test_all_required_fields_present ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_permission_mode_custom_value ... ok [INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_command ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_permission_mode_default ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_permission_mode_wrong_type_boolean ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_session_id_wrong_type_boolean ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_session_id_wrong_type_number ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_tool_input_wrong_type_number ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_tool_input_wrong_type_string ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_transcript_path_wrong_type_number ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_command ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_tool_name_wrong_type_object ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_file_path ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_tool_use_id_wrong_type_array ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_pattern ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_hook_event_name ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_session_id ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_transcript_path ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_tool_name ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_hook_event_name ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_cwd ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_permission_mode ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_tool_input_file_path ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_tool_input_command ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_session_id ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_transcript_path ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_tool_name ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_permission_mode ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_tool_use_id ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_tool_use_id ... ok [INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_empty_object ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_hook_event_name_wrong_type_array ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_many_extra_fields ... ok [INFO] [stdout] test hook_input_tests::types_and_fields::test_permission_mode_approved ... ok [INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_search_path ... ok [INFO] [stdout] test hook_input_tests::required_fields::test_missing_tool_name_fails ... ok [INFO] [stdout] test hook_input_tests::claude_tools::test_read_tool_with_pdf_pages ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 136 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.21s [INFO] [stdout] [INFO] [stderr] Running tests/integration.rs (/opt/rustwide/target/debug/deps/integration-9472fc64811cdd4a) [INFO] [stdout] [INFO] [stdout] running 38 tests [INFO] [stdout] test integration::blocked_commands::test_block_rm_rf ... ok [INFO] [stdout] test integration::blocked_commands::test_no_rules_allows_all ... ok [INFO] [stdout] test integration::blocked_files::test_multiple_blocked_patterns ... ok [INFO] [stdout] test integration::blocked_files::test_allow_normal_file_read ... ok [INFO] [stdout] test integration::cli::test_bare_invocation_in_tty_shows_friendly_usage ... ok [INFO] [stdout] test integration::cli::test_version_flag_in_tty ... ok [INFO] [stdout] test integration::config::test_cli_no_system_dirs_allows_tmp_write ... ok [INFO] [stdout] test integration::cli::test_positional_with_flags_error ... ok [INFO] [stdout] test integration::blocked_files::test_block_env_file_read ... ok [INFO] [stdout] test integration::config::test_claude_project_dir_override ... ok [INFO] [stdout] test integration::cli::test_version_flag ... ok [INFO] [stdout] test integration::config::test_cli_no_system_dirs_blocks_brace_expansion_bypass ... ok [INFO] [stdout] test integration::config::test_cli_no_system_dirs_blocks_tilde_root_bypass ... ok [INFO] [stdout] test integration::config::test_relative_config_without_project_dir_uses_cwd ... ok [INFO] [stdout] test integration::config::test_relative_config_resolved_against_project_dir ... ok [INFO] [stdout] test integration::cli::test_help_flag ... ok [INFO] [stdout] test integration::cli::test_help_flag_in_tty ... ok [INFO] [stdout] test integration::internal_only::test_block_eval_external ... ok [INFO] [stdout] test integration::internal_only::test_block_rg_external_path ... ok [INFO] [stdout] test integration::internal_only::test_internal_only_blocks_grep_outside ... ok [INFO] [stdout] test integration::config::test_cli_internal_only_blocks_tilde_user_bypass ... ok [INFO] [stdout] test integration::internal_only::test_internal_only_blocks_write_outside ... ok [INFO] [stdout] test integration::logging::test_log_dir_file ... ok [INFO] [stdout] test integration::internal_only::test_block_bash_c_external ... ok [INFO] [stdout] test integration::internal_only::test_internal_only_blocks_glob_outside ... ok [INFO] [stdout] test integration::passthrough::test_web_tools_always_allowed ... ok [INFO] [stdout] test integration::passthrough::test_task_tool_allowed ... ok [INFO] [stdout] test integration::config::test_cli_no_root_denies_rm_rf_root ... ok [INFO] [stdout] test integration::internal_only::test_allow_rg_internal_path ... ok [INFO] [stdout] test integration::passthrough::test_unknown_tool_allowed ... ok [INFO] [stdout] test integration::config::test_cli_no_unknown_tools_allows_known_tool ... ok [INFO] [stdout] test integration::config::test_cli_no_unknown_tools_denies_mcp_tool ... ok [INFO] [stdout] test integration::internal_only::test_block_cd_external_chained ... ok [INFO] [stdout] test integration::config::test_yaml_special_flags_no_system_dirs_denies_read_etc ... ok [INFO] [stdout] test integration::config::test_yaml_config_equivalent ... ok [INFO] [stdout] test integration::cli::test_malformed_json_fail_closed ... ok [INFO] [stdout] test integration::cli::test_empty_stdin_fail_closed ... ok [INFO] [stdout] test integration::config::test_yaml_special_flags_typo_fails_closed ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 38 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.46s [INFO] [stdout] [INFO] [stderr] Running tests/internalonly_tests.rs (/opt/rustwide/target/debug/deps/internalonly_tests-fca4b4f648498dfb) [INFO] [stdout] [INFO] [stdout] running 91 tests [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_absolute_outside_path ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_child_is_inside ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_different_context_strings ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_prefix_attack_blocked ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_deeply_nested_is_inside ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_sibling_is_outside ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_exact_match_is_inside ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_dollar_home_in_middle_unchanged ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_dollar_home_nested_path ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_reason_contains_outside ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_curly_brace_syntax_not_expanded ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_reason_contains_blocked_by_clarg ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_minus_alone_literal ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_reason_contains_context ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_reason_contains_target_path ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_other_env_vars_not_expanded ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_empty_string ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_relative_path_unchanged ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_reason_contains_project_root ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_root_is_outside ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_dollar_home_only ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_dollar_home_slash_only ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_absolute_path_unchanged ... ok [INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_parent_is_outside ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_digit_left_literal ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_in_middle_unchanged ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_minus_digit_left_literal ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_minus_left_literal ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_nested_path ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_plus_alone_literal ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_punctuation_left_literal ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_plus_digit_left_literal ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_slash_only ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_root_lands_in_system_dir ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_with_dash_after_alpha_still_resolves ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_plus_left_literal ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_unicode ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_complex_path ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_with_dots ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_double_dot_at_end ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_double_dot_at_root_stays_at_root ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_with_spaces ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_double_dot_with_no_parent ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_with_path ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_empty_path ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_double_slash ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_leading_dot ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_mixed_dots ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_path_with_spaces ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_double_dot_pops_directory ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_path_with_special_chars ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_preserves_absolute ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_multiple_consecutive_dots ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_preserves_relative ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_relative_path ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_removes_single_dots ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_simple_path ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_user_resolves_to_platform_home ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_single_dot ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_single_component ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_user_with_path ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_trailing_dot ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_unicode_path ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_trailing_slash ... ok [INFO] [stdout] test internalonly_tests::resolve_project_root::test_resolve_project_root_empty_path ... ok [INFO] [stdout] test internalonly_tests::resolve_project_root::test_resolve_project_root_canonicalizes_path ... ok [INFO] [stdout] test internalonly_tests::resolve_project_root::test_resolve_project_root_existing_dir ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_root_only ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_root_no_path ... ok [INFO] [stdout] test internalonly_tests::resolve_project_root::test_resolve_project_root_returns_absolute ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_absolute_with_dots_normalized ... ok [INFO] [stdout] test internalonly_tests::resolve_project_root::test_resolve_project_root_follows_symlinks ... ok [INFO] [stdout] test internalonly_tests::resolve_project_root::test_resolve_project_root_nonexistent_path ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_many_parent_dirs ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_relative_with_dots_normalized ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_absolute_path_unchanged ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_dollar_home_expanded ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_relative_joined_to_root ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_empty_string ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_relative_with_parent_dir ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_unicode ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_tilde_only ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_single_dot ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_tilde_expanded ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_with_spaces ... ok [INFO] [stdout] test internalonly_tests::resolve_project_root::test_resolve_project_root_current_dir ... ok [INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_dotslash_prefix ... ok [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_dollar_home_with_path ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_double_dot_exceeds_path ... ok [INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_multiple_double_dots ... ok [INFO] [stderr] Running tests/output_tests.rs (/opt/rustwide/target/debug/deps/output_tests-5afb39d27588d693) [INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_only ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 91 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.19s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 28 tests [INFO] [stdout] test output_tests::deny_json::test_deny_json_permission_decision_is_deny ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_hook_event_name_is_correct ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_control_characters ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_empty_reason ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_json_braces ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_structure_is_correct ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_json_quotes ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_newlines ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_backslashes ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_is_valid_json ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_null_character ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_special_characters ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_unicode_emojis ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_unicode_reason ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_very_long_reason ... ok [INFO] [stdout] test output_tests::edge_cases::test_deny_json_hook_output_keys_exact ... ok [INFO] [stdout] test output_tests::edge_cases::test_deny_json_reason_with_xml_entities ... ok [INFO] [stdout] test output_tests::edge_cases::test_deny_json_reason_with_html_tags ... ok [INFO] [stdout] test output_tests::edge_cases::test_deny_json_structure_immutability ... ok [INFO] [stdout] test output_tests::edge_cases::test_deny_json_top_level_keys_exact ... ok [INFO] [stdout] test output_tests::edge_cases::test_deny_json_value_type_check ... ok [INFO] [stdout] test output_tests::edge_cases::test_deny_json_with_maximum_unicode_characters ... ok [INFO] [stdout] test output_tests::integration::test_deny_json_serialization_roundtrip ... ok [INFO] [stdout] test output_tests::integration::test_deny_json_with_json_injection_attempt ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_serializes_correctly ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_simple_reason ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_with_tabs ... ok [INFO] [stdout] test output_tests::deny_json::test_deny_json_all_keys_present ... ok [INFO] [stderr] Running tests/router_tests.rs (/opt/rustwide/target/debug/deps/router_tests-345c1e74df51f0fe) [INFO] [stdout] [INFO] [stdout] test result: ok. 28 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.11s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 189 tests [INFO] [stdout] test router_tests::bash_tool::test_bash_allows_non_matching_paths_with_flags_on ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_blocked_command_denied ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_blocked_command_after_internal_check_passes ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_blocked_files_non_match_allowed ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_blocked_files_curl_upload ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_blocked_files_piped_command ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_blocked_files_redirect_to_env ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_blocked_files_sed_on_env ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_blocked_files_wildcard_pattern ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_brace_expansion_does_not_false_positive_in_project ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_brace_expansion_with_ls_unknown_command_blocked ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_brace_expansion_in_redirection_blocked ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_cd_dash_allowed_when_only_system_path_flags_active ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_brace_expansion_with_traversal_blocked ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_cd_implicit_home_allowed_when_only_system_path_flags_active ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_chained_command_with_external_blocked ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_brace_expansion_in_first_component_blocked_by_no_system_dirs ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_internal_only_allows_internal_path ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_eval_with_external_path_blocked ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_missing_command_allowed ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_internal_only_checked_before_blocked_commands ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_mkdir_secrets_denied_by_dir_only_pattern ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_cd_system_dir_blocked_by_no_system_dirs ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_root_blocks_lex_variant_dot ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_root_blocks_lex_variant_parent ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_root_blocks_lex_variant_tmp_parent ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_curl_config_external_denied_under_i ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_double_quoted_dollar_home_redirect_still_blocked_under_internal_only ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_root_blocks_ls_root_glob ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_blocked_files_cat_env_denied ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_cd_root_blocked_by_no_root ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_internal_only_blocks_external_path ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_internal_only_blocks_bare_python_c ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_internal_only_blocks_dynamic_traversal ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_root_blocks_python_inline_bare_root ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_inline_code_still_blocks_literal_external_path_without_internal_only ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_cd_secrets_denied_by_dir_only_pattern ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_inline_code_allowed_without_internal_only ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_root_blocks_redirect_to_root ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_internal_only_blocks_redirect_outside ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_internal_only_blocks_cd_outside ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_root_blocks_rg_root ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_escaped_dollar_home_redirect_allowed_under_internal_only ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_root_blocks_rm_rf_root ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_root_blocks_rm_rf_root_glob ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_rules_allows_anything ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_allows_dd_if_dev_null_to_local ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_allows_private_tmp ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_cp_to_usr_bin ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_cat_etc_passwd ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_dd_of_usr_bin ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_rmdir_secrets_denied_by_dir_only_pattern ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_piped_command_with_external_path_blocked ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_find_var ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_non_blocked_command_allowed ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_single_quoted_brace_literal_allowed_under_no_system_dirs ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_unknown_cmd_flag_value ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_sed_f_external_script_denied_under_i ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_single_quoted_redirect_tilde_allowed_under_internal_only ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_tilde_user_blocked_by_internal_access_only ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_unquoted_braces_still_blocked_under_no_system_dirs ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_tilde_root_blocked_by_no_system_dirs ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_unquoted_dollar_home_redirect_still_blocked_under_internal_only ... ok [INFO] [stdout] test router_tests::construction::test_build_blocked_files_without_internal_only ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_wget_input_file_external_denied_under_i ... ok [INFO] [stdout] test router_tests::construction::test_build_with_all_rules ... ok [INFO] [stdout] test router_tests::construction::test_build_with_blocked_commands ... ok [INFO] [stdout] test router_tests::construction::test_build_with_blocked_files ... ok [INFO] [stdout] test router_tests::construction::test_build_with_empty_config ... ok [INFO] [stdout] test router_tests::construction::test_build_with_internal_only ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_tilde_user_bare_blocked_by_internal_access_only ... ok [INFO] [stdout] test router_tests::construction::test_build_with_nonexistent_project_root_for_internal_only_fails ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_tilde_root_still_blocked_under_no_system_dirs ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_tilde_minus_path_allowed_under_internal_only ... ok [INFO] [stdout] test router_tests::construction::test_build_with_invalid_regex_fails ... ok [INFO] [stdout] test router_tests::construction::test_build_with_multiple_file_patterns ... ok [INFO] [stdout] test router_tests::file_tools::test_edit_blocked_files_denies_match ... ok [INFO] [stdout] test router_tests::file_tools::test_edit_internal_only_blocks_external ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_tilde_plus_path_allowed_under_internal_only ... ok [INFO] [stdout] test router_tests::file_tools::test_edit_no_system_dirs_allows_tmp_when_only_system_flag_active ... ok [INFO] [stdout] test router_tests::file_tools::test_edit_internal_only_allows_internal ... ok [INFO] [stdout] test router_tests::construction::test_build_with_multiple_command_patterns ... ok [INFO] [stdout] test router_tests::file_tools::test_edit_no_system_dirs_allows_private_tmp ... ok [INFO] [stdout] test router_tests::file_tools::test_notebookedit_blocked_files_denies_match ... ok [INFO] [stdout] test router_tests::file_tools::test_notebookedit_internal_only_allows_internal ... ok [INFO] [stdout] test router_tests::file_tools::test_path_tool_with_only_system_paths_rule_does_not_short_circuit_allow ... ok [INFO] [stdout] test router_tests::file_tools::test_notebookedit_case_insensitive_routing ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_curl_data_at_etc_passwd ... ok [INFO] [stdout] test router_tests::file_tools::test_read_blocked_files_allows_non_match ... ok [INFO] [stdout] test router_tests::file_tools::test_notebookedit_no_rules_allows ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_curl_upload_etc_passwd ... ok [INFO] [stdout] test router_tests::file_tools::test_read_internal_only_allows_internal ... ok [INFO] [stdout] test router_tests::file_tools::test_read_blocked_files_denies_match ... ok [INFO] [stdout] test router_tests::file_tools::test_read_no_system_dirs_inside_project_allowed ... ok [INFO] [stdout] test router_tests::file_tools::test_read_internal_only_blocks_external ... ok [INFO] [stdout] test router_tests::file_tools::test_notebookedit_internal_only_blocks_external ... ok [INFO] [stdout] test router_tests::file_tools::test_read_no_system_dirs_blocks_private_etc ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_python_inline_etc_passwd ... ok [INFO] [stdout] test router_tests::file_tools::test_read_parent_traversal_blocked ... ok [INFO] [stdout] test router_tests::file_tools::test_read_no_root_blocks_root ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_redirect_to_etc ... ok [INFO] [stdout] test router_tests::file_tools::test_read_no_rules_allows_anything ... ok [INFO] [stdout] test router_tests::file_tools::test_file_tool_missing_file_path_allowed ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_root_blocks_unknown_cmd_bare_root ... ok [INFO] [stdout] test router_tests::file_tools::test_read_tilde_plus_allowed_under_internal_only ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_curl_output_usr_bin ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_quoted_redirect_outside_blocked ... ok [INFO] [stdout] test router_tests::file_tools::test_file_tool_internal_only_checked_before_blocked_files ... ok [INFO] [stdout] test router_tests::file_tools::test_write_tilde_expansion_blocked ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_internal_checked_before_blocked_files ... ok [INFO] [stdout] test router_tests::file_tools::test_write_tilde_minus_allowed_under_internal_only ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_internal_only_allows_internal_path ... ok [INFO] [stdout] test router_tests::file_tools::test_write_tilde_user_blocked_by_internal_access_only ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_blocked_files_allows_non_blocked_path ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_blocked_files_denies_blocked_path ... ok [INFO] [stdout] test router_tests::file_tools::test_write_blocked_files_denies_match ... ok [INFO] [stdout] test router_tests::file_tools::test_write_internal_only_allows_internal ... ok [INFO] [stdout] test router_tests::file_tools::test_write_internal_only_blocks_external ... ok [INFO] [stdout] test router_tests::file_tools::test_write_no_system_dirs_blocks_etc ... ok [INFO] [stdout] test router_tests::file_tools::test_read_tilde_root_blocked_by_no_system_dirs ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_internal_only_blocks_tilde_path ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_missing_path_allowed ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_no_root_blocks_root ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_absolute_internal_path_allowed ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_blocked_files_denies_blocked_path ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_internal_only_allows_internal_path ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_internal_only_blocks_parent_traversal ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_internal_only_blocks_external_path ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_no_rules_allows_anything ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_blocked_files_allows_non_blocked_path ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_relative_path_inside_allowed ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_internal_checked_before_blocked_files ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_no_system_dirs_blocks_usr ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_no_root_blocks_root ... ok [INFO] [stdout] test router_tests::glob_tool::test_glob_relative_parent_traversal_blocked ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_internal_only_blocks_parent_traversal ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_missing_path_allowed ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_no_rules_allows_anything ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_known_tool_mixed_case_allowed_when_no_unknown_tools ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_tilde_root_blocked_by_no_system_dirs ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_bash_lowercase_routed_correctly ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_bash_uppercase_routed_correctly ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_glob_case_insensitive_routing ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_no_system_dirs_blocks_usr ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_relative_path_inside_allowed ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_relative_parent_traversal_blocked ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_grep_lowercase_routed_correctly ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_read_still_routed_when_no_unknown_tools ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_task_always_allowed_no_rules ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_task_still_allowed_when_no_unknown_tools ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_task_allowed_with_internal_only ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_mcp_tool_allowed ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_unknown_tool_reason_mentions_tool_name_and_flag ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_mcp_tool_denied_when_no_unknown_tools ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_unknown_tool_denied_with_all_other_rules_when_no_unknown_tools ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_unknown_tool_allowed_with_all_rules ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_read_mixed_case_routed_correctly ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_task_empty_input_allowed ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_unknown_tool_allowed_no_rules ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_unknown_tool_denied_when_no_unknown_tools ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_internal_only_blocks_external_path ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_bash_still_routed_when_no_unknown_tools ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_webfetch_always_allowed_no_rules ... ok [INFO] [stdout] test router_tests::rule_ordering::test_file_blocked_files_triggers_when_internal ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_webfetch_allowed_with_all_rules ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_webfetch_empty_input_allowed ... ok [INFO] [stdout] test router_tests::rule_ordering::test_bash_internalonly_before_blocked_commands_external ... ok [INFO] [stdout] test router_tests::rule_ordering::test_bash_system_paths_before_internal_access_only ... ok [INFO] [stdout] test router_tests::rule_ordering::test_bash_system_paths_before_blocked_files ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_webfetch_still_allowed_when_no_unknown_tools ... ok [INFO] [stdout] test router_tests::rule_ordering::test_bash_both_rules_pass_allows ... ok [INFO] [stdout] test router_tests::rule_ordering::test_file_internalonly_before_blocked_files ... ok [INFO] [stdout] test router_tests::rule_ordering::test_no_rules_allows_everything_bash ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_websearch_allowed_with_internal_only ... ok [INFO] [stdout] test router_tests::grep_tool::test_grep_internal_only_blocks_home_var ... ok [INFO] [stdout] test router_tests::rule_ordering::test_only_blocked_commands_blocks_matching_pattern ... ok [INFO] [stdout] test router_tests::rule_ordering::test_no_rules_allows_everything_read ... ok [INFO] [stdout] test router_tests::rule_ordering::test_file_both_rules_pass_allows ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_websearch_always_allowed_no_rules ... ok [INFO] [stdout] test router_tests::rule_ordering::test_bash_blocked_commands_triggers_when_internal ... ok [INFO] [stdout] test router_tests::passthrough_tools::test_webfetch_allowed_with_internal_only ... ok [INFO] [stdout] test router_tests::rule_ordering::test_only_blocked_commands_allows_external_paths_in_bash ... ok [INFO] [stdout] test router_tests::rule_ordering::test_only_blocked_files_blocks_matching_pattern ... ok [INFO] [stdout] test router_tests::rule_ordering::test_only_blocked_files_allows_non_matching_internal ... ok [INFO] [stdout] test router_tests::rule_ordering::test_only_internalonly_blocks_external ... ok [INFO] [stdout] test router_tests::rule_ordering::test_only_internalonly_allows_internal ... ok [INFO] [stdout] test router_tests::rule_ordering::test_path_tool_system_paths_before_blocked_files ... ok [INFO] [stdout] test router_tests::rule_ordering::test_path_tool_system_paths_before_internal_access_only ... ok [INFO] [stdout] test router_tests::bash_tool::test_bash_quoted_redirect_with_space_outside_blocked ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 189 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.08s [INFO] [stdout] [INFO] [stderr] Running tests/system_paths_tests.rs (/opt/rustwide/target/debug/deps/system_paths_tests-c08d784126a8800d) [INFO] [stdout] [INFO] [stdout] running 25 tests [INFO] [stdout] test system_paths_tests::construction::test_inactive_rule_allows_everything ... ok [INFO] [stdout] test system_paths_tests::construction::test_is_active_when_both_flags ... ok [INFO] [stdout] test system_paths_tests::construction::test_is_active_when_no_system_dirs_only ... ok [INFO] [stdout] test system_paths_tests::construction::test_is_inactive_when_both_flags_off ... ok [INFO] [stdout] test system_paths_tests::no_root::test_no_root_blocks_exact_root ... ok [INFO] [stdout] test system_paths_tests::no_root::test_no_root_blocks_lexically_normalized_root_globs ... ok [INFO] [stdout] test system_paths_tests::no_root::test_no_root_blocks_normalized_root_aliases ... ok [INFO] [stdout] test system_paths_tests::no_root::test_no_root_does_not_block_non_root_absolute_paths ... ok [INFO] [stdout] test system_paths_tests::no_root::test_no_root_does_not_block_project_relative_paths ... ok [INFO] [stdout] test system_paths_tests::no_root::test_no_root_blocks_root_glob_forms ... ok [INFO] [stdout] test system_paths_tests::no_system_dirs::test_no_system_dirs_allows_private_tmp_exception ... ok [INFO] [stdout] test system_paths_tests::no_system_dirs::test_no_system_dirs_blocks_descendants_of_system_dirs ... ok [INFO] [stdout] test system_paths_tests::no_system_dirs::test_no_system_dirs_blocks_exact_system_dirs ... ok [INFO] [stdout] test system_paths_tests::no_root::test_no_root_does_not_block_root_followed_by_non_glob_segment ... ok [INFO] [stdout] test system_paths_tests::reason_messages::test_no_system_dirs_reason_includes_matched_system_dir_and_path ... ok [INFO] [stdout] test system_paths_tests::no_system_dirs::test_no_system_dirs_does_not_block_excluded_dirs ... ok [INFO] [stdout] test system_paths_tests::no_system_dirs::test_no_system_dirs_does_not_block_prefix_lookalikes ... ok [INFO] [stdout] test system_paths_tests::project_root_escape_hatch::test_no_root_escape_hatch_does_not_apply ... ok [INFO] [stdout] test system_paths_tests::no_system_dirs::test_no_system_dirs_with_no_root_flag_blocks_root_too ... ok [INFO] [stdout] test system_paths_tests::project_root_escape_hatch::test_no_system_dirs_allows_paths_inside_project_root_when_project_is_under_system_dir ... ok [INFO] [stdout] test system_paths_tests::project_root_escape_hatch::test_no_system_dirs_blocks_sibling_outside_project_even_under_same_system_prefix ... ok [INFO] [stdout] test system_paths_tests::project_root_escape_hatch::test_project_root_escape_hatch_handles_canonical_vs_alias_paths ... ok [INFO] [stdout] test system_paths_tests::reason_messages::test_no_root_glob_reason_mentions_glob ... ok [INFO] [stdout] test system_paths_tests::reason_messages::test_no_root_reason_is_specific ... ok [INFO] [stdout] test system_paths_tests::construction::test_is_active_when_no_root_only ... ok [INFO] [stderr] Doc-tests clarg [INFO] [stdout] [INFO] [stdout] test result: ok. 25 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s [INFO] [stdout] [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] running `Command { std: "docker" "inspect" "c57f26f53741e54b8903955ac643a9723a0590b7b35cfd9a0b3bf98f7ac3c79b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c57f26f53741e54b8903955ac643a9723a0590b7b35cfd9a0b3bf98f7ac3c79b", kill_on_drop: false }` [INFO] [stdout] c57f26f53741e54b8903955ac643a9723a0590b7b35cfd9a0b3bf98f7ac3c79b