[INFO] fetching crate nexus-orchestrator 0.4.0... [INFO] testing nexus-orchestrator-0.4.0 against try#dec9417b8611e34e787a3e4c37686b5131f9e5c5 for pr-154210 [INFO] extracting crate nexus-orchestrator 0.4.0 into /workspace/builds/worker-0-tc2/source [INFO] started tweaking crates.io crate nexus-orchestrator 0.4.0 [INFO] finished tweaking crates.io crate nexus-orchestrator 0.4.0 [INFO] tweaked toml for crates.io crate nexus-orchestrator 0.4.0 written to /workspace/builds/worker-0-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate nexus-orchestrator 0.4.0 on toolchain dec9417b8611e34e787a3e4c37686b5131f9e5c5 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate nexus-orchestrator 0.4.0 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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 76aea9e6630489e31920e878fe79dfa36102f2f6d169e01cd5cfcc3b8d9c51fa [INFO] running `Command { std: "docker" "start" "-a" "76aea9e6630489e31920e878fe79dfa36102f2f6d169e01cd5cfcc3b8d9c51fa", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "76aea9e6630489e31920e878fe79dfa36102f2f6d169e01cd5cfcc3b8d9c51fa", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "76aea9e6630489e31920e878fe79dfa36102f2f6d169e01cd5cfcc3b8d9c51fa", kill_on_drop: false }` [INFO] [stdout] 76aea9e6630489e31920e878fe79dfa36102f2f6d169e01cd5cfcc3b8d9c51fa [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 775391c5ee930b5bd4f217f2fad5b937590e91913f8ae0a9a7bc7b995c6ecf06 [INFO] running `Command { std: "docker" "start" "-a" "775391c5ee930b5bd4f217f2fad5b937590e91913f8ae0a9a7bc7b995c6ecf06", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.106 [INFO] [stderr] Compiling zerocopy v0.8.37 [INFO] [stderr] Compiling cc v1.2.55 [INFO] [stderr] Compiling regex-syntax v0.8.8 [INFO] [stderr] Compiling aws-lc-rs v1.15.4 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling zmij v1.0.18 [INFO] [stderr] Compiling rustls v0.23.36 [INFO] [stderr] Compiling rustix v1.1.3 [INFO] [stderr] Compiling polling v2.8.0 [INFO] [stderr] Compiling raw-cpuid v11.6.0 [INFO] [stderr] Compiling unicase v2.9.0 [INFO] [stderr] Compiling litrs v1.0.0 [INFO] [stderr] Compiling bit-vec v0.6.3 [INFO] [stderr] Compiling toml_write v0.1.2 [INFO] [stderr] Compiling winnow v0.7.14 [INFO] [stderr] Compiling hashbrown v0.15.5 [INFO] [stderr] Compiling bit-set v0.5.3 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling clap_builder v4.5.56 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Compiling rust-embed-utils v8.11.0 [INFO] [stderr] Compiling rand_xoshiro v0.7.0 [INFO] [stderr] Compiling sketches-ddsketch v0.3.0 [INFO] [stderr] Compiling flume v0.11.1 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling quote v1.0.44 [INFO] [stderr] Compiling document-features v0.2.12 [INFO] [stderr] Compiling serde_path_to_error v0.1.20 [INFO] [stderr] Compiling socket2 v0.5.10 [INFO] [stderr] Compiling if-addrs v0.13.4 [INFO] [stderr] Compiling syn v2.0.114 [INFO] [stderr] Compiling cmake v0.1.57 [INFO] [stderr] Compiling rustc-hash v1.1.0 [INFO] [stderr] Compiling pathdiff v0.2.3 [INFO] [stderr] Compiling iana-time-zone v0.1.65 [INFO] [stderr] Compiling hashbrown v0.14.5 [INFO] [stderr] Compiling mdns-sd v0.11.5 [INFO] [stderr] Compiling colored v2.2.0 [INFO] [stderr] Compiling uuid v1.20.0 [INFO] [stderr] Compiling crossterm v0.29.0 [INFO] [stderr] Compiling quanta v0.12.6 [INFO] [stderr] Compiling dashmap v6.1.0 [INFO] [stderr] Compiling aws-lc-sys v0.37.1 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling comfy-table v7.2.2 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling ahash v0.8.12 [INFO] [stderr] Compiling metrics v0.24.3 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling regex v1.12.2 [INFO] [stderr] Compiling bstr v1.12.1 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling rand v0.9.2 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling clap_derive v4.5.55 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling metrics-util v0.19.1 [INFO] [stderr] Compiling fancy-regex v0.12.0 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling axum-macros v0.4.2 [INFO] [stderr] Compiling async-stream-impl v0.3.6 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling tungstenite v0.24.0 [INFO] [stderr] Compiling rust-embed-impl v8.11.0 [INFO] [stderr] Compiling async-stream v0.3.6 [INFO] [stderr] Compiling tiktoken-rs v0.5.9 [INFO] [stderr] Compiling tower v0.4.13 [INFO] [stderr] Compiling globset v0.4.18 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling rust-embed v8.11.0 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling clap v4.5.56 [INFO] [stderr] Compiling clap_complete v4.5.65 [INFO] [stderr] Compiling serde v1.0.228 [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.4.5 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling futures-executor v0.3.31 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling tracing-serde v0.2.0 [INFO] [stderr] Compiling toml_edit v0.22.27 [INFO] [stderr] Compiling futures v0.3.31 [INFO] [stderr] Compiling chrono v0.4.43 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling tokio-tungstenite v0.24.0 [INFO] [stderr] Compiling tower-http v0.5.2 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling config v0.14.1 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.19 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling axum v0.7.9 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling metrics-exporter-prometheus v0.16.2 [INFO] [stderr] Compiling nexus-orchestrator v0.4.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 29s [INFO] running `Command { std: "docker" "inspect" "775391c5ee930b5bd4f217f2fad5b937590e91913f8ae0a9a7bc7b995c6ecf06", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "775391c5ee930b5bd4f217f2fad5b937590e91913f8ae0a9a7bc7b995c6ecf06", kill_on_drop: false }` [INFO] [stdout] 775391c5ee930b5bd4f217f2fad5b937590e91913f8ae0a9a7bc7b995c6ecf06 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 467371e31902f8157ae0c90e927eb82fdcc3139b0c6248a45298805345bbb655 [INFO] running `Command { std: "docker" "start" "-a" "467371e31902f8157ae0c90e927eb82fdcc3139b0c6248a45298805345bbb655", kill_on_drop: false }` [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling zerocopy v0.8.37 [INFO] [stderr] Compiling zerocopy-derive v0.8.37 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling regex v1.12.2 [INFO] [stderr] Compiling rustix v1.1.3 [INFO] [stderr] Compiling bstr v1.12.1 [INFO] [stderr] Compiling wait-timeout v0.2.1 [INFO] [stderr] Compiling predicates-core v1.0.9 [INFO] [stderr] Compiling itertools v0.10.5 [INFO] [stderr] Compiling float-cmp v0.10.0 [INFO] [stderr] Compiling num_cpus v1.17.0 [INFO] [stderr] Compiling assert_cmd v2.1.2 [INFO] [stderr] Compiling quick-error v1.2.3 [INFO] [stderr] Compiling deadpool-runtime v0.1.4 [INFO] [stderr] Compiling normalize-line-endings v0.3.0 [INFO] [stderr] Compiling difflib v0.4.0 [INFO] [stderr] Compiling termtree v0.5.1 [INFO] [stderr] Compiling bit-vec v0.8.0 [INFO] [stderr] Compiling rand_xorshift v0.4.0 [INFO] [stderr] Compiling is-terminal v0.4.17 [INFO] [stderr] Compiling predicates-tree v1.0.12 [INFO] [stderr] Compiling unarray v0.1.4 [INFO] [stderr] Compiling similar v2.7.0 [INFO] [stderr] Compiling bit-set v0.8.0 [INFO] [stderr] Compiling globset v0.4.18 [INFO] [stderr] Compiling fancy-regex v0.12.0 [INFO] [stderr] Compiling predicates v3.1.3 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling assert-json-diff v2.0.2 [INFO] [stderr] Compiling tracing-serde v0.2.0 [INFO] [stderr] Compiling chrono v0.4.43 [INFO] [stderr] Compiling tinytemplate v1.2.1 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling criterion-plot v0.5.0 [INFO] [stderr] Compiling toml_edit v0.22.27 [INFO] [stderr] Compiling tiktoken-rs v0.5.9 [INFO] [stderr] Compiling crossterm v0.29.0 [INFO] [stderr] Compiling tempfile v3.24.0 [INFO] [stderr] Compiling comfy-table v7.2.2 [INFO] [stderr] Compiling rusty-fork v0.3.1 [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling config v0.14.1 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling tower-http v0.5.2 [INFO] [stderr] Compiling deadpool v0.12.3 [INFO] [stderr] Compiling tokio-stream v0.1.18 [INFO] [stderr] Compiling tokio-test v0.4.5 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling ahash v0.8.12 [INFO] [stderr] Compiling half v2.7.1 [INFO] [stderr] Compiling metrics v0.24.3 [INFO] [stderr] Compiling ciborium-ll v0.2.2 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling ciborium v0.2.2 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling rand v0.9.2 [INFO] [stderr] Compiling criterion v0.5.1 [INFO] [stderr] Compiling tungstenite v0.24.0 [INFO] [stderr] Compiling metrics-util v0.19.1 [INFO] [stderr] Compiling proptest v1.9.0 [INFO] [stderr] Compiling tokio-tungstenite v0.24.0 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.19 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling axum v0.7.9 [INFO] [stderr] Compiling wiremock v0.6.5 [INFO] [stderr] Compiling mockito v1.7.2 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling metrics-exporter-prometheus v0.16.2 [INFO] [stderr] Compiling nexus-orchestrator v0.4.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 40s [INFO] running `Command { std: "docker" "inspect" "467371e31902f8157ae0c90e927eb82fdcc3139b0c6248a45298805345bbb655", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "467371e31902f8157ae0c90e927eb82fdcc3139b0c6248a45298805345bbb655", kill_on_drop: false }` [INFO] [stdout] 467371e31902f8157ae0c90e927eb82fdcc3139b0c6248a45298805345bbb655 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 0dde3e48754fcffcf78d3829202f6ed71c64b7cfb74c5f7a42b42f6c4ae78639 [INFO] running `Command { std: "docker" "start" "-a" "0dde3e48754fcffcf78d3829202f6ed71c64b7cfb74c5f7a42b42f6c4ae78639", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.51s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/nexus-72173bba52e14971) [INFO] [stdout] [INFO] [stdout] running 1262 tests [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_stream_error ... ok [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_invalid_json_response ... ok [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_with_system_message ... ok [INFO] [stdout] test agent::anthropic::tests::test_count_tokens_returns_heuristic_variant ... ok [INFO] [stdout] test agent::anthropic::tests::test_health_check_success ... ok [INFO] [stdout] test agent::anthropic::tests::test_count_tokens_empty_string ... ok [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_non_streaming_auth_header_override ... ok [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_non_streaming_invalid_json ... ok [INFO] [stdout] test agent::anthropic::tests::test_health_check_failure ... ok [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_stream_timeout ... ok [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_non_streaming_network_error ... ok [INFO] [stdout] test agent::anthropic::tests::test_list_models ... ok [INFO] [stdout] test agent::anthropic::tests::test_count_tokens_known_length ... ok [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_non_streaming_api_error ... ok [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_upstream_error ... ok [INFO] [stdout] test agent::anthropic::tests::test_health_check_network_error ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_empty_content_string ... ok [INFO] [stdout] test agent::anthropic::tests::test_health_check_unhealthy ... ok [INFO] [stdout] test agent::anthropic::tests::test_profile ... ok [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_stream_success ... ok [INFO] [stdout] test agent::anthropic::tests::test_heuristic_token_counting ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_extracts_system_message ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_no_system_message ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_empty_messages ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_explicit_max_tokens ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_multiple_user_messages ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_multiple_system_messages ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_only_system_messages ... ok [INFO] [stdout] test agent::anthropic::tests::test_chat_completion_stream_api_key_from_header ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_preserves_temperature ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_maps_end_turn_to_stop ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_maps_usage_fields ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_stop_sequence_reason ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_sets_max_tokens_default ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_request_temperature_zero ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_empty_content_array ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_stop_sequence_maps_to_stop ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_content_block_start_returns_none ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_none_stop_reason ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_multiple_content_blocks ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_maps_max_tokens_to_length ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_content_block_delta_non_text_type_returns_none ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_non_text_content_block_skipped ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_content_block_delta_non_text ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_none_stop_reason_default ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_invalid_message_start_json ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_message_delta_null_stop_reason ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_zero_usage_tokens ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_message_start_invalid_json_returns_none ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_content_block_delta ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_response_unknown_stop_reason ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_message_start ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_message_delta_max_tokens_stop ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_message_stop_returns_done ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_message_delta_max_tokens ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_message_delta_stop ... ok [INFO] [stdout] test agent::factory::tests::test_create_exo_agent ... ok [INFO] [stdout] test agent::factory::tests::test_create_generic_agent ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_unknown_event_returns_none ... ok [INFO] [stdout] test agent::factory::tests::test_create_anthropic_agent_with_env_key ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_ping_returns_none ... ok [INFO] [stdout] test agent::factory::tests::test_create_anthropic_agent_missing_key ... ok [INFO] [stdout] test agent::factory::tests::test_create_anthropic_agent_with_direct_key ... ok [INFO] [stdout] test agent::factory::tests::test_create_llamacpp_agent ... ok [INFO] [stdout] test agent::factory::tests::test_create_vllm_agent ... ok [INFO] [stdout] test agent::factory::tests::test_create_google_agent_missing_key ... ok [INFO] [stdout] test agent::factory::tests::test_create_ollama_agent ... ok [INFO] [stdout] test agent::factory::tests::test_create_google_agent_with_direct_key ... ok [INFO] [stdout] test agent::anthropic::tests::test_translate_stream_chunk_unknown_event_type_returns_none ... ok [INFO] [stdout] test agent::factory::tests::test_create_openai_agent_missing_key ... ok [INFO] [stdout] test agent::factory::tests::test_create_lmstudio_agent ... ok [INFO] [stdout] test agent::factory::tests::test_create_google_agent_with_env_key ... ok [INFO] [stdout] test agent::generic::tests::test_chat_completion_non_streaming_network_error ... ok [INFO] [stdout] test agent::factory::tests::test_create_openai_agent_with_direct_key ... ok [INFO] [stdout] test agent::generic::tests::test_chat_completion_non_streaming_api_error ... ok [INFO] [stdout] test agent::generic::tests::test_chat_completion_non_streaming_invalid_json ... ok [INFO] [stdout] test agent::factory::tests::test_create_openai_agent_with_env_key ... ok [INFO] [stdout] test agent::factory::tests::test_shared_client ... ok [INFO] [stdout] test agent::generic::tests::test_chat_completion_stream_success ... ok [INFO] [stdout] test agent::generic::tests::test_chat_completion ... ok [INFO] [stdout] test agent::generic::tests::test_error_handling ... ok [INFO] [stdout] test agent::generic::tests::test_chat_completion_invalid_json_response ... ok [INFO] [stdout] test agent::generic::tests::test_chat_completion_with_auth_header_forwarding ... ok [INFO] [stdout] test agent::generic::tests::test_chat_completion_with_auth_header ... ok [INFO] [stdout] test agent::generic::tests::test_fallback_profile_for_unexpected_backend_type ... ok [INFO] [stdout] test agent::generic::tests::test_chat_completion_returns_invalid_json ... ok [INFO] [stdout] test agent::generic::tests::test_chat_completion_stream_error ... ok [INFO] [stdout] test agent::generic::tests::test_generic_profile ... ok [INFO] [stdout] test agent::generic::tests::test_health_check_network_error ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_bakllava_vision ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_claude_opus_no_tools ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_command_tools ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_context_128k ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_context_16k ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_context_32k ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_context_4k ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_context_8k ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_empty_name_defaults ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_functionary_tools ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_gpt4_turbo_no_special ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_llama_vision ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_no_match ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_tool_keyword ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_tools ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_unknown_model_defaults ... ok [INFO] [stdout] test agent::generic::tests::test_name_heuristics_vision ... ok [INFO] [stdout] test agent::generic::tests::test_health_check_failure ... ok [INFO] [stdout] test agent::generic::tests::test_health_check ... ok [INFO] [stdout] test agent::generic::tests::test_exo_profile ... ok [INFO] [stdout] test agent::generic::tests::test_health_check_invalid_json_body ... ok [INFO] [stdout] test agent::generic::tests::test_health_check_invalid_json ... ok [INFO] [stdout] test agent::generic::tests::test_health_check_network_failure ... ok [INFO] [stdout] test agent::generic::tests::test_health_check_returns_invalid_json ... ok [INFO] [stdout] test agent::generic::tests::test_list_models_invalid_json ... ok [INFO] [stdout] test agent::generic::tests::test_profile_with_capability_tier ... ok [INFO] [stdout] test agent::generic::tests::test_llamacpp_profile ... ok [INFO] [stdout] test agent::generic::tests::test_list_models ... ok [INFO] [stdout] test agent::generic::tests::test_list_models_invalid_json_body ... ok [INFO] [stdout] test agent::generic::tests::test_list_models_network_error ... ok [INFO] [stdout] test agent::google::tests::test_chat_completion_with_system_message ... ok [INFO] [stdout] test agent::generic::tests::test_list_models_upstream_error ... ok [INFO] [stdout] test agent::generic::tests::test_list_models_api_error ... ok [INFO] [stdout] test agent::google::tests::test_chat_completion_non_streaming_invalid_json ... ok [INFO] [stdout] test agent::google::tests::test_chat_completion_invalid_json ... ok [INFO] [stdout] test agent::generic::tests::test_vllm_profile ... ok [INFO] [stdout] test agent::google::tests::test_health_check_invalid_json ... ok [INFO] [stdout] test agent::google::tests::test_chat_completion_stream_error ... ok [INFO] [stdout] test agent::google::tests::test_name_heuristics_gemini_1_0_pro_vision ... ok [INFO] [stdout] test agent::google::tests::test_name_heuristics_gemini_1_5_flash ... ok [INFO] [stdout] test agent::google::tests::test_name_heuristics_gemini_2_0_flash ... ok [INFO] [stdout] test agent::google::tests::test_name_heuristics_gemini_pro_vision ... ok [INFO] [stdout] test agent::google::tests::test_name_heuristics_unknown_model ... ok [INFO] [stdout] test agent::google::tests::test_chat_completion_stream_network_error ... ok [INFO] [stdout] test agent::google::tests::test_count_tokens_empty_string ... ok [INFO] [stdout] test agent::generic::tests::test_list_models_returns_invalid_json ... ok [INFO] [stdout] test agent::google::tests::test_chat_completion_non_streaming_network_error ... ok [INFO] [stdout] test agent::google::tests::test_chat_completion_non_streaming_api_error ... ok [INFO] [stdout] test agent::google::tests::test_count_tokens_returns_heuristic ... ok [INFO] [stdout] test agent::google::tests::test_list_models_invalid_json ... ok [INFO] [stdout] test agent::google::tests::test_health_check_failure ... ok [INFO] [stdout] test agent::google::tests::test_list_models_api_error ... ok [INFO] [stdout] test agent::google::tests::test_health_check_network_error ... ok [INFO] [stdout] test agent::google::tests::test_health_check_success ... ok [INFO] [stdout] test agent::google::tests::test_profile ... ok [INFO] [stdout] test agent::google::tests::test_heuristic_token_counting ... ok [INFO] [stdout] test agent::google::tests::test_list_models_network_error ... ok [INFO] [stdout] test agent::google::tests::test_translate_request_multiple_system_messages_concatenated ... ok [INFO] [stdout] test agent::google::tests::test_translate_request_empty_messages ... ok [INFO] [stdout] test agent::google::tests::test_translate_request_no_system_instruction ... ok [INFO] [stdout] test agent::google::tests::test_chat_completion_stream_success ... ok [INFO] [stdout] test agent::google::tests::test_translate_request_no_temperature_default ... ok [INFO] [stdout] test agent::google::tests::test_translate_request_generation_config ... ok [INFO] [stdout] test agent::google::tests::test_list_models ... ok [INFO] [stdout] test agent::google::tests::test_translate_request_only_system_messages ... ok [INFO] [stdout] test agent::google::tests::test_translate_request_role_mapping_assistant_to_model ... ok [INFO] [stdout] test agent::google::tests::test_translate_request_system_instruction ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_finish_reason_safety ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_empty_candidates ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_finish_reason_stop ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_multiple_parts_concat ... ok [INFO] [stdout] test agent::google::tests::test_translate_request_unknown_role_kept_as_is ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_finish_reason_none ... ok [INFO] [stdout] test agent::google::tests::test_translate_request_top_p_ignored ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_finish_reason_recitation ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_no_usage_metadata ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_finish_reason_max_tokens ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_content ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_finish_reason_other ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_empty_parts ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_usage_metadata_partial_none_fields ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_finish_reason ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_invalid_json_returns_none ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_empty_line ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_empty_candidates ... ok [INFO] [stdout] test agent::google::tests::test_translate_response_usage_metadata_mapping ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_data_done_sse ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_ndjson_array_framing ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_multiple_parts ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_safety_filter ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_max_tokens_finish_reason_in_stream ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_safety_finish_reason_in_stream ... ok [INFO] [stdout] test agent::lmstudio::tests::test_chat_completion_stream_with_auth_header ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_done_marker ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_recitation_finish_reason_in_stream ... ok [INFO] [stdout] test agent::lmstudio::tests::test_chat_completion_non_streaming_api_error ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_command_tools ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_context_16k ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_context_32k ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_context_4k ... ok [INFO] [stdout] test agent::lmstudio::tests::test_health_check_network_error ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_deepseek_coder_no_tools ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_empty_name_defaults ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_llava_vision ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_phi3_128k_context ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_random_model_defaults ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_tools ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_vision ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_vision_keyword ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_unknown_finish_reason_in_stream ... ok [INFO] [stdout] test agent::lmstudio::tests::test_chat_completion_non_streaming_invalid_json ... ok [INFO] [stdout] test agent::lmstudio::tests::test_chat_completion_stream_success ... ok [INFO] [stdout] test agent::google::tests::test_translate_stream_chunk_valid_ndjson_object ... ok [INFO] [stdout] test agent::lmstudio::tests::test_chat_completion ... ok [INFO] [stdout] test agent::lmstudio::tests::test_chat_completion_with_auth_header ... ok [INFO] [stdout] test agent::lmstudio::tests::test_name_heuristics_context_8k ... ok [INFO] [stdout] test agent::lmstudio::tests::test_list_models ... ok [INFO] [stdout] test agent::lmstudio::tests::test_health_check_unhealthy ... ok [INFO] [stdout] test agent::lmstudio::tests::test_health_check_invalid_json ... ok [INFO] [stdout] test agent::lmstudio::tests::test_chat_completion_stream_error ... ok [INFO] [stdout] test agent::lmstudio::tests::test_health_check_failure ... ok [INFO] [stdout] test agent::lmstudio::tests::test_list_models_invalid_json ... ok [INFO] [stdout] test agent::lmstudio::tests::test_health_check_success ... ok [INFO] [stdout] test agent::lmstudio::tests::test_profile_with_capability_tier ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_stream_success_with_data ... ok [INFO] [stdout] test agent::lmstudio::tests::test_list_models_api_error ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_non_streaming_network_error ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_invalid_json_response ... ok [INFO] [stdout] test agent::lmstudio::tests::test_profile ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_stream_data_chunks ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_stream_error ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_non_streaming_invalid_json ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_stream_upstream_error ... ok [INFO] [stdout] test agent::lmstudio::tests::test_timeout_error ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_success ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_upstream_error ... ok [INFO] [stdout] test agent::ollama::tests::test_embeddings_api_success ... ok [INFO] [stdout] test agent::ollama::tests::test_embeddings_api_upstream_error ... ok [INFO] [stdout] test agent::ollama::tests::test_embeddings_api_invalid_response ... ok [INFO] [stdout] test agent::ollama::tests::test_embeddings_multiple_inputs ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_bakllava_vision ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_codellama_no_tools ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_command_tools ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_context_128k ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_context_16k ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_context_32k ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_context_4k ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_context_8k ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_context_length_128k ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_empty_name_defaults ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_functionary_tools ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_hermes_tools ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_llava_vision ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_mixtral_no_context_marker ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_no_special_name ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_phi3_128k_context ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_random_model_defaults ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_tool_model ... ok [INFO] [stdout] test agent::ollama::tests::test_name_heuristics_vision_model ... ok [INFO] [stdout] test agent::ollama::tests::test_health_check_failure ... ok [INFO] [stdout] test agent::ollama::tests::test_embeddings_invalid_response ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_stream_success ... ok [INFO] [stdout] test agent::ollama::tests::test_chat_completion_with_auth_header ... ok [INFO] [stdout] test agent::ollama::tests::test_embeddings_error ... ok [INFO] [stdout] test agent::ollama::tests::test_embeddings_success ... ok [INFO] [stdout] test agent::ollama::tests::test_health_check_invalid_json ... ok [INFO] [stdout] test agent::ollama::tests::test_embeddings_single_input ... ok [INFO] [stdout] test agent::ollama::tests::test_health_check_network_error ... ok [INFO] [stdout] test agent::ollama::tests::test_list_models_api_error ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_non_streaming_api_error ... ok [INFO] [stdout] test agent::ollama::tests::test_profile ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_non_streaming_invalid_json ... ok [INFO] [stdout] test agent::ollama::tests::test_list_models_upstream_error ... ok [INFO] [stdout] test agent::ollama::tests::test_list_models_fallback_heuristics ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_invalid_json_body ... ok [INFO] [stdout] test agent::ollama::tests::test_health_check_success ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_stream_error ... ok [INFO] [stdout] test agent::ollama::tests::test_profile_with_capability_tier ... ok [INFO] [stdout] test agent::ollama::tests::test_list_models_invalid_json ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_stream_success ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_non_streaming_auth_header_override ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_upstream_error_429 ... ok [INFO] [stdout] test agent::ollama::tests::test_list_models_with_enrichment ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_stream_upstream_error ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_non_streaming_network_error ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_with_header_override ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_with_auth_header_forwarding ... ok [INFO] [stdout] test agent::openai::tests::test_chat_completion_with_bearer_auth ... ok [INFO] [stdout] test agent::openai::tests::test_embeddings_invalid_response ... ok [INFO] [stdout] test agent::openai::tests::test_embeddings_api_error ... ok [INFO] [stdout] test agent::openai::tests::test_embeddings_success ... ok [INFO] [stdout] test agent::openai::tests::test_embeddings_error ... ok [INFO] [stdout] test agent::openai::tests::test_health_check_invalid_json ... ok [INFO] [stdout] test agent::openai::tests::test_health_check_success ... ok [INFO] [stdout] test agent::openai::tests::test_health_check_unauthorized ... ok [INFO] [stdout] test agent::openai::tests::test_embeddings_with_mock_server ... ok [INFO] [stdout] test agent::openai::tests::test_embeddings_upstream_error_response ... ok [INFO] [stdout] test agent::openai::tests::test_health_check_invalid_json_body ... ok [INFO] [stdout] test agent::openai::tests::test_list_models_invalid_json_response ... ok [INFO] [stdout] test agent::openai::tests::test_list_models_invalid_json ... ok [INFO] [stdout] test agent::openai::tests::test_list_models_upstream_error ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_dall_e ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_gpt35 ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_gpt35_16k ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_gpt4_32k ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_gpt4_base ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_gpt4_turbo ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_gpt4o ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_gpt4o_mini ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_o1_mini ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_o1_preview ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_plain_gpt4 ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_text_embedding ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_unknown_model ... ok [INFO] [stdout] test agent::openai::tests::test_name_heuristics_vision_keyword ... ok [INFO] [stdout] test agent::openai::tests::test_list_models_api_error ... ok [INFO] [stdout] test agent::pricing::tests::test_anthropic_haiku_pricing ... ok [INFO] [stdout] test agent::pricing::tests::test_anthropic_pricing ... ok [INFO] [stdout] test agent::pricing::tests::test_anthropic_sonnet_pricing ... ok [INFO] [stdout] test agent::pricing::tests::test_get_pricing ... ok [INFO] [stdout] test agent::pricing::tests::test_google_pricing ... ok [INFO] [stdout] test agent::pricing::tests::test_gpt4_pricing ... ok [INFO] [stdout] test agent::pricing::tests::test_gpt4_turbo_preview_pricing ... ok [INFO] [stdout] test agent::pricing::tests::test_has_pricing ... ok [INFO] [stdout] test agent::pricing::tests::test_openai_pricing ... ok [INFO] [stdout] test agent::pricing::tests::test_pricing_default ... ok [INFO] [stdout] test agent::pricing::tests::test_unknown_model ... ok [INFO] [stdout] test agent::pricing::tests::test_zero_tokens ... ok [INFO] [stdout] test agent::quality::tests::all_successes_give_zero_error_rate ... ok [INFO] [stdout] test agent::quality::tests::get_all_metrics_returns_all ... ok [INFO] [stdout] test agent::quality::tests::last_failure_ts_tracked ... ok [INFO] [stdout] test agent::quality::tests::recompute_handles_empty_store ... ok [INFO] [stdout] test agent::quality::tests::record_outcome_stores_data ... ok [INFO] [stdout] test agent::quality::tests::store_returns_default_for_unknown_agent ... ok [INFO] [stdout] test agent::quality::tests::success_rate_24h_computed ... ok [INFO] [stdout] test agent::quality::tests::test_config_returns_configuration ... ok [INFO] [stdout] test agent::quality::tests::test_quality_metrics_store_multiple_agents ... ok [INFO] [stdout] test agent::quality::tests::test_quality_reconciler_excludes_high_error_rate_agent ... ok [INFO] [stdout] test agent::quality::tests::test_quality_reconciler_skips_agents_without_history ... ok [INFO] [stdout] test agent::quality::tests::test_quality_reconciliation_deprioritizes_high_ttft ... ok [INFO] [stdout] test agent::openai::tests::test_list_models_with_heuristics ... ok [INFO] [stdout] test agent::quality::tests::test_quality_reconciliation_loop_recomputes ... ok [INFO] [stdout] test agent::openai::tests::test_profile ... ok [INFO] [stdout] test agent::quality::tests::test_quality_reconciliation_with_errors ... ok [INFO] [stdout] test agent::quality::tests::test_quality_store_concurrent_access ... ok [INFO] [stdout] test agent::quality::tests::test_quality_store_get_profile_unknown_agent ... ok [INFO] [stdout] test agent::openai::tests::test_network_error ... ok [INFO] [stdout] test agent::quality::tests::test_quality_store_record_outcome_multiple ... ok [INFO] [stdout] test agent::tests::count_tokens_100_chars ... ok [INFO] [stdout] test agent::tests::count_tokens_empty_string ... ok [INFO] [stdout] test agent::tests::count_tokens_short_string ... ok [INFO] [stdout] test agent::tests::embeddings_returns_unsupported ... ok [INFO] [stdout] test agent::tests::load_model_returns_unsupported ... ok [INFO] [stdout] test agent::tests::quality_metrics_default_values ... ok [INFO] [stdout] test agent::tests::quality_metrics_is_healthy_with_low_error_rate ... ok [INFO] [stdout] test agent::tests::quality_metrics_is_healthy_with_no_history ... ok [INFO] [stdout] test agent::tests::quality_metrics_is_unhealthy_with_high_error_rate ... ok [INFO] [stdout] test agent::tests::quality_metrics_new_creates_healthy_defaults ... ok [INFO] [stdout] test agent::tests::quality_metrics_threshold_at_boundary ... ok [INFO] [stdout] test agent::tests::resource_usage_returns_default ... ok [INFO] [stdout] test agent::tests::unload_model_returns_unsupported ... ok [INFO] [stdout] test agent::quality::tests::test_quality_reconciliation_loop_stops_on_cancel ... ok [INFO] [stdout] test agent::tokenizer::tests::heuristic_counts_tokens_conservatively ... ok [INFO] [stdout] test agent::tokenizer::tests::heuristic_default_uses_1_15x_multiplier ... ok [INFO] [stdout] test agent::tokenizer::tests::heuristic_empty_string ... ok [INFO] [stdout] test agent::tokenizer::tests::heuristic_longer_text ... ok [INFO] [stdout] test agent::tokenizer::tests::heuristic_minimum_one_token ... ok [INFO] [stdout] test agent::tokenizer::tests::heuristic_tier_is_heuristic ... ok [INFO] [stdout] test agent::quality::tests::test_quality_reconciliation_loop_runs_metrics_tick ... ok [INFO] [stdout] test agent::quality::tests::test_quality_store_max_outcomes_cap ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_long_text ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_trait_empty ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_code_snippet ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_special_characters ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_empty_via_trait ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_single_word ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_whitespace_only ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_exact_value ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_exact_via_trait ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_trait_returns_exact ... ok [INFO] [stdout] test agent::tokenizer::tests::sc006_month_key_format_enables_auto_reset ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_empty_string ... ok [INFO] [stdout] test agent::openai::tests::test_count_tokens_exact ... ok [INFO] [stdout] test agent::tokenizer::tests::tier_constants_are_ordered ... ok [INFO] [stdout] test agent::tokenizer::tests::tier_name_mappings ... ok [INFO] [stdout] test agent::tokenizer::tests::tiktoken_approximation_counts_tokens ... ok [INFO] [stdout] test agent::tokenizer::tests::tiktoken_approximation_creates_successfully ... ok [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] [stderr] [INFO] [stderr] Caused by: [INFO] [stderr] process didn't exit successfully: `/opt/rustwide/target/debug/deps/nexus-72173bba52e14971` (signal: 9, SIGKILL: kill) [INFO] running `Command { std: "docker" "inspect" "0dde3e48754fcffcf78d3829202f6ed71c64b7cfb74c5f7a42b42f6c4ae78639", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "0dde3e48754fcffcf78d3829202f6ed71c64b7cfb74c5f7a42b42f6c4ae78639", kill_on_drop: false }` [INFO] [stdout] 0dde3e48754fcffcf78d3829202f6ed71c64b7cfb74c5f7a42b42f6c4ae78639