[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] caba32bd9466662bc418d4115228f96a1ea1439c [INFO] testing wannabefro/polybot against master#ec6f9a5b4413f74386267ef8efc93712c2ce6db6 for pr-155739 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwannabefro%2Fpolybot" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/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-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/wannabefro/polybot on toolchain ec6f9a5b4413f74386267ef8efc93712c2ce6db6 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating git repository `https://github.com/Polymarket/rs-clob-client` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded deadpool-runtime v0.1.4 [INFO] [stderr] Downloaded assert-json-diff v2.0.2 [INFO] [stderr] Downloaded wiremock v0.6.5 [INFO] [stderr] Downloaded deadpool v0.12.3 [INFO] [stderr] Downloaded uuid v1.21.0 [INFO] [stderr] Downloaded tracing-serde v0.2.0 [INFO] [stderr] Downloaded aws-lc-rs v1.16.0 [INFO] [stderr] Downloaded iri-string v0.7.10 [INFO] [stderr] Downloaded webpki-roots v1.0.6 [INFO] [stderr] Downloaded tokio-tungstenite v0.28.0 [INFO] [stderr] Downloaded tungstenite v0.28.0 [INFO] [stderr] Downloaded serde_with_macros v3.17.0 [INFO] [stderr] Downloaded serde_with v3.17.0 [INFO] [stderr] Downloaded serde_ignored v0.1.14 [INFO] [stderr] Downloaded alloy-trie v0.9.4 [INFO] [stderr] Downloaded bon v3.9.0 [INFO] [stderr] Downloaded alloy v1.7.3 [INFO] [stderr] Downloaded bon-macros v3.9.0 [INFO] [stderr] Downloaded proptest v1.10.0 [INFO] [stderr] Downloaded nybbles v0.4.8 [INFO] [stderr] Downloaded alloy-rlp v0.3.13 [INFO] [stderr] Downloaded alloy-rlp-derive v0.3.13 [INFO] [stderr] Downloaded rapidhash v4.4.1 [INFO] [stderr] Downloaded alloy-primitives v1.5.7 [INFO] [stderr] Downloaded keccak-asm v0.1.5 [INFO] [stderr] Downloaded alloy-transport-http v1.7.3 [INFO] [stderr] Downloaded alloy-json-rpc v1.7.3 [INFO] [stderr] Downloaded alloy-sol-macro v1.5.7 [INFO] [stderr] Downloaded alloy-network v1.7.3 [INFO] [stderr] Downloaded alloy-sol-macro-input v1.5.7 [INFO] [stderr] Downloaded alloy-sol-macro-expander v1.5.7 [INFO] [stderr] Downloaded alloy-signer v1.7.3 [INFO] [stderr] Downloaded aws-lc-sys v0.37.1 [INFO] [stderr] Downloaded alloy-sol-types v1.5.7 [INFO] [stderr] Downloaded syn-solidity v1.5.7 [INFO] [stderr] Downloaded sha3-asm v0.1.5 [INFO] [stderr] Downloaded const-hex v1.18.0 [INFO] [stderr] Downloaded alloy-json-abi v1.5.7 [INFO] [stderr] Downloaded alloy-sol-type-parser v1.5.7 [INFO] [stderr] Downloaded alloy-signer-local v1.7.3 [INFO] [stderr] Downloaded alloy-rpc-types-eth v1.7.3 [INFO] [stderr] Downloaded alloy-eip7928 v0.3.2 [INFO] [stderr] Downloaded alloy-consensus v1.7.3 [INFO] [stderr] Downloaded alloy-network-primitives v1.7.3 [INFO] [stderr] Downloaded alloy-tx-macros v1.7.3 [INFO] [stderr] Downloaded alloy-rpc-types-any v1.7.3 [INFO] [stderr] Downloaded alloy-eips v1.7.3 [INFO] [stderr] Downloaded alloy-consensus-any v1.7.3 [INFO] [stderr] Downloaded alloy-core v1.5.7 [INFO] [stderr] Downloaded alloy-dyn-abi v1.5.7 [INFO] [stderr] Downloaded alloy-serde v1.7.3 [INFO] [stderr] Downloaded alloy-rpc-client v1.7.3 [INFO] [stderr] Downloaded alloy-chains v0.2.30 [INFO] [stderr] Downloaded alloy-transport v1.7.3 [INFO] [stderr] Downloaded alloy-provider v1.7.3 [INFO] [stderr] Downloaded c-kzg v2.1.6 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 39d085bde47c191696befcd21e34104cb8cf47c6c1625738350cb309666fb8bf [INFO] running `Command { std: "docker" "start" "-a" "39d085bde47c191696befcd21e34104cb8cf47c6c1625738350cb309666fb8bf", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "39d085bde47c191696befcd21e34104cb8cf47c6c1625738350cb309666fb8bf", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "39d085bde47c191696befcd21e34104cb8cf47c6c1625738350cb309666fb8bf", kill_on_drop: false }` [INFO] [stdout] 39d085bde47c191696befcd21e34104cb8cf47c6c1625738350cb309666fb8bf [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] f8977f4b56003d8ba9318db6f6c25118131121b3c9693b96267f5d75059b7c12 [INFO] running `Command { std: "docker" "start" "-a" "f8977f4b56003d8ba9318db6f6c25118131121b3c9693b96267f5d75059b7c12", kill_on_drop: false }` [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling foldhash v0.2.0 [INFO] [stderr] Compiling generic-array v0.14.9 [INFO] [stderr] Compiling der v0.7.10 [INFO] [stderr] Compiling dunce v1.0.5 [INFO] [stderr] Compiling keccak v0.1.6 [INFO] [stderr] Compiling quote v1.0.44 [INFO] [stderr] Compiling unicode-segmentation v1.12.0 [INFO] [stderr] Compiling ruint-macro v1.2.1 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling rustc-hash v2.1.1 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling strsim v0.11.1 [INFO] [stderr] Compiling ident_case v1.0.1 [INFO] [stderr] Compiling ff v0.13.1 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling group v0.13.0 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling convert_case v0.10.0 [INFO] [stderr] Compiling fs_extra v1.3.0 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling socket2 v0.6.2 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling proc-macro-error-attr2 v2.0.0 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling const-hex v1.18.0 [INFO] [stderr] Compiling aws-lc-rs v1.16.0 [INFO] [stderr] Compiling zerocopy v0.8.40 [INFO] [stderr] Compiling hashbrown v0.16.1 [INFO] [stderr] Compiling crc v3.4.0 [INFO] [stderr] Compiling block-buffer v0.10.4 [INFO] [stderr] Compiling crypto-common v0.1.6 [INFO] [stderr] Compiling rustls v0.23.37 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling sha3 v0.10.8 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling winnow v0.7.14 [INFO] [stderr] Compiling crypto-bigint v0.5.5 [INFO] [stderr] Compiling ipnet v2.11.0 [INFO] [stderr] Compiling siphasher v1.0.2 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling rand_core v0.9.5 [INFO] [stderr] Compiling rand_core v0.10.0 [INFO] [stderr] Compiling prettyplease v0.2.37 [INFO] [stderr] Compiling native-tls v0.2.18 [INFO] [stderr] Compiling indexmap v2.13.0 [INFO] [stderr] Compiling getrandom v0.4.1 [INFO] [stderr] Compiling phf_shared v0.13.1 [INFO] [stderr] Compiling webpki-roots v1.0.6 [INFO] [stderr] Compiling iri-string v0.7.10 [INFO] [stderr] Compiling hmac v0.12.1 [INFO] [stderr] Compiling signature v2.2.0 [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling spki v0.7.3 [INFO] [stderr] Compiling sec1 v0.7.3 [INFO] [stderr] Compiling rfc6979 v0.4.0 [INFO] [stderr] Compiling cmake v0.1.57 [INFO] [stderr] Compiling pkcs8 v0.10.2 [INFO] [stderr] Compiling futures-utils-wasm v0.1.0 [INFO] [stderr] Compiling fastrand v2.3.0 [INFO] [stderr] Compiling sha1 v0.10.6 [INFO] [stderr] Compiling data-encoding v2.10.0 [INFO] [stderr] Compiling utf-8 v0.7.6 [INFO] [stderr] Compiling phf_generator v0.13.1 [INFO] [stderr] Compiling cpufeatures v0.3.0 [INFO] [stderr] Compiling rust_decimal v1.40.0 [INFO] [stderr] Compiling regex-syntax v0.8.10 [INFO] [stderr] Compiling chacha20 v0.10.0 [INFO] [stderr] Compiling instant v0.1.13 [INFO] [stderr] Compiling hashbrown v0.14.5 [INFO] [stderr] Compiling sharded-slab v0.1.7 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling aws-lc-sys v0.37.1 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling rand v0.10.0 [INFO] [stderr] Compiling elliptic-curve v0.13.8 [INFO] [stderr] Compiling ecdsa v0.16.9 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling k256 v0.13.4 [INFO] [stderr] Compiling uuid v1.21.0 [INFO] [stderr] Compiling serde_path_to_error v0.1.20 [INFO] [stderr] Compiling serde_ignored v0.1.14 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.21.3 [INFO] [stderr] Compiling syn-solidity v1.5.7 [INFO] [stderr] Compiling macro-string v0.1.4 [INFO] [stderr] Compiling proc-macro-error2 v2.0.1 [INFO] [stderr] Compiling darling_core v0.23.0 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling serde_html_form v0.4.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 thiserror-impl v2.0.18 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Compiling auto_impl v1.3.0 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling alloy-sol-macro-input v1.5.7 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling alloy-sol-macro-expander v1.5.7 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling phf_macros v0.13.1 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling async-stream-impl v0.3.6 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling rand v0.9.2 [INFO] [stderr] Compiling async-stream v0.3.6 [INFO] [stderr] Compiling darling_macro v0.21.3 [INFO] [stderr] Compiling rust_decimal_macros v1.40.0 [INFO] [stderr] Compiling phf v0.13.1 [INFO] [stderr] Compiling backoff v0.4.0 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling serde_repr v0.1.20 [INFO] [stderr] Compiling strum_macros v0.28.0 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling icu_collections v2.1.1 [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 darling_macro v0.23.0 [INFO] [stderr] Compiling darling v0.23.0 [INFO] [stderr] Compiling bon-macros v3.9.0 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling derive_more v2.1.1 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling futures-executor v0.3.32 [INFO] [stderr] Compiling futures v0.3.32 [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 chrono v0.4.44 [INFO] [stderr] Compiling alloy-sol-macro v1.5.7 [INFO] [stderr] Compiling alloy-sol-type-parser v1.5.7 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling itertools v0.14.0 [INFO] [stderr] Compiling dashmap v6.1.0 [INFO] [stderr] Compiling tracing-serde v0.2.0 [INFO] [stderr] Compiling secrecy v0.10.3 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling alloy-rlp v0.3.13 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling ruint v1.17.2 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling url v2.5.8 [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 serde_with v3.17.0 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling alloy-serde v1.7.3 [INFO] [stderr] Compiling alloy-eip7928 v0.3.2 [INFO] [stderr] Compiling alloy-eip2124 v0.2.0 [INFO] [stderr] Compiling alloy-eip2930 v0.2.3 [INFO] [stderr] Compiling alloy-eip7702 v0.6.3 [INFO] [stderr] Compiling alloy-sol-types v1.5.7 [INFO] [stderr] Compiling alloy-trie v0.9.4 [INFO] [stderr] Compiling alloy-json-abi v1.5.7 [INFO] [stderr] Compiling alloy-signer v1.7.3 [INFO] [stderr] Compiling bon v3.9.0 [INFO] [stderr] Compiling alloy-eips v1.7.3 [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 alloy-json-rpc v1.7.3 [INFO] [stderr] Compiling alloy-dyn-abi v1.5.7 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling alloy-consensus v1.7.3 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling alloy-core v1.5.7 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [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 v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling alloy-rpc-types-any v1.7.3 [INFO] [stderr] Compiling alloy-network v1.7.3 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling rustls-platform-verifier v0.6.2 [INFO] [stderr] Compiling tungstenite v0.28.0 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling alloy-signer-local v1.7.3 [INFO] [stderr] Compiling reqwest v0.13.2 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling alloy v1.7.3 [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 22s [INFO] running `Command { std: "docker" "inspect" "f8977f4b56003d8ba9318db6f6c25118131121b3c9693b96267f5d75059b7c12", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f8977f4b56003d8ba9318db6f6c25118131121b3c9693b96267f5d75059b7c12", kill_on_drop: false }` [INFO] [stdout] f8977f4b56003d8ba9318db6f6c25118131121b3c9693b96267f5d75059b7c12 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 7cb36fd7ae551e9725264b8532ecd854999665b358a92ed352547cec5b29891e [INFO] running `Command { std: "docker" "start" "-a" "7cb36fd7ae551e9725264b8532ecd854999665b358a92ed352547cec5b29891e", kill_on_drop: false }` [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling regex-syntax v0.8.10 [INFO] [stderr] Compiling num_cpus v1.17.0 [INFO] [stderr] Compiling deadpool-runtime v0.1.4 [INFO] [stderr] Compiling assert-json-diff v2.0.2 [INFO] [stderr] Compiling regex-automata v0.4.14 [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 matchers v0.2.0 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling hyper-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 1m 15s [INFO] running `Command { std: "docker" "inspect" "7cb36fd7ae551e9725264b8532ecd854999665b358a92ed352547cec5b29891e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7cb36fd7ae551e9725264b8532ecd854999665b358a92ed352547cec5b29891e", kill_on_drop: false }` [INFO] [stdout] 7cb36fd7ae551e9725264b8532ecd854999665b358a92ed352547cec5b29891e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 224f684d3e7ff17fa703b6b43288160c4722f01272a2b5f9e3627bd62f580c5a [INFO] running `Command { std: "docker" "start" "-a" "224f684d3e7ff17fa703b6b43288160c4722f01272a2b5f9e3627bd62f580c5a", kill_on_drop: false }` [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: 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" test) generated 3 warnings (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] warning: `polybot` (bin "polybot") generated 3 warnings (1 duplicate) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.83s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/polybot-fbe61c118f828147) [INFO] [stdout] [INFO] [stdout] running 219 tests [INFO] [stdout] test intelligence::llm::tests::pull_response_converts ... 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 config::tests::max_active_markets_tiers ... ok [INFO] [stdout] test config::tests::default_risk_limits_match_plan ... 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::effective_caps_unchanged_for_large_accounts ... ok [INFO] [stdout] test config::tests::effective_caps_increase_for_small_accounts ... ok [INFO] [stdout] test intelligence::signal::tests::default_signal_is_neutral ... ok [INFO] [stdout] test config::tests::default_hosts_are_production ... ok [INFO] [stdout] test intelligence::signal::tests::multiplier_clamped_to_unit_range ... ok [INFO] [stdout] test intelligence::signal::tests::expired_signal_reverts_to_full ... ok [INFO] [stdout] test config::tests::nav_limit_zero_fraction ... ok [INFO] [stdout] test config::tests::env_or_returns_default ... ok [INFO] [stdout] test intelligence::llm::tests::valid_response_converts ... 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 intelligence::llm::tests::rejects_oversized_reason_code ... 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::llm::tests::llm_response_serialization_roundtrip ... ok [INFO] [stdout] test intelligence::signal::tests::multiple_receivers_see_same_signal ... ok [INFO] [stdout] test intelligence::signal::tests::bridge_send_receive ... ok [INFO] [stdout] test market::book::tests::empty_sides_no_mid ... ok [INFO] [stdout] test market::book::tests::apply_and_get ... ok [INFO] [stdout] test market::book::tests::mid_price_calculation ... ok [INFO] [stdout] test market::book::tests::multiple_levels ... ok [INFO] [stdout] test market::book::tests::all_mids_across_tokens ... ok [INFO] [stdout] test market::book::tests::hash_returns_stored_value ... ok [INFO] [stdout] test market::book::tests::one_sided_book_no_mid ... ok [INFO] [stdout] test market::book::tests::any_stale_detection ... ok [INFO] [stdout] test market::book::tests::apply_snapshot_populates_book ... ok [INFO] [stdout] test market::book::tests::newer_timestamp_accepted ... ok [INFO] [stdout] test config::tests::from_env_behavior ... ok [INFO] [stdout] test market::book::tests::pause_and_resume ... 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::spread_calculation ... ok [INFO] [stdout] test market::book::tests::update_replaces_previous ... ok [INFO] [stdout] test market::book::tests::stale_detection ... ok [INFO] [stdout] test market::ws::tests::authoritative_batch_count_matches_batch_size ... ok [INFO] [stdout] test market::discovery::tests::parse_volume_handles_nested_markets_shape ... ok [INFO] [stdout] test ops::metrics::tests::cancel_latency_tracking ... ok [INFO] [stdout] test market::ws::tests::prioritized_token_ids_prefers_sports_for_small_accounts ... ok [INFO] [stdout] test ops::metrics::tests::fill_rate_numerator_tracking ... ok [INFO] [stdout] test market::ws::tests::prioritized_token_ids_keeps_reward_priority_for_non_small_accounts ... ok [INFO] [stdout] test market::book::tests::pause_does_not_block_apply ... ok [INFO] [stdout] test market::book::tests::timestamp_regression_rejected ... ok [INFO] [stdout] test ops::metrics::tests::concurrent_increments ... ok [INFO] [stdout] test market::discovery::tests::enrich_volume_empty_input_ok ... ok [INFO] [stdout] test ops::metrics::tests::initial_counters_are_zero ... ok [INFO] [stdout] test ops::metrics::tests::pnl_and_rebate_tracking ... ok [INFO] [stdout] test ops::metrics::tests::reset_daily_clears_counters ... ok [INFO] [stdout] test ops::metrics::tests::reset_daily_clears_new_metrics ... ok [INFO] [stdout] test ops::metrics::tests::throttle_count_tracking ... ok [INFO] [stdout] test ops::metrics::tests::quote_age_tracking ... ok [INFO] [stdout] test ops::metrics::tests::snapshot_serializes_to_json ... ok [INFO] [stdout] test ops::metrics::tests::slippage_total_tracking ... 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::no_book_means_resting ... ok [INFO] [stdout] test ops::paper::tests::net_notional_tracking ... ok [INFO] [stdout] test ops::paper::tests::cancel_all_orders ... ok [INFO] [stdout] test ops::metrics::tests::heartbeat_age_tracking ... ok [INFO] [stdout] test ops::metrics::tests::increment_counters ... ok [INFO] [stdout] test ops::paper::tests::place_crossing_order_fills ... ok [INFO] [stdout] test ops::paper::tests::place_resting_order ... ok [INFO] [stdout] test ops::paper::tests::sequential_ids ... ok [INFO] [stdout] test ops::paper::tests::post_only_prevents_crossing_fill ... ok [INFO] [stdout] test order::heartbeat::tests::fresh_monitor_is_not_stale ... ok [INFO] [stdout] test ops::rewards::tests::tracker_updates ... ok [INFO] [stdout] test order::heartbeat::tests::heartbeat_id_updates ... ok [INFO] [stdout] test ops::paper::tests::sell_crossing_fills ... 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 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_engine_accessor ... ok [INFO] [stdout] test order::router::tests::paper_router_cancel_all ... ok [INFO] [stdout] test order::heartbeat::tests::reset_failures_clears_count ... ok [INFO] [stdout] test order::router::tests::paper_router_places_order ... 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_cancel_specific ... ok [INFO] [stdout] test ops::rewards::tests::tracker_starts_at_zero ... ok [INFO] [stdout] test ops::paper::tests::simulate_resting_fills_when_book_crosses ... ok [INFO] [stdout] test risk::guardrails::tests::inventory_snapshot_empty_initially ... ok [INFO] [stdout] test risk::guardrails::tests::halt_and_check_is_halted ... ok [INFO] [stdout] test risk::guardrails::tests::approved_within_limits ... ok [INFO] [stdout] test risk::guardrails::tests::cancel_failure_reset ... ok [INFO] [stdout] test risk::guardrails::tests::inventory_snapshot_returns_all_tokens ... ok [INFO] [stdout] test risk::guardrails::tests::gross_derisking_order_is_allowed_near_limit ... ok [INFO] [stdout] test risk::guardrails::tests::cancel_failure_at_threshold_halts ... ok [INFO] [stdout] test risk::guardrails::tests::daily_loss_stop ... ok [INFO] [stdout] test risk::guardrails::tests::gross_exposure_limit ... ok [INFO] [stdout] test risk::guardrails::tests::cancel_failure_below_threshold ... 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::daily_pnl_accumulates ... ok [INFO] [stdout] test risk::guardrails::tests::per_market_derisking_sell_is_allowed ... ok [INFO] [stdout] test risk::guardrails::tests::rejected_when_halted ... ok [INFO] [stdout] test risk::guardrails::tests::resume_clears_halt ... ok [INFO] [stdout] test risk::guardrails::tests::one_sided_inventory_short_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::safe_nav_decimal_valid_value ... ok [INFO] [stdout] test risk::guardrails::tests::separate_markets_have_separate_limits ... 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::guardrails::tests::set_daily_pnl_enforces_loss_stop ... ok [INFO] [stdout] test risk::guardrails::tests::pre_computed_limits_match_config ... ok [INFO] [stdout] test risk::guardrails::tests::update_nav_recalculates_limits ... ok [INFO] [stdout] test risk::position::tests::mismatch_partial_overlap ... ok [INFO] [stdout] test risk::position::tests::mismatch_empty_both ... 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::guardrails::tests::rejected_per_market_limit ... ok [INFO] [stdout] test risk::position::tests::snapshot_with_positions ... ok [INFO] [stdout] test risk::position::tests::mismatch_local_only ... ok [INFO] [stdout] test risk::rate_limit::tests::backoff_blocks_acquire ... 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::backoff_jitter_produces_variation ... ok [INFO] [stdout] test risk::rate_limit::tests::exponential_backoff_increases ... ok [INFO] [stdout] test strategy::decay::tests::evaluate_caps_size_to_available_liquidity ... 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_respects_max_bet ... 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 strategy::decay::tests::evaluate_skips_when_available_below_min_order ... ok [INFO] [stdout] test strategy::decay::tests::is_sports_market_detects_various_tags ... ok [INFO] [stdout] test strategy::decay::tests::evaluate_uses_sports_max_bet_for_sports_candidates ... 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_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_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_skips_low_price ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_fallback_rejects_markets_beyond_max_future_horizon ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_fallback_rejects_wide_or_illiquid_book ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_fallback_scores_far_future_markets_lower ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_fallback_selects_more_favored_live_book_side ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_at_90_price_qualifies ... ok [INFO] [stdout] test strategy::decay::tests::scan_accepts_neg_risk ... 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::evaluate_skips_duplicate_market ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_market_outside_sports_window_skipped ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_market_within_sports_window ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_no_end_date_qualifies_via_live_book_fallback ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_requires_higher_min_price ... ok [INFO] [stdout] test strategy::decay::tests::score_opportunity_favors_shorter_resolution ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_outside_window_qualifies_via_live_book_fallback ... ok [INFO] [stdout] test strategy::decay::tests::tracker_cleanup_removes_resolved ... 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::mean_revert::tests::evaluate_entry_generates_sell_when_above_sma ... ok [INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_rejects_not_ready ... ok [INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_rejects_low_volume ... 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::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::position_price_stop_buy ... 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::positions_to_close_time_stop ... ok [INFO] [stdout] test strategy::mean_revert::tests::price_tracker_empty_sma ... ok [INFO] [stdout] test strategy::mean_revert::tests::price_tracker_readiness ... 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::remove_position ... ok [INFO] [stdout] test strategy::reward::tests::expired_unwinds_do_not_mark_hedged_without_fill ... ok [INFO] [stdout] test strategy::rebate_mm::tests::round_to_tick_works ... ok [INFO] [stdout] test strategy::reward::tests::hard_stop_failures_increment_and_state_available ... 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::reward_quote_no_book ... ok [INFO] [stdout] test strategy::reward::tests::reward_quote_no_rewards_active ... ok [INFO] [stdout] test strategy::reward::tests::round_to_tick_works ... ok [INFO] [stdout] test strategy::reward::tests::reward_quote_skips_small_account ... ok [INFO] [stdout] test strategy::reward::tests::tracker_complement_fill_auto_hedges ... 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::decay::tests::evaluate_respects_nav_cap ... ok [INFO] [stdout] test strategy::reward::tests::reward_quote_min_size_enforced ... ok [INFO] [stdout] test config::tests::env_or_returns_env_value ... 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::unhedged_fill_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::reward::tests::tracker_unhedged_conditions_blocks_quoting ... 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::scalper::tests::rejects_thin_touch_notional ... 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::scalper::tests::rejects_high_volatility ... ok [INFO] [stdout] test intelligence::llm::tests::boundary_multiplier_values_accepted ... ok [INFO] [stdout] test market::book::tests::older_snapshot_is_rejected ... ok [INFO] [stdout] test ops::nav::tests::min_nav_change_filters_noise ... ok [INFO] [stdout] test risk::guardrails::tests::one_sided_inventory_sell_reduces ... ok [INFO] [stdout] test risk::guardrails::tests::update_nav_to_small_account_uses_boosted_caps ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_game_too_old_skipped ... 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. 219 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.39s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/polybot-ac1a83822eba2b8c) [INFO] [stdout] [INFO] [stdout] running 227 tests [INFO] [stdout] test config::tests::default_hosts_are_production ... ok [INFO] [stdout] test config::tests::default_risk_limits_match_plan ... ok [INFO] [stdout] test config::tests::effective_caps_unchanged_for_large_accounts ... 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::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 config::tests::from_env_behavior ... ok [INFO] [stdout] test config::tests::effective_caps_increase_for_small_accounts ... ok [INFO] [stdout] test intelligence::llm::tests::pull_response_converts ... ok [INFO] [stdout] test intelligence::llm::tests::llm_response_serialization_roundtrip ... ok [INFO] [stdout] test intelligence::llm::tests::boundary_multiplier_values_accepted ... ok [INFO] [stdout] test intelligence::llm::tests::rejects_empty_reason_code ... 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::valid_response_converts ... ok [INFO] [stdout] test intelligence::signal::tests::pull_signal_zeroes_multiplier ... ok [INFO] [stdout] test intelligence::signal::tests::bridge_send_receive ... ok [INFO] [stdout] test intelligence::signal::tests::signal_none_created_at_is_expired ... ok [INFO] [stdout] test market::book::tests::any_stale_detection ... ok [INFO] [stdout] test market::book::tests::apply_and_get ... 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 market::book::tests::apply_snapshot_populates_book ... ok [INFO] [stdout] test market::book::tests::empty_book_returns_none ... ok [INFO] [stdout] test market::book::tests::empty_sides_no_mid ... ok [INFO] [stdout] test market::book::tests::older_snapshot_is_rejected ... ok [INFO] [stdout] test market::book::tests::mid_price_calculation ... ok [INFO] [stdout] test market::book::tests::newer_timestamp_accepted ... ok [INFO] [stdout] test market::book::tests::one_sided_book_no_mid ... ok [INFO] [stdout] test config::tests::env_or_returns_env_value ... ok [INFO] [stdout] test intelligence::signal::tests::multiple_receivers_see_same_signal ... ok [INFO] [stdout] test market::book::tests::pause_and_resume ... ok [INFO] [stdout] test market::book::tests::retain_removes_stale_assets ... ok [INFO] [stdout] test market::book::tests::all_mids_across_tokens ... ok [INFO] [stdout] test market::book::tests::hash_returns_stored_value ... ok [INFO] [stdout] test market::book::tests::multiple_levels ... ok [INFO] [stdout] test market::book::tests::hash_returns_none_for_missing ... ok [INFO] [stdout] test market::book::tests::pause_does_not_block_apply ... ok [INFO] [stdout] test market::book::tests::same_timestamp_accepted ... 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::timestamp_regression_rejected ... ok [INFO] [stdout] test market::book::tests::stale_detection ... ok [INFO] [stdout] test market::discovery::tests::enrich_volume_empty_input_ok ... ok [INFO] [stdout] test market::discovery::tests::parse_volume_handles_nested_markets_shape ... ok [INFO] [stdout] test intelligence::llm::tests::rejects_zero_ttl ... ok [INFO] [stdout] test market::ws::tests::authoritative_batch_count_matches_batch_size ... ok [INFO] [stdout] test market::ws::tests::prioritized_token_ids_keeps_reward_priority_for_non_small_accounts ... ok [INFO] [stdout] test ops::metrics::tests::fill_rate_numerator_tracking ... ok [INFO] [stdout] test ops::metrics::tests::cancel_latency_tracking ... ok [INFO] [stdout] test ops::metrics::tests::initial_counters_are_zero ... ok [INFO] [stdout] test ops::metrics::tests::reset_daily_clears_new_metrics ... ok [INFO] [stdout] test ops::metrics::tests::throttle_count_tracking ... ok [INFO] [stdout] test ops::metrics::tests::ws_reconnects_and_llm_counters ... ok [INFO] [stdout] test ops::metrics::tests::concurrent_increments ... ok [INFO] [stdout] test market::ws::tests::prioritized_token_ids_prefers_sports_for_small_accounts ... ok [INFO] [stdout] test ops::nav::tests::min_nav_change_filters_noise ... ok [INFO] [stdout] test ops::metrics::tests::pnl_and_rebate_tracking ... ok [INFO] [stdout] test ops::paper::tests::cancel_order ... ok [INFO] [stdout] test ops::paper::tests::cancel_all_orders ... ok [INFO] [stdout] test ops::paper::tests::post_only_prevents_crossing_fill ... ok [INFO] [stdout] test ops::paper::tests::sequential_ids ... ok [INFO] [stdout] test ops::paper::tests::sell_crossing_fills ... ok [INFO] [stdout] test ops::paper::tests::net_notional_tracking ... 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::simulate_resting_fills_when_book_crosses ... ok [INFO] [stdout] test ops::paper::tests::place_crossing_order_fills ... ok [INFO] [stdout] test ops::metrics::tests::heartbeat_age_tracking ... ok [INFO] [stdout] test ops::rewards::tests::tracker_updates ... ok [INFO] [stdout] test ops::metrics::tests::increment_counters ... ok [INFO] [stdout] test order::heartbeat::tests::fresh_monitor_is_not_stale ... ok [INFO] [stdout] test ops::metrics::tests::quote_age_tracking ... ok [INFO] [stdout] test ops::paper::tests::place_resting_order ... ok [INFO] [stdout] test ops::metrics::tests::reset_daily_clears_counters ... ok [INFO] [stdout] test ops::metrics::tests::slippage_total_tracking ... ok [INFO] [stdout] test order::heartbeat::tests::record_failure_increments ... ok [INFO] [stdout] test order::heartbeat::tests::stale_after_three_intervals ... ok [INFO] [stdout] test order::heartbeat::tests::heartbeat_id_updates ... ok [INFO] [stdout] test order::heartbeat::tests::reset_failures_clears_count ... ok [INFO] [stdout] test ops::metrics::tests::snapshot_serializes_to_json ... ok [INFO] [stdout] test order::heartbeat::tests::set_and_get_heartbeat_id ... ok [INFO] [stdout] test order::router::tests::paper_engine_accessor ... ok [INFO] [stdout] test risk::guardrails::tests::cancel_failure_at_threshold_halts ... ok [INFO] [stdout] test risk::guardrails::tests::approved_within_limits ... ok [INFO] [stdout] test order::router::tests::paper_router_cancel_all ... ok [INFO] [stdout] test risk::guardrails::tests::cancel_failure_reset ... ok [INFO] [stdout] test order::router::tests::paper_router_detects_immediate_fill ... 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::halt_and_check_is_halted ... ok [INFO] [stdout] test risk::guardrails::tests::inventory_snapshot_empty_initially ... ok [INFO] [stdout] test risk::guardrails::tests::daily_loss_stop ... ok [INFO] [stdout] test risk::guardrails::tests::gross_derisking_order_is_allowed_near_limit ... ok [INFO] [stdout] test risk::guardrails::tests::daily_pnl_accumulates ... ok [INFO] [stdout] test risk::guardrails::tests::gross_exposure_limit ... ok [INFO] [stdout] test order::heartbeat::tests::not_stale_within_threshold ... ok [INFO] [stdout] test order::heartbeat::tests::record_success_resets_timer ... ok [INFO] [stdout] test risk::guardrails::tests::inventory_snapshot_returns_all_tokens ... 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_sell_reduces ... ok [INFO] [stdout] test risk::guardrails::tests::one_sided_inventory_short_limit ... ok [INFO] [stdout] test risk::guardrails::tests::reset_daily_clears_pnl ... ok [INFO] [stdout] test risk::guardrails::tests::rejected_per_market_limit ... 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 order::router::tests::paper_router_no_fill_for_resting ... ok [INFO] [stdout] test order::router::tests::paper_router_places_order ... ok [INFO] [stdout] test risk::guardrails::tests::rejected_when_halted ... 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::update_nav_to_small_account_uses_boosted_caps ... ok [INFO] [stdout] test risk::guardrails::tests::set_daily_pnl_enforces_loss_stop ... 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::update_nav_recalculates_limits ... ok [INFO] [stdout] test risk::position::tests::mismatch_empty_both ... ok [INFO] [stdout] test risk::guardrails::tests::zero_notional_order_passes ... ok [INFO] [stdout] test risk::position::tests::mismatch_partial_overlap ... ok [INFO] [stdout] test risk::position::tests::mismatch_local_only ... ok [INFO] [stdout] test risk::position::tests::mismatch_remote_only ... ok [INFO] [stdout] test risk::position::tests::mismatch_exact_match ... ok [INFO] [stdout] test risk::rate_limit::tests::exhausts_bucket ... ok [INFO] [stdout] test risk::rate_limit::tests::backoff_jitter_produces_variation ... ok [INFO] [stdout] test risk::rate_limit::tests::burst_capacity_allows_short_bursts ... 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::record_429_sets_backoff ... ok [INFO] [stdout] test strategy::decay::tests::evaluate_respects_max_bet ... ok [INFO] [stdout] test risk::position::tests::snapshot_with_positions ... ok [INFO] [stdout] test risk::position::tests::empty_snapshot ... ok [INFO] [stdout] test strategy::decay::tests::evaluate_respects_nav_cap ... ok [INFO] [stdout] test strategy::decay::tests::candidates_sorted_by_score_descending ... ok [INFO] [stdout] test strategy::decay::tests::evaluate_skips_duplicate_market ... ok [INFO] [stdout] test strategy::decay::tests::scan_accepts_neg_risk ... ok [INFO] [stdout] test strategy::decay::tests::evaluate_uses_sports_max_bet_for_sports_candidates ... ok [INFO] [stdout] test risk::rate_limit::tests::initial_tokens_available ... ok [INFO] [stdout] test strategy::decay::tests::evaluate_skips_when_available_below_min_order ... 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_not_price ... ok [INFO] [stdout] test strategy::decay::tests::evaluate_caps_size_to_available_liquidity ... 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::scan_skips_multi_outcome ... ok [INFO] [stdout] test strategy::decay::tests::scan_non_sports_outside_24h_window_skipped ... 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_fallback_rejects_markets_beyond_max_future_horizon ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_fallback_scores_far_future_markets_lower ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_fallback_rejects_wide_or_illiquid_book ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_fallback_selects_more_favored_live_book_side ... ok [INFO] [stdout] test strategy::decay::tests::scan_non_sports_within_24h_window ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_game_too_old_skipped ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_in_progress_game_found ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_in_progress_2x_bonus_applied ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_market_outside_sports_window_skipped ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_market_within_sports_window ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_no_end_date_qualifies_via_live_book_fallback ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_outside_window_qualifies_via_live_book_fallback ... ok [INFO] [stdout] test strategy::decay::tests::scan_sports_requires_higher_min_price ... ok [INFO] [stdout] test strategy::decay::tests::tracker_cleanup_removes_resolved ... ok [INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_generates_buy_when_below_sma ... ok [INFO] [stdout] test strategy::decay::tests::score_opportunity_favors_shorter_resolution ... ok [INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_empty_tokens ... 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_rejects_not_ready ... ok [INFO] [stdout] test strategy::mean_revert::tests::position_price_stop_buy ... ok [INFO] [stdout] test strategy::mean_revert::tests::evaluate_entry_rejects_small_deviation ... ok [INFO] [stdout] test strategy::mean_revert::tests::position_price_stop_sell ... ok [INFO] [stdout] test strategy::mean_revert::tests::mean_revert_state_record_and_sma ... ok [INFO] [stdout] test strategy::mean_revert::tests::mean_revert_state_retain_tokens ... ok [INFO] [stdout] test strategy::mean_revert::tests::position_time_stop ... ok [INFO] [stdout] test strategy::mean_revert::tests::price_tracker_window_eviction ... ok [INFO] [stdout] test strategy::mean_revert::tests::remove_position ... ok [INFO] [stdout] test strategy::mean_revert::tests::positions_to_close_none_when_fresh ... ok [INFO] [stdout] test strategy::reward::tests::expired_unwinds_do_not_mark_hedged_without_fill ... ok [INFO] [stdout] test strategy::reward::tests::hard_stop_failures_increment_and_state_available ... ok [INFO] [stdout] test strategy::mean_revert::tests::positions_to_close_time_stop ... ok [INFO] [stdout] test strategy::mean_revert::tests::price_tracker_empty_sma ... ok [INFO] [stdout] test strategy::reward::tests::reward_quote_empty_tokens ... ok [INFO] [stdout] test strategy::mean_revert::tests::price_tracker_readiness ... 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::mean_revert::tests::price_tracker_sma ... ok [INFO] [stdout] test strategy::reward::tests::tracker_clear ... ok [INFO] [stdout] test strategy::reward::tests::reward_quote_skips_small_account ... ok [INFO] [stdout] test strategy::reward::tests::tracker_different_conditions_not_matched ... ok [INFO] [stdout] test strategy::reward::tests::round_to_tick_works ... 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::tracker_unhedged_conditions_blocks_quoting ... 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_complement_fill_auto_hedges ... ok [INFO] [stdout] test strategy::reward::tests::unhedged_fill_expired ... ok [INFO] [stdout] test strategy::reward::tests::reward_quote_no_book ... ok [INFO] [stdout] test strategy::rebate_mm::tests::round_to_tick_works ... ok [INFO] [stdout] test strategy::reward::tests::unwind_stage_progression_and_price ... ok [INFO] [stdout] test strategy::scalper::tests::ranking_is_deterministic ... ok [INFO] [stdout] test strategy::reward::tests::unhedged_fill_not_expired ... ok [INFO] [stdout] test strategy::scalper::tests::rejects_high_volatility ... ok [INFO] [stdout] test strategy::scalper::tests::accepts_wide_spread_and_touch ... ok [INFO] [stdout] test strategy::reward::tests::unwind_intent_no_book_returns_none ... ok [INFO] [stdout] test tests::authoritative_restore_requires_complete_snapshot_set ... ok [INFO] [stdout] test tests::authoritative_restore_accepts_matching_existing_hash ... 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 tests::replace_on_one_tick_move ... ok [INFO] [stdout] test tests::replace_on_size_change ... ok [INFO] [stdout] test strategy::reward::tests::unwind_intent_inherits_neg_risk_and_fee ... ok [INFO] [stdout] test strategy::scalper::tests::rejects_thin_touch_notional ... ok [INFO] [stdout] test tests::resync_failure_keeps_books_paused_until_success ... ok [INFO] [stdout] test tests::replace_on_ttl_expiry ... ok [INFO] [stdout] test intelligence::signal::tests::multiplier_clamped_to_unit_range ... ok [INFO] [stdout] test strategy::reward::tests::unwind_intent_sells_at_best_bid ... 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. 227 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.41s [INFO] [stdout] [INFO] [stderr] Running tests/integration.rs (/opt/rustwide/target/debug/deps/integration-190211a8a9a61b07) [INFO] [stdout] [INFO] [stdout] running 23 tests [INFO] [stdout] test book_pause_resume_cycle ... ok [INFO] [stdout] test complement_fills_auto_hedge ... ok [INFO] [stdout] test cancel_failure_threshold_halts_engine ... ok [INFO] [stdout] test expired_fill_generates_unwind ... ok [INFO] [stdout] test inventory_snapshot_for_recon ... ok [INFO] [stdout] test book_timestamp_regression_rejected ... ok [INFO] [stdout] test neg_risk_stale_pair_detection ... ok [INFO] [stdout] test one_sided_inventory_blocks_excessive_exposure ... ok [INFO] [stdout] test inventory_skew_shifts_quotes ... ok [INFO] [stdout] test paper_pipeline_reward_tick ... ok [INFO] [stdout] test paper_pipeline_rebate_mm_tick ... ok [INFO] [stdout] test multi_strategy_coexistence ... ok [INFO] [stdout] test cancel_all_clears_paper_engine ... ok [INFO] [stdout] test decay_buy_paper_cycle ... ok [INFO] [stdout] test fill_detection_through_router ... ok [INFO] [stdout] test paper_fill_returned_atomically ... ok [INFO] [stdout] test mean_revert_full_cycle ... ok [INFO] [stdout] test risk_daily_reset_clears_loss ... ok [INFO] [stdout] test risk_halt_stops_all_orders ... ok [INFO] [stdout] test order_intent_carries_neg_risk_fields ... ok [INFO] [stdout] test decay_excludes_crypto_markets ... ok [INFO] [stdout] test risk_daily_loss_rejects_orders ... ok [INFO] [stdout] test paper_resting_returns_no_fill ... 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" "224f684d3e7ff17fa703b6b43288160c4722f01272a2b5f9e3627bd62f580c5a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "224f684d3e7ff17fa703b6b43288160c4722f01272a2b5f9e3627bd62f580c5a", kill_on_drop: false }` [INFO] [stdout] 224f684d3e7ff17fa703b6b43288160c4722f01272a2b5f9e3627bd62f580c5a