[INFO] cloning repository https://github.com/maltyxx/guardix
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/maltyxx/guardix" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmaltyxx%2Fguardix", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmaltyxx%2Fguardix'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 9fe5a866915d63740e9d2b4a644d188c53942aa5
[INFO] testing maltyxx/guardix against beta-2026-04-21 for beta-1.96-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmaltyxx%2Fguardix" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc2/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-3-tc2/source/rust-toolchain.toml
[INFO] started tweaking git repo https://github.com/maltyxx/guardix
[INFO] finished tweaking git repo https://github.com/maltyxx/guardix
[INFO] tweaked toml for git repo https://github.com/maltyxx/guardix written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/maltyxx/guardix on toolchain beta-2026-04-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/maltyxx/guardix 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" "+beta-2026-04-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 3a216be2ed573b7e9d86905a684404887f2d69dfa6fafb868bc3008db3d8b729
[INFO] running `Command { std: "docker" "start" "-a" "3a216be2ed573b7e9d86905a684404887f2d69dfa6fafb868bc3008db3d8b729", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "3a216be2ed573b7e9d86905a684404887f2d69dfa6fafb868bc3008db3d8b729", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3a216be2ed573b7e9d86905a684404887f2d69dfa6fafb868bc3008db3d8b729", kill_on_drop: false }`
[INFO] [stdout] 3a216be2ed573b7e9d86905a684404887f2d69dfa6fafb868bc3008db3d8b729
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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" "+beta-2026-04-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c97ee0507438735af9a8c97605ac9e24a3997293a079df08e824c2982860d8f5
[INFO] running `Command { std: "docker" "start" "-a" "c97ee0507438735af9a8c97605ac9e24a3997293a079df08e824c2982860d8f5", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.103
[INFO] [stderr]    Compiling quote v1.0.41
[INFO] [stderr]    Compiling libc v0.2.177
[INFO] [stderr]    Compiling find-msvc-tools v0.1.4
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling icu_properties_data v2.1.1
[INFO] [stderr]    Compiling hashbrown v0.16.0
[INFO] [stderr]    Compiling openssl v0.10.74
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]    Compiling generic-array v0.14.9
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling iana-time-zone v0.1.64
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling cc v1.2.44
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling event-listener v5.4.1
[INFO] [stderr]    Compiling base64 v0.22.1
[INFO] [stderr]    Compiling flume v0.11.1
[INFO] [stderr]    Compiling dotenvy v0.15.7
[INFO] [stderr]    Compiling hex v0.4.3
[INFO] [stderr]    Compiling regex-syntax v0.8.8
[INFO] [stderr]    Compiling indexmap v2.12.0
[INFO] [stderr]    Compiling hashlink v0.10.0
[INFO] [stderr]    Compiling atoi v2.0.0
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling iri-string v0.7.9
[INFO] [stderr]    Compiling rustls-pki-types v1.13.0
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling backon v1.6.0
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling num-bigint v0.4.6
[INFO] [stderr]    Compiling unsafe-libyaml v0.2.11
[INFO] [stderr]    Compiling syn v2.0.109
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling arc-swap v1.7.1
[INFO] [stderr]    Compiling socket2 v0.6.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling mio v1.1.0
[INFO] [stderr]    Compiling signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling openssl-sys v0.9.110
[INFO] [stderr]    Compiling libsqlite3-sys v0.30.1
[INFO] [stderr]    Compiling futures-intrusive v0.5.0
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling tokio v1.48.0
[INFO] [stderr]    Compiling inotify-sys v0.1.5
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling inotify v0.11.0
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling notify-types v2.0.0
[INFO] [stderr]    Compiling urlencoding v2.1.3
[INFO] [stderr]    Compiling serde_path_to_error v0.1.20
[INFO] [stderr]    Compiling notify v8.2.0
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling axum-core v0.5.5
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling tracing-serde v0.2.0
[INFO] [stderr]    Compiling serde_yaml_ng v0.10.0
[INFO] [stderr]    Compiling uuid v1.18.1
[INFO] [stderr]    Compiling tracing-subscriber v0.3.20
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.1
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling url v2.5.7
[INFO] [stderr]    Compiling sqlx-core v0.8.6
[INFO] [stderr]    Compiling tokio-util v0.7.17
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling h2 v0.4.12
[INFO] [stderr]    Compiling combine v4.6.7
[INFO] [stderr]    Compiling tower-http v0.6.6
[INFO] [stderr]    Compiling sqlx-sqlite v0.8.6
[INFO] [stderr]    Compiling hyper v1.7.0
[INFO] [stderr]    Compiling sqlx-macros-core v0.8.6
[INFO] [stderr]    Compiling hyper-util v0.1.17
[INFO] [stderr]    Compiling redis v0.32.7
[INFO] [stderr]    Compiling sqlx-macros v0.8.6
[INFO] [stderr]    Compiling sqlx v0.8.6
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling axum v0.8.6
[INFO] [stderr]    Compiling reqwest v0.12.24
[INFO] [stderr]    Compiling guardix v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 04s
[INFO] running `Command { std: "docker" "inspect" "c97ee0507438735af9a8c97605ac9e24a3997293a079df08e824c2982860d8f5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c97ee0507438735af9a8c97605ac9e24a3997293a079df08e824c2982860d8f5", kill_on_drop: false }`
[INFO] [stdout] c97ee0507438735af9a8c97605ac9e24a3997293a079df08e824c2982860d8f5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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" "+beta-2026-04-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] ed58f6af4f0f978fba24cb4b86f1abe025c3d33bfa59af5ec0337707aeea5fbf
[INFO] running `Command { std: "docker" "start" "-a" "ed58f6af4f0f978fba24cb4b86f1abe025c3d33bfa59af5ec0337707aeea5fbf", kill_on_drop: false }`
[INFO] [stderr]    Compiling openssl v0.10.74
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling inotify v0.11.0
[INFO] [stderr]    Compiling tower-http v0.6.6
[INFO] [stderr]    Compiling backon v1.6.0
[INFO] [stderr]    Compiling rustix v1.1.2
[INFO] [stderr]    Compiling redis v0.32.7
[INFO] [stderr]    Compiling notify v8.2.0
[INFO] [stderr]    Compiling tempfile v3.23.0
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling sqlx-core v0.8.6
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling reqwest v0.12.24
[INFO] [stderr]    Compiling sqlx-sqlite v0.8.6
[INFO] [stderr]    Compiling sqlx-macros-core v0.8.6
[INFO] [stderr]    Compiling sqlx-macros v0.8.6
[INFO] [stderr]    Compiling sqlx v0.8.6
[INFO] [stderr]    Compiling guardix v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 55.61s
[INFO] running `Command { std: "docker" "inspect" "ed58f6af4f0f978fba24cb4b86f1abe025c3d33bfa59af5ec0337707aeea5fbf", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ed58f6af4f0f978fba24cb4b86f1abe025c3d33bfa59af5ec0337707aeea5fbf", kill_on_drop: false }`
[INFO] [stdout] ed58f6af4f0f978fba24cb4b86f1abe025c3d33bfa59af5ec0337707aeea5fbf
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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" "+beta-2026-04-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 9e64de63eaf737f8742af05b1db086e289a4b1644a204d0ec4d8d9e1496b6902
[INFO] running `Command { std: "docker" "start" "-a" "9e64de63eaf737f8742af05b1db086e289a4b1644a204d0ec4d8d9e1496b6902", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.31s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/guardix-fedf200f866832a1)
[INFO] [stdout] 
[INFO] [stdout] running 102 tests
[INFO] [stdout] test config::tests::test_config_validation ... ok
[INFO] [stdout] test config::tests::test_cache_config_ttl ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_llm_base_url ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_storage_paths ... ok
[INFO] [stdout] test config::tests::test_config_validation_zero_judge_timeout ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_upstream_url ... ok
[INFO] [stdout] test config::tests::test_config_validation_zero_request_timeout ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_llm_model ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_listen_addr ... ok
[INFO] [stdout] test config::tests::test_learner_config_batch_interval ... ok
[INFO] [stdout] test config::tests::test_llm_config_judge_timeout ... ok
[INFO] [stdout] test config::tests::test_waf_config_request_timeout ... ok
[INFO] [stdout] test core::rulebook::tests::test_get_nonexistent_rule ... ok
[INFO] [stdout] test core::judge::tests::test_fail_mode_closed ... ok
[INFO] [stdout] test core::judge::tests::test_metrics_tracking ... ok
[INFO] [stdout] test core::judge::tests::test_judge_with_mock_llm ... ok
[INFO] [stdout] test core::rulebook::tests::test_add_multiple_rules ... ok
[INFO] [stdout] test core::rulebook::tests::test_add_rule ... ok
[INFO] [stdout] test core::judge::tests::test_fail_mode_open ... ok
[INFO] [stdout] test core::judge::tests::test_judge_block_decision ... ok
[INFO] [stdout] test core::rulebook::tests::test_rule_unique_ids ... ok
[INFO] [stdout] test core::rulebook::tests::test_rule_with_description ... ok
[INFO] [stdout] test core::rulebook::tests::test_remove_rule ... ok
[INFO] [stdout] test core::rulebook::tests::test_rulebook_new ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_redis_url_when_enabled ... ok
[INFO] [stdout] test core::rulebook::tests::test_rulebook_serialization ... ok
[INFO] [stdout] test core::rulebook::tests::test_rulebook_version_increments ... ok
[INFO] [stdout] test core::rulebook::tests::test_get_rule ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_with_body ... ok
[INFO] [stdout] test core::rulebook::tests::test_get_rules_by_type ... ok
[INFO] [stdout] test http::middleware::tests::test_tracing_middleware ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_with_encoded_query_params ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_basic ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_normalized_hash ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_with_ip_from_x_forwarded_for ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_with_query_params ... ok
[INFO] [stdout] test core::rulebook::tests::test_remove_nonexistent_rule ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_query_params ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_with_headers ... ok
[INFO] [stdout] test http::proxy::tests::test_health_handler ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_threat_level ... ok
[INFO] [stdout] test llm::ollama::tests::test_chat_request_structure ... ok
[INFO] [stdout] test core::rulebook::tests::test_rule_new ... ok
[INFO] [stdout] test core::rulebook::tests::test_rulebook_default ... ok
[INFO] [stdout] test core::learner::tests::test_learner_applies_changes ... ok
[INFO] [stdout] test llm::prompts::tests::test_judge_prompt_generation ... ok
[INFO] [stdout] test models::decision::tests::test_judge_decision_is_flag ... ok
[INFO] [stdout] test models::decision::tests::test_judge_decision_serialization ... ok
[INFO] [stdout] test models::decision::tests::test_judge_decision_type ... ok
[INFO] [stdout] test llm::prompts::tests::test_learner_prompt_generation ... ok
[INFO] [stdout] test llm::prompts::tests::test_truncate ... ok
[INFO] [stdout] test models::decision::tests::test_judge_decision_confidence ... ok
[INFO] [stdout] test models::decision::tests::test_judge_decision_is_block ... ok
[INFO] [stdout] test models::decision::tests::test_learner_output_structure ... ok
[INFO] [stdout] test models::decision::tests::test_rule_action_as_str ... ok
[INFO] [stdout] test models::decision::tests::test_rule_action_serialization ... ok
[INFO] [stdout] test models::decision::tests::test_threat_level_as_str ... ok
[INFO] [stdout] test models::request::tests::test_compute_hash_with_body ... ok
[INFO] [stdout] test models::decision::tests::test_threat_level_serialization ... ok
[INFO] [stdout] test models::request::tests::test_compute_hash_without_body ... ok
[INFO] [stdout] test models::request::tests::test_compute_hash_consistency ... ok
[INFO] [stdout] test models::request::tests::test_content_type_case_insensitive ... ok
[INFO] [stdout] test models::request::tests::test_content_type ... ok
[INFO] [stdout] test models::request::tests::test_content_type_missing ... ok
[INFO] [stdout] test models::request::tests::test_get_user_agent_missing ... ok
[INFO] [stdout] test models::request::tests::test_get_user_agent_case_insensitive ... ok
[INFO] [stdout] test models::request::tests::test_log_entry_structure ... ok
[INFO] [stdout] test models::request::tests::test_request_payload_new ... ok
[INFO] [stdout] test models::request::tests::test_compute_hash_different_for_different_requests ... ok
[INFO] [stdout] test models::request::tests::test_get_user_agent ... ok
[INFO] [stdout] test models::request::tests::test_request_payload_serialization ... ok
[INFO] [stdout] test storage::cache::tests::test_cache_ttl_with_redis ... ignored
[INFO] [stdout] test storage::cache::tests::test_get_nonexistent_verdict_with_redis ... ignored
[INFO] [stdout] test storage::cache::tests::test_invalidate_verdict_with_redis ... ignored
[INFO] [stdout] test storage::cache::tests::test_ping_with_redis ... ignored
[INFO] [stdout] test storage::cache::tests::test_redis_connection_failure ... ignored
[INFO] [stdout] test storage::cache::tests::test_set_and_get_verdict_with_redis ... ignored
[INFO] [stdout] test storage::cache::tests::test_verdict_key_empty_hash ... ok
[INFO] [stdout] test storage::cache::tests::test_verdict_key_format ... ok
[INFO] [stdout] test storage::cache::tests::test_redis_invalid_url ... ok
[INFO] [stdout] test storage::cache::tests::test_verdict_key_with_special_chars ... ok
[INFO] [stdout] test storage::cache::tests::test_redis_empty_url ... ok
[INFO] [stdout] test http::proxy::tests::test_app_state_creation ... ok
[INFO] [stdout] test storage::logs::tests::test_get_flagged_since ... ok
[INFO] [stdout] test storage::logs::tests::test_get_events_since_with_limit ... ok
[INFO] [stdout] test storage::logs::tests::test_count_events_by_decision ... ok
[INFO] [stdout] test storage::rules::tests::test_save_and_load ... ok
[INFO] [stdout] test storage::logs::tests::test_log_event_with_allow_decision ... ok
[INFO] [stdout] test storage::logs::tests::test_log_event ... ok
[INFO] [stdout] test storage::logs::tests::test_get_flagged_since_timestamp_filter ... ok
[INFO] [stdout] test storage::logs::tests::test_get_blocked_since ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_block ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_invalid_decision ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_learner_response_empty ... ok
[INFO] [stdout] test storage::rules::tests::test_watch_changes ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_invalid_json ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_block_without_threat_level ... ok
[INFO] [stdout] test llm::ollama::tests::test_ollama_provider_creation ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_flag ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_learner_response_invalid_json ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_allow ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_learner_response ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 96 passed; 0 failed; 6 ignored; 0 measured; 0 filtered out; finished in 0.76s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/guardix-242a3fd34dc45ce4)
[INFO] [stdout] 
[INFO] [stdout] running 102 tests
[INFO] [stdout] test config::tests::test_cache_config_ttl ... ok
[INFO] [stdout] test config::tests::test_config_validation ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_listen_addr ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_llm_base_url ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_llm_model ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_redis_url_when_enabled ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_storage_paths ... ok
[INFO] [stdout] test config::tests::test_config_validation_empty_upstream_url ... ok
[INFO] [stdout] test config::tests::test_config_validation_zero_judge_timeout ... ok
[INFO] [stdout] test config::tests::test_config_validation_zero_request_timeout ... ok
[INFO] [stdout] test config::tests::test_llm_config_judge_timeout ... ok
[INFO] [stdout] test config::tests::test_waf_config_request_timeout ... ok
[INFO] [stdout] test core::judge::tests::test_fail_mode_closed ... ok
[INFO] [stdout] test core::judge::tests::test_metrics_tracking ... ok
[INFO] [stdout] test core::judge::tests::test_fail_mode_open ... ok
[INFO] [stdout] test core::rulebook::tests::test_get_rules_by_type ... ok
[INFO] [stdout] test core::judge::tests::test_judge_with_mock_llm ... ok
[INFO] [stdout] test core::rulebook::tests::test_add_multiple_rules ... ok
[INFO] [stdout] test core::rulebook::tests::test_add_rule ... ok
[INFO] [stdout] test core::rulebook::tests::test_remove_nonexistent_rule ... ok
[INFO] [stdout] test core::judge::tests::test_judge_block_decision ... ok
[INFO] [stdout] test core::rulebook::tests::test_remove_rule ... ok
[INFO] [stdout] test core::rulebook::tests::test_get_nonexistent_rule ... ok
[INFO] [stdout] test core::rulebook::tests::test_rule_new ... ok
[INFO] [stdout] test core::rulebook::tests::test_rule_unique_ids ... ok
[INFO] [stdout] test core::rulebook::tests::test_rule_with_description ... ok
[INFO] [stdout] test core::rulebook::tests::test_rulebook_new ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_with_headers ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_normalized_hash ... ok
[INFO] [stdout] test core::rulebook::tests::test_rulebook_version_increments ... ok
[INFO] [stdout] test http::middleware::tests::test_tracing_middleware ... ok
[INFO] [stdout] test config::tests::test_learner_config_batch_interval ... ok
[INFO] [stdout] test core::rulebook::tests::test_get_rule ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_with_ip_from_x_forwarded_for ... ok
[INFO] [stdout] test core::rulebook::tests::test_rulebook_serialization ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_with_query_params ... ok
[INFO] [stdout] test core::rulebook::tests::test_rulebook_default ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_with_encoded_query_params ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_query_params ... ok
[INFO] [stdout] test http::proxy::tests::test_health_handler ... ok
[INFO] [stdout] test llm::ollama::tests::test_chat_request_structure ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_with_body ... ok
[INFO] [stdout] test http::proxy::tests::test_extract_payload_basic ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_threat_level ... ok
[INFO] [stdout] test llm::prompts::tests::test_judge_prompt_generation ... ok
[INFO] [stdout] test llm::prompts::tests::test_learner_prompt_generation ... ok
[INFO] [stdout] test llm::prompts::tests::test_truncate ... ok
[INFO] [stdout] test models::decision::tests::test_judge_decision_confidence ... ok
[INFO] [stdout] test models::decision::tests::test_judge_decision_is_flag ... ok
[INFO] [stdout] test models::decision::tests::test_judge_decision_is_block ... ok
[INFO] [stdout] test models::decision::tests::test_judge_decision_serialization ... ok
[INFO] [stdout] test models::decision::tests::test_rule_action_as_str ... ok
[INFO] [stdout] test models::decision::tests::test_rule_action_serialization ... ok
[INFO] [stdout] test models::decision::tests::test_threat_level_as_str ... ok
[INFO] [stdout] test models::decision::tests::test_threat_level_serialization ... ok
[INFO] [stdout] test models::decision::tests::test_learner_output_structure ... ok
[INFO] [stdout] test models::request::tests::test_compute_hash_consistency ... ok
[INFO] [stdout] test models::request::tests::test_compute_hash_with_body ... ok
[INFO] [stdout] test models::request::tests::test_compute_hash_without_body ... ok
[INFO] [stdout] test models::request::tests::test_compute_hash_different_for_different_requests ... ok
[INFO] [stdout] test models::request::tests::test_content_type_missing ... ok
[INFO] [stdout] test models::request::tests::test_content_type ... ok
[INFO] [stdout] test models::decision::tests::test_judge_decision_type ... ok
[INFO] [stdout] test models::request::tests::test_get_user_agent_case_insensitive ... ok
[INFO] [stdout] test models::request::tests::test_get_user_agent ... ok
[INFO] [stdout] test models::request::tests::test_content_type_case_insensitive ... ok
[INFO] [stdout] test models::request::tests::test_get_user_agent_missing ... ok
[INFO] [stdout] test storage::cache::tests::test_cache_ttl_with_redis ... ignored
[INFO] [stdout] test storage::cache::tests::test_get_nonexistent_verdict_with_redis ... ignored
[INFO] [stdout] test storage::cache::tests::test_invalidate_verdict_with_redis ... ignored
[INFO] [stdout] test storage::cache::tests::test_ping_with_redis ... ignored
[INFO] [stdout] test storage::cache::tests::test_redis_connection_failure ... ignored
[INFO] [stdout] test models::request::tests::test_log_entry_structure ... ok
[INFO] [stdout] test models::request::tests::test_request_payload_new ... ok
[INFO] [stdout] test models::request::tests::test_request_payload_serialization ... ok
[INFO] [stdout] test core::learner::tests::test_learner_applies_changes ... ok
[INFO] [stdout] test storage::cache::tests::test_redis_invalid_url ... ok
[INFO] [stdout] test storage::cache::tests::test_set_and_get_verdict_with_redis ... ignored
[INFO] [stdout] test storage::cache::tests::test_verdict_key_empty_hash ... ok
[INFO] [stdout] test storage::cache::tests::test_redis_empty_url ... ok
[INFO] [stdout] test storage::cache::tests::test_verdict_key_with_special_chars ... ok
[INFO] [stdout] test storage::cache::tests::test_verdict_key_format ... ok
[INFO] [stdout] test storage::logs::tests::test_get_flagged_since_timestamp_filter ... ok
[INFO] [stdout] test http::proxy::tests::test_app_state_creation ... ok
[INFO] [stdout] test storage::logs::tests::test_get_flagged_since ... ok
[INFO] [stdout] test storage::rules::tests::test_save_and_load ... ok
[INFO] [stdout] test storage::logs::tests::test_get_blocked_since ... ok
[INFO] [stdout] test storage::logs::tests::test_get_events_since_with_limit ... ok
[INFO] [stdout] test storage::logs::tests::test_count_events_by_decision ... ok
[INFO] [stdout] test storage::logs::tests::test_log_event_with_allow_decision ... ok
[INFO] [stdout] test storage::logs::tests::test_log_event ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_block_without_threat_level ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_learner_response_invalid_json ... ok
[INFO] [stdout] test storage::rules::tests::test_watch_changes ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_allow ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_learner_response_empty ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_block ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_learner_response ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_invalid_decision ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_flag ... ok
[INFO] [stdout] test llm::ollama::tests::test_ollama_provider_creation ... ok
[INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_invalid_json ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 96 passed; 0 failed; 6 ignored; 0 measured; 0 filtered out; finished in 0.55s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/e2e_tests.rs (/opt/rustwide/target/debug/deps/e2e_tests-62789172102887f4)
[INFO] [stdout] 
[INFO] [stdout] running 18 tests
[INFO] [stdout] test test_command_injection_backticks ... ignored
[INFO] [stdout] test test_command_injection_pipe ... ignored
[INFO] [stdout] test test_command_injection_semicolon ... ignored
[INFO] [stdout] test test_empty_request ... ignored
[INFO] [stdout] test test_health_endpoint ... ignored
[INFO] [stdout] test test_legitimate_get_root ... ignored
[INFO] [stdout] test test_legitimate_get_with_normal_params ... ignored
[INFO] [stdout] test test_legitimate_post_json ... ignored
[INFO] [stdout] test test_legitimate_search_normal_query ... ignored
[INFO] [stdout] test test_path_traversal_etc_passwd ... ignored
[INFO] [stdout] test test_path_traversal_in_url_path ... ignored
[INFO] [stdout] test test_sqli_classic_tautology ... ignored
[INFO] [stdout] test test_sqli_drop_table ... ignored
[INFO] [stdout] test test_sqli_in_post_body ... ignored
[INFO] [stdout] test test_sqli_union_select ... ignored
[INFO] [stdout] test test_xss_javascript_protocol ... ignored
[INFO] [stdout] test test_xss_onerror ... ignored
[INFO] [stdout] test test_xss_script_tag ... ignored
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 18 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests guardix
[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" "9e64de63eaf737f8742af05b1db086e289a4b1644a204d0ec4d8d9e1496b6902", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9e64de63eaf737f8742af05b1db086e289a4b1644a204d0ec4d8d9e1496b6902", kill_on_drop: false }`
[INFO] [stdout] 9e64de63eaf737f8742af05b1db086e289a4b1644a204d0ec4d8d9e1496b6902
