[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] abd6b40d22b5ce16df0968ca9c2fb9da286e2aca
[INFO] testing bn-l/clarg against 1.95.0 for beta-1.96-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbn-l%2Fclarg" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-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-3-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]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded owo-colors v4.2.3
[INFO] [stderr]   Downloaded colorchoice v1.0.4
[INFO] [stderr]   Downloaded serde_yaml v0.9.34+deprecated
[INFO] [stderr]   Downloaded once_cell v1.21.3
[INFO] [stderr]   Downloaded wasm-bindgen-macro v0.2.108
[INFO] [stderr]   Downloaded gix-ignore v0.19.1
[INFO] [stderr]   Downloaded itoa v1.0.17
[INFO] [stderr]   Downloaded unsafe-libyaml v0.2.11
[INFO] [stderr]   Downloaded clap_lex v0.7.7
[INFO] [stderr]   Downloaded addr2line v0.25.1
[INFO] [stderr]   Downloaded pin-project-lite v0.2.16
[INFO] [stderr]   Downloaded anstyle-parse v0.2.7
[INFO] [stderr]   Downloaded color-spantrace v0.3.0
[INFO] [stderr]   Downloaded indenter v0.3.4
[INFO] [stderr]   Downloaded gix-validate v0.11.0
[INFO] [stderr]   Downloaded zmij v1.0.19
[INFO] [stderr]   Downloaded anstyle-query v1.1.5
[INFO] [stderr]   Downloaded cc v1.2.56
[INFO] [stderr]   Downloaded regex v1.12.3
[INFO] [stderr]   Downloaded clap_derive v4.5.55
[INFO] [stderr]   Downloaded object v0.37.3
[INFO] [stderr]   Downloaded js-sys v0.3.85
[INFO] [stderr]   Downloaded quote v1.0.44
[INFO] [stderr]   Downloaded strsim v0.11.1
[INFO] [stderr]   Downloaded unicode-bom v2.0.3
[INFO] [stderr]   Downloaded unicode-ident v1.0.22
[INFO] [stderr]   Downloaded pty-process v0.5.3
[INFO] [stderr]   Downloaded gimli v0.32.3
[INFO] [stderr]   Downloaded iana-time-zone v0.1.65
[INFO] [stderr]   Downloaded gix-path v0.11.2
[INFO] [stderr]   Downloaded tracing-subscriber v0.3.22
[INFO] [stderr]   Downloaded syn v2.0.114
[INFO] [stderr]   Downloaded backtrace v0.3.76
[INFO] [stderr]   Downloaded linux-raw-sys v0.11.0
[INFO] [stderr]   Downloaded once_cell_polyfill v1.70.2
[INFO] [stderr]   Downloaded rustc-demangle v0.1.27
[INFO] [stderr]   Downloaded anstyle v1.0.13
[INFO] [stderr]   Downloaded anstream v0.6.21
[INFO] [stderr]   Downloaded gix-features v0.46.2
[INFO] [stderr]   Downloaded wasm-bindgen-shared v0.2.108
[INFO] [stderr]   Downloaded bitflags v2.10.0
[INFO] [stderr]   Downloaded iana-time-zone-haiku v0.1.2
[INFO] [stderr]   Downloaded miniz_oxide v0.8.9
[INFO] [stderr]   Downloaded clap_builder v4.5.57
[INFO] [stderr]   Downloaded chrono v0.4.43
[INFO] [stderr]   Downloaded wasm-bindgen v0.2.108
[INFO] [stderr]   Downloaded ryu v1.0.22
[INFO] [stderr]   Downloaded tempfile v3.24.0
[INFO] [stderr]   Downloaded eyre v0.6.12
[INFO] [stderr]   Downloaded gix-glob v0.24.0
[INFO] [stderr]   Downloaded regex-syntax v0.8.9
[INFO] [stderr]   Downloaded is_terminal_polyfill v1.70.2
[INFO] [stderr]   Downloaded flexi_logger v0.31.8
[INFO] [stderr]   Downloaded color-eyre v0.6.5
[INFO] [stderr]   Downloaded fastrand v2.3.0
[INFO] [stderr]   Downloaded rustix v1.1.3
[INFO] [stderr]   Downloaded android_system_properties v0.1.5
[INFO] [stderr]   Downloaded anstyle-wincon v3.0.11
[INFO] [stderr]   Downloaded utf8parse v0.2.2
[INFO] [stderr]   Downloaded clap v4.5.57
[INFO] [stderr]   Downloaded adler2 v2.0.1
[INFO] [stderr]   Downloaded tracing-error v0.2.1
[INFO] [stderr]   Downloaded gix-trace v0.1.18
[INFO] [stderr]   Downloaded libc v0.2.184
[INFO] [stderr]   Downloaded bstr v1.12.1
[INFO] [stderr]   Downloaded wasm-bindgen-macro-support v0.2.108
[INFO] [stderr]   Downloaded memchr v2.7.6
[INFO] [stderr]   Downloaded bumpalo v3.19.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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] 4842da6f8657894c16b157eaaa7784a4665f06d3fefb3cb8bc090258161ed305
[INFO] running `Command { std: "docker" "start" "-a" "4842da6f8657894c16b157eaaa7784a4665f06d3fefb3cb8bc090258161ed305", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4842da6f8657894c16b157eaaa7784a4665f06d3fefb3cb8bc090258161ed305", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4842da6f8657894c16b157eaaa7784a4665f06d3fefb3cb8bc090258161ed305", kill_on_drop: false }`
[INFO] [stdout] 4842da6f8657894c16b157eaaa7784a4665f06d3fefb3cb8bc090258161ed305
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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] 2f0985aabd7eb76c4a7e5260066eefdb084120d9e1ffb6af69d58ed4e1db75c3
[INFO] running `Command { std: "docker" "start" "-a" "2f0985aabd7eb76c4a7e5260066eefdb084120d9e1ffb6af69d58ed4e1db75c3", 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 lazy_static v1.5.0
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling utf8parse v0.2.2
[INFO] [stderr]    Compiling pin-project-lite v0.2.16
[INFO] [stderr]    Compiling object v0.37.3
[INFO] [stderr]    Compiling owo-colors v4.2.3
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling gix-trace v0.1.18
[INFO] [stderr]    Compiling anstyle-parse v0.2.7
[INFO] [stderr]    Compiling colorchoice v1.0.4
[INFO] [stderr]    Compiling sharded-slab v0.1.7
[INFO] [stderr]    Compiling is_terminal_polyfill v1.70.2
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling color-spantrace v0.3.0
[INFO] [stderr]    Compiling anstyle-query v1.1.5
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling eyre v0.6.12
[INFO] [stderr]    Compiling adler2 v2.0.1
[INFO] [stderr]    Compiling zmij v1.0.19
[INFO] [stderr]    Compiling gimli v0.32.3
[INFO] [stderr]    Compiling anstyle v1.0.13
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling clap_lex v0.7.7
[INFO] [stderr]    Compiling tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling anstream v0.6.21
[INFO] [stderr]    Compiling itoa v1.0.17
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling rustc-demangle v0.1.27
[INFO] [stderr]    Compiling indenter v0.3.4
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling heck v0.5.0
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling equivalent v1.0.2
[INFO] [stderr]    Compiling iana-time-zone v0.1.65
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]    Compiling log v0.4.29
[INFO] [stderr]    Compiling gix-features v0.46.2
[INFO] [stderr]    Compiling clap_builder v4.5.57
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling unicode-bom v2.0.3
[INFO] [stderr]    Compiling ryu v1.0.22
[INFO] [stderr]    Compiling unsafe-libyaml v0.2.11
[INFO] [stderr]    Compiling nu-ansi-term v0.50.3
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling tracing-error v0.2.1
[INFO] [stderr]    Compiling shlex v1.3.0
[INFO] [stderr]    Compiling chrono v0.4.43
[INFO] [stderr]    Compiling addr2line v0.25.1
[INFO] [stderr]    Compiling backtrace v0.3.76
[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 thiserror-impl v2.0.18
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling clap_derive v4.5.55
[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 clap v4.5.57
[INFO] [stderr]    Compiling gix-glob v0.24.0
[INFO] [stderr]    Compiling gix-ignore v0.19.1
[INFO] [stderr]    Compiling serde_yaml v0.9.34+deprecated
[INFO] [stderr]    Compiling clarg v0.3.3 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 25.45s
[INFO] running `Command { std: "docker" "inspect" "2f0985aabd7eb76c4a7e5260066eefdb084120d9e1ffb6af69d58ed4e1db75c3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2f0985aabd7eb76c4a7e5260066eefdb084120d9e1ffb6af69d58ed4e1db75c3", kill_on_drop: false }`
[INFO] [stdout] 2f0985aabd7eb76c4a7e5260066eefdb084120d9e1ffb6af69d58ed4e1db75c3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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] a9262dad7a464ca67c3f3cc0463281e4a6d438bcf85f7c1a654066b96f6cedf7
[INFO] running `Command { std: "docker" "start" "-a" "a9262dad7a464ca67c3f3cc0463281e4a6d438bcf85f7c1a654066b96f6cedf7", 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.3 (/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.97s
[INFO] running `Command { std: "docker" "inspect" "a9262dad7a464ca67c3f3cc0463281e4a6d438bcf85f7c1a654066b96f6cedf7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a9262dad7a464ca67c3f3cc0463281e4a6d438bcf85f7c1a654066b96f6cedf7", kill_on_drop: false }`
[INFO] [stdout] a9262dad7a464ca67c3f3cc0463281e4a6d438bcf85f7c1a654066b96f6cedf7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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] 078ed9c74a6ffd5aa7d9621de891e5bc0eff5ee351271b32805e16f9d9b8c7a4
[INFO] running `Command { std: "docker" "start" "-a" "078ed9c74a6ffd5aa7d9621de891e5bc0eff5ee351271b32805e16f9d9b8c7a4", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.12s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/clarg-95c9fab78fd3dd58)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/clarg-969e750b3e15c7eb)
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[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] [stderr]      Running tests/bash_analyzer_tests.rs (/opt/rustwide/target/debug/deps/bash_analyzer_tests-4d9299d7d9987533)
[INFO] [stdout] 
[INFO] [stdout] running 360 tests
[INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_brace_without_comma_passes_through ... 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_file_command ... ok
[INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_empty_brace_parts_preserved ... 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_extract_paths_expands_brace_with_normalization_prep ... 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_path_with_multiple_expansions ... ok
[INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_no_braces_passes_through ... 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_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_unquoted_braces_still_expand_alongside_quoted_ones ... ok
[INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_quoted_braces_in_redirect_target_not_expanded ... 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_quoted_set_literal_in_python_c_survives ... ok
[INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_cartesian_product ... 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_root_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_to_parent_blocked ... 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_env_cd_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_tilde_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_in_semicolon_chain_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_subdirectory_allowed ... 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::download_commands::test_curl_config_long_separated_external_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_no_args_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_config_short_separated_external_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_d_concatenated_at_file_blocked ... 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_data_at_file_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_form_at_file_blocked ... 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_data_binary_at_file_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_form_equals_at_file_blocked ... 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_output_inside_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_no_output_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_unmatched_brace_passes_through ... ok
[INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_pipe_allowed ... 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::download_commands::test_curl_t_flag_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_with_dot_allowed ... 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_wget_input_file_internal_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_home_var_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_curl_upload_file_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::download_commands::test_curl_t_concatenated_path_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_to_nested_subdirectory_allowed ... 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_wget_input_file_short_concatenated_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_curl_output_tilde_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_output_home_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_c_chain_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_output_outside_blocked ... 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_with_long_unicode_command_no_panic ... ok
[INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_no_output_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_script_inside_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_input_file_long_separated_external_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_c_safe_command_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_pipe_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_bash_script_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_dash_c_safe_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_eval_nested_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::brace_expansion::test_simple_brace_expansion ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_deeply_nested_eval_limited ... ok
[INFO] [stdout] test bash_analyzer_tests::download_commands::test_wget_input_file_short_separated_external_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_eval_cat_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_eval_empty_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_eval_unsafe_cd_blocked ... 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_eval_with_long_unicode_command_no_panic ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_sh_c_unsafe_blocked ... 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_zsh_c_unsafe_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_eval_safe_command_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::exec_commands::test_dot_script_outside_blocked ... 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_inline_code_deny_reason_mentions_inline_code ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_zsh_c_safe_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_bun_run_inside_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::eval_and_shell::test_sh_c_safe_command_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::exec_commands::test_bun_run_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::exec_commands::test_deno_run_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_python_script_inside_allowed ... 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_node_e_with_external_path_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python3_c_with_external_path_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::cd_command::test_cd_with_parent_escaping_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_node_eval_flag_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python_c_dynamically_constructed_path_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_python_c_inline_code_denied_under_internal_only ... 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_perl_e_pure_code_denied ... ok
[INFO] [stdout] test bash_analyzer_tests::exec_commands::test_python_c_with_external_path_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::download_commands::test_curl_config_long_equals_external_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_python_script_still_works_after_inline_check ... 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_python_with_flags_then_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_cat_absolute_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_cat_with_flags_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_chmod_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::exec_commands::test_ruby_script_inside_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_cat_multiple_files_one_outside ... 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_chown_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::exec_commands::test_source_script_inside_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_chmod_inside_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::exec_commands::test_source_script_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::exec_commands::test_ruby_script_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_cat_inside_allowed ... 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_cp_dest_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_less_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_mkdir_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_ln_target_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_ln_inside_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_cp_recursive_outside_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_cp_source_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_dd_if_tilde_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_head_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_dd_no_path_args_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_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_pushd_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_rm_recursive_outside_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_more_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_tail_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_find_heredoc_spans_orders_op_and_body ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_rm_root_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_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_tar_create_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::exec_commands::test_source_bashrc_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_touch_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_double_less_inside_quotes_is_not_a_heredoc ... 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_extract_paths_skips_heredoc_body_paths ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_touch_inside_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_tar_extract_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_double_quoted_not_treated_as_path ... 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_heredoc_inside_bash_c_recursion_strips_body ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_command_sub_with_inner_quoted_paren ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_inside_eval_recursion_strips_body ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_single_quoted_delim ... 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_followed_by_real_redirect_still_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_tab_stripped_closer_matches ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_with_backtick_substitution ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_backslash_escaped_delim ... 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_here_string_with_command_sub_then_real_redirect ... 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_mixed_quoted_delim_strips_body_normally ... 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_multiple_heredocs_separate_commands ... 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_here_string_with_nested_command_substitution ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_here_string_with_parameter_expansion ... ok
[INFO] [stdout] test bash_analyzer_tests::file_commands::test_rmdir_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_same_line_redirect_after_heredoc_op_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_here_string_bareword_not_treated_as_path ... 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_quoted_then_bare_mixed_delim_resolves_correctly ... 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_preserves_same_line_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_real_external_write_inside_bash_c_still_blocked ... 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_strip_heredocs_handles_unclosed_input_safely ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_strip_heredocs_no_op_when_no_doubleless ... ok
[INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_hidden_file_looks_like_path ... 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_absolute_path_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_dotdot_prefix_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_command_not_path ... 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_dot_prefix_looks_like_path ... ok
[INFO] [stdout] test bash_analyzer_tests::heredocs::test_heredoc_double_quoted_delim ... 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_long_flag_not_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_pattern_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::looks_like_path::test_tilde_looks_like_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_url_looks_like_path ... ok
[INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_word_containing_dot_not_path ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_multiple_redirects_all_inside ... ok
[INFO] [stdout] test bash_analyzer_tests::looks_like_path::test_trailing_slash_looks_like_path ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_double_quoted_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_multiple_redirects_one_outside ... 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_double_quoted_with_space_outside_blocked ... 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_tilde_user_looks_like_path ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_append_outside ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_combined_outside ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_append_inside_project ... 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_parent_dir_outside ... 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_escaped_tilde_outside_quotes_is_literal_and_allowed ... 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_quoted_inside_allowed ... 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_single_quoted_dollar_home_is_literal_and_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_relative_path_inside ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_to_etc ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_to_dev_zero ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_to_dev_null ... 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_stderr_outside ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_unquoted_tilde_user_expands ... 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_double_quoted_tilde_is_literal_and_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_unseparated_bare_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_to_absolute_outside ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_stderr_inside_project ... 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_to_file_inside_project ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_single_quoted_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_with_home_var_outside ... ok
[INFO] [stdout] test bash_analyzer_tests::search_commands::test_ack_outside_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::search_commands::test_fd_inside_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::redirections::test_redirect_with_tilde_outside ... 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_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_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_grep_outside_blocked ... 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_grep_recursive_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_type_flag_not_treated_as_path ... ok
[INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_long_file_flag_equals_external_blocked ... 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_long_file_flag_separated_external_blocked ... 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_multiple_files_one_external_blocked ... 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::sed_command::test_sed_expression_looks_like_path_allowed ... 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_f_flag_external_script_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_on_external_file_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_f_flag_internal_script_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_with_f_flag_internal_allowed ... 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_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::split_shell_operators::test_split_double_quoted_and ... 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_inplace_external_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::search_commands::test_rg_inside_allowed ... 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_double_quoted_semicolon ... 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_expression_flag_equals_internal_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_escaped_pipe ... 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_empty_string ... 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_grep_pipe_chain ... 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_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::sed_command::test_sed_on_internal_file_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::split_shell_operators::test_split_mixed_pipe_and_semicolon ... ok
[INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_short_file_flag_concatenated_external_blocked ... 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_mixed_quotes_and_operators ... 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_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_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_single_quoted_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_single_ampersand ... 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_simple_command ... 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_unknown_cmd_flag_equals_tilde_path_blocked ... 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_all_internal_paths_allowed ... 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_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_with_dotdot_path_blocked ... 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_hidden_file_inside_allowed ... 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_mixed_args_one_bad_blocked ... ok
[INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_with_text_args_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::unknown_commands::test_unknown_cmd_with_tilde_blocked ... 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_and_operator ... ok
[INFO] [stdout] test bash_analyzer_tests::search_commands::test_ack_inside_allowed ... ok
[INFO] [stdout] test bash_analyzer_tests::sed_command::test_sed_with_e_flag_internal_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_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_numbers_allowed ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 359 passed; 0 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.17s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/blocked_commands_tests.rs (/opt/rustwide/target/debug/deps/blocked_commands_tests-99d994e2b5d7dbfd)
[INFO] [stdout] 
[INFO] [stdout] running 63 tests
[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_alternation ... ok
[INFO] [stdout] test blocked_commands_tests::construction::test_new_with_character_class ... ok
[INFO] [stdout] test blocked_commands_tests::construction::test_new_with_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_invalid_regex_unclosed_bracket ... 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_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_word_boundary ... ok
[INFO] [stdout] test blocked_commands_tests::construction::test_new_with_multiple_patterns ... 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_no_match_returns_none ... ok
[INFO] [stdout] test blocked_commands_tests::construction::test_new_with_regex_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_single_literal_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_reason_truncates_long_command ... ok
[INFO] [stdout] test blocked_commands_tests::reason_messages::test_truncate_emoji_command_no_panic ... ok
[INFO] [stdout] test blocked_commands_tests::construction::test_new_with_complex_regex ... ok
[INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_contains_forbidden ... ok
[INFO] [stdout] test blocked_commands_tests::construction::test_new_with_invalid_repetition ... ok
[INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_contains_matched ... ok
[INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_short_command_not_truncated ... 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_reason_contains_pattern ... 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_empty_command_with_dot_pattern ... ok
[INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_both_anchored ... ok
[INFO] [stdout] test blocked_commands_tests::reason_messages::test_empty_patterns_never_matches ... ok
[INFO] [stdout] test blocked_commands_tests::reason_messages::test_first_matching_pattern_in_reason ... ok
[INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_alternation ... ok
[INFO] [stdout] test blocked_commands_tests::reason_messages::test_reason_contains_command ... 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::regex_matching::test_check_literal_substring_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_multiple_patterns_middle_matches ... 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_literal_match ... 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_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_pipe_character ... ok
[INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_semicolon ... ok
[INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_dd_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_digit_class ... 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_question ... ok
[INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_dot_plus ... ok
[INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_redirect ... ok
[INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_dot_star ... ok
[INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_case_sensitive ... 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_word_boundary ... ok
[INFO] [stdout] test blocked_commands_tests::construction::test_new_with_empty_patterns ... ok
[INFO] [stdout] test blocked_commands_tests::construction::test_new_with_many_patterns ... ok
[INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_start_anchored ... ok
[INFO] [stdout] test blocked_commands_tests::regex_matching::test_check_whitespace ... 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.05s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/blocked_files_tests.rs (/opt/rustwide/target/debug/deps/blocked_files_tests-285cb735b1a7682e)
[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_absolute_pattern_reason_includes_expanded_pattern_and_path ... 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_bare_absolute_pattern_blocks_filesystem_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_home_pattern_is_not_re_expanded_after_construction ... 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_new_with_only_project_patterns_does_not_check_home ... 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::absolute_patterns::test_mixed_pattern_groups_both_fire ... ok
[INFO] [stdout] test blocked_files_tests::absolute_patterns::test_unanchored_basename_pattern_blocks_outside_project ... 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::absolute_patterns::test_directory_pattern_blocks_outside_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_path_outside_project_root_is_checked_against_absolute_patterns ... 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_tilde_pattern_ignores_project_relative_paths ... 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_anchored_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::construction::test_new_with_emoji_pattern ... ok
[INFO] [stdout] test blocked_files_tests::construction::test_new_with_negation_pattern ... 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_question_mark_pattern ... 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_character_class_pattern ... ok
[INFO] [stdout] test blocked_files_tests::construction::test_new_with_empty_patterns ... ok
[INFO] [stdout] test blocked_files_tests::construction::test_new_with_mixed_unicode_patterns ... ok
[INFO] [stdout] test blocked_files_tests::construction::test_new_with_single_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::absolute_patterns::test_tilde_slash_pattern_blocks_absolute_path_outside_project ... ok
[INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_anchored_pattern_matches_root ... ok
[INFO] [stdout] test blocked_files_tests::construction::test_new_with_multiple_patterns ... ok
[INFO] [stdout] test blocked_files_tests::construction::test_new_with_many_patterns ... ok
[INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_anchored_pattern_no_match_nested ... ok
[INFO] [stdout] test blocked_files_tests::construction::test_new_with_unclosed_bracket_treated_literally ... 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_directory_pattern_nested ... 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_dot_path ... 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_multiple_patterns_any_match ... 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_doublestar_directory_pattern ... 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_doublestar_extension ... ok
[INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_doublestar_match_any_depth ... 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_negated_character_class ... 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_character_class_letters ... ok
[INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_empty_path ... 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_star_extension_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_star_extension_no_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_check_star_middle_match ... 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_check_star_prefix_match ... ok
[INFO] [stdout] test blocked_files_tests::pattern_matching::test_dir_only_pattern_matches_leaf_with_hint ... 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_empty_patterns_never_matches ... 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_exact_filename_no_match ... 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_exact_filename_match ... ok
[INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_contains_pattern ... ok
[INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_with_complex_pattern ... 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_with_nested_path ... ok
[INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_filename_deeply_nested ... ok
[INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_contains_forbidden ... 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_contains_matched ... 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::pattern_matching::test_check_filename_in_subdirectory ... ok
[INFO] [stdout] test blocked_files_tests::pattern_matching::test_check_hidden_files_pattern ... 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::reason_messages::test_reason_contains_blocked_by_clarg ... ok
[INFO] [stdout] test blocked_files_tests::reason_messages::test_reason_contains_path ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 84 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/cli_tests.rs (/opt/rustwide/target/debug/deps/cli_tests-5e112904fa3c1ee4)
[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_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_all_flags_combined_short ... ok
[INFO] [stdout] test cli_tests::combinations::test_b_and_c_combined_only ... ok
[INFO] [stdout] test cli_tests::combinations::test_equals_syntax_for_all_long_flags ... 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_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_flags_in_different_order ... ok
[INFO] [stdout] test cli_tests::combinations::test_flags_interleaved ... 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_json ... ok
[INFO] [stdout] test cli_tests::config_path::test_config_path_positional_simple ... ok
[INFO] [stdout] test cli_tests::config_path::test_config_path_with_tilde ... ok
[INFO] [stdout] test cli_tests::combinations::test_l_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::config_path::test_config_path_multiple_dots ... 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_relative ... ok
[INFO] [stdout] test cli_tests::config_path::test_config_path_with_extension_yml ... ok
[INFO] [stdout] test cli_tests::config_path::test_config_path_with_extension_yaml ... ok
[INFO] [stdout] test cli_tests::config_path::test_config_path_with_spaces ... 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::conflicts::test_config_path_conflicts_with_log_dir ... ok
[INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_no_root ... ok
[INFO] [stdout] test cli_tests::config_path::test_config_path_unicode ... ok
[INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_no_unknown_tools ... ok
[INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_b ... ok
[INFO] [stdout] test cli_tests::config_path::test_config_path_positional_absolute ... ok
[INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_block_access_to ... ok
[INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_no_system_dirs ... 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_i ... 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_internal_access_only ... ok
[INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_l ... 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_comma_separated_with_spaces_around_comma ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_current_directory ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_dot_files ... ok
[INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_commands_forbidden ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_double_star_pattern ... ok
[INFO] [stdout] test cli_tests::conflicts::test_config_path_conflicts_with_c ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_missing_value ... 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_negation_pattern ... 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_parent_directory ... 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_patterns_with_backslashes ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_value_with_internal_spaces ... 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_pattern_with_dollar ... 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_pattern_with_semicolon ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_with_absolute_paths ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_with_home_directory_paths ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_numeric_pattern ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_value_with_trailing_space ... 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_with_many_comma_separated_items ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_root_directory ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_unicode_patterns ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_glob_with_question_mark ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_c_flag_regex_with_character_classes ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_with_relative_paths ... 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_missing_value ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_c_flag_numeric_pattern ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_c_flag_regex_with_escape_sequences ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_c_flag_regex_with_groups ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_pattern_with_parentheses ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_equals_with_comma_in_value ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_c_flag_unicode_patterns ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_c_flag_pattern_with_backticks ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_equals_with_empty_value ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_b_flag_pattern_with_pipe ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_log_dir_missing_value ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_c_flag_regex_with_anchors ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_double_dash_before_config_path ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_c_flag_pattern_with_single_quotes ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_c_flag_pattern_with_quotes ... 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_with_flags_before ... 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_l_flag_missing_value ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_equals_with_equals_in_value ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_extremely_long_pattern_list ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_commands_forbidden_missing_value ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_multiple_commas ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_unknown_short_flag ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_very_long_log_path ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_leading_comma ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_multiple_positional_arguments_error ... 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_internal_access_only ... 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_single ... ok
[INFO] [stdout] test cli_tests::long_flags::test_long_flag_commands_forbidden_multiple_flags ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_misspelled_long_flag ... 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_log_dir_path_with_spaces ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_unknown_long_flag ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_log_path_unicode ... 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_log_dir_equals_syntax ... 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_single_comma ... 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_trailing_comma ... 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_block_access_to_multiple_flags ... ok
[INFO] [stdout] test cli_tests::edge_cases::test_very_long_single_pattern ... ok
[INFO] [stdout] test cli_tests::short_flags::test_short_flag_b_comma_separated_multiple_items ... 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_glob_patterns ... 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_mixed_comma_and_multiple_flags ... 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_special_characters ... 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_mixed_comma_and_multiple_flags ... ok
[INFO] [stdout] test cli_tests::short_flags::test_short_flag_c_comma_separated_multiple_items ... 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_patterns_with_dots ... 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_empty_string ... 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_c_command_with_spaces_quoted ... 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_c_multiple_flags_three_items ... 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_c_single_command ... ok
[INFO] [stdout] test cli_tests::short_flags::test_short_flag_i_alone ... 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_path_with_spaces ... 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::short_flags::test_short_flag_l_simple_path ... ok
[INFO] [stdout] test cli_tests::short_flags::test_short_flag_l_very_long_path ... ok
[INFO] [stdout] test cli_tests::version_help::test_help_and_version_help_wins ... ok
[INFO] [stdout] test cli_tests::version_help::test_help_flag_long ... ok
[INFO] [stdout] test cli_tests::version_help::test_help_at_end ... ok
[INFO] [stdout] test cli_tests::version_help::test_help_flag_short ... 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_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_version_flag_short ... ok
[INFO] [stdout] test cli_tests::version_help::test_version_with_other_flags_shows_version ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 157 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.06s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/config_tests.rs (/opt/rustwide/target/debug/deps/config_tests-42297054568124e8)
[INFO] [stdout] 
[INFO] [stdout] running 113 tests
[INFO] [stdout] test config_tests::defaults_and_complex::test_config_default_trait ... 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_from_yaml_boolean_on ... 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_variations ... 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_boolean_no ... 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_document_markers ... 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_commands_with_shell_metacharacters ... 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_duplicate_patterns ... 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_log_dir_empty_string ... ok
[INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_mac_classic_line_endings ... ok
[INFO] [stdout] test config_tests::from_cli::test_from_cli_all_flags_populated ... ok
[INFO] [stdout] test config_tests::from_cli::test_from_cli_only_block_access_to ... ok
[INFO] [stdout] test config_tests::from_cli::test_from_cli_only_commands_forbidden ... 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_only_no_root ... 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_partial_flags ... ok
[INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_utf8_bom ... ok
[INFO] [stdout] test config_tests::from_cli::test_from_cli_only_no_system_dirs ... ok
[INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_mixed_array_and_block_style ... ok
[INFO] [stdout] test config_tests::from_cli::test_from_cli_with_config_path ... ok
[INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_windows_line_endings ... 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_no_flags ... ok
[INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_patterns_with_only_whitespace ... 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_log_dir ... ok
[INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_patterns_with_dots ... ok
[INFO] [stdout] test config_tests::defaults_and_complex::test_from_yaml_trailing_comma_not_allowed ... ok
[INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_minimal_valid ... 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_only_block_access_to ... ok
[INFO] [stdout] test config_tests::from_cli::test_from_cli_with_config_path_no_unknown_tools ... ok
[INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_all_fields ... ok
[INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_only_commands_forbidden ... 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_special_flags_alongside_other_fields ... 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_empty_file ... 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_special_flags_parses_both_true ... 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_internal_access_only_false ... 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_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_special_flags_no_unknown_tools_wrong_type ... 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_special_flags_no_unknown_tools_null_errors ... 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_null_commands_forbidden ... 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_string ... 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_complex_regex_patterns ... 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_gitignore_glob_patterns ... 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_wrong_type_commands_forbidden_string ... 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_wrong_type_internal_access_only_number ... 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_patterns::test_from_yaml_complex_gitignore_patterns ... ok
[INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_log_dir_absolute_path ... 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_patterns::test_from_yaml_log_dir_relative_path ... 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_errors::test_from_yaml_special_flags_no_root_null_errors ... 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_with_spaces ... 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_strings::test_from_yaml_empty_strings_in_commands_forbidden ... 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_log_dir_parent_directory ... ok
[INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_many_commands ... 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_escaped_quotes_in_values ... ok
[INFO] [stdout] test config_tests::from_yaml_strings::test_from_yaml_patterns_with_leading_spaces ... ok
[INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_unicode_log_path ... 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_flow_style_arrays ... 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_strings::test_from_yaml_patterns_with_trailing_spaces ... 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_flow_style_complete ... 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_syntax::test_from_yaml_backslashes_in_patterns ... ok
[INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_mixed_quoted_values ... ok
[INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_many_patterns ... ok
[INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_single_quoted_values ... ok
[INFO] [stdout] test config_tests::from_yaml_patterns::test_from_yaml_very_large_arrays ... 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_special_characters_in_patterns ... 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_multiline_literal_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_with_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_very_long_strings ... ok
[INFO] [stdout] test config_tests::from_yaml_syntax::test_from_yaml_yaml_numbers_as_strings ... 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_patterns_with_forward_slashes ... ok
[INFO] [stdout] test config_tests::from_yaml_basic::test_from_yaml_special_flags_partial_section_defaults_other_flag_false ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 113 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/hook_input_tests.rs (/opt/rustwide/target/debug/deps/hook_input_tests-b37e5ba4b6b518df)
[INFO] [stdout] 
[INFO] [stdout] running 136 tests
[INFO] [stdout] test hook_input_tests::claude_tools::test_bash_tool_with_run_in_background ... 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_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_edit_tool_with_old_and_new_string ... ok
[INFO] [stdout] test hook_input_tests::claude_tools::test_glob_tool_with_pattern ... 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_grep_tool_with_pattern ... ok
[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_read_tool_with_file_path ... ok
[INFO] [stdout] test hook_input_tests::claude_tools::test_task_update_tool ... 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_webfetch_tool_with_url_and_prompt ... ok
[INFO] [stdout] test hook_input_tests::claude_tools::test_task_create_tool ... ok
[INFO] [stdout] test hook_input_tests::claude_tools::test_read_tool_with_pdf_pages ... ok
[INFO] [stdout] test hook_input_tests::claude_tools::test_websearch_tool_with_domain_filters ... ok
[INFO] [stdout] test hook_input_tests::claude_tools::test_websearch_tool_with_query ... 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_transcript_path_explicit_null ... ok
[INFO] [stdout] test hook_input_tests::complex_scenarios::test_very_long_strings ... ok
[INFO] [stdout] test hook_input_tests::complex_scenarios::test_command_with_pipes_and_redirects ... ok
[INFO] [stdout] test hook_input_tests::complex_scenarios::test_file_path_with_backslashes ... 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_multiple_helper_methods_on_same_input ... ok
[INFO] [stdout] test hook_input_tests::complex_scenarios::test_permission_mode_explicit_null ... 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_tool_input_deeply_nested ... 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_large_array ... ok
[INFO] [stdout] test hook_input_tests::edge_cases::test_debug_format ... ok
[INFO] [stdout] test hook_input_tests::edge_cases::test_skill_tool ... ok
[INFO] [stdout] test hook_input_tests::edge_cases::test_strings_with_tabs ... ok
[INFO] [stdout] test hook_input_tests::edge_cases::test_minimal_valid_json ... ok
[INFO] [stdout] test hook_input_tests::edge_cases::test_tool_input_with_prompt ... 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_query ... ok
[INFO] [stdout] test hook_input_tests::complex_scenarios::test_tool_use_id_explicit_null ... 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_not_a_string ... 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_array ... 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_tool_input_empty ... 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::helper_methods::test_file_path_returns_some_when_present ... ok
[INFO] [stdout] test hook_input_tests::helper_methods::test_search_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_search_path_returns_none_when_not_a_string ... 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::helper_methods::test_pattern_returns_some_when_present ... 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_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_pattern_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_file_path_returns_none_when_file_path_is_boolean ... ok
[INFO] [stdout] test hook_input_tests::optional_fields::test_all_optional_fields_missing ... 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::optional_fields::test_all_optional_fields_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_pattern_returns_none_when_absent ... ok
[INFO] [stdout] test hook_input_tests::helper_methods::test_command_returns_some_when_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_tool_use_id_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_permission_mode_present ... ok
[INFO] [stdout] test hook_input_tests::optional_fields::test_transcript_path_and_permission_mode_present ... ok
[INFO] [stdout] test hook_input_tests::optional_fields::test_transcript_path_present ... ok
[INFO] [stdout] test hook_input_tests::paths::test_cwd_relative_path ... 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_with_spaces ... 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_post_tool_use ... 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_tool_input_with_booleans ... ok
[INFO] [stdout] test hook_input_tests::permission_and_events::test_tool_input_with_null_values ... ok
[INFO] [stdout] test hook_input_tests::permission_and_events::test_tool_input_with_numbers ... ok
[INFO] [stdout] test hook_input_tests::required_fields::test_missing_cwd_fails ... ok
[INFO] [stdout] test hook_input_tests::required_fields::test_all_required_fields_present ... 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_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_arrays ... 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_tool_use_id_missing ... ok
[INFO] [stdout] test hook_input_tests::optional_fields::test_tool_use_id_present ... 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_missing ... ok
[INFO] [stdout] test hook_input_tests::paths::test_cwd_absolute_path ... 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::tool_input::test_tool_input_empty_object ... ok
[INFO] [stdout] test hook_input_tests::required_fields::test_missing_tool_name_fails ... ok
[INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_command ... ok
[INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_file_path ... ok
[INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_path_only ... ok
[INFO] [stdout] test hook_input_tests::types_and_fields::test_hook_event_name_wrong_type_array ... ok
[INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_nested_objects ... ok
[INFO] [stdout] test hook_input_tests::tool_input::test_tool_input_with_path_and_pattern ... ok
[INFO] [stdout] test hook_input_tests::types_and_fields::test_cwd_wrong_type_number ... ok
[INFO] [stdout] test hook_input_tests::types_and_fields::test_extra_fields_ignored ... 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::types_and_fields::test_permission_mode_default ... 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_name_wrong_type_object ... ok
[INFO] [stdout] test hook_input_tests::types_and_fields::test_tool_use_id_wrong_type_array ... 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_pattern ... 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_session_id ... 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_empty_tool_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_empty_transcript_path ... 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_permission_mode ... 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_tool_input_command ... ok
[INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_tool_use_id ... ok
[INFO] [stdout] test hook_input_tests::types_and_fields::test_permission_mode_custom_value ... ok
[INFO] [stdout] test hook_input_tests::unicode_and_strings::test_unicode_in_transcript_path ... 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_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::unicode_and_strings::test_empty_command ... ok
[INFO] [stdout] test hook_input_tests::unicode_and_strings::test_empty_file_path ... 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_search_path ... 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_name ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 136 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/integration.rs (/opt/rustwide/target/debug/deps/integration-2b93e1767f430059)
[INFO] [stdout] 
[INFO] [stdout] running 38 tests
[INFO] [stdout] test integration::blocked_commands::test_block_rm_rf ... ok
[INFO] [stdout] test integration::blocked_files::test_allow_normal_file_read ... 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::cli::test_version_flag_in_tty ... 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::config::test_relative_config_resolved_against_project_dir ... ok
[INFO] [stdout] test integration::config::test_relative_config_without_project_dir_uses_cwd ... ok
[INFO] [stdout] test integration::config::test_yaml_config_equivalent ... ok
[INFO] [stdout] test integration::config::test_yaml_special_flags_no_system_dirs_denies_read_etc ... ok
[INFO] [stdout] test integration::internal_only::test_allow_rg_internal_path ... ok
[INFO] [stdout] test integration::internal_only::test_block_bash_c_external ... ok
[INFO] [stdout] test integration::internal_only::test_block_cd_external_chained ... ok
[INFO] [stdout] test integration::internal_only::test_block_eval_external ... ok
[INFO] [stdout] test integration::cli::test_version_flag ... ok
[INFO] [stdout] test integration::cli::test_help_flag ... ok
[INFO] [stdout] test integration::cli::test_bare_invocation_in_tty_shows_friendly_usage ... ok
[INFO] [stdout] test integration::internal_only::test_block_rg_external_path ... ok
[INFO] [stdout] test integration::cli::test_help_flag_in_tty ... ok
[INFO] [stdout] test integration::config::test_claude_project_dir_override ... ok
[INFO] [stdout] test integration::passthrough::test_task_tool_allowed ... ok
[INFO] [stdout] test integration::blocked_commands::test_no_rules_allows_all ... ok
[INFO] [stdout] test integration::passthrough::test_web_tools_always_allowed ... ok
[INFO] [stdout] test integration::blocked_files::test_multiple_blocked_patterns ... ok
[INFO] [stdout] test integration::config::test_cli_no_system_dirs_allows_tmp_write ... ok
[INFO] [stdout] test integration::config::test_cli_internal_only_blocks_tilde_user_bypass ... ok
[INFO] [stdout] test integration::config::test_cli_no_system_dirs_blocks_tilde_root_bypass ... ok
[INFO] [stdout] test integration::config::test_cli_no_root_denies_rm_rf_root ... ok
[INFO] [stdout] test integration::internal_only::test_internal_only_blocks_grep_outside ... ok
[INFO] [stdout] test integration::config::test_cli_no_system_dirs_blocks_brace_expansion_bypass ... ok
[INFO] [stdout] test integration::internal_only::test_internal_only_blocks_glob_outside ... ok
[INFO] [stdout] test integration::internal_only::test_internal_only_blocks_write_outside ... ok
[INFO] [stdout] test integration::passthrough::test_unknown_tool_allowed ... ok
[INFO] [stdout] test integration::logging::test_log_dir_file ... 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] [stderr]      Running tests/internalonly_tests.rs (/opt/rustwide/target/debug/deps/internalonly_tests-504084911a32963e)
[INFO] [stdout] test integration::cli::test_malformed_json_fail_closed ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 38 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.52s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 91 tests
[INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_child_is_inside ... 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_different_context_strings ... ok
[INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_exact_match_is_inside ... 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::check_path_containment::test_containment_parent_is_outside ... ok
[INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_reason_contains_blocked_by_clarg ... 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_absolute_path_unchanged ... ok
[INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_curly_brace_syntax_not_expanded ... ok
[INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_dollar_home_in_middle_unchanged ... ok
[INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_sibling_is_outside ... ok
[INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_dollar_home_nested_path ... 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_dollar_home_with_path ... ok
[INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_empty_string ... 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_relative_path_unchanged ... 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_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_in_middle_unchanged ... 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_only ... 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_plus_digit_left_literal ... ok
[INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_minus_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_left_literal ... ok
[INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_root_no_path ... 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_dots ... ok
[INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_user_resolves_to_platform_home ... ok
[INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_user_with_path ... ok
[INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_tilde_with_path ... ok
[INFO] [stdout] test internalonly_tests::expand_home::test_expand_home_with_spaces ... 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::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_tilde_with_dash_after_alpha_still_resolves ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_double_dot_with_no_parent ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_double_slash ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_double_dot_pops_directory ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_empty_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] [stdout] test internalonly_tests::normalize_path::test_normalize_mixed_dots ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_multiple_consecutive_dots ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_path_with_special_chars ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_path_with_spaces ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_preserves_absolute ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_removes_single_dots ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_preserves_relative ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_root_only ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_simple_path ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_single_component ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_leading_dot ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_single_dot ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_trailing_dot ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_relative_path ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_trailing_slash ... ok
[INFO] [stdout] test internalonly_tests::normalize_path::test_normalize_unicode_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_current_dir ... 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_existing_dir ... ok
[INFO] [stdout] test internalonly_tests::resolve_project_root::test_resolve_project_root_nonexistent_path ... ok
[INFO] [stdout] test internalonly_tests::resolve_project_root::test_resolve_project_root_follows_symlinks ... ok
[INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_dotslash_prefix ... 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_path_unchanged ... ok
[INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_absolute_outside_path ... ok
[INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_absolute_with_dots_normalized ... 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_tilde_expanded ... 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_tilde_only ... 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::check_path_containment::test_containment_reason_contains_project_root ... ok
[INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_prefix_attack_blocked ... ok
[INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_empty_string ... ok
[INFO] [stdout] test internalonly_tests::check_path_containment::test_containment_root_is_outside ... 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_single_dot ... ok
[INFO] [stdout] test internalonly_tests::resolve_target::test_resolve_target_with_spaces ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 91 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]      Running tests/output_tests.rs (/opt/rustwide/target/debug/deps/output_tests-45ca8a3a455d42c5)
[INFO] [stdout] running 28 tests
[INFO] [stdout] test output_tests::deny_json::test_deny_json_all_keys_present ... 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_permission_decision_is_deny ... 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_structure_is_correct ... 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_backslashes ... 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_with_control_characters ... 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_null_character ... 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_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_with_unicode_emojis ... ok
[INFO] [stdout] test output_tests::deny_json::test_deny_json_with_unicode_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_html_tags ... 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_value_type_check ... 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_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_with_special_characters ... ok
[INFO] [stdout] test output_tests::edge_cases::test_deny_json_structure_immutability ... ok
[INFO] [stdout] test output_tests::deny_json::test_deny_json_with_very_long_reason ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 28 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/router_tests.rs (/opt/rustwide/target/debug/deps/router_tests-22ad9289be1c140e)
[INFO] [stdout] 
[INFO] [stdout] running 192 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_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_command_after_internal_check_passes ... 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_blocked_files_wildcard_pattern ... 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_brace_expansion_does_not_false_positive_in_project ... 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_non_match_allowed ... 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_cd_root_blocked_by_no_root ... 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_cd_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_internal_only_blocks_external_path ... 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_chained_command_with_external_blocked ... 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_mkdir_secrets_denied_by_dir_only_pattern ... 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_internal_only_checked_before_blocked_commands ... 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_double_quoted_dollar_home_redirect_still_blocked_under_internal_only ... 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_inline_code_still_blocks_literal_external_path_without_internal_only ... 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_internal_only_blocks_dynamic_traversal ... 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_eval_with_external_path_blocked ... 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_no_root_blocks_lex_variant_tmp_parent ... 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_no_root_blocks_ls_root_glob ... 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_rg_root ... 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_root_blocks_unknown_cmd_bare_root ... ok
[INFO] [stdout] test router_tests::bash_tool::test_bash_missing_command_allowed ... 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_no_rules_allows_anything ... ok
[INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_allows_usr_bin_log ... 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_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_root_blocks_redirect_to_root ... 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_allows_private_tmp ... 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_no_system_dirs_blocks_find_var ... 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_curl_data_at_etc_passwd ... ok
[INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_curl_upload_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_no_system_dirs_blocks_python_inline_etc_passwd ... ok
[INFO] [stdout] test router_tests::bash_tool::test_bash_no_system_dirs_blocks_redirect_to_etc ... 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_quoted_redirect_outside_blocked ... 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_sed_f_external_script_denied_under_i ... 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_tilde_user_bare_blocked_by_internal_access_only ... ok
[INFO] [stdout] test router_tests::bash_tool::test_bash_quoted_redirect_with_space_outside_blocked ... 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_unquoted_braces_still_blocked_under_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::bash_tool::test_bash_tilde_minus_path_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_wget_input_file_external_denied_under_i ... 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_tilde_plus_path_allowed_under_internal_only ... 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_rmdir_secrets_denied_by_dir_only_pattern ... ok
[INFO] [stdout] test router_tests::construction::test_build_blocked_files_without_internal_only ... ok
[INFO] [stdout] test router_tests::construction::test_build_with_blocked_files ... ok
[INFO] [stdout] test router_tests::construction::test_build_with_internal_only ... ok
[INFO] [stdout] test router_tests::construction::test_build_with_blocked_commands ... ok
[INFO] [stdout] test router_tests::construction::test_build_with_nonexistent_project_root_for_internal_only_fails ... ok
[INFO] [stdout] test router_tests::construction::test_build_with_all_rules ... ok
[INFO] [stdout] test router_tests::construction::test_build_with_invalid_regex_fails ... ok
[INFO] [stdout] test router_tests::file_tools::test_edit_blocked_files_denies_match ... ok
[INFO] [stdout] test router_tests::file_tools::test_notebookedit_blocked_files_denies_match ... ok
[INFO] [stdout] test router_tests::file_tools::test_edit_internal_only_allows_internal ... ok
[INFO] [stdout] test router_tests::file_tools::test_notebookedit_case_insensitive_routing ... ok
[INFO] [stdout] test router_tests::file_tools::test_edit_internal_only_blocks_external ... 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_notebookedit_internal_only_allows_internal ... ok
[INFO] [stdout] test router_tests::construction::test_build_with_multiple_file_patterns ... 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_no_system_dirs_allows_private_tmp ... ok
[INFO] [stdout] test router_tests::construction::test_build_with_empty_config ... ok
[INFO] [stdout] test router_tests::file_tools::test_file_tool_missing_file_path_allowed ... ok
[INFO] [stdout] test router_tests::file_tools::test_read_no_system_dirs_blocks_private_etc ... 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_read_internal_only_allows_internal ... ok
[INFO] [stdout] test router_tests::file_tools::test_read_internal_only_blocks_external ... ok
[INFO] [stdout] test router_tests::file_tools::test_read_blocked_files_allows_non_match ... ok
[INFO] [stdout] test router_tests::file_tools::test_read_no_root_blocks_root ... ok
[INFO] [stdout] test router_tests::file_tools::test_read_no_rules_allows_anything ... 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_write_blocked_files_denies_match ... 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_parent_traversal_blocked ... ok
[INFO] [stdout] test router_tests::file_tools::test_write_internal_only_allows_internal ... ok
[INFO] [stdout] test router_tests::file_tools::test_read_no_system_dirs_blocks_usr_bin_login_lookalike ... ok
[INFO] [stdout] test router_tests::file_tools::test_write_tilde_expansion_blocked ... ok
[INFO] [stdout] test router_tests::file_tools::test_read_tilde_plus_allowed_under_internal_only ... ok
[INFO] [stdout] test router_tests::file_tools::test_read_no_system_dirs_allows_usr_bin_log ... ok
[INFO] [stdout] test router_tests::file_tools::test_notebookedit_no_rules_allows ... ok
[INFO] [stdout] test router_tests::file_tools::test_read_tilde_root_blocked_by_no_system_dirs ... ok
[INFO] [stdout] test router_tests::file_tools::test_write_internal_only_blocks_external ... 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_missing_path_allowed ... ok
[INFO] [stdout] test router_tests::file_tools::test_read_blocked_files_denies_match ... ok
[INFO] [stdout] test router_tests::construction::test_build_with_multiple_command_patterns ... ok
[INFO] [stdout] test router_tests::glob_tool::test_glob_blocked_files_denies_blocked_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_blocked_files_allows_non_blocked_path ... ok
[INFO] [stdout] test router_tests::glob_tool::test_glob_relative_parent_traversal_blocked ... 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_internal_only_allows_internal_path ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_internal_only_blocks_external_path ... 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_rules_allows_anything ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_no_rules_allows_anything ... 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_system_dirs_blocks_usr ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_relative_parent_traversal_blocked ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_relative_path_inside_allowed ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_tilde_root_blocked_by_no_system_dirs ... ok
[INFO] [stdout] test router_tests::glob_tool::test_glob_no_root_blocks_root ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_no_root_blocks_root ... ok
[INFO] [stdout] test router_tests::glob_tool::test_glob_internal_only_blocks_external_path ... ok
[INFO] [stdout] test router_tests::file_tools::test_notebookedit_internal_only_blocks_external ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_glob_case_insensitive_routing ... ok
[INFO] [stdout] test router_tests::glob_tool::test_glob_internal_checked_before_blocked_files ... ok
[INFO] [stdout] test router_tests::glob_tool::test_glob_relative_path_inside_allowed ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_grep_lowercase_routed_correctly ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_internal_only_blocks_home_var ... ok
[INFO] [stdout] test router_tests::glob_tool::test_glob_internal_only_blocks_tilde_path ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_absolute_internal_path_allowed ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_task_allowed_with_internal_only ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_missing_path_allowed ... 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_bash_lowercase_routed_correctly ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_internal_only_blocks_parent_traversal ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_task_empty_input_allowed ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_blocked_files_allows_non_blocked_path ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_internal_only_allows_internal_path ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_unknown_tool_allowed_no_rules ... ok
[INFO] [stdout] test router_tests::grep_tool::test_grep_blocked_files_denies_blocked_path ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_mcp_tool_allowed ... 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_known_tool_mixed_case_allowed_when_no_unknown_tools ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_bash_uppercase_routed_correctly ... 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_reason_mentions_tool_name_and_flag ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_webfetch_still_allowed_when_no_unknown_tools ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_webfetch_allowed_with_all_rules ... 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_webfetch_allowed_with_internal_only ... 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_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_unknown_tool_denied_when_no_unknown_tools ... 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_websearch_allowed_with_internal_only ... ok
[INFO] [stdout] test router_tests::rule_ordering::test_bash_internalonly_before_blocked_commands_external ... 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_read ... 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_only_blocked_files_blocks_matching_pattern ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_webfetch_empty_input_allowed ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_task_always_allowed_no_rules ... ok
[INFO] [stdout] test router_tests::rule_ordering::test_no_rules_allows_everything_bash ... ok
[INFO] [stdout] test router_tests::rule_ordering::test_bash_both_rules_pass_allows ... ok
[INFO] [stdout] test router_tests::passthrough_tools::test_webfetch_always_allowed_no_rules ... ok
[INFO] [stdout] test router_tests::rule_ordering::test_file_both_rules_pass_allows ... 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_path_tool_system_paths_before_internal_access_only ... ok
[INFO] [stdout] test router_tests::rule_ordering::test_only_blocked_commands_blocks_matching_pattern ... ok
[INFO] [stdout] test router_tests::rule_ordering::test_only_internalonly_blocks_external ... ok
[INFO] [stdout] test router_tests::rule_ordering::test_bash_system_paths_before_blocked_files ... ok
[INFO] [stdout] test router_tests::rule_ordering::test_only_internalonly_allows_internal ... ok
[INFO] [stdout] test router_tests::rule_ordering::test_file_blocked_files_triggers_when_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_only_blocked_commands_allows_external_paths_in_bash ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 192 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.06s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/system_paths_tests.rs (/opt/rustwide/target/debug/deps/system_paths_tests-740479590bd1da0f)
[INFO] [stdout] 
[INFO] [stdout] running 26 tests
[INFO] [stdout] test system_paths_tests::construction::test_is_active_when_no_root_only ... 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::construction::test_inactive_rule_allows_everything ... 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_blocks_root_glob_forms ... 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_does_not_block_project_relative_paths ... ok
[INFO] [stdout] test system_paths_tests::construction::test_is_active_when_both_flags ... 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::no_root::test_no_root_does_not_block_non_root_absolute_paths ... 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_exact_system_dirs ... 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::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::no_system_dirs::test_no_system_dirs_does_not_block_prefix_lookalikes ... ok
[INFO] [stdout] test system_paths_tests::reason_messages::test_no_root_glob_reason_mentions_glob ... 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::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::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_allows_usr_bin_log_exception ... ok
[INFO] [stdout] test system_paths_tests::reason_messages::test_no_system_dirs_reason_includes_matched_system_dir_and_path ... ok
[INFO] [stderr]    Doc-tests clarg
[INFO] [stdout] test system_paths_tests::reason_messages::test_no_root_reason_is_specific ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 26 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[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" "078ed9c74a6ffd5aa7d9621de891e5bc0eff5ee351271b32805e16f9d9b8c7a4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "078ed9c74a6ffd5aa7d9621de891e5bc0eff5ee351271b32805e16f9d9b8c7a4", kill_on_drop: false }`
[INFO] [stdout] 078ed9c74a6ffd5aa7d9621de891e5bc0eff5ee351271b32805e16f9d9b8c7a4
