[INFO] cloning repository https://github.com/Macbet/harbor_router [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Macbet/harbor_router" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMacbet%2Fharbor_router", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMacbet%2Fharbor_router'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 3e4818c939cafc0696c4257a5c5c22bc0cbd22cc [INFO] testing Macbet/harbor_router against try#8da20828b6ea601dfd8e2448cb50ace88876bd78 for pr-150933 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMacbet%2Fharbor_router" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/Macbet/harbor_router [INFO] finished tweaking git repo https://github.com/Macbet/harbor_router [INFO] tweaked toml for git repo https://github.com/Macbet/harbor_router written to /workspace/builds/worker-1-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/Macbet/harbor_router on toolchain 8da20828b6ea601dfd8e2448cb50ace88876bd78 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/Macbet/harbor_router 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" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 4775498d1b84e89f261b17d06c4c16e2e9244f9aa6c7394024189618c587bd24 [INFO] running `Command { std: "docker" "start" "-a" "4775498d1b84e89f261b17d06c4c16e2e9244f9aa6c7394024189618c587bd24", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "4775498d1b84e89f261b17d06c4c16e2e9244f9aa6c7394024189618c587bd24", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4775498d1b84e89f261b17d06c4c16e2e9244f9aa6c7394024189618c587bd24", kill_on_drop: false }` [INFO] [stdout] 4775498d1b84e89f261b17d06c4c16e2e9244f9aa6c7394024189618c587bd24 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] fe1d247433391ad36e8f001f1b65da7c9d28a8721c7b49661f7aca689dfd7d6d [INFO] running `Command { std: "docker" "start" "-a" "fe1d247433391ad36e8f001f1b65da7c9d28a8721c7b49661f7aca689dfd7d6d", kill_on_drop: false }` [INFO] [stderr] Compiling unicode-ident v1.0.24 [INFO] [stderr] Compiling libc v0.2.182 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling futures-core v0.3.32 [INFO] [stderr] Compiling bytes v1.11.1 [INFO] [stderr] Compiling futures-sink v0.3.32 [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling log v0.4.29 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling slab v0.4.12 [INFO] [stderr] Compiling fs_extra v1.3.0 [INFO] [stderr] Compiling futures-task v0.3.32 [INFO] [stderr] Compiling futures-io v0.3.32 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling zeroize v1.8.2 [INFO] [stderr] Compiling aws-lc-rs v1.16.0 [INFO] [stderr] Compiling proc-macro2 v1.0.106 [INFO] [stderr] Compiling futures-channel v0.3.32 [INFO] [stderr] Compiling foldhash v0.2.0 [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling rustls-pki-types v1.14.0 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling rustls v0.23.36 [INFO] [stderr] Compiling zerocopy v0.8.39 [INFO] [stderr] Compiling zmij v1.0.21 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling hashbrown v0.16.1 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling portable-atomic v1.13.1 [INFO] [stderr] Compiling getrandom v0.4.1 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling rustversion v1.0.22 [INFO] [stderr] Compiling quote v1.0.44 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling openssl-probe v0.2.1 [INFO] [stderr] Compiling linux-raw-sys v0.4.15 [INFO] [stderr] Compiling time-core v0.1.8 [INFO] [stderr] Compiling protobuf v3.7.2 [INFO] [stderr] Compiling num-conv v0.2.0 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling rustls-native-certs v0.8.3 [INFO] [stderr] Compiling procfs v0.17.0 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling time-macros v0.2.27 [INFO] [stderr] Compiling deranged v0.5.8 [INFO] [stderr] Compiling procfs-core v0.17.0 [INFO] [stderr] Compiling raw-cpuid v11.6.0 [INFO] [stderr] Compiling iri-string v0.7.10 [INFO] [stderr] Compiling indexmap v2.13.0 [INFO] [stderr] Compiling anyhow v1.0.102 [INFO] [stderr] Compiling num-integer v0.1.46 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling socket2 v0.6.2 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling rand_core v0.9.5 [INFO] [stderr] Compiling num_threads v0.1.7 [INFO] [stderr] Compiling prometheus v0.14.0 [INFO] [stderr] Compiling fastrand v2.3.0 [INFO] [stderr] Compiling dashmap v6.1.0 [INFO] [stderr] Compiling uuid v1.21.0 [INFO] [stderr] Compiling backon v1.6.0 [INFO] [stderr] Compiling time v0.3.47 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling num-bigint v0.4.6 [INFO] [stderr] Compiling arc-swap v1.8.2 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling cmake v0.1.57 [INFO] [stderr] Compiling crossbeam-epoch v0.9.18 [INFO] [stderr] Compiling spinning_top v0.3.0 [INFO] [stderr] Compiling thread_local v1.1.9 [INFO] [stderr] Compiling matchit v0.8.4 [INFO] [stderr] Compiling xxhash-rust v0.8.15 [INFO] [stderr] Compiling futures-timer v3.0.3 [INFO] [stderr] Compiling quanta v0.12.6 [INFO] [stderr] Compiling arcstr v1.2.0 [INFO] [stderr] Compiling tagptr v0.2.0 [INFO] [stderr] Compiling sha1_smol v1.0.1 [INFO] [stderr] Compiling nonzero_ext v0.3.0 [INFO] [stderr] Compiling web-time v1.1.0 [INFO] [stderr] Compiling moka v0.12.13 [INFO] [stderr] Compiling num_cpus v1.17.0 [INFO] [stderr] Compiling socket2 v0.5.10 [INFO] [stderr] Compiling aws-lc-sys v0.37.1 [INFO] [stderr] Compiling serde_path_to_error v0.1.20 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling rand v0.9.2 [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 tokio-macros v2.6.0 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling axum-macros v0.5.0 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling protobuf-support v3.7.2 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling axum-core v0.5.6 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling tracing-serde v0.2.0 [INFO] [stderr] Compiling secrecy v0.10.3 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling futures-executor v0.3.32 [INFO] [stderr] Compiling governor v0.10.4 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling futures v0.3.32 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling combine v4.6.7 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling axum v0.8.8 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling rustls-platform-verifier v0.6.2 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling redis v1.0.4 [INFO] [stderr] Compiling reqwest v0.13.2 [INFO] [stderr] Compiling harbor-router v1.4.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 08s [INFO] running `Command { std: "docker" "inspect" "fe1d247433391ad36e8f001f1b65da7c9d28a8721c7b49661f7aca689dfd7d6d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "fe1d247433391ad36e8f001f1b65da7c9d28a8721c7b49661f7aca689dfd7d6d", kill_on_drop: false }` [INFO] [stdout] fe1d247433391ad36e8f001f1b65da7c9d28a8721c7b49661f7aca689dfd7d6d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] d3e1fbb84088cad3428277fb253a727f172a433dbc1d7900c478e895eb8955a6 [INFO] running `Command { std: "docker" "start" "-a" "d3e1fbb84088cad3428277fb253a727f172a433dbc1d7900c478e895eb8955a6", kill_on_drop: false }` [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling regex-syntax v0.8.9 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling deadpool-runtime v0.1.4 [INFO] [stderr] Compiling assert-json-diff v2.0.2 [INFO] [stderr] Compiling deadpool v0.12.3 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling axum v0.8.8 [INFO] [stderr] Compiling reqwest v0.13.2 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling wiremock v0.6.5 [INFO] [stderr] Compiling harbor-router v1.4.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 9.23s [INFO] running `Command { std: "docker" "inspect" "d3e1fbb84088cad3428277fb253a727f172a433dbc1d7900c478e895eb8955a6", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "d3e1fbb84088cad3428277fb253a727f172a433dbc1d7900c478e895eb8955a6", kill_on_drop: false }` [INFO] [stdout] d3e1fbb84088cad3428277fb253a727f172a433dbc1d7900c478e895eb8955a6 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] edbe604e8cfb25e5ca5b2fe17db51fd37a60e22c51abc8f3a3b58d52f4f78613 [INFO] running `Command { std: "docker" "start" "-a" "edbe604e8cfb25e5ca5b2fe17db51fd37a60e22c51abc8f3a3b58d52f4f78613", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.15s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/harbor_router-5d011191634366f4) [INFO] [stdout] [INFO] [stdout] running 108 tests [INFO] [stdout] test cache::tests::test_moka_cache_delete ... ok [INFO] [stdout] test cache::tests::test_moka_cache_miss ... ok [INFO] [stdout] test cache::tests::test_moka_cache_delete_nonexistent ... ok [INFO] [stdout] test cache::tests::test_moka_cache_clone_shares_data ... ok [INFO] [stdout] test config::tests::test_circuit_breaker_threshold_custom ... ok [INFO] [stdout] test cache::tests::test_moka_cache_set_and_get ... ok [INFO] [stdout] test cache::tests::test_moka_cache_overwrite ... ok [INFO] [stdout] test config::tests::test_circuit_breaker_threshold_default ... ok [INFO] [stdout] test config::tests::test_circuit_breaker_threshold_invalid ... ok [INFO] [stdout] test config::tests::test_circuit_breaker_timeout_custom ... ok [INFO] [stdout] test config::tests::test_circuit_breaker_timeout_default ... ok [INFO] [stdout] test config::tests::test_circuit_breaker_timeout_invalid ... ok [INFO] [stdout] test config::tests::test_env_str_or_file_empty_returns_empty ... ok [INFO] [stdout] test config::tests::test_env_str_or_file_from_env ... ok [INFO] [stdout] test config::tests::test_negative_cache_ttl_custom ... ok [INFO] [stdout] test config::tests::test_negative_cache_ttl_default ... ok [INFO] [stdout] test config::tests::test_negative_cache_ttl_invalid ... ok [INFO] [stdout] test config::tests::test_parse_go_duration_fractional ... ok [INFO] [stdout] test config::tests::test_parse_go_duration_combined ... ok [INFO] [stdout] test config::tests::test_parse_go_duration_hours ... ok [INFO] [stdout] test config::tests::test_parse_go_duration_milliseconds ... ok [INFO] [stdout] test config::tests::test_parse_go_duration_invalid ... ok [INFO] [stdout] test config::tests::test_should_warn_plaintext_url_127_0_0_1 ... ok [INFO] [stdout] test config::tests::test_parse_go_duration_seconds ... ok [INFO] [stdout] test config::tests::test_parse_go_duration_minutes ... ok [INFO] [stdout] test config::tests::test_should_warn_plaintext_url_harbor_core ... ok [INFO] [stdout] test config::tests::test_should_warn_plaintext_url_http_remote ... ok [INFO] [stdout] test config::tests::test_should_warn_plaintext_url_https ... ok [INFO] [stdout] test config::tests::test_should_warn_plaintext_url_localhost ... ok [INFO] [stdout] test config::tests::test_stale_while_revalidate_default ... ok [INFO] [stdout] test config::tests::test_stale_while_revalidate_custom ... ok [INFO] [stdout] test config::tests::test_stale_while_revalidate_invalid ... ok [INFO] [stdout] test discovery::tests::rejects_control_characters ... ok [INFO] [stdout] test discovery::tests::rejects_path_traversal ... ok [INFO] [stdout] test discovery::tests::rejects_empty ... ok [INFO] [stdout] test discovery::tests::rejects_slashes ... ok [INFO] [stdout] test discovery::tests::safe_project_names ... ok [INFO] [stdout] test metrics::tests::test_escape_label_value ... ok [INFO] [stdout] test discovery::tests::rejects_whitespace_padding ... ok [INFO] [stdout] test proxy::tests::test_is_safe_image_name ... ok [INFO] [stdout] test proxy::tests::test_copy_headers_allows_location ... ok [INFO] [stdout] test proxy::tests::test_copy_headers_filters_unsafe ... ok [INFO] [stdout] test config::tests::test_env_str_or_file_missing_file_error ... ok [INFO] [stdout] test config::tests::test_env_str_or_file_file_takes_precedence ... ok [INFO] [stdout] test config::tests::test_env_str_or_file_from_file ... ok [INFO] [stdout] test proxy::tests::test_parse_path_accepts_valid_digest ... ok [INFO] [stdout] test proxy::tests::test_parse_path_blob_nested_image ... ok [INFO] [stdout] test proxy::tests::test_is_safe_reference ... ok [INFO] [stdout] test proxy::tests::test_parse_path_empty_image ... ok [INFO] [stdout] test proxy::tests::test_parse_path_manifest_deeply_nested ... ok [INFO] [stdout] test proxy::tests::test_parse_path_empty_reference ... ok [INFO] [stdout] test proxy::tests::test_parse_path_empty_both ... ok [INFO] [stdout] test proxy::tests::test_parse_path_blob_simple ... ok [INFO] [stdout] test proxy::tests::test_parse_path_manifest_simple ... ok [INFO] [stdout] test proxy::tests::test_parse_path_manifest_nested_image ... ok [INFO] [stdout] test proxy::tests::test_parse_path_missing_kind ... ok [INFO] [stdout] test metrics::tests::test_record_manifest_request ... ok [INFO] [stdout] test proxy::tests::test_parse_path_rejects_control_chars_in_image ... ok [INFO] [stdout] test metrics::tests::test_upstream_project_duration_histogram ... ok [INFO] [stdout] test proxy::tests::test_parse_path_rejects_backslash_in_image ... ok [INFO] [stdout] test proxy::tests::test_parse_path_rejects_mid_traversal_in_image ... ok [INFO] [stdout] test proxy::tests::test_parse_path_rejects_deep_traversal_in_image ... ok [INFO] [stdout] test proxy::tests::test_parse_path_rejects_slash_in_blob_digest ... ok [INFO] [stdout] test proxy::tests::test_parse_path_rejects_slash_in_reference ... ok [INFO] [stdout] test proxy::tests::test_parse_path_rejects_traversal_in_image ... ok [INFO] [stdout] test proxy::tests::test_parse_path_rejects_traversal_in_blob_image ... ok [INFO] [stdout] test proxy::tests::test_parse_path_rejects_leading_slash_in_image ... ok [INFO] [stdout] test proxy::tests::test_parse_path_tags ... ok [INFO] [stdout] test proxy::tests::test_parse_path_rejects_traversal_in_reference ... ok [INFO] [stdout] test proxy::tests::test_parse_path_tags_deeply_nested ... ok [INFO] [stdout] test proxy::tests::test_parse_path_tags_empty_image ... ok [INFO] [stdout] test proxy::tests::test_parse_path_tags_nested_image ... ok [INFO] [stdout] test proxy::tests::test_parse_path_tags_rejects_traversal ... ok [INFO] [stdout] test proxy::tests::test_parse_path_uses_last_match ... ok [INFO] [stdout] test circuit_breaker::tests::test_circuit_breaker_opens_after_threshold ... ok [INFO] [stdout] test resolver::tests::test_content_type_matches ... ok [INFO] [stdout] test resolver::tests::test_encode_decode_cache_value ... ok [INFO] [stdout] test resolver::tests::test_helper_is_retryable_error ... ok [INFO] [stdout] test resolver::tests::test_helper_is_retryable_status ... ok [INFO] [stdout] test cache::tests::test_moka_cache_expiry ... ok [INFO] [stdout] test resolver::tests::test_fetch_manifest_success ... ok [INFO] [stdout] test resolver::tests::test_cached_project_fallback_to_image_level ... ok [INFO] [stdout] test resolver::tests::test_handle_tags_returns_tag_list ... ok [INFO] [stdout] test resolver::tests::test_fetch_manifest_with_auth ... ok [INFO] [stdout] test resolver::tests::test_fetch_manifest_records_latency ... ok [INFO] [stdout] test resolver::tests::test_fetch_manifest_with_accept_headers ... ok [INFO] [stdout] test resolver::tests::test_cached_project_returns_cached_value ... ok [INFO] [stdout] test resolver::tests::test_cached_project_returns_none_when_empty ... ok [INFO] [stdout] test resolver::tests::test_fetch_manifest_not_found ... ok [INFO] [stdout] test resolver::tests::test_content_type_fallback_on_no_match ... ok [INFO] [stdout] test resolver::tests::test_negative_cache_prevents_fanout ... ok [INFO] [stdout] test resolver::tests::test_content_type_negotiation_picks_best_match ... ok [INFO] [stdout] test resolver::tests::test_retry_no_retry_on_client_error ... ok [INFO] [stdout] test resolver::tests::test_retry_exhausts_all_attempts ... ok [INFO] [stdout] test resolver::tests::test_warm_cache_handles_missing_data ... ok [INFO] [stdout] test resolver::tests::test_retry_on_server_error ... ok [INFO] [stdout] test resolver::tests::test_retry_disabled_when_max_attempts_is_one ... ok [INFO] [stdout] test resolver::tests::test_warm_cache_from_redis ... ok [INFO] [stdout] test resolver::tests::test_stale_while_revalidate_serves_stale ... ok [INFO] [stdout] test resolver::tests::test_tags_cached ... ok [INFO] [stdout] test resolver::tests::test_warm_cache_skips_unsafe_projects ... ok [INFO] [stdout] test resolver::tests::test_stale_while_revalidate_triggers_background_refresh ... ok [INFO] [stdout] test resolver::tests::test_persist_hot_entries_and_warm_roundtrip ... ok [INFO] [stdout] test resolver::tests::test_negative_cache_expires ... ok [INFO] [stdout] test circuit_breaker::tests::test_circuit_breaker_half_open ... ok [INFO] [stdout] test circuit_breaker::tests::test_circuit_breaker_recovers_after_timeout ... ok [INFO] [stdout] test cache::tests::test_moka_cache_set_with_ttl ... ok [INFO] [stdout] test resolver::tests::test_singleflight_follower_timeout ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 108 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 5.60s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "edbe604e8cfb25e5ca5b2fe17db51fd37a60e22c51abc8f3a3b58d52f4f78613", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "edbe604e8cfb25e5ca5b2fe17db51fd37a60e22c51abc8f3a3b58d52f4f78613", kill_on_drop: false }` [INFO] [stdout] edbe604e8cfb25e5ca5b2fe17db51fd37a60e22c51abc8f3a3b58d52f4f78613