[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 1.95.0 for beta-1.96-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmaltyxx%2Fguardix" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'... [INFO] [stderr] done. [INFO] removed /workspace/builds/worker-0-tc1/source/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-0-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/maltyxx/guardix 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/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" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded tracing-serde v0.2.0 [INFO] [stderr] Downloaded crc v3.3.0 [INFO] [stderr] Downloaded notify-types v2.0.0 [INFO] [stderr] Downloaded base64ct v1.8.0 [INFO] [stderr] Downloaded generic-array v0.14.9 [INFO] [stderr] Downloaded serde_yaml_ng v0.10.0 [INFO] [stderr] Downloaded rsa v0.9.8 [INFO] [stderr] Downloaded num-bigint-dig v0.8.5 [INFO] [stderr] Downloaded redis v0.32.7 [INFO] [stderr] Downloaded syn v2.0.109 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 14d0adb04c7e033c99cac210a0b602572075a9c2b9dd2b3c9c6b930d228a0055 [INFO] running `Command { std: "docker" "start" "-a" "14d0adb04c7e033c99cac210a0b602572075a9c2b9dd2b3c9c6b930d228a0055", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "14d0adb04c7e033c99cac210a0b602572075a9c2b9dd2b3c9c6b930d228a0055", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "14d0adb04c7e033c99cac210a0b602572075a9c2b9dd2b3c9c6b930d228a0055", kill_on_drop: false }` [INFO] [stdout] 14d0adb04c7e033c99cac210a0b602572075a9c2b9dd2b3c9c6b930d228a0055 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 38108f6f3f5893f7906bec09de8099c7cf2cc624e7ec399c8e27ccc945956e8e [INFO] running `Command { std: "docker" "start" "-a" "38108f6f3f5893f7906bec09de8099c7cf2cc624e7ec399c8e27ccc945956e8e", kill_on_drop: false }` [INFO] [stderr] Compiling quote v1.0.41 [INFO] [stderr] Compiling libc v0.2.177 [INFO] [stderr] Compiling bytes v1.10.1 [INFO] [stderr] Compiling log v0.4.28 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling find-msvc-tools v0.1.4 [INFO] [stderr] Compiling litemap v0.8.1 [INFO] [stderr] Compiling writeable v0.6.2 [INFO] [stderr] Compiling slab v0.4.11 [INFO] [stderr] Compiling icu_normalizer_data v2.1.1 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling futures-sink v0.3.31 [INFO] [stderr] Compiling futures-io v0.3.31 [INFO] [stderr] Compiling icu_properties_data v2.1.1 [INFO] [stderr] Compiling tracing-core v0.1.34 [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling hashbrown v0.16.0 [INFO] [stderr] Compiling openssl v0.10.74 [INFO] [stderr] Compiling typenum v1.19.0 [INFO] [stderr] Compiling cc v1.2.44 [INFO] [stderr] Compiling generic-array v0.14.9 [INFO] [stderr] Compiling utf8_iter v1.0.4 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling openssl-probe v0.1.6 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling syn v2.0.109 [INFO] [stderr] Compiling thiserror v2.0.17 [INFO] [stderr] Compiling iana-time-zone v0.1.64 [INFO] [stderr] Compiling hashbrown v0.15.5 [INFO] [stderr] Compiling concurrent-queue v2.5.0 [INFO] [stderr] Compiling futures-channel v0.3.31 [INFO] [stderr] Compiling parking v2.2.1 [INFO] [stderr] Compiling cpufeatures v0.2.17 [INFO] [stderr] Compiling crc v3.3.0 [INFO] [stderr] Compiling http v1.3.1 [INFO] [stderr] Compiling event-listener v5.4.1 [INFO] [stderr] Compiling crossbeam-queue v0.3.12 [INFO] [stderr] Compiling indexmap v2.12.0 [INFO] [stderr] Compiling spin v0.9.8 [INFO] [stderr] Compiling base64 v0.22.1 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling hashlink v0.10.0 [INFO] [stderr] Compiling flume v0.11.1 [INFO] [stderr] Compiling chrono v0.4.42 [INFO] [stderr] Compiling atoi v2.0.0 [INFO] [stderr] Compiling ipnet v2.11.0 [INFO] [stderr] Compiling openssl-sys v0.9.110 [INFO] [stderr] Compiling libsqlite3-sys v0.30.1 [INFO] [stderr] Compiling socket2 v0.6.1 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling mio v1.1.0 [INFO] [stderr] Compiling signal-hook-registry v1.4.6 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling block-buffer v0.10.4 [INFO] [stderr] Compiling crypto-common v0.1.6 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling futures-intrusive v0.5.0 [INFO] [stderr] Compiling hex v0.4.3 [INFO] [stderr] Compiling tokio v1.48.0 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling regex-syntax v0.8.8 [INFO] [stderr] Compiling dotenvy v0.15.7 [INFO] [stderr] Compiling inotify-sys v0.1.5 [INFO] [stderr] Compiling num-integer v0.1.46 [INFO] [stderr] Compiling iri-string v0.7.9 [INFO] [stderr] Compiling zeroize v1.8.2 [INFO] [stderr] Compiling fastrand v2.3.0 [INFO] [stderr] Compiling anyhow v1.0.100 [INFO] [stderr] Compiling backon v1.6.0 [INFO] [stderr] Compiling rustls-pki-types v1.13.0 [INFO] [stderr] Compiling num-bigint v0.4.6 [INFO] [stderr] Compiling futures-executor v0.3.31 [INFO] [stderr] Compiling inotify v0.11.0 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling encoding_rs v0.8.35 [INFO] [stderr] Compiling arc-swap v1.7.1 [INFO] [stderr] Compiling serde_json v1.0.145 [INFO] [stderr] Compiling serde_path_to_error v0.1.20 [INFO] [stderr] Compiling unsafe-libyaml v0.2.11 [INFO] [stderr] Compiling sha1_smol v1.0.1 [INFO] [stderr] Compiling notify-types v2.0.0 [INFO] [stderr] Compiling notify v8.2.0 [INFO] [stderr] Compiling regex-automata v0.4.13 [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 tracing v0.1.41 [INFO] [stderr] Compiling axum-core v0.5.5 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling matchers v0.2.0 [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 icu_provider v2.1.1 [INFO] [stderr] Compiling tokio-stream v0.1.17 [INFO] [stderr] Compiling icu_properties v2.1.1 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [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 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 redis v0.32.7 [INFO] [stderr] Compiling sqlx-macros-core v0.8.6 [INFO] [stderr] Compiling hyper v1.7.0 [INFO] [stderr] Compiling sqlx-macros v0.8.6 [INFO] [stderr] Compiling sqlx v0.8.6 [INFO] [stderr] Compiling hyper-util v0.1.17 [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 33s [INFO] running `Command { std: "docker" "inspect" "38108f6f3f5893f7906bec09de8099c7cf2cc624e7ec399c8e27ccc945956e8e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "38108f6f3f5893f7906bec09de8099c7cf2cc624e7ec399c8e27ccc945956e8e", kill_on_drop: false }` [INFO] [stdout] 38108f6f3f5893f7906bec09de8099c7cf2cc624e7ec399c8e27ccc945956e8e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 374ac18b61e5e0103130d90dbbf9a63d7d3eeea86b99c770bdab9a4f07f78c36 [INFO] running `Command { std: "docker" "start" "-a" "374ac18b61e5e0103130d90dbbf9a63d7d3eeea86b99c770bdab9a4f07f78c36", kill_on_drop: false }` [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling backon v1.6.0 [INFO] [stderr] Compiling rustix v1.1.2 [INFO] [stderr] Compiling openssl v0.10.74 [INFO] [stderr] Compiling inotify v0.11.0 [INFO] [stderr] Compiling tower-http v0.6.6 [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 1m 14s [INFO] running `Command { std: "docker" "inspect" "374ac18b61e5e0103130d90dbbf9a63d7d3eeea86b99c770bdab9a4f07f78c36", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "374ac18b61e5e0103130d90dbbf9a63d7d3eeea86b99c770bdab9a4f07f78c36", kill_on_drop: false }` [INFO] [stdout] 374ac18b61e5e0103130d90dbbf9a63d7d3eeea86b99c770bdab9a4f07f78c36 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 2d822cb81280b5fb532aa8c6f61ff26d624c0222f11b8a51721f3a2bc311250c [INFO] running `Command { std: "docker" "start" "-a" "2d822cb81280b5fb532aa8c6f61ff26d624c0222f11b8a51721f3a2bc311250c", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.76s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/guardix-abf06bfefbb92248) [INFO] [stdout] [INFO] [stdout] running 102 tests [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_redis_url_when_enabled ... ok [INFO] [stdout] test config::tests::test_config_validation_empty_llm_model ... ok [INFO] [stdout] test config::tests::test_config_validation_empty_upstream_url ... 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 config::tests::test_config_validation_zero_judge_timeout ... ok [INFO] [stdout] test core::rulebook::tests::test_add_rule ... ok [INFO] [stdout] test config::tests::test_config_validation_zero_request_timeout ... ok [INFO] [stdout] test core::rulebook::tests::test_remove_rule ... ok [INFO] [stdout] test core::rulebook::tests::test_get_rule ... ok [INFO] [stdout] test core::judge::tests::test_fail_mode_open ... ok [INFO] [stdout] test core::rulebook::tests::test_remove_nonexistent_rule ... ok [INFO] [stdout] test core::rulebook::tests::test_rule_with_description ... ok [INFO] [stdout] test core::judge::tests::test_judge_with_mock_llm ... ok [INFO] [stdout] test core::rulebook::tests::test_rulebook_default ... ok [INFO] [stdout] test core::rulebook::tests::test_rulebook_new ... ok [INFO] [stdout] test core::judge::tests::test_fail_mode_closed ... ok [INFO] [stdout] test core::rulebook::tests::test_add_multiple_rules ... ok [INFO] [stdout] test core::rulebook::tests::test_rulebook_serialization ... ok [INFO] [stdout] test core::judge::tests::test_metrics_tracking ... ok [INFO] [stdout] test core::rulebook::tests::test_get_nonexistent_rule ... ok [INFO] [stdout] test core::rulebook::tests::test_rulebook_version_increments ... ok [INFO] [stdout] test core::judge::tests::test_judge_block_decision ... ok [INFO] [stdout] test http::middleware::tests::test_tracing_middleware ... ok [INFO] [stdout] test core::rulebook::tests::test_get_rules_by_type ... ok [INFO] [stdout] test http::proxy::tests::test_extract_payload_with_encoded_query_params ... ok [INFO] [stdout] test core::rulebook::tests::test_rule_unique_ids ... ok [INFO] [stdout] test http::proxy::tests::test_extract_payload_with_ip_from_x_forwarded_for ... ok [INFO] [stdout] test llm::ollama::tests::test_chat_request_structure ... ok [INFO] [stdout] test http::proxy::tests::test_extract_payload_with_headers ... ok [INFO] [stdout] test http::proxy::tests::test_extract_payload_basic ... 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 config::tests::test_config_validation_empty_storage_paths ... ok [INFO] [stdout] test http::proxy::tests::test_extract_payload_normalized_hash ... ok [INFO] [stdout] test http::proxy::tests::test_extract_payload_with_body ... ok [INFO] [stdout] test config::tests::test_learner_config_batch_interval ... ok [INFO] [stdout] test core::rulebook::tests::test_rule_new ... ok [INFO] [stdout] test http::proxy::tests::test_extract_payload_with_query_params ... ok [INFO] [stdout] test llm::ollama::tests::test_parse_threat_level ... ok [INFO] [stdout] test llm::prompts::tests::test_truncate ... ok [INFO] [stdout] test models::decision::tests::test_judge_decision_confidence ... ok [INFO] [stdout] test http::proxy::tests::test_app_state_creation ... ok [INFO] [stdout] test core::learner::tests::test_learner_applies_changes ... 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_learner_output_structure ... ok [INFO] [stdout] test models::decision::tests::test_rule_action_as_str ... ok [INFO] [stdout] test config::tests::test_cache_config_ttl ... ok [INFO] [stdout] test models::decision::tests::test_threat_level_as_str ... 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 models::decision::tests::test_judge_decision_is_block ... ok [INFO] [stdout] test models::decision::tests::test_judge_decision_type ... ok [INFO] [stdout] test models::decision::tests::test_rule_action_serialization ... ok [INFO] [stdout] test models::decision::tests::test_threat_level_serialization ... 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_content_type_missing ... ok [INFO] [stdout] test models::request::tests::test_get_user_agent ... ok [INFO] [stdout] test models::request::tests::test_get_user_agent_case_insensitive ... ok [INFO] [stdout] test models::request::tests::test_get_user_agent_missing ... 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_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_redis_empty_url ... 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_verdict_key_format ... ok [INFO] [stdout] test storage::cache::tests::test_verdict_key_with_special_chars ... ok [INFO] [stdout] test models::request::tests::test_compute_hash_consistency ... ok [INFO] [stdout] test models::request::tests::test_compute_hash_different_for_different_requests ... ok [INFO] [stdout] test models::request::tests::test_content_type ... ok [INFO] [stdout] test models::request::tests::test_content_type_case_insensitive ... ok [INFO] [stdout] test storage::logs::tests::test_get_blocked_since ... 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_get_flagged_since ... ok [INFO] [stdout] test storage::logs::tests::test_get_events_since_with_limit ... ok [INFO] [stdout] test storage::logs::tests::test_get_flagged_since_timestamp_filter ... ok [INFO] [stdout] test storage::logs::tests::test_log_event ... ok [INFO] [stdout] test llm::ollama::tests::test_parse_learner_response_empty ... ok [INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_flag ... ok [INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_invalid_decision ... ok [INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_block ... 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 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 ... ok [INFO] [stdout] test llm::ollama::tests::test_parse_learner_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.75s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/guardix-8d5e67fb5bb68d5d) [INFO] [stdout] [INFO] [stdout] running 102 tests [INFO] [stdout] test config::tests::test_config_validation ... ok [INFO] [stdout] test config::tests::test_config_validation_empty_llm_model ... ok [INFO] [stdout] test config::tests::test_learner_config_batch_interval ... ok [INFO] [stdout] test config::tests::test_config_validation_zero_judge_timeout ... ok [INFO] [stdout] test config::tests::test_waf_config_request_timeout ... ok [INFO] [stdout] test config::tests::test_config_validation_empty_llm_base_url ... ok [INFO] [stdout] test config::tests::test_config_validation_empty_redis_url_when_enabled ... ok [INFO] [stdout] test core::rulebook::tests::test_add_multiple_rules ... ok [INFO] [stdout] test core::judge::tests::test_judge_with_mock_llm ... 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 config::tests::test_config_validation_zero_request_timeout ... ok [INFO] [stdout] test config::tests::test_config_validation_empty_listen_addr ... ok [INFO] [stdout] test core::judge::tests::test_fail_mode_closed ... ok [INFO] [stdout] test core::rulebook::tests::test_remove_nonexistent_rule ... ok [INFO] [stdout] test core::rulebook::tests::test_remove_rule ... ok [INFO] [stdout] test config::tests::test_config_validation_empty_upstream_url ... ok [INFO] [stdout] test core::rulebook::tests::test_add_rule ... ok [INFO] [stdout] test core::rulebook::tests::test_rule_new ... ok [INFO] [stdout] test core::judge::tests::test_judge_block_decision ... ok [INFO] [stdout] test config::tests::test_llm_config_judge_timeout ... ok [INFO] [stdout] test core::rulebook::tests::test_rule_with_description ... ok [INFO] [stdout] test core::rulebook::tests::test_get_rule ... ok [INFO] [stdout] test core::rulebook::tests::test_rulebook_default ... ok [INFO] [stdout] test core::rulebook::tests::test_rulebook_serialization ... ok [INFO] [stdout] test core::rulebook::tests::test_rulebook_new ... ok [INFO] [stdout] test core::rulebook::tests::test_rule_unique_ids ... ok [INFO] [stdout] test core::rulebook::tests::test_rulebook_version_increments ... ok [INFO] [stdout] test http::proxy::tests::test_health_handler ... 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::middleware::tests::test_tracing_middleware ... ok [INFO] [stdout] test llm::ollama::tests::test_chat_request_structure ... ok [INFO] [stdout] test core::rulebook::tests::test_get_rules_by_type ... ok [INFO] [stdout] test http::proxy::tests::test_extract_payload_with_encoded_query_params ... 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 http::proxy::tests::test_extract_query_params ... ok [INFO] [stdout] test http::proxy::tests::test_extract_payload_with_body ... ok [INFO] [stdout] test http::proxy::tests::test_extract_payload_with_headers ... ok [INFO] [stdout] test config::tests::test_cache_config_ttl ... 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_truncate ... ok [INFO] [stdout] test llm::prompts::tests::test_learner_prompt_generation ... 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_judge_decision_is_flag ... ok [INFO] [stdout] test models::decision::tests::test_judge_decision_type ... 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_judge_decision_serialization ... ok [INFO] [stdout] test config::tests::test_config_validation_empty_storage_paths ... ok [INFO] [stdout] test core::rulebook::tests::test_get_nonexistent_rule ... ok [INFO] [stdout] test models::decision::tests::test_rule_action_serialization ... ok [INFO] [stdout] test models::decision::tests::test_threat_level_serialization ... ok [INFO] [stdout] test models::request::tests::test_compute_hash_consistency ... ok [INFO] [stdout] test models::request::tests::test_compute_hash_different_for_different_requests ... ok [INFO] [stdout] test models::request::tests::test_compute_hash_with_body ... ok [INFO] [stdout] test models::decision::tests::test_threat_level_as_str ... ok [INFO] [stdout] test models::request::tests::test_content_type ... ok [INFO] [stdout] test models::request::tests::test_compute_hash_without_body ... ok [INFO] [stdout] test models::request::tests::test_content_type_case_insensitive ... ok [INFO] [stdout] test models::request::tests::test_content_type_missing ... ok [INFO] [stdout] test models::request::tests::test_get_user_agent ... 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 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_request_payload_serialization ... ok [INFO] [stdout] test storage::cache::tests::test_redis_invalid_url ... ok [INFO] [stdout] test storage::cache::tests::test_redis_empty_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 models::request::tests::test_get_user_agent_missing ... ok [INFO] [stdout] test storage::cache::tests::test_verdict_key_with_special_chars ... ok [INFO] [stdout] test models::request::tests::test_get_user_agent_case_insensitive ... ok [INFO] [stdout] test core::learner::tests::test_learner_applies_changes ... ok [INFO] [stdout] test storage::cache::tests::test_verdict_key_format ... 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_blocked_since ... ok [INFO] [stdout] test storage::logs::tests::test_log_event ... ok [INFO] [stdout] test storage::logs::tests::test_get_events_since_with_limit ... ok [INFO] [stdout] test storage::rules::tests::test_save_and_load ... ok [INFO] [stdout] test storage::logs::tests::test_get_flagged_since_timestamp_filter ... ok [INFO] [stdout] test storage::logs::tests::test_count_events_by_decision ... ok [INFO] [stdout] test llm::ollama::tests::test_parse_learner_response ... ok [INFO] [stdout] test llm::ollama::tests::test_parse_learner_response_invalid_json ... ok [INFO] [stdout] test storage::logs::tests::test_log_event_with_allow_decision ... 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 ... 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_judge_response_invalid_decision ... ok [INFO] [stdout] test llm::ollama::tests::test_parse_learner_response_empty ... ok [INFO] [stdout] test llm::ollama::tests::test_parse_judge_response_block_without_threat_level ... 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] [INFO] [stdout] test result: ok. 96 passed; 0 failed; 6 ignored; 0 measured; 0 filtered out; finished in 0.78s [INFO] [stdout] [INFO] [stderr] Running tests/e2e_tests.rs (/opt/rustwide/target/debug/deps/e2e_tests-9bc3ad98bcbc8d6b) [INFO] [stdout] [INFO] [stderr] Doc-tests guardix [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.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" "2d822cb81280b5fb532aa8c6f61ff26d624c0222f11b8a51721f3a2bc311250c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2d822cb81280b5fb532aa8c6f61ff26d624c0222f11b8a51721f3a2bc311250c", kill_on_drop: false }` [INFO] [stdout] 2d822cb81280b5fb532aa8c6f61ff26d624c0222f11b8a51721f3a2bc311250c