[INFO] cloning repository https://github.com/wannabefro/polybot
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/wannabefro/polybot" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwannabefro%2Fpolybot", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwannabefro%2Fpolybot'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] b4831945c1b4bce61f7adabdbd06d4ed8d38c2ed
[INFO] testing wannabefro/polybot against beta-2026-03-05 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwannabefro%2Fpolybot" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/wannabefro/polybot
[INFO] finished tweaking git repo https://github.com/wannabefro/polybot
[INFO] tweaked toml for git repo https://github.com/wannabefro/polybot written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/wannabefro/polybot on toolchain beta-2026-03-05
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/wannabefro/polybot already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-03-05" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 6a40570520da81b7fd674a99343809e2a9bb8f8831cd325e3a9b7ab825b6008d
[INFO] running `Command { std: "docker" "start" "-a" "6a40570520da81b7fd674a99343809e2a9bb8f8831cd325e3a9b7ab825b6008d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "6a40570520da81b7fd674a99343809e2a9bb8f8831cd325e3a9b7ab825b6008d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6a40570520da81b7fd674a99343809e2a9bb8f8831cd325e3a9b7ab825b6008d", kill_on_drop: false }`
[INFO] [stdout] 6a40570520da81b7fd674a99343809e2a9bb8f8831cd325e3a9b7ab825b6008d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6f9688745405af4463ee7114faaf1e03de988060260d39ee23615d03c274e304
[INFO] running `Command { std: "docker" "start" "-a" "6f9688745405af4463ee7114faaf1e03de988060260d39ee23615d03c274e304", kill_on_drop: false }`
[INFO] [stderr]    Compiling der v0.7.10
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling generic-array v0.14.9
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling const-hex v1.18.0
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling alloy-rlp-derive v0.3.13
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling aws-lc-sys v0.37.1
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling ff v0.13.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-bigint v0.5.5
[INFO] [stderr]    Compiling group v0.13.0
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling macro-string v0.1.4
[INFO] [stderr]    Compiling syn-solidity v1.5.7
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling rfc6979 v0.4.0
[INFO] [stderr]    Compiling signature v2.2.0
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling sha3 v0.10.8
[INFO] [stderr]    Compiling aws-lc-rs v1.16.0
[INFO] [stderr]    Compiling proc-macro-error2 v2.0.1
[INFO] [stderr]    Compiling spki v0.7.3
[INFO] [stderr]    Compiling sec1 v0.7.3
[INFO] [stderr]    Compiling futures-macro v0.3.32
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling pkcs8 v0.10.2
[INFO] [stderr]    Compiling crc-catalog v2.4.0
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling iana-time-zone v0.1.65
[INFO] [stderr]    Compiling auto_impl v1.3.0
[INFO] [stderr]    Compiling crc v3.4.0
[INFO] [stderr]    Compiling elliptic-curve v0.13.8
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling rustls v0.23.37
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling bitflags v2.11.0
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling ecdsa v0.16.9
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling rand_core v0.9.5
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling k256 v0.13.4
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling rand_core v0.10.0
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling getrandom v0.4.1
[INFO] [stderr]    Compiling native-tls v0.2.18
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling phf_shared v0.13.1
[INFO] [stderr]    Compiling rustls-native-certs v0.8.3
[INFO] [stderr]    Compiling webpki-roots v1.0.6
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling futures-utils-wasm v0.1.0
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling prettyplease v0.2.37
[INFO] [stderr]    Compiling phf_generator v0.13.1
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling rust_decimal v1.40.0
[INFO] [stderr]    Compiling data-encoding v2.10.0
[INFO] [stderr]    Compiling alloy-sol-macro-input v1.5.7
[INFO] [stderr]    Compiling utf-8 v0.7.6
[INFO] [stderr]    Compiling derive_more v2.1.1
[INFO] [stderr]    Compiling bytes v1.11.1
[INFO] [stderr]    Compiling arrayvec v0.7.6
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling alloy-sol-macro-expander v1.5.7
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling alloy-sol-type-parser v1.5.7
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling cpufeatures v0.3.0
[INFO] [stderr]    Compiling futures-executor v0.3.32
[INFO] [stderr]    Compiling alloy-rlp v0.3.13
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling ruint v1.17.2
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]    Compiling chacha20 v0.10.0
[INFO] [stderr]    Compiling phf_macros v0.13.1
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]    Compiling bon-macros v3.9.0
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling instant v0.1.13
[INFO] [stderr]    Compiling dashmap v6.1.0
[INFO] [stderr]    Compiling backoff v0.4.0
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling phf v0.13.1
[INFO] [stderr]    Compiling alloy-primitives v1.5.7
[INFO] [stderr]    Compiling nybbles v0.4.8
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling rand v0.10.0
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling futures v0.3.32
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling secrecy v0.10.3
[INFO] [stderr]    Compiling tracing-serde v0.2.0
[INFO] [stderr]    Compiling uuid v1.21.0
[INFO] [stderr]    Compiling serde_html_form v0.4.0
[INFO] [stderr]    Compiling strum_macros v0.28.0
[INFO] [stderr]    Compiling rust_decimal_macros v1.40.0
[INFO] [stderr]    Compiling serde_repr v0.1.20
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling serde_ignored v0.1.14
[INFO] [stderr]    Compiling serde_path_to_error v0.1.20
[INFO] [stderr]    Compiling tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling dotenvy v0.15.7
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]    Compiling alloy-eip7928 v0.3.2
[INFO] [stderr]    Compiling alloy-sol-macro v1.5.7
[INFO] [stderr]    Compiling alloy-eip7702 v0.6.3
[INFO] [stderr]    Compiling alloy-eip2930 v0.2.3
[INFO] [stderr]    Compiling alloy-eip2124 v0.2.0
[INFO] [stderr]    Compiling alloy-serde v1.7.3
[INFO] [stderr]    Compiling alloy-trie v0.9.4
[INFO] [stderr]    Compiling alloy-signer v1.7.3
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]    Compiling serde_with_macros v3.17.0
[INFO] [stderr]    Compiling alloy-tx-macros v1.7.3
[INFO] [stderr]    Compiling alloy-sol-types v1.5.7
[INFO] [stderr]    Compiling alloy-json-abi v1.5.7
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling serde_with v3.17.0
[INFO] [stderr]    Compiling bon v3.9.0
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling alloy-json-rpc v1.7.3
[INFO] [stderr]    Compiling alloy-dyn-abi v1.5.7
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling alloy-eips v1.7.3
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling alloy-core v1.5.7
[INFO] [stderr]    Compiling alloy-consensus v1.7.3
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling alloy-consensus-any v1.7.3
[INFO] [stderr]    Compiling alloy-network-primitives v1.7.3
[INFO] [stderr]    Compiling alloy-rpc-types-eth v1.7.3
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling rustls-webpki v0.103.9
[INFO] [stderr]    Compiling alloy-rpc-types-any v1.7.3
[INFO] [stderr]    Compiling alloy-network v1.7.3
[INFO] [stderr]    Compiling alloy-signer-local v1.7.3
[INFO] [stderr]    Compiling alloy v1.7.3
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling tungstenite v0.28.0
[INFO] [stderr]    Compiling rustls-platform-verifier v0.6.2
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling reqwest v0.13.2
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling tokio-tungstenite v0.28.0
[INFO] [stderr]    Compiling polymarket-client-sdk v0.4.3 (https://github.com/Polymarket/rs-clob-client#44b68ef0)
[INFO] [stderr]    Compiling polybot v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: fields `is_unwind` and `strategy_tag` are never read
[INFO] [stdout]   --> src/main.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 35 | struct ActiveQuote {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 44 |     is_unwind: bool,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 45 |     strategy_tag: &'static str,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ActiveQuote` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `hedge_expired` is never used
[INFO] [stdout]   --> src/strategy/reward.rs:58:12
[INFO] [stdout]    |
[INFO] [stdout] 56 | impl UnhedgedFill {
[INFO] [stdout]    | ----------------- method in this implementation
[INFO] [stdout] 57 |     /// Check if this fill has exceeded the hedge window.
[INFO] [stdout] 58 |     pub fn hedge_expired(&self, timeout: Duration) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `hard_stop_state` is never used
[INFO] [stdout]    --> src/strategy/reward.rs:195:12
[INFO] [stdout]     |
[INFO] [stdout] 128 | impl HedgeTracker {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 195 |     pub fn hard_stop_state(&self, token_id: &str) -> Option<(String, u32)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 47s
[INFO] running `Command { std: "docker" "inspect" "6f9688745405af4463ee7114faaf1e03de988060260d39ee23615d03c274e304", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6f9688745405af4463ee7114faaf1e03de988060260d39ee23615d03c274e304", kill_on_drop: false }`
[INFO] [stdout] 6f9688745405af4463ee7114faaf1e03de988060260d39ee23615d03c274e304
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 9c6550c7f714eea592b5762b43488346175cc6587ab03b8726710de925111acc
[INFO] running `Command { std: "docker" "start" "-a" "9c6550c7f714eea592b5762b43488346175cc6587ab03b8726710de925111acc", kill_on_drop: false }`
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling deadpool-runtime v0.1.4
[INFO] [stderr]    Compiling assert-json-diff v2.0.2
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling deadpool v0.12.3
[INFO] [stderr]    Compiling tokio-tungstenite v0.28.0
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling wiremock v0.6.5
[INFO] [stderr]    Compiling reqwest v0.13.2
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling polymarket-client-sdk v0.4.3 (https://github.com/Polymarket/rs-clob-client#44b68ef0)
[INFO] [stderr]    Compiling polybot v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]   --> src/intelligence/signal.rs:81:9
[INFO] [stdout]    |
[INFO] [stdout] 81 |     use std::thread;
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::config::tests::test_config`
[INFO] [stdout]    --> src/order/router.rs:167:9
[INFO] [stdout]     |
[INFO] [stdout] 167 |     use crate::config::tests::test_config;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]   --> src/intelligence/signal.rs:81:9
[INFO] [stdout]    |
[INFO] [stdout] 81 |     use std::thread;
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::config::tests::test_config`
[INFO] [stdout]    --> src/order/router.rs:167:9
[INFO] [stdout]     |
[INFO] [stdout] 167 |     use crate::config::tests::test_config;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `is_unwind` and `strategy_tag` are never read
[INFO] [stdout]   --> src/main.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 35 | struct ActiveQuote {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 44 |     is_unwind: bool,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 45 |     strategy_tag: &'static str,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ActiveQuote` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `hedge_expired` is never used
[INFO] [stdout]   --> src/strategy/reward.rs:58:12
[INFO] [stdout]    |
[INFO] [stdout] 56 | impl UnhedgedFill {
[INFO] [stdout]    | ----------------- method in this implementation
[INFO] [stdout] 57 |     /// Check if this fill has exceeded the hedge window.
[INFO] [stdout] 58 |     pub fn hedge_expired(&self, timeout: Duration) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `hard_stop_state` is never used
[INFO] [stdout]    --> src/strategy/reward.rs:195:12
[INFO] [stdout]     |
[INFO] [stdout] 128 | impl HedgeTracker {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 195 |     pub fn hard_stop_state(&self, token_id: &str) -> Option<(String, u32)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `is_unwind` and `strategy_tag` are never read
[INFO] [stdout]   --> src/main.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 35 | struct ActiveQuote {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 44 |     is_unwind: bool,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 45 |     strategy_tag: &'static str,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ActiveQuote` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 34.84s
[INFO] running `Command { std: "docker" "inspect" "9c6550c7f714eea592b5762b43488346175cc6587ab03b8726710de925111acc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9c6550c7f714eea592b5762b43488346175cc6587ab03b8726710de925111acc", kill_on_drop: false }`
[INFO] [stdout] 9c6550c7f714eea592b5762b43488346175cc6587ab03b8726710de925111acc
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 9301805d39489c3985c87bf121b34b141863e7d7ac0db39ba3b46ca7386187af
[INFO] running `Command { std: "docker" "start" "-a" "9301805d39489c3985c87bf121b34b141863e7d7ac0db39ba3b46ca7386187af", kill_on_drop: false }`
[INFO] [stderr] warning: fields `is_unwind` and `strategy_tag` are never read
[INFO] [stderr]   --> src/main.rs:44:5
[INFO] [stderr]    |
[INFO] [stderr] 35 | struct ActiveQuote {
[INFO] [stderr]    |        ----------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 44 |     is_unwind: bool,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 45 |     strategy_tag: &'static str,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ActiveQuote` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: method `hedge_expired` is never used
[INFO] [stderr]   --> src/strategy/reward.rs:58:12
[INFO] [stderr]    |
[INFO] [stderr] 56 | impl UnhedgedFill {
[INFO] [stderr]    | ----------------- method in this implementation
[INFO] [stderr] 57 |     /// Check if this fill has exceeded the hedge window.
[INFO] [stderr] 58 |     pub fn hedge_expired(&self, timeout: Duration) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `hard_stop_state` is never used
[INFO] [stderr]    --> src/strategy/reward.rs:195:12
[INFO] [stderr]     |
[INFO] [stderr] 128 | impl HedgeTracker {
[INFO] [stderr]     | ----------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 195 |     pub fn hard_stop_state(&self, token_id: &str) -> Option<(String, u32)> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `polybot` (bin "polybot") generated 3 warnings
[INFO] [stderr] warning: unused import: `std::thread`
[INFO] [stderr]   --> src/intelligence/signal.rs:81:9
[INFO] [stderr]    |
[INFO] [stderr] 81 |     use std::thread;
[INFO] [stderr]    |         ^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::config::tests::test_config`
[INFO] [stderr]    --> src/order/router.rs:167:9
[INFO] [stderr]     |
[INFO] [stderr] 167 |     use crate::config::tests::test_config;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `polybot` (bin "polybot" test) generated 3 warnings (1 duplicate) (run `cargo fix --bin "polybot" -p polybot --tests` to apply 2 suggestions)
[INFO] [stderr] warning: `polybot` (lib test) generated 2 warnings (2 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.47s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/polybot-53c8e0db721d750a)
[INFO] [stdout] 
[INFO] [stdout] running 209 tests
[INFO] [stdout] test intelligence::llm::tests::boundary_multiplier_values_accepted ... ok
[INFO] [stdout] test config::tests::env_or_returns_env_value ... ok
[INFO] [stdout] test intelligence::llm::tests::pull_response_converts ... ok
[INFO] [stdout] test config::tests::default_hosts_are_production ... ok
[INFO] [stdout] test config::tests::max_active_markets_tiers ... ok
[INFO] [stdout] test config::tests::nav_limit_full_nav ... ok
[INFO] [stdout] test config::tests::nav_limit_calculation ... ok
[INFO] [stdout] test config::tests::nav_limit_zero_fraction ... ok
[INFO] [stdout] test config::tests::effective_caps_unchanged_for_large_accounts ... ok
[INFO] [stdout] test config::tests::effective_caps_increase_for_small_accounts ... ok
[INFO] [stdout] test config::tests::default_risk_limits_match_plan ... ok
[INFO] [stdout] test intelligence::llm::tests::valid_response_converts ... ok
[INFO] [stdout] test intelligence::signal::tests::default_signal_is_neutral ... ok
[INFO] [stdout] test intelligence::signal::tests::expired_signal_reverts_to_full ... ok
[INFO] [stdout] test intelligence::signal::tests::multiplier_clamped_to_unit_range ... ok
[INFO] [stdout] test intelligence::signal::tests::pull_signal_zeroes_multiplier ... ok
[INFO] [stdout] test intelligence::signal::tests::signal_none_created_at_is_expired ... ok
[INFO] [stdout] test market::book::tests::hash_returns_none_for_missing ... ok
[INFO] [stdout] test market::book::tests::empty_book_returns_none ... ok
[INFO] [stdout] test intelligence::signal::tests::bridge_send_receive ... ok
[INFO] [stdout] test intelligence::signal::tests::multiple_receivers_see_same_signal ... ok
[INFO] [stdout] test intelligence::llm::tests::rejects_out_of_range_multiplier ... ok
[INFO] [stdout] test intelligence::llm::tests::rejects_empty_reason_code ... ok
[INFO] [stdout] test intelligence::llm::tests::rejects_zero_ttl ... ok
[INFO] [stdout] test market::book::tests::pause_and_resume ... ok
[INFO] [stdout] test config::tests::env_or_returns_default ... ok
[INFO] [stdout] test intelligence::llm::tests::rejects_oversized_reason_code ... ok
[INFO] [stdout] test intelligence::llm::tests::llm_response_serialization_roundtrip ... ok
[INFO] [stdout] test market::book::tests::any_stale_detection ... ok
[INFO] [stdout] test market::book::tests::hash_returns_stored_value ... ok
[INFO] [stdout] test market::book::tests::same_timestamp_accepted ... ok
[INFO] [stdout] test market::book::tests::all_mids_across_tokens ... ok
[INFO] [stdout] test config::tests::from_env_behavior ... ok
[INFO] [stdout] test market::book::tests::update_replaces_previous ... ok
[INFO] [stdout] test market::book::tests::multiple_levels ... ok
[INFO] [stdout] test market::book::tests::apply_and_get ... ok
[INFO] [stdout] test market::book::tests::newer_timestamp_accepted ... ok
[INFO] [stdout] test market::book::tests::older_snapshot_is_rejected ... ok
[INFO] [stdout] test market::book::tests::apply_snapshot_populates_book ... ok
[INFO] [stdout] test market::book::tests::retain_removes_stale_assets ... ok
[INFO] [stdout] test market::book::tests::mid_price_calculation ... ok
[INFO] [stdout] test market::book::tests::pause_does_not_block_apply ... ok
[INFO] [stdout] test market::book::tests::spread_calculation ... ok
[INFO] [stdout] test market::book::tests::empty_sides_no_mid ... ok
[INFO] [stdout] test market::book::tests::one_sided_book_no_mid ... ok
[INFO] [stdout] test market::book::tests::timestamp_regression_rejected ... ok
[INFO] [stdout] test market::book::tests::stale_detection ... ok
[INFO] [stdout] test market::discovery::tests::parse_volume_handles_nested_markets_shape ... ok
[INFO] [stdout] test ops::metrics::tests::fill_rate_numerator_tracking ... ok
[INFO] [stdout] test ops::metrics::tests::heartbeat_age_tracking ... ok
[INFO] [stdout] test ops::metrics::tests::cancel_latency_tracking ... ok
[INFO] [stdout] test market::discovery::tests::enrich_volume_empty_input_ok ... ok
[INFO] [stdout] test ops::metrics::tests::increment_counters ... ok
[INFO] [stdout] test ops::metrics::tests::initial_counters_are_zero ... ok
[INFO] [stdout] test ops::metrics::tests::concurrent_increments ... ok
[INFO] [stdout] test ops::metrics::tests::pnl_and_rebate_tracking ... ok
[INFO] [stdout] test ops::metrics::tests::quote_age_tracking ... ok
[INFO] [stdout] test ops::metrics::tests::reset_daily_clears_new_metrics ... ok
[INFO] [stdout] test ops::metrics::tests::slippage_total_tracking ... ok
[INFO] [stdout] test ops::metrics::tests::snapshot_serializes_to_json ... ok
[INFO] [stdout] test ops::metrics::tests::throttle_count_tracking ... ok
[INFO] [stdout] test ops::nav::tests::min_nav_change_filters_noise ... ok
[INFO] [stdout] test ops::metrics::tests::reset_daily_clears_counters ... ok
[INFO] [stdout] test ops::paper::tests::cancel_all_orders ... ok
[INFO] [stdout] test ops::metrics::tests::ws_reconnects_and_llm_counters ... ok
[INFO] [stdout] test ops::paper::tests::cancel_order ... ok
[INFO] [stdout] test ops::paper::tests::net_notional_tracking ... ok
[INFO] [stdout] test ops::paper::tests::no_book_means_resting ... ok
[INFO] [stdout] test ops::paper::tests::place_resting_order ... ok
[INFO] [stdout] test ops::paper::tests::post_only_prevents_crossing_fill ... ok
[INFO] [stdout] test ops::paper::tests::sell_crossing_fills ... ok
[INFO] [stdout] test ops::rewards::tests::tracker_updates ... ok
[INFO] [stdout] test order::heartbeat::tests::fresh_monitor_is_not_stale ... ok
[INFO] [stdout] test ops::paper::tests::place_crossing_order_fills ... ok
[INFO] [stdout] test order::heartbeat::tests::heartbeat_id_updates ... ok
[INFO] [stdout] test order::heartbeat::tests::not_stale_within_threshold ... ok
[INFO] [stdout] test order::heartbeat::tests::record_failure_increments ... ok
[INFO] [stdout] test ops::paper::tests::sequential_ids ... ok
[INFO] [stdout] test order::heartbeat::tests::record_success_resets_timer ... ok
[INFO] [stdout] test order::heartbeat::tests::reset_failures_clears_count ... ok
[INFO] [stdout] test order::heartbeat::tests::set_and_get_heartbeat_id ... ok
[INFO] [stdout] test order::heartbeat::tests::stale_after_three_intervals ... ok
[INFO] [stdout] test order::router::tests::paper_engine_accessor ... ok
[INFO] [stdout] test ops::rewards::tests::tracker_starts_at_zero ... ok
[INFO] [stdout] test order::router::tests::paper_router_cancel_specific ... ok
[INFO] [stdout] test order::router::tests::paper_router_detects_immediate_fill ... ok
[INFO] [stdout] test risk::guardrails::tests::approved_within_limits ... ok
[INFO] [stdout] test order::router::tests::paper_router_no_fill_for_resting ... ok
[INFO] [stdout] test risk::guardrails::tests::cancel_failure_at_threshold_halts ... ok
[INFO] [stdout] test order::router::tests::paper_router_places_order ... ok
[INFO] [stdout] test ops::paper::tests::simulate_resting_fills_when_book_crosses ... ok
[INFO] [stdout] test risk::guardrails::tests::daily_pnl_accumulates ... ok
[INFO] [stdout] test risk::guardrails::tests::cancel_failure_below_threshold ... ok
[INFO] [stdout] test risk::guardrails::tests::halt_and_check_is_halted ... ok
[INFO] [stdout] test risk::guardrails::tests::cancel_failure_reset ... ok
[INFO] [stdout] test risk::guardrails::tests::daily_loss_stop ... ok
[INFO] [stdout] test order::router::tests::paper_router_cancel_all ... ok
[INFO] [stdout] test risk::guardrails::tests::inventory_snapshot_empty_initially ... ok
[INFO] [stdout] test risk::guardrails::tests::inventory_snapshot_returns_all_tokens ... ok
[INFO] [stdout] test risk::guardrails::tests::gross_exposure_limit ... ok
[INFO] [stdout] test risk::guardrails::tests::gross_derisking_order_is_allowed_near_limit ... ok
[INFO] [stdout] test risk::guardrails::tests::one_sided_inventory_buy_limit ... ok
[INFO] [stdout] test risk::guardrails::tests::mark_to_market_pnl_tracks_inventory_and_cashflow ... ok
[INFO] [stdout] test risk::guardrails::tests::one_sided_inventory_short_limit ... ok
[INFO] [stdout] test risk::guardrails::tests::one_sided_inventory_sell_reduces ... ok
[INFO] [stdout] test risk::guardrails::tests::per_market_derisking_sell_is_allowed ... ok
[INFO] [stdout] test risk::guardrails::tests::rejected_per_market_limit ... ok
[INFO] [stdout] test risk::guardrails::tests::reset_daily_clears_pnl ... ok
[INFO] [stdout] test risk::guardrails::tests::reset_daily_clears_halt_and_counters ... ok
[INFO] [stdout] test risk::guardrails::tests::resume_clears_halt ... ok
[INFO] [stdout] test risk::guardrails::tests::safe_nav_decimal_valid_value ... ok
[INFO] [stdout] test risk::guardrails::tests::rejected_when_halted ... ok
[INFO] [stdout] test risk::guardrails::tests::separate_markets_have_separate_limits ... ok
[INFO] [stdout] test risk::guardrails::tests::set_daily_pnl_enforces_loss_stop ... ok
[INFO] [stdout] test risk::position::tests::empty_snapshot ... ok
[INFO] [stdout] test risk::guardrails::tests::zero_notional_order_passes ... ok
[INFO] [stdout] test risk::position::tests::mismatch_empty_both ... ok
[INFO] [stdout] test risk::guardrails::tests::update_nav_recalculates_limits ... ok
[INFO] [stdout] test risk::position::tests::mismatch_local_only ... ok
[INFO] [stdout] test risk::guardrails::tests::update_nav_to_small_account_uses_boosted_caps ... ok
[INFO] [stdout] test risk::guardrails::tests::pre_computed_limits_match_config ... ok
[INFO] [stdout] test risk::position::tests::mismatch_exact_match ... ok
[INFO] [stdout] test risk::position::tests::mismatch_remote_only ... ok
[INFO] [stdout] test risk::position::tests::snapshot_with_positions ... ok
[INFO] [stdout] test risk::position::tests::mismatch_partial_overlap ... ok
[INFO] [stdout] test risk::rate_limit::tests::burst_capacity_allows_short_bursts ... ok
[INFO] [stdout] test risk::rate_limit::tests::exhausts_bucket ... ok
[INFO] [stdout] test risk::rate_limit::tests::initial_tokens_available ... ok
[INFO] [stdout] test strategy::decay::tests::candidates_sorted_by_score_descending ... ok
[INFO] [stdout] test risk::rate_limit::tests::backoff_blocks_acquire ... ok
[INFO] [stdout] test risk::rate_limit::tests::exponential_backoff_increases ... ok
[INFO] [stdout] test risk::rate_limit::tests::backoff_jitter_produces_variation ... ok
[INFO] [stdout] test risk::rate_limit::tests::record_429_sets_backoff ... ok
[INFO] [stdout] test strategy::decay::tests::candidates_sorted_by_score_descending_not_price ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_skips_duplicate_market ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_respects_nav_cap ... ok
[INFO] [stdout] test strategy::decay::tests::is_sports_market_detects_various_tags ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_skips_when_available_below_min_order ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_respects_max_bet ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_caps_size_to_available_liquidity ... ok
[INFO] [stdout] test strategy::decay::tests::scan_accepts_neg_risk ... ok
[INFO] [stdout] test strategy::decay::tests::scan_non_sports_within_24h_window ... ok
[INFO] [stdout] test strategy::decay::tests::scan_skips_excluded_tags ... ok
[INFO] [stdout] test strategy::decay::tests::scan_skips_low_price ... ok
[INFO] [stdout] test strategy::decay::tests::scan_skips_market_outside_window ... ok
[INFO] [stdout] test strategy::decay::tests::scan_finds_candidate_within_window ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_uses_sports_max_bet_for_sports_candidates ... ok
[INFO] [stdout] test strategy::decay::tests::scan_non_sports_outside_24h_window_skipped ... ok
[INFO] [stdout] test strategy::decay::tests::scan_skips_multi_outcome ... ok
[INFO] [stdout] test strategy::decay::tests::scan_skips_no_end_date ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_at_90_price_qualifies ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_in_progress_2x_bonus_applied ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_in_progress_game_found ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_requires_higher_min_price ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_market_within_sports_window ... ok
[INFO] [stdout] test strategy::decay::tests::score_opportunity_favors_shorter_resolution ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_game_too_old_skipped ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_generates_buy_when_below_sma ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_generates_sell_when_above_sma ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_rejects_low_volume ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_empty_tokens ... ok
[INFO] [stdout] test strategy::decay::tests::tracker_cleanup_removes_resolved ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_market_outside_sports_window_skipped ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_rejects_not_ready ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_rejects_small_deviation ... ok
[INFO] [stdout] test strategy::mean_revert::tests::mean_revert_state_record_and_sma ... ok
[INFO] [stdout] test strategy::mean_revert::tests::position_price_stop_buy ... ok
[INFO] [stdout] test strategy::mean_revert::tests::mean_revert_state_retain_tokens ... ok
[INFO] [stdout] test strategy::mean_revert::tests::position_price_stop_sell ... ok
[INFO] [stdout] test strategy::mean_revert::tests::positions_to_close_time_stop ... ok
[INFO] [stdout] test strategy::mean_revert::tests::position_time_stop ... ok
[INFO] [stdout] test strategy::mean_revert::tests::positions_to_close_none_when_fresh ... ok
[INFO] [stdout] test strategy::mean_revert::tests::price_tracker_empty_sma ... ok
[INFO] [stdout] test strategy::mean_revert::tests::price_tracker_sma ... ok
[INFO] [stdout] test strategy::mean_revert::tests::price_tracker_window_eviction ... ok
[INFO] [stdout] test strategy::mean_revert::tests::price_tracker_readiness ... ok
[INFO] [stdout] test strategy::rebate_mm::tests::round_to_tick_works ... ok
[INFO] [stdout] test strategy::mean_revert::tests::remove_position ... ok
[INFO] [stdout] test strategy::reward::tests::expired_unwinds_do_not_mark_hedged_without_fill ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_empty_tokens ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_generates_two_sided ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_max_spread_tightens ... ok
[INFO] [stdout] test strategy::reward::tests::hard_stop_failures_increment_and_state_available ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_min_size_enforced ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_no_book ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_expired_unwinds ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_mark_hedged ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_clear ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_no_rewards_active ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_complement_fill_auto_hedges ... ok
[INFO] [stdout] test strategy::reward::tests::round_to_tick_works ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_different_conditions_not_matched ... ok
[INFO] [stdout] test strategy::reward::tests::unhedged_fill_expired ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_record_and_count ... ok
[INFO] [stdout] test strategy::reward::tests::unhedged_fill_not_expired ... ok
[INFO] [stdout] test strategy::reward::tests::unwind_intent_inherits_neg_risk_and_fee ... ok
[INFO] [stdout] test strategy::reward::tests::unwind_intent_sells_at_best_bid ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_unhedged_conditions_blocks_quoting ... ok
[INFO] [stdout] test strategy::reward::tests::unwind_stage_progression_and_price ... ok
[INFO] [stdout] test strategy::scalper::tests::accepts_wide_spread_and_touch ... ok
[INFO] [stdout] test strategy::scalper::tests::ranking_is_deterministic ... ok
[INFO] [stdout] test strategy::reward::tests::unwind_intent_no_book_returns_none ... ok
[INFO] [stdout] test strategy::scalper::tests::rejects_high_volatility ... ok
[INFO] [stdout] test strategy::scalper::tests::rejects_thin_touch_notional ... ok
[INFO] [stdout] test risk::guardrails::tests::safe_nav_decimal_panics_on_nan ... ok
[INFO] [stdout] test risk::guardrails::tests::safe_nav_decimal_panics_on_inf ... ok
[INFO] [stdout] test risk::position::tests::retries_transient_position_api_errors ... ok
[INFO] [stdout] test risk::position::tests::malformed_json_returns_error ... ok
[INFO] [stdout] test risk::position::tests::mismatch_requires_confirmation_before_halt ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 209 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.26s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/polybot-03af4a1eb4657634)
[INFO] [stdout] 
[INFO] [stdout] running 217 tests
[INFO] [stdout] test config::tests::default_hosts_are_production ... ok
[INFO] [stdout] test config::tests::effective_caps_increase_for_small_accounts ... ok
[INFO] [stdout] test config::tests::effective_caps_unchanged_for_large_accounts ... ok
[INFO] [stdout] test config::tests::default_risk_limits_match_plan ... ok
[INFO] [stdout] test config::tests::env_or_returns_default ... ok
[INFO] [stdout] test config::tests::max_active_markets_tiers ... ok
[INFO] [stdout] test config::tests::env_or_returns_env_value ... ok
[INFO] [stdout] test config::tests::nav_limit_calculation ... ok
[INFO] [stdout] test config::tests::nav_limit_full_nav ... ok
[INFO] [stdout] test config::tests::nav_limit_zero_fraction ... ok
[INFO] [stdout] test intelligence::llm::tests::boundary_multiplier_values_accepted ... ok
[INFO] [stdout] test config::tests::from_env_behavior ... ok
[INFO] [stdout] test intelligence::llm::tests::pull_response_converts ... ok
[INFO] [stdout] test intelligence::llm::tests::rejects_empty_reason_code ... ok
[INFO] [stdout] test intelligence::llm::tests::llm_response_serialization_roundtrip ... ok
[INFO] [stdout] test intelligence::llm::tests::rejects_out_of_range_multiplier ... ok
[INFO] [stdout] test intelligence::llm::tests::rejects_oversized_reason_code ... ok
[INFO] [stdout] test intelligence::llm::tests::rejects_zero_ttl ... ok
[INFO] [stdout] test intelligence::llm::tests::valid_response_converts ... ok
[INFO] [stdout] test intelligence::signal::tests::expired_signal_reverts_to_full ... ok
[INFO] [stdout] test intelligence::signal::tests::default_signal_is_neutral ... ok
[INFO] [stdout] test intelligence::signal::tests::bridge_send_receive ... ok
[INFO] [stdout] test intelligence::signal::tests::pull_signal_zeroes_multiplier ... ok
[INFO] [stdout] test intelligence::signal::tests::multiple_receivers_see_same_signal ... ok
[INFO] [stdout] test intelligence::signal::tests::multiplier_clamped_to_unit_range ... ok
[INFO] [stdout] test intelligence::signal::tests::signal_none_created_at_is_expired ... ok
[INFO] [stdout] test market::book::tests::all_mids_across_tokens ... ok
[INFO] [stdout] test market::book::tests::any_stale_detection ... ok
[INFO] [stdout] test market::book::tests::empty_book_returns_none ... ok
[INFO] [stdout] test market::book::tests::apply_snapshot_populates_book ... ok
[INFO] [stdout] test market::book::tests::apply_and_get ... ok
[INFO] [stdout] test market::book::tests::hash_returns_none_for_missing ... ok
[INFO] [stdout] test market::book::tests::empty_sides_no_mid ... ok
[INFO] [stdout] test market::book::tests::hash_returns_stored_value ... ok
[INFO] [stdout] test market::book::tests::newer_timestamp_accepted ... ok
[INFO] [stdout] test market::book::tests::multiple_levels ... ok
[INFO] [stdout] test market::book::tests::one_sided_book_no_mid ... ok
[INFO] [stdout] test market::book::tests::older_snapshot_is_rejected ... ok
[INFO] [stdout] test market::book::tests::retain_removes_stale_assets ... ok
[INFO] [stdout] test market::book::tests::same_timestamp_accepted ... ok
[INFO] [stdout] test market::book::tests::mid_price_calculation ... ok
[INFO] [stdout] test market::book::tests::stale_detection ... ok
[INFO] [stdout] test market::book::tests::timestamp_regression_rejected ... ok
[INFO] [stdout] test market::discovery::tests::parse_volume_handles_nested_markets_shape ... ok
[INFO] [stdout] test market::book::tests::update_replaces_previous ... ok
[INFO] [stdout] test market::book::tests::spread_calculation ... ok
[INFO] [stdout] test market::book::tests::pause_does_not_block_apply ... ok
[INFO] [stdout] test ops::metrics::tests::cancel_latency_tracking ... ok
[INFO] [stdout] test ops::metrics::tests::fill_rate_numerator_tracking ... ok
[INFO] [stdout] test ops::metrics::tests::heartbeat_age_tracking ... ok
[INFO] [stdout] test market::book::tests::pause_and_resume ... ok
[INFO] [stdout] test ops::metrics::tests::increment_counters ... ok
[INFO] [stdout] test market::discovery::tests::enrich_volume_empty_input_ok ... ok
[INFO] [stdout] test ops::metrics::tests::pnl_and_rebate_tracking ... ok
[INFO] [stdout] test ops::metrics::tests::initial_counters_are_zero ... ok
[INFO] [stdout] test ops::metrics::tests::quote_age_tracking ... ok
[INFO] [stdout] test ops::metrics::tests::reset_daily_clears_counters ... ok
[INFO] [stdout] test ops::metrics::tests::concurrent_increments ... ok
[INFO] [stdout] test ops::metrics::tests::reset_daily_clears_new_metrics ... ok
[INFO] [stdout] test ops::metrics::tests::ws_reconnects_and_llm_counters ... ok
[INFO] [stdout] test ops::metrics::tests::slippage_total_tracking ... ok
[INFO] [stdout] test ops::nav::tests::min_nav_change_filters_noise ... ok
[INFO] [stdout] test ops::paper::tests::cancel_all_orders ... ok
[INFO] [stdout] test ops::paper::tests::cancel_order ... ok
[INFO] [stdout] test ops::metrics::tests::snapshot_serializes_to_json ... ok
[INFO] [stdout] test ops::paper::tests::net_notional_tracking ... ok
[INFO] [stdout] test ops::paper::tests::place_crossing_order_fills ... ok
[INFO] [stdout] test ops::metrics::tests::throttle_count_tracking ... ok
[INFO] [stdout] test ops::paper::tests::place_resting_order ... ok
[INFO] [stdout] test ops::rewards::tests::tracker_starts_at_zero ... ok
[INFO] [stdout] test ops::paper::tests::no_book_means_resting ... ok
[INFO] [stdout] test ops::paper::tests::post_only_prevents_crossing_fill ... ok
[INFO] [stdout] test ops::paper::tests::simulate_resting_fills_when_book_crosses ... ok
[INFO] [stdout] test order::heartbeat::tests::fresh_monitor_is_not_stale ... ok
[INFO] [stdout] test order::heartbeat::tests::not_stale_within_threshold ... ok
[INFO] [stdout] test order::heartbeat::tests::heartbeat_id_updates ... ok
[INFO] [stdout] test order::heartbeat::tests::record_failure_increments ... ok
[INFO] [stdout] test ops::paper::tests::sell_crossing_fills ... ok
[INFO] [stdout] test ops::rewards::tests::tracker_updates ... ok
[INFO] [stdout] test order::heartbeat::tests::reset_failures_clears_count ... ok
[INFO] [stdout] test ops::paper::tests::sequential_ids ... ok
[INFO] [stdout] test order::heartbeat::tests::record_success_resets_timer ... ok
[INFO] [stdout] test order::heartbeat::tests::set_and_get_heartbeat_id ... ok
[INFO] [stdout] test order::heartbeat::tests::stale_after_three_intervals ... ok
[INFO] [stdout] test order::router::tests::paper_router_cancel_all ... ok
[INFO] [stdout] test risk::guardrails::tests::cancel_failure_at_threshold_halts ... ok
[INFO] [stdout] test order::router::tests::paper_router_cancel_specific ... ok
[INFO] [stdout] test risk::guardrails::tests::cancel_failure_below_threshold ... ok
[INFO] [stdout] test risk::guardrails::tests::approved_within_limits ... ok
[INFO] [stdout] test order::router::tests::paper_router_no_fill_for_resting ... ok
[INFO] [stdout] test order::router::tests::paper_router_detects_immediate_fill ... ok
[INFO] [stdout] test order::router::tests::paper_router_places_order ... ok
[INFO] [stdout] test order::router::tests::paper_engine_accessor ... ok
[INFO] [stdout] test risk::guardrails::tests::cancel_failure_reset ... ok
[INFO] [stdout] test risk::guardrails::tests::halt_and_check_is_halted ... ok
[INFO] [stdout] test risk::guardrails::tests::gross_exposure_limit ... ok
[INFO] [stdout] test risk::guardrails::tests::daily_pnl_accumulates ... ok
[INFO] [stdout] test risk::guardrails::tests::mark_to_market_pnl_tracks_inventory_and_cashflow ... ok
[INFO] [stdout] test risk::guardrails::tests::one_sided_inventory_buy_limit ... ok
[INFO] [stdout] test risk::guardrails::tests::one_sided_inventory_sell_reduces ... ok
[INFO] [stdout] test risk::guardrails::tests::inventory_snapshot_empty_initially ... ok
[INFO] [stdout] test risk::guardrails::tests::gross_derisking_order_is_allowed_near_limit ... ok
[INFO] [stdout] test risk::guardrails::tests::one_sided_inventory_short_limit ... ok
[INFO] [stdout] test risk::guardrails::tests::per_market_derisking_sell_is_allowed ... ok
[INFO] [stdout] test risk::guardrails::tests::pre_computed_limits_match_config ... ok
[INFO] [stdout] test risk::guardrails::tests::rejected_per_market_limit ... ok
[INFO] [stdout] test risk::guardrails::tests::daily_loss_stop ... ok
[INFO] [stdout] test risk::guardrails::tests::rejected_when_halted ... ok
[INFO] [stdout] test risk::guardrails::tests::reset_daily_clears_halt_and_counters ... ok
[INFO] [stdout] test risk::guardrails::tests::inventory_snapshot_returns_all_tokens ... ok
[INFO] [stdout] test risk::guardrails::tests::reset_daily_clears_pnl ... ok
[INFO] [stdout] test risk::guardrails::tests::resume_clears_halt ... ok
[INFO] [stdout] test risk::guardrails::tests::safe_nav_decimal_valid_value ... ok
[INFO] [stdout] test risk::guardrails::tests::separate_markets_have_separate_limits ... ok
[INFO] [stdout] test risk::guardrails::tests::set_daily_pnl_enforces_loss_stop ... ok
[INFO] [stdout] test risk::guardrails::tests::update_nav_to_small_account_uses_boosted_caps ... ok
[INFO] [stdout] test risk::position::tests::mismatch_empty_both ... ok
[INFO] [stdout] test risk::guardrails::tests::update_nav_recalculates_limits ... ok
[INFO] [stdout] test risk::position::tests::mismatch_exact_match ... ok
[INFO] [stdout] test risk::guardrails::tests::zero_notional_order_passes ... ok
[INFO] [stdout] test risk::position::tests::mismatch_local_only ... ok
[INFO] [stdout] test risk::position::tests::empty_snapshot ... ok
[INFO] [stdout] test risk::position::tests::mismatch_partial_overlap ... ok
[INFO] [stdout] test risk::position::tests::mismatch_remote_only ... ok
[INFO] [stdout] test risk::position::tests::snapshot_with_positions ... ok
[INFO] [stdout] test risk::rate_limit::tests::backoff_jitter_produces_variation ... ok
[INFO] [stdout] test risk::rate_limit::tests::backoff_blocks_acquire ... ok
[INFO] [stdout] test risk::rate_limit::tests::record_429_sets_backoff ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_caps_size_to_available_liquidity ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_respects_max_bet ... ok
[INFO] [stdout] test risk::rate_limit::tests::burst_capacity_allows_short_bursts ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_respects_nav_cap ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_skips_duplicate_market ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_skips_when_available_below_min_order ... ok
[INFO] [stdout] test strategy::decay::tests::evaluate_uses_sports_max_bet_for_sports_candidates ... ok
[INFO] [stdout] test strategy::decay::tests::is_sports_market_detects_various_tags ... ok
[INFO] [stdout] test strategy::decay::tests::candidates_sorted_by_score_descending ... ok
[INFO] [stdout] test strategy::decay::tests::scan_accepts_neg_risk ... ok
[INFO] [stdout] test risk::rate_limit::tests::exhausts_bucket ... ok
[INFO] [stdout] test strategy::decay::tests::scan_finds_candidate_within_window ... ok
[INFO] [stdout] test strategy::decay::tests::scan_non_sports_outside_24h_window_skipped ... ok
[INFO] [stdout] test strategy::decay::tests::scan_skips_excluded_tags ... ok
[INFO] [stdout] test strategy::decay::tests::scan_non_sports_within_24h_window ... ok
[INFO] [stdout] test strategy::decay::tests::scan_skips_low_price ... ok
[INFO] [stdout] test strategy::decay::tests::candidates_sorted_by_score_descending_not_price ... ok
[INFO] [stdout] test risk::rate_limit::tests::initial_tokens_available ... ok
[INFO] [stdout] test risk::rate_limit::tests::exponential_backoff_increases ... ok
[INFO] [stdout] test strategy::decay::tests::scan_skips_market_outside_window ... ok
[INFO] [stdout] test strategy::decay::tests::scan_skips_multi_outcome ... ok
[INFO] [stdout] test strategy::decay::tests::scan_skips_no_end_date ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_game_too_old_skipped ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_at_90_price_qualifies ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_in_progress_2x_bonus_applied ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_in_progress_game_found ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_market_outside_sports_window_skipped ... ok
[INFO] [stdout] test strategy::decay::tests::tracker_cleanup_removes_resolved ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_requires_higher_min_price ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_empty_tokens ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_generates_buy_when_below_sma ... ok
[INFO] [stdout] test strategy::decay::tests::scan_sports_market_within_sports_window ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_generates_sell_when_above_sma ... ok
[INFO] [stdout] test strategy::mean_revert::tests::mean_revert_state_record_and_sma ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_rejects_small_deviation ... ok
[INFO] [stdout] test strategy::decay::tests::score_opportunity_favors_shorter_resolution ... ok
[INFO] [stdout] test strategy::mean_revert::tests::mean_revert_state_retain_tokens ... ok
[INFO] [stdout] test strategy::mean_revert::tests::position_price_stop_buy ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_rejects_low_volume ... ok
[INFO] [stdout] test strategy::mean_revert::tests::position_price_stop_sell ... ok
[INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_rejects_not_ready ... ok
[INFO] [stdout] test strategy::mean_revert::tests::position_time_stop ... ok
[INFO] [stdout] test strategy::mean_revert::tests::price_tracker_empty_sma ... ok
[INFO] [stdout] test strategy::mean_revert::tests::positions_to_close_none_when_fresh ... ok
[INFO] [stdout] test strategy::mean_revert::tests::positions_to_close_time_stop ... ok
[INFO] [stdout] test strategy::mean_revert::tests::price_tracker_sma ... ok
[INFO] [stdout] test strategy::mean_revert::tests::price_tracker_window_eviction ... ok
[INFO] [stdout] test strategy::mean_revert::tests::price_tracker_readiness ... ok
[INFO] [stdout] test strategy::rebate_mm::tests::round_to_tick_works ... ok
[INFO] [stdout] test strategy::mean_revert::tests::remove_position ... ok
[INFO] [stdout] test strategy::reward::tests::hard_stop_failures_increment_and_state_available ... ok
[INFO] [stdout] test strategy::reward::tests::expired_unwinds_do_not_mark_hedged_without_fill ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_empty_tokens ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_max_spread_tightens ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_generates_two_sided ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_min_size_enforced ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_no_book ... ok
[INFO] [stdout] test strategy::reward::tests::round_to_tick_works ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_clear ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_different_conditions_not_matched ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_complement_fill_auto_hedges ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_mark_hedged ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_expired_unwinds ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_record_and_count ... ok
[INFO] [stdout] test strategy::reward::tests::reward_quote_no_rewards_active ... ok
[INFO] [stdout] test strategy::reward::tests::unhedged_fill_expired ... ok
[INFO] [stdout] test strategy::reward::tests::tracker_unhedged_conditions_blocks_quoting ... ok
[INFO] [stdout] test strategy::reward::tests::unhedged_fill_not_expired ... ok
[INFO] [stdout] test strategy::reward::tests::unwind_intent_no_book_returns_none ... ok
[INFO] [stdout] test strategy::reward::tests::unwind_intent_inherits_neg_risk_and_fee ... ok
[INFO] [stdout] test strategy::reward::tests::unwind_intent_sells_at_best_bid ... ok
[INFO] [stdout] test strategy::reward::tests::unwind_stage_progression_and_price ... ok
[INFO] [stdout] test strategy::scalper::tests::rejects_thin_touch_notional ... ok
[INFO] [stdout] test strategy::scalper::tests::rejects_high_volatility ... ok
[INFO] [stdout] test tests::authoritative_restore_accepts_matching_existing_hash ... ok
[INFO] [stdout] test strategy::scalper::tests::accepts_wide_spread_and_touch ... ok
[INFO] [stdout] test tests::authoritative_restore_requires_complete_snapshot_set ... ok
[INFO] [stdout] test tests::no_replace_within_threshold_and_ttl ... ok
[INFO] [stdout] test tests::book_updates_are_ignored_until_resync_is_live ... ok
[INFO] [stdout] test strategy::scalper::tests::ranking_is_deterministic ... ok
[INFO] [stdout] test tests::replace_on_size_change ... ok
[INFO] [stdout] test tests::replace_on_ttl_expiry ... ok
[INFO] [stdout] test tests::resync_failure_keeps_books_paused_until_success ... ok
[INFO] [stdout] test tests::replace_on_one_tick_move ... ok
[INFO] [stdout] test risk::guardrails::tests::safe_nav_decimal_panics_on_inf ... ok
[INFO] [stdout] test risk::guardrails::tests::safe_nav_decimal_panics_on_nan ... ok
[INFO] [stdout] test risk::position::tests::retries_transient_position_api_errors ... ok
[INFO] [stdout] test risk::position::tests::malformed_json_returns_error ... ok
[INFO] [stdout] test risk::position::tests::mismatch_requires_confirmation_before_halt ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 217 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.13s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/integration.rs (/opt/rustwide/target/debug/deps/integration-bb1c5e0de15a12e0)
[INFO] [stdout] 
[INFO] [stdout] running 23 tests
[INFO] [stdout] test book_pause_resume_cycle ... ok
[INFO] [stdout] test cancel_failure_threshold_halts_engine ... ok
[INFO] [stdout] test complement_fills_auto_hedge ... ok
[INFO] [stdout] test inventory_snapshot_for_recon ... ok
[INFO] [stdout] test book_timestamp_regression_rejected ... ok
[INFO] [stdout] test expired_fill_generates_unwind ... ok
[INFO] [stdout] test paper_pipeline_reward_tick ... ok
[INFO] [stdout] test cancel_all_clears_paper_engine ... ok
[INFO] [stdout] test paper_fill_returned_atomically ... ok
[INFO] [stdout] test decay_excludes_crypto_markets ... ok
[INFO] [stdout] test mean_revert_full_cycle ... ok
[INFO] [stdout] test fill_detection_through_router ... ok
[INFO] [stdout] test paper_pipeline_rebate_mm_tick ... ok
[INFO] [stdout] test paper_resting_returns_no_fill ... ok
[INFO] [stdout] test risk_daily_reset_clears_loss ... ok
[INFO] [stdout] test risk_halt_stops_all_orders ... ok
[INFO] [stdout] test risk_daily_loss_rejects_orders ... ok
[INFO] [stdout] test decay_buy_paper_cycle ... ok
[INFO] [stdout] test order_intent_carries_neg_risk_fields ... ok
[INFO] [stdout] test neg_risk_stale_pair_detection ... ok
[INFO] [stdout] test one_sided_inventory_blocks_excessive_exposure ... ok
[INFO] [stdout] test multi_strategy_coexistence ... ok
[INFO] [stdout] test inventory_skew_shifts_quotes ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 23 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests polybot
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "9301805d39489c3985c87bf121b34b141863e7d7ac0db39ba3b46ca7386187af", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9301805d39489c3985c87bf121b34b141863e7d7ac0db39ba3b46ca7386187af", kill_on_drop: false }`
[INFO] [stdout] 9301805d39489c3985c87bf121b34b141863e7d7ac0db39ba3b46ca7386187af
