[INFO] cloning repository https://github.com/electricessence/claw-router
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/electricessence/claw-router" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Felectricessence%2Fclaw-router", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Felectricessence%2Fclaw-router'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 2ea90e7671b726ca3a4af1df46b9767301a22b38
[INFO] testing electricessence/claw-router against try#33835004928d3bf65db4d4712e1330766263b0bd for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Felectricessence%2Fclaw-router" "/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/electricessence/claw-router
[INFO] finished tweaking git repo https://github.com/electricessence/claw-router
[INFO] tweaked toml for git repo https://github.com/electricessence/claw-router written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/electricessence/claw-router on toolchain 33835004928d3bf65db4d4712e1330766263b0bd
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/electricessence/claw-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" "+33835004928d3bf65db4d4712e1330766263b0bd" "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" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c514292ce77e443a39524dda3167bb3d409b758b376f225e670eef320f2daf8f
[INFO] running `Command { std: "docker" "start" "-a" "c514292ce77e443a39524dda3167bb3d409b758b376f225e670eef320f2daf8f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c514292ce77e443a39524dda3167bb3d409b758b376f225e670eef320f2daf8f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c514292ce77e443a39524dda3167bb3d409b758b376f225e670eef320f2daf8f", kill_on_drop: false }`
[INFO] [stdout] c514292ce77e443a39524dda3167bb3d409b758b376f225e670eef320f2daf8f
[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=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 643054170b0b499d3859d1813add2078c777f3fe5b9251073fd20482573b375a
[INFO] running `Command { std: "docker" "start" "-a" "643054170b0b499d3859d1813add2078c777f3fe5b9251073fd20482573b375a", kill_on_drop: false }`
[INFO] [stderr]    Compiling unicode-ident v1.0.24
[INFO] [stderr]    Compiling quote v1.0.44
[INFO] [stderr]    Compiling libc v0.2.182
[INFO] [stderr]    Compiling itoa v1.0.17
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling cc v1.2.56
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling regex-syntax v0.8.10
[INFO] [stderr]    Compiling proc-macro2 v1.0.106
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling futures-channel v0.3.32
[INFO] [stderr]    Compiling native-tls v0.2.18
[INFO] [stderr]    Compiling openssl-probe v0.2.1
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling socket2 v0.6.2
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling getrandom v0.4.1
[INFO] [stderr]    Compiling bit-vec v0.6.3
[INFO] [stderr]    Compiling iri-string v0.7.10
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling bit-set v0.5.3
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling serde_path_to_error v0.1.20
[INFO] [stderr]    Compiling iana-time-zone v0.1.65
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling uuid v1.21.0
[INFO] [stderr]    Compiling dashmap v6.1.0
[INFO] [stderr]    Compiling fancy-regex v0.13.0
[INFO] [stderr]    Compiling bstr v1.12.1
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling tiktoken-rs v0.9.1
[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 displaydoc v0.2.5
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling futures-macro v0.3.32
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[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 zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling tracing v0.1.44
[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 axum-core v0.5.6
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling tracing-serde v0.2.0
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling axum v0.8.8
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling lm-gateway-rs v0.4.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 56s
[INFO] running `Command { std: "docker" "inspect" "643054170b0b499d3859d1813add2078c777f3fe5b9251073fd20482573b375a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "643054170b0b499d3859d1813add2078c777f3fe5b9251073fd20482573b375a", kill_on_drop: false }`
[INFO] [stdout] 643054170b0b499d3859d1813add2078c777f3fe5b9251073fd20482573b375a
[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=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f9d832e5f151bba678179175de30caae32384fed0892bf25fff7bc2e5b3e7423
[INFO] running `Command { std: "docker" "start" "-a" "f9d832e5f151bba678179175de30caae32384fed0892bf25fff7bc2e5b3e7423", kill_on_drop: false }`
[INFO] [stderr]    Compiling slab v0.4.12
[INFO] [stderr]    Compiling futures-io v0.3.32
[INFO] [stderr]    Compiling num_cpus v1.17.0
[INFO] [stderr]    Compiling deadpool-runtime v0.1.4
[INFO] [stderr]    Compiling assert-json-diff v2.0.2
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling deadpool v0.12.3
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling futures-executor v0.3.32
[INFO] [stderr]    Compiling futures v0.3.32
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling axum v0.8.8
[INFO] [stderr]    Compiling wiremock v0.6.5
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling lm-gateway-rs v0.4.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 47.19s
[INFO] running `Command { std: "docker" "inspect" "f9d832e5f151bba678179175de30caae32384fed0892bf25fff7bc2e5b3e7423", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f9d832e5f151bba678179175de30caae32384fed0892bf25fff7bc2e5b3e7423", kill_on_drop: false }`
[INFO] [stdout] f9d832e5f151bba678179175de30caae32384fed0892bf25fff7bc2e5b3e7423
[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=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 7c09b090f2072f0fd08b4366c313df22f95770c5e56a75372f79191bbc080335
[INFO] running `Command { std: "docker" "start" "-a" "7c09b090f2072f0fd08b4366c313df22f95770c5e56a75372f79191bbc080335", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.32s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/lm_gateway-0baf46396ecf4aba)
[INFO] [stdout] 
[INFO] [stdout] running 146 tests
[INFO] [stdout] test api::admin::tests::config_serializes_routing_mode_using_display_not_debug ... ok
[INFO] [stdout] test api::admin::tests::traffic_returns_pushed_entries_newest_first ... ok
[INFO] [stdout] test api::admin::tests::config_redacts_api_key_value_and_shows_env_var_name ... ok
[INFO] [stdout] test api::admin::tests::health_returns_ok_with_tier_and_backend_counts ... ok
[INFO] [stdout] test api::admin::tests::traffic_returns_stats_and_empty_entries_list_on_fresh_log ... ok
[INFO] [stdout] test api::client::tests::list_models_returns_all_tiers ... ok
[INFO] [stdout] test api::client_auth::tests::missing_key_when_clients_configured_returns_401 ... ok
[INFO] [stdout] test api::client_auth::tests::invalid_key_returns_401 ... ok
[INFO] [stdout] test api::client_auth::tests::no_clients_configured_passes_through ... ok
[INFO] [stdout] test api::metrics::tests::error_count_is_accurate ... ok
[INFO] [stdout] test api::client_auth::tests::valid_key_injects_profile ... ok
[INFO] [stdout] test api::metrics::tests::latency_sum_is_accurate ... ok
[INFO] [stdout] test api::metrics::tests::window_size_equals_entry_count ... ok
[INFO] [stdout] test api::rate_limit::tests::different_ips_have_independent_buckets ... ok
[INFO] [stdout] test api::client::tests::healthz_returns_200_ok ... ok
[INFO] [stdout] test api::rate_limit::tests::exceeding_capacity_returns_retry_after ... ok
[INFO] [stdout] test api::client::tests::list_models_includes_aliases ... ok
[INFO] [stdout] test api::rate_limit::tests::fresh_bucket_allows_up_to_capacity ... ok
[INFO] [stdout] test api::status::tests::status_ready_false_when_backend_api_key_missing ... ok
[INFO] [stdout] test api::status::tests::status_response_contains_no_backend_or_tier_names ... ok
[INFO] [stdout] test api::status::tests::status_counts_errors_and_computes_error_rate ... ok
[INFO] [stdout] test api::status::tests::status_returns_ok_with_zero_metrics_on_fresh_state ... ok
[INFO] [stdout] test backends::anthropic::tests::from_anthropic_maps_end_turn_to_stop ... ok
[INFO] [stdout] test backends::anthropic::tests::from_anthropic_maps_max_tokens_stop_reason_to_length ... ok
[INFO] [stdout] test backends::anthropic::tests::from_anthropic_preserves_message_id ... ok
[INFO] [stdout] test backends::anthropic::tests::from_anthropic_errors_when_no_text_block_present ... ok
[INFO] [stdout] test backends::anthropic::tests::to_anthropic_errors_without_messages ... ok
[INFO] [stdout] test backends::anthropic::tests::to_anthropic_errors_without_model ... ok
[INFO] [stdout] test backends::anthropic::tests::to_anthropic_defaults_max_tokens_when_absent ... ok
[INFO] [stdout] test backends::anthropic::tests::to_anthropic_concatenates_multiple_system_messages ... ok
[INFO] [stdout] test backends::anthropic::tests::to_anthropic_extracts_system_message_to_top_level ... ok
[INFO] [stdout] test backends::anthropic::tests::to_anthropic_uses_caller_max_tokens ... ok
[INFO] [stdout] test backends::anthropic::tests::translate_content_block_delta_emits_text ... ok
[INFO] [stdout] test backends::anthropic::tests::translate_message_delta_maps_stop_reasons ... ok
[INFO] [stdout] test backends::anthropic::tests::to_anthropic_forwards_temperature ... ok
[INFO] [stdout] test backends::tests::api_key_returns_none_when_env_var_field_is_none ... ok
[INFO] [stdout] test backends::anthropic::tests::translate_message_start_sets_role_and_captures_model ... ok
[INFO] [stdout] test backends::anthropic::tests::translate_skips_ping_and_housekeeping_events ... ok
[INFO] [stdout] test backends::tests::chat_completions_returns_parsed_json_on_success ... ok
[INFO] [stdout] test backends::tests::health_check_errors_on_non_2xx ... ok
[INFO] [stdout] test backends::tests::new_resolves_api_key_from_env_var ... ok
[INFO] [stdout] test backends::tests::chat_completions_errors_on_invalid_json_response_body ... ok
[INFO] [stdout] test api::admin::tests::backends_health_returns_multi_status_when_any_backend_is_down ... ok
[INFO] [stdout] test config::gateway::tests::default_options_parses_from_toml ... ok
[INFO] [stdout] test backends::tests::chat_completions_errors_on_non_2xx_status ... ok
[INFO] [stdout] test api::admin::tests::backends_health_returns_200_all_ok_when_backends_respond ... ok
[INFO] [stdout] test config::tests::deep_merge_array_appends_new_named_entry ... ok
[INFO] [stdout] test config::tests::deep_merge_array_replaces_same_named_entry ... ok
[INFO] [stdout] test config::tests::conf_d_is_silently_skipped_when_absent ... ok
[INFO] [stdout] test config::tests::conf_d_overrides_backend_url ... ok
[INFO] [stdout] test config::tests::deep_merge_table_overlay_wins_per_key ... ok
[INFO] [stdout] test config::tests::no_cycle_passes_validation ... ok
[INFO] [stdout] test config::tests::normalize_compiles_regex_rules_sorted_by_priority_desc ... ok
[INFO] [stdout] test config::tests::gateway_defaults_are_applied_when_section_is_minimal ... ok
[INFO] [stdout] test config::tests::normalize_rejects_invalid_regex_pattern ... ok
[INFO] [stdout] test config::tests::profile_dir_is_silently_skipped_when_absent ... ok
[INFO] [stdout] test config::tests::parse_example_config ... ok
[INFO] [stdout] test config::tests::profile_dir_loads_profiles_from_directory ... ok
[INFO] [stdout] test config::tests::profile_dir_name_override_takes_precedence ... ok
[INFO] [stdout] test config::tests::profile_falls_back_to_default_for_unknown_name ... ok
[INFO] [stdout] test config::tests::profile_returns_named_profile_when_present ... ok
[INFO] [stdout] test config::tests::profile_returns_none_when_neither_named_nor_default_exists ... ok
[INFO] [stdout] test config::tests::provider_deserializes_lowercase ... ok
[INFO] [stdout] test config::tests::provider_display_matches_serde_key ... ok
[INFO] [stdout] test config::tests::resolve_tier_by_direct_name ... ok
[INFO] [stdout] test config::tests::resolve_tier_returns_none_for_unknown ... ok
[INFO] [stdout] test config::tests::resolve_tier_via_alias ... ok
[INFO] [stdout] test config::tests::routing_mode_deserializes_from_snake_case ... ok
[INFO] [stdout] test config::tests::three_hop_cascade_without_cycle_passes ... ok
[INFO] [stdout] test config::tests::three_hop_cycle_is_rejected ... ok
[INFO] [stdout] test config::tests::tier_route_to_is_ignored_by_cycle_check ... ok
[INFO] [stdout] test config::tests::two_hop_cycle_is_rejected ... ok
[INFO] [stdout] test config::tests::validation_rejects_alias_pointing_to_unknown_tier ... ok
[INFO] [stdout] test config::tests::validation_rejects_profile_with_unknown_classifier ... ok
[INFO] [stdout] test config::tests::validation_rejects_tier_with_unknown_backend ... ok
[INFO] [stdout] test error::tests::converts_from_anyhow_error ... ok
[INFO] [stdout] test error::tests::converts_from_io_error ... ok
[INFO] [stdout] test config::tests::profile_dir_overrides_inline_profiles ... ok
[INFO] [stdout] test error::tests::debug_format_includes_inner_error_message ... ok
[INFO] [stdout] test error::tests::error_message_survives_io_error_conversion ... ok
[INFO] [stdout] test error::tests::into_response_returns_500_with_json_error_body ... ok
[INFO] [stdout] test router::priority::tests::empty_gate_fires_any_priority ... ok
[INFO] [stdout] test router::priority::tests::background_queues_behind_normal_in_flight ... ok
[INFO] [stdout] test router::priority::tests::high_priority_fires_immediately_over_lower_in_flight ... ok
[INFO] [stdout] test router::priority::tests::equal_priority_queues_behind_in_flight ... ok
[INFO] [stdout] test router::priority::tests::high_priority_jumps_queue_of_waiting_background ... ok
[INFO] [stdout] test config::tests::direct_self_cycle_is_rejected ... ok
[INFO] [stdout] test backends::tests::health_check_returns_ok_on_2xx ... ok
[INFO] [stdout] test backends::tests::new_succeeds_when_configured_api_key_env_var_is_unset ... ok
[INFO] [stdout] test backends::tests::new_succeeds_without_api_key ... ok
[INFO] [stdout] test router::tests::dispatch_resolves_direct_tier_name_without_alias ... ok
[INFO] [stdout] test api::client::tests::chat_completions_proxies_to_backend_and_returns_response ... ok
[INFO] [stdout] test api::client::tests::chat_completions_returns_user_friendly_message_when_backend_is_unreachable ... ok
[INFO] [stdout] test router::tests::classify_regex_rule_bypasses_classifier_on_match ... ok
[INFO] [stdout] test router::tests::dispatch_falls_back_to_classifier_tier_on_unknown_model ... ok
[INFO] [stdout] test router::tests::find_min_tier_all_too_small_falls_back_to_last ... ok
[INFO] [stdout] test router::tests::find_min_tier_fits_first ... ok
[INFO] [stdout] test router::tests::find_min_tier_respects_start_idx ... ok
[INFO] [stdout] test router::tests::find_min_tier_skips_small_context ... ok
[INFO] [stdout] test router::tests::find_min_tier_uncapped_always_fits ... ok
[INFO] [stdout] test router::tests::inject_inserts_system_message_when_none_exists ... ok
[INFO] [stdout] test router::tests::inject_is_noop_when_messages_key_is_absent ... ok
[INFO] [stdout] test router::tests::inject_prepends_to_empty_existing_system_message ... ok
[INFO] [stdout] test router::tests::inject_prepends_to_existing_system_message ... ok
[INFO] [stdout] test router::tests::insufficient_when_choices_array_is_missing ... ok
[INFO] [stdout] test router::tests::insufficient_when_content_is_very_short ... ok
[INFO] [stdout] test router::tests::insufficient_when_model_refuses ... ok
[INFO] [stdout] test router::tests::parse_classification_empty_response_defaults_to_instant ... ok
[INFO] [stdout] test router::tests::parse_classification_label_delegates_to_parse_classification ... ok
[INFO] [stdout] test router::tests::parse_classification_legacy_single_token ... ok
[INFO] [stdout] test router::tests::parse_classification_missing_tier_key_uses_first_bare_token ... ok
[INFO] [stdout] test router::tests::parse_classification_structured_extracts_all_tags ... ok
[INFO] [stdout] test router::tests::parse_classification_think_suffix_in_structured ... ok
[INFO] [stdout] test router::tests::parse_classification_tier_key_wins_over_bare_tokens ... ok
[INFO] [stdout] test router::tests::parse_label_is_lowercased ... ok
[INFO] [stdout] test router::tests::parse_label_missing_content_falls_back_to_instant ... ok
[INFO] [stdout] test router::tests::parse_label_multiword_response_uses_first_token ... ok
[INFO] [stdout] test router::tests::parse_label_no_think_suffix_has_no_override ... ok
[INFO] [stdout] test router::tests::parse_label_simple_returns_simple_no_think ... ok
[INFO] [stdout] test router::tests::parse_label_think_suffix_sets_override ... ok
[INFO] [stdout] test router::tests::parse_label_trailing_punctuation_is_stripped ... ok
[INFO] [stdout] test router::tests::refusal_detection_is_case_insensitive ... ok
[INFO] [stdout] test router::tests::resolve_exact_full_name_matches ... ok
[INFO] [stdout] test router::tests::resolve_exact_name_takes_priority_over_suffix ... ok
[INFO] [stdout] test router::tests::resolve_single_tier_always_returns_it ... ok
[INFO] [stdout] test router::tests::resolve_suffix_after_colon_matches ... ok
[INFO] [stdout] test router::tests::resolve_unknown_label_falls_back_to_middle_tier ... ok
[INFO] [stdout] test router::tests::route_errors_when_no_profile_is_configured ... ok
[INFO] [stdout] test router::tests::dispatch_bumps_tier_when_context_window_exceeded ... ok
[INFO] [stdout] test router::tests::sufficient_for_normal_response ... ok
[INFO] [stdout] test traffic::tests::entry_has_unique_ids ... ok
[INFO] [stdout] test traffic::tests::entry_records_success_flag ... ok
[INFO] [stdout] test traffic::tests::oldest_entry_evicted_when_capacity_exceeded ... ok
[INFO] [stdout] test traffic::tests::push_and_retrieve_single_entry ... ok
[INFO] [stdout] test traffic::tests::recent_limits_result_count ... ok
[INFO] [stdout] test traffic::tests::recent_returns_entries_newest_first ... ok
[INFO] [stdout] test traffic::tests::stats_averages_latency_correctly ... ok
[INFO] [stdout] test traffic::tests::stats_counts_requests_per_tier ... ok
[INFO] [stdout] test traffic::tests::stats_on_empty_log ... ok
[INFO] [stdout] test router::tests::classify_regex_rule_falls_through_to_classifier_on_no_match ... FAILED
[INFO] [stdout] test router::tests::dispatch_routes_to_resolved_tier_and_returns_response ... ok
[INFO] [stdout] test router::tests::estimate_tokens_includes_tools ... ok
[INFO] [stdout] test router::tests::escalate_returns_first_sufficient_response ... ok
[INFO] [stdout] test router::tests::estimate_tokens_empty_body ... ok
[INFO] [stdout] test router::tests::estimate_tokens_from_messages ... ok
[INFO] [stdout] test router::tests::route_records_entry_in_traffic_log ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- router::tests::classify_regex_rule_falls_through_to_classifier_on_no_match stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'router::tests::classify_regex_rule_falls_through_to_classifier_on_no_match' (117) panicked at src/router/tests.rs:1133:5:
[INFO] [stdout] assertion `left == right` failed: non-matching message should fall through to classifier (which returns 'instant' → local:fast)
[INFO] [stdout]   left: "cloud:economy"
[INFO] [stdout]  right: "local:fast"
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5598a80b23ea - std[ec419fa8110287d5]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5598a80b23ea - std[ec419fa8110287d5]::backtrace_rs::backtrace::trace_unsynchronized::<std[ec419fa8110287d5]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5598a80b23ea - std[ec419fa8110287d5]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5598a80b23ea - <<std[ec419fa8110287d5]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[35159d6ffb30e017]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5598a80cb45a - <core[35159d6ffb30e017]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5598a80cb45a - core[35159d6ffb30e017]::fmt::write
[INFO] [stdout]    6:     0x5598a80b7e32 - std[ec419fa8110287d5]::io::default_write_fmt::<alloc[a8a7aba520129d98]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/io/mod.rs:621:11
[INFO] [stdout]    7:     0x5598a80b7e32 - <alloc[a8a7aba520129d98]::vec::Vec<u8> as std[ec419fa8110287d5]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/io/mod.rs:1976:13
[INFO] [stdout]    8:     0x5598a808d61f - <std[ec419fa8110287d5]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5598a808d61f - std[ec419fa8110287d5]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5598a80a9319 - std[ec419fa8110287d5]::panicking::default_hook
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5598a773f14c - <alloc[a8a7aba520129d98]::boxed::Box<dyn for<'a, 'b> core[35159d6ffb30e017]::ops::function::Fn<(&'a std[ec419fa8110287d5]::panic::PanicHookInfo<'b>,), Output = ()> + core[35159d6ffb30e017]::marker::Sync + core[35159d6ffb30e017]::marker::Send> as core[35159d6ffb30e017]::ops::function::Fn<(&std[ec419fa8110287d5]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2285:9
[INFO] [stdout]   12:     0x5598a773f14c - test[a8007afcd3effadc]::test_main_inner::<test[a8007afcd3effadc]::test_main_static::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:155:21
[INFO] [stdout]   13:     0x5598a80a9592 - <alloc[a8a7aba520129d98]::boxed::Box<dyn for<'a, 'b> core[35159d6ffb30e017]::ops::function::Fn<(&'a std[ec419fa8110287d5]::panic::PanicHookInfo<'b>,), Output = ()> + core[35159d6ffb30e017]::marker::Sync + core[35159d6ffb30e017]::marker::Send> as core[35159d6ffb30e017]::ops::function::Fn<(&std[ec419fa8110287d5]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2285:9
[INFO] [stdout]   14:     0x5598a80a9592 - std[ec419fa8110287d5]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5598a808d6d8 - std[ec419fa8110287d5]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x5598a8084649 - std[ec419fa8110287d5]::sys::backtrace::__rust_end_short_backtrace::<std[ec419fa8110287d5]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5598a808e85d - __rustc[cfb3622dd870db93]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5598a80cbccc - core[35159d6ffb30e017]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5598a80cbbb3 - core[35159d6ffb30e017]::panicking::assert_failed_inner
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panicking.rs:434:23
[INFO] [stdout]   20:     0x5598a764d641 - core[35159d6ffb30e017]::panicking::assert_failed::<alloc[a8a7aba520129d98]::string::String, &str>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x5598a747a2fc - lm_gateway[bf534003d944c0c6]::router::tests::classify_regex_rule_falls_through_to_classifier_on_no_match::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/router/tests.rs:1133:5
[INFO] [stdout]   22:     0x5598a76cb092 - <core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>> as core[35159d6ffb30e017]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x5598a76cb14d - <core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>> as core[35159d6ffb30e017]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x5598a758644d - <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:753:70
[INFO] [stdout]   25:     0x5598a758616b - tokio[697e508dc9e00bbd]::task::coop::with_budget::<core[35159d6ffb30e017]::task::poll::Poll<()>, <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/task/coop/mod.rs:167:5
[INFO] [stdout]   26:     0x5598a758616b - tokio[697e508dc9e00bbd]::task::coop::budget::<core[35159d6ffb30e017]::task::poll::Poll<()>, <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/task/coop/mod.rs:133:5
[INFO] [stdout]   27:     0x5598a758616b - <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:753:25
[INFO] [stdout]   28:     0x5598a75602f0 - <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::Context>::enter::<core[35159d6ffb30e017]::task::poll::Poll<()>, <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:442:19
[INFO] [stdout]   29:     0x5598a75846ad - <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:752:44
[INFO] [stdout]   30:     0x5598a7582ef4 - <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::option::Option<()>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:840:68
[INFO] [stdout]   31:     0x5598a739909b - <tokio[697e508dc9e00bbd]::runtime::context::scoped::Scoped<tokio[697e508dc9e00bbd]::runtime::scheduler::Context>>::set::<<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::option::Option<()>>::{closure#0}, (alloc[a8a7aba520129d98]::boxed::Box<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>)>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x5598a7356e79 - tokio[697e508dc9e00bbd]::runtime::context::set_scheduler::<(alloc[a8a7aba520129d98]::boxed::Box<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>), <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::option::Option<()>>::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context.rs:176:38
[INFO] [stdout]   33:     0x5598a7564402 - <std[ec419fa8110287d5]::thread::local::LocalKey<tokio[697e508dc9e00bbd]::runtime::context::Context>>::try_with::<tokio[697e508dc9e00bbd]::runtime::context::set_scheduler<(alloc[a8a7aba520129d98]::boxed::Box<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>), <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[a8a7aba520129d98]::boxed::Box<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/local.rs:462:12
[INFO] [stdout]   34:     0x5598a7563bee - <std[ec419fa8110287d5]::thread::local::LocalKey<tokio[697e508dc9e00bbd]::runtime::context::Context>>::with::<tokio[697e508dc9e00bbd]::runtime::context::set_scheduler<(alloc[a8a7aba520129d98]::boxed::Box<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>), <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[a8a7aba520129d98]::boxed::Box<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/local.rs:426:20
[INFO] [stdout]   35:     0x5598a734d79d - tokio[697e508dc9e00bbd]::runtime::context::set_scheduler::<(alloc[a8a7aba520129d98]::boxed::Box<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>), <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::option::Option<()>>::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context.rs:176:17
[INFO] [stdout]   36:     0x5598a756a940 - <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::option::Option<()>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:840:27
[INFO] [stdout]   37:     0x5598a756b0d6 - <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:740:24
[INFO] [stdout]   38:     0x5598a7581b50 - <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   39:     0x5598a764e6d3 - tokio[697e508dc9e00bbd]::runtime::context::runtime::enter_runtime::<<tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CurrentThread>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>::{closure#0}, ()>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x5598a755ceb1 - <tokio[697e508dc9e00bbd]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   41:     0x5598a7594144 - <tokio[697e508dc9e00bbd]::runtime::runtime::Runtime>::block_on_inner::<core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/runtime.rs:368:52
[INFO] [stdout]   42:     0x5598a75944bf - <tokio[697e508dc9e00bbd]::runtime::runtime::Runtime>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/runtime.rs:342:18
[INFO] [stdout]   43:     0x5598a74a432f - lm_gateway[bf534003d944c0c6]::router::tests::classify_regex_rule_falls_through_to_classifier_on_no_match
[INFO] [stdout]                                at /opt/rustwide/workdir/src/router/tests.rs:1141:6
[INFO] [stdout]   44:     0x5598a746b2d7 - lm_gateway[bf534003d944c0c6]::router::tests::classify_regex_rule_falls_through_to_classifier_on_no_match::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/router/tests.rs:1024:71
[INFO] [stdout]   45:     0x5598a743be36 - <lm_gateway[bf534003d944c0c6]::router::tests::classify_regex_rule_falls_through_to_classifier_on_no_match::{closure#0} as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x5598a773242b - <fn() -> core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x5598a773242b - test[a8007afcd3effadc]::__rust_begin_short_backtrace::<core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>, fn() -> core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:724:18
[INFO] [stdout]   48:     0x5598a773fc1b - test[a8007afcd3effadc]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:74
[INFO] [stdout]   49:     0x5598a773fc1b - <core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   50:     0x5598a773fc1b - std[ec419fa8110287d5]::panicking::catch_unwind::do_call::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}>, core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   51:     0x5598a773fc1b - std[ec419fa8110287d5]::panicking::catch_unwind::<core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>, core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   52:     0x5598a773fc1b - std[ec419fa8110287d5]::panic::catch_unwind::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}>, core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   53:     0x5598a773fc1b - test[a8007afcd3effadc]::run_test_in_process
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:27
[INFO] [stdout]   54:     0x5598a773fc1b - test[a8007afcd3effadc]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:668:43
[INFO] [stdout]   55:     0x5598a773a5f4 - test[a8007afcd3effadc]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:698:41
[INFO] [stdout]   56:     0x5598a773a5f4 - std[ec419fa8110287d5]::sys::backtrace::__rust_begin_short_backtrace::<test[a8007afcd3effadc]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   57:     0x5598a7742822 - std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked::<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:70:13
[INFO] [stdout]   58:     0x5598a7742822 - <core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   59:     0x5598a7742822 - std[ec419fa8110287d5]::panicking::catch_unwind::do_call::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   60:     0x5598a7742822 - std[ec419fa8110287d5]::panicking::catch_unwind::<(), core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   61:     0x5598a7742822 - std[ec419fa8110287d5]::panic::catch_unwind::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   62:     0x5598a7742822 - std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked::<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:68:26
[INFO] [stdout]   63:     0x5598a7742822 - <std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1} as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   64:     0x5598a80b145f - <alloc[a8a7aba520129d98]::boxed::Box<dyn core[35159d6ffb30e017]::ops::function::FnOnce<(), Output = ()> + core[35159d6ffb30e017]::marker::Send> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2271:9
[INFO] [stdout]   65:     0x5598a80b145f - <std[ec419fa8110287d5]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   66:     0x7e4e6cfaeaa4 - <unknown>
[INFO] [stdout]   67:     0x7e4e6d03ba64 - clone
[INFO] [stdout]   68:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     router::tests::classify_regex_rule_falls_through_to_classifier_on_no_match
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 145 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 21.89s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin lm-gateway`
[INFO] running `Command { std: "docker" "inspect" "7c09b090f2072f0fd08b4366c313df22f95770c5e56a75372f79191bbc080335", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7c09b090f2072f0fd08b4366c313df22f95770c5e56a75372f79191bbc080335", kill_on_drop: false }`
[INFO] [stdout] 7c09b090f2072f0fd08b4366c313df22f95770c5e56a75372f79191bbc080335
