[INFO] cloning repository https://github.com/umangPokhriyall/Web3-Terminal
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/umangPokhriyall/Web3-Terminal" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FumangPokhriyall%2FWeb3-Terminal", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FumangPokhriyall%2FWeb3-Terminal'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 7df040daafb686c47e62759a16859b2a1810e103
[INFO] checking umangPokhriyall/Web3-Terminal against try#446cb600aa4837dd6c513f14fa0d25a909b177d7 for pr-149195
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FumangPokhriyall%2FWeb3-Terminal" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/umangPokhriyall/Web3-Terminal
[INFO] finished tweaking git repo https://github.com/umangPokhriyall/Web3-Terminal
[INFO] tweaked toml for git repo https://github.com/umangPokhriyall/Web3-Terminal written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/umangPokhriyall/Web3-Terminal on toolchain 446cb600aa4837dd6c513f14fa0d25a909b177d7
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+446cb600aa4837dd6c513f14fa0d25a909b177d7" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/umangPokhriyall/Web3-Terminal 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" "+446cb600aa4837dd6c513f14fa0d25a909b177d7" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[ERROR] error running command: no output for 300 seconds
[INFO] checking umangPokhriyall/Web3-Terminal against try#446cb600aa4837dd6c513f14fa0d25a909b177d7 for pr-149195
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FumangPokhriyall%2FWeb3-Terminal" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/umangPokhriyall/Web3-Terminal
[INFO] finished tweaking git repo https://github.com/umangPokhriyall/Web3-Terminal
[INFO] tweaked toml for git repo https://github.com/umangPokhriyall/Web3-Terminal written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/umangPokhriyall/Web3-Terminal on toolchain 446cb600aa4837dd6c513f14fa0d25a909b177d7
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+446cb600aa4837dd6c513f14fa0d25a909b177d7" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/umangPokhriyall/Web3-Terminal 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" "+446cb600aa4837dd6c513f14fa0d25a909b177d7" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded webpki-roots v0.26.11
[INFO] [stderr]   Downloaded compression-core v0.4.30
[INFO] [stderr]   Downloaded tokio-tungstenite v0.21.0
[INFO] [stderr]   Downloaded ordered-float v3.9.2
[INFO] [stderr]   Downloaded halfbrown v0.1.18
[INFO] [stderr]   Downloaded dashmap v5.5.3
[INFO] [stderr]   Downloaded tungstenite v0.21.0
[INFO] [stderr]   Downloaded lexical-write-integer v1.0.6
[INFO] [stderr]   Downloaded cc v1.2.45
[INFO] [stderr]   Downloaded async-compression v0.4.33
[INFO] [stderr]   Downloaded simd-json v0.4.15
[INFO] [stderr]   Downloaded lexical-util v1.0.7
[INFO] [stderr]   Downloaded webpki-roots v1.0.4
[INFO] [stderr]   Downloaded lexical-write-float v1.0.6
[INFO] [stderr]   Downloaded simd-json v0.13.11
[INFO] [stderr]   Downloaded redis v0.24.0
[INFO] [stderr]   Downloaded lexical-parse-float v1.0.6
[INFO] [stderr]   Downloaded halfbrown v0.2.5
[INFO] [stderr]   Downloaded tokio-rustls v0.25.0
[INFO] [stderr]   Downloaded value-trait v0.2.12
[INFO] [stderr]   Downloaded compression-codecs v0.4.32
[INFO] [stderr]   Downloaded lexical-parse-integer v1.0.6
[INFO] [stderr]   Downloaded rustls v0.22.4
[INFO] [stderr]   Downloaded lexical-core v1.0.6
[INFO] [stderr]   Downloaded value-trait v0.8.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:94a0c148923f5b2b52a63ef0eeb1882ad339ab61bce784c8077cbe41c61feb6c" "/opt/rustwide/cargo-home/bin/cargo" "+446cb600aa4837dd6c513f14fa0d25a909b177d7" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] fc9a398e56db7f2cd0f5962ff73f292cc5d889add6b1a76f2456e3df19e4dd3d
[INFO] running `Command { std: "docker" "start" "-a" "fc9a398e56db7f2cd0f5962ff73f292cc5d889add6b1a76f2456e3df19e4dd3d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "fc9a398e56db7f2cd0f5962ff73f292cc5d889add6b1a76f2456e3df19e4dd3d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fc9a398e56db7f2cd0f5962ff73f292cc5d889add6b1a76f2456e3df19e4dd3d", kill_on_drop: false }`
[INFO] [stdout] fc9a398e56db7f2cd0f5962ff73f292cc5d889add6b1a76f2456e3df19e4dd3d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:94a0c148923f5b2b52a63ef0eeb1882ad339ab61bce784c8077cbe41c61feb6c" "/opt/rustwide/cargo-home/bin/cargo" "+446cb600aa4837dd6c513f14fa0d25a909b177d7" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0aadd020f6a9ad1b3e0db04f20c13df4f10ce1c504efe85ed1e47f6de91fad9b
[INFO] running `Command { std: "docker" "start" "-a" "0aadd020f6a9ad1b3e0db04f20c13df4f10ce1c504efe85ed1e47f6de91fad9b", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.103
[INFO] [stderr]    Compiling unicode-ident v1.0.22
[INFO] [stderr]    Compiling quote v1.0.42
[INFO] [stderr]     Checking bytes v1.10.1
[INFO] [stderr]    Compiling find-msvc-tools v0.1.4
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]     Checking signal-hook-registry v1.4.6
[INFO] [stderr]     Checking mio v1.1.0
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking rustls-pki-types v1.13.0
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]     Checking memchr v2.7.6
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]     Checking allocator-api2 v0.2.21
[INFO] [stderr]    Compiling generic-array v0.14.9
[INFO] [stderr]     Checking hashbrown v0.16.0
[INFO] [stderr]    Compiling cc v1.2.45
[INFO] [stderr]     Checking subtle v2.6.1
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking lexical-util v1.0.7
[INFO] [stderr]    Compiling anyhow v1.0.100
[INFO] [stderr]     Checking bitflags v2.10.0
[INFO] [stderr]     Checking socket2 v0.4.10
[INFO] [stderr]     Checking http v1.3.1
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]     Checking sha1_smol v1.0.1
[INFO] [stderr]    Compiling rustls v0.23.35
[INFO] [stderr]    Compiling rustls v0.22.4
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]     Checking simd-adler32 v0.3.7
[INFO] [stderr]     Checking crc32fast v1.5.0
[INFO] [stderr]     Checking webpki-roots v1.0.4
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking compression-core v0.4.30
[INFO] [stderr]    Compiling ref-cast v1.0.25
[INFO] [stderr]     Checking webpki-roots v0.26.11
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking unsafe-libyaml v0.2.11
[INFO] [stderr]     Checking simdutf8 v0.1.5
[INFO] [stderr]     Checking serde_json v1.0.145
[INFO] [stderr]     Checking num_cpus v1.17.0
[INFO] [stderr]     Checking indexmap v2.12.0
[INFO] [stderr]     Checking rand_core v0.9.3
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]     Checking flate2 v1.1.5
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling syn v2.0.109
[INFO] [stderr]     Checking lexical-parse-integer v1.0.6
[INFO] [stderr]     Checking lexical-write-integer v1.0.6
[INFO] [stderr]     Checking lexical-parse-float v1.0.6
[INFO] [stderr]     Checking crypto-common v0.1.6
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]     Checking float-cmp v0.9.0
[INFO] [stderr]     Checking ordered-float v3.9.2
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking compression-codecs v0.4.32
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]     Checking lexical-write-float v1.0.6
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking lexical-core v1.0.6
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand_chacha v0.9.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking rand v0.9.2
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking dashmap v5.5.3
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]     Checking rustls-webpki v0.102.8
[INFO] [stderr]     Checking rustls-webpki v0.103.8
[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 serde_derive v1.0.228
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling ref-cast-impl v1.0.25
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]     Checking tokio v1.48.0
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking yoke v0.8.1
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking zerovec v0.11.5
[INFO] [stderr]     Checking zerotrie v0.2.3
[INFO] [stderr]     Checking tinystr v0.8.2
[INFO] [stderr]     Checking potential_utf v0.1.4
[INFO] [stderr]     Checking icu_collections v2.1.1
[INFO] [stderr]     Checking icu_locale_core v2.1.1
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking icu_properties v2.1.1
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking halfbrown v0.2.5
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking serde_yaml v0.9.34+deprecated
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking value-trait v0.8.1
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking url v2.5.7
[INFO] [stderr]     Checking simd-json v0.13.11
[INFO] [stderr]     Checking tungstenite v0.21.0
[INFO] [stderr]     Checking tokio-util v0.7.17
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking tokio-rustls v0.26.4
[INFO] [stderr]     Checking tokio-rustls v0.25.0
[INFO] [stderr]     Checking async-compression v0.4.33
[INFO] [stderr]     Checking tokio-tungstenite v0.21.0
[INFO] [stderr]     Checking tower-http v0.6.6
[INFO] [stderr]     Checking h2 v0.4.12
[INFO] [stderr]     Checking combine v4.6.7
[INFO] [stderr]     Checking hyper v1.7.0
[INFO] [stderr]     Checking hyper-util v0.1.17
[INFO] [stderr]     Checking redis v0.24.0
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking hyper-rustls v0.27.7
[INFO] [stderr]     Checking reqwest v0.12.24
[INFO] [stderr]     Checking arbitrage v0.1.0 (/opt/rustwide/workdir/arbitrage)
[INFO] [stderr]     Checking collector v0.1.0 (/opt/rustwide/workdir/collector)
[INFO] [stderr]     Checking arb_v1 v0.1.0 (/opt/rustwide/workdir/arb_v1)
[INFO] [stdout] warning: unused import: `Instant`
[INFO] [stdout]   --> arbitrage/src/main.rs:12:22
[INFO] [stdout]    |
[INFO] [stdout] 12 |     time::{Duration, Instant, SystemTime, UNIX_EPOCH},
[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: `AsyncCommands`
[INFO] [stdout]  --> arbitrage/src/main.rs:7:13
[INFO] [stdout]   |
[INFO] [stdout] 7 | use redis::{AsyncCommands, FromRedisValue, RedisResult};
[INFO] [stdout]   |             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Instant`
[INFO] [stdout]   --> arbitrage/src/main.rs:12:22
[INFO] [stdout]    |
[INFO] [stdout] 12 |     time::{Duration, Instant, SystemTime, UNIX_EPOCH},
[INFO] [stdout]    |                      ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `maker` is never read
[INFO] [stdout]   --> arb_v1/src/main.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 40 | struct Fee {
[INFO] [stdout]    |        --- field in this struct
[INFO] [stdout] 41 |     maker: f64,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Fee` has a derived impl for the trait `Clone`, but this is 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: unused variable: `volume`
[INFO] [stdout]    --> arbitrage/src/main.rs:321:13
[INFO] [stdout]     |
[INFO] [stdout] 321 |         let volume = buy_qty.min(sell_qty);
[INFO] [stdout]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_volume`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `now_ms` is never used
[INFO] [stdout]   --> arbitrage/src/main.rs:98:4
[INFO] [stdout]    |
[INFO] [stdout] 98 | fn now_ms() -> u64 {
[INFO] [stdout]    |    ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `maker` is never read
[INFO] [stdout]   --> arb_v1/src/main.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 40 | struct Fee {
[INFO] [stdout]    |        --- field in this struct
[INFO] [stdout] 41 |     maker: f64,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Fee` has a derived impl for the trait `Clone`, but this is 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: unused import: `SinkExt`
[INFO] [stdout]  --> collector/src/exchanges/binance.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use futures_util::{SinkExt, StreamExt};
[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: `sync::Mutex`
[INFO] [stdout]   --> collector/src/exchanges/binance.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     sync::Mutex,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tungstenite::Message`
[INFO] [stdout]   --> collector/src/exchanges/binance.rs:15:40
[INFO] [stdout]    |
[INFO] [stdout] 15 | use tokio_tungstenite::{connect_async, tungstenite::Message};
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> collector/src/exchanges/binance.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ExchangeHealth`
[INFO] [stdout]  --> collector/src/exchanges/binance2.rs:2:21
[INFO] [stdout]   |
[INFO] [stdout] 2 |     ExchangeClient, ExchangeHealth, NormalizedData, OrderBookSnapshot, OrderBookTop, TradeEvent,
[INFO] [stdout]   |                     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration` and `sleep`
[INFO] [stdout]   --> collector/src/exchanges/binance2.rs:10:19
[INFO] [stdout]    |
[INFO] [stdout] 10 | use tokio::time::{Duration, sleep};
[INFO] [stdout]    |                   ^^^^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SinkExt`
[INFO] [stdout]  --> collector/src/exchanges/binance.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use futures_util::{SinkExt, StreamExt};
[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: `sync::Mutex`
[INFO] [stdout]   --> collector/src/exchanges/binance.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     sync::Mutex,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tungstenite::Message`
[INFO] [stdout]   --> collector/src/exchanges/binance.rs:15:40
[INFO] [stdout]    |
[INFO] [stdout] 15 | use tokio_tungstenite::{connect_async, tungstenite::Message};
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> collector/src/exchanges/binance.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ExchangeHealth`
[INFO] [stdout]  --> collector/src/exchanges/binance2.rs:2:21
[INFO] [stdout]   |
[INFO] [stdout] 2 |     ExchangeClient, ExchangeHealth, NormalizedData, OrderBookSnapshot, OrderBookTop, TradeEvent,
[INFO] [stdout]   |                     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration` and `sleep`
[INFO] [stdout]   --> collector/src/exchanges/binance2.rs:10:19
[INFO] [stdout]    |
[INFO] [stdout] 10 | use tokio::time::{Duration, sleep};
[INFO] [stdout]    |                   ^^^^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AsyncCommands`
[INFO] [stdout]  --> arbitrage/src/main.rs:7:13
[INFO] [stdout]   |
[INFO] [stdout] 7 | use redis::{AsyncCommands, FromRedisValue, RedisResult};
[INFO] [stdout]   |             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> collector/src/exchanges/hyperliquid.rs:86:14
[INFO] [stdout]    |
[INFO] [stdout] 86 |         let (mut write, mut read) = ws.split();
[INFO] [stdout]    |              ----^^^^^
[INFO] [stdout]    |              |
[INFO] [stdout]    |              help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> collector/src/exchanges/hyperliquid.rs:86:14
[INFO] [stdout]    |
[INFO] [stdout] 86 |         let (mut write, mut read) = ws.split();
[INFO] [stdout]    |              ----^^^^^
[INFO] [stdout]    |              |
[INFO] [stdout]    |              help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `volume`
[INFO] [stdout]    --> arbitrage/src/main.rs:321:13
[INFO] [stdout]     |
[INFO] [stdout] 321 |         let volume = buy_qty.min(sell_qty);
[INFO] [stdout]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_volume`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `now_ms` is never used
[INFO] [stdout]   --> arbitrage/src/main.rs:98:4
[INFO] [stdout]    |
[INFO] [stdout] 98 | fn now_ms() -> u64 {
[INFO] [stdout]    |    ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `redis::AsyncCommands`
[INFO] [stdout]  --> collector/src/exchanges/binance.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use redis::AsyncCommands;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `redis::AsyncCommands`
[INFO] [stdout]  --> collector/src/exchanges/bybit.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use redis::AsyncCommands;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `redis::AsyncCommands`
[INFO] [stdout]   --> collector/src/exchanges/hyperliquid.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use redis::AsyncCommands;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `redis::AsyncCommands`
[INFO] [stdout]   --> collector/src/exchanges/kraken.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use redis::AsyncCommands;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `redis::AsyncCommands`
[INFO] [stdout]  --> collector/src/exchanges/binance.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use redis::AsyncCommands;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `redis::AsyncCommands`
[INFO] [stdout]  --> collector/src/exchanges/bybit.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use redis::AsyncCommands;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `redis::AsyncCommands`
[INFO] [stdout]   --> collector/src/exchanges/hyperliquid.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use redis::AsyncCommands;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `redis::AsyncCommands`
[INFO] [stdout]   --> collector/src/exchanges/kraken.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use redis::AsyncCommands;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> collector/src/exchanges/binance.rs:63:13
[INFO] [stdout]    |
[INFO] [stdout] 63 |         let mut topics: Vec<String> = self
[INFO] [stdout]    |             ----^^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> collector/src/exchanges/binance.rs:102:13
[INFO] [stdout]     |
[INFO] [stdout] 102 |         let mut topics: Vec<String> = self
[INFO] [stdout]     |             ----^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> collector/src/exchanges/binance.rs:140:13
[INFO] [stdout]     |
[INFO] [stdout] 140 |         let mut topics: Vec<String> = self
[INFO] [stdout]     |             ----^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> collector/src/exchanges/binance.rs:63:13
[INFO] [stdout]    |
[INFO] [stdout] 63 |         let mut topics: Vec<String> = self
[INFO] [stdout]    |             ----^^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> collector/src/exchanges/binance.rs:102:13
[INFO] [stdout]     |
[INFO] [stdout] 102 |         let mut topics: Vec<String> = self
[INFO] [stdout]     |             ----^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> collector/src/exchanges/binance.rs:140:13
[INFO] [stdout]     |
[INFO] [stdout] 140 |         let mut topics: Vec<String> = self
[INFO] [stdout]     |             ----^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ExchangeHealth` is never constructed
[INFO] [stdout]   --> collector/src/exchange.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub struct ExchangeHealth {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `OrderBookSnapshot` is never constructed
[INFO] [stdout]   --> collector/src/exchange.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct OrderBookSnapshot {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `name` and `get_snapshot` are never used
[INFO] [stdout]   --> collector/src/exchange.rs:54:8
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub trait ExchangeClient: Send + Sync {
[INFO] [stdout]    |           -------------- methods in this trait
[INFO] [stdout] 54 |     fn name(&self) -> &'static str;
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60 |     async fn get_snapshot(&self, symbol: &str) -> Result<OrderBookSnapshot>;
[INFO] [stdout]    |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `stream` is never read
[INFO] [stdout]   --> collector/src/exchanges/binance2.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 35 | struct Binance2StreamWrapper {
[INFO] [stdout]    |        --------------------- field in this struct
[INFO] [stdout] 36 |     stream: String,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Binance2StreamWrapper` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CoinbaseCollector` is never constructed
[INFO] [stdout]   --> collector/src/exchanges/coinbase.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct CoinbaseCollector {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `current_millis` is never used
[INFO] [stdout]    --> collector/src/exchanges/coinbase.rs:450:4
[INFO] [stdout]     |
[INFO] [stdout] 450 | fn current_millis() -> u64 {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `lastUpdateId` should have a snake case name
[INFO] [stdout]   --> collector/src/exchange.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 47 |     pub lastUpdateId: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^ help: convert the identifier to snake case: `last_update_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `E` should have a snake case name
[INFO] [stdout]   --> collector/src/exchanges/binance2.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 |     pub E: u64,
[INFO] [stdout]    |         ^ help: convert the identifier to snake case: `e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ExchangeHealth` is never constructed
[INFO] [stdout]   --> collector/src/exchange.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub struct ExchangeHealth {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `OrderBookSnapshot` is never constructed
[INFO] [stdout]   --> collector/src/exchange.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct OrderBookSnapshot {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `name` and `get_snapshot` are never used
[INFO] [stdout]   --> collector/src/exchange.rs:54:8
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub trait ExchangeClient: Send + Sync {
[INFO] [stdout]    |           -------------- methods in this trait
[INFO] [stdout] 54 |     fn name(&self) -> &'static str;
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60 |     async fn get_snapshot(&self, symbol: &str) -> Result<OrderBookSnapshot>;
[INFO] [stdout]    |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `stream` is never read
[INFO] [stdout]   --> collector/src/exchanges/binance2.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 35 | struct Binance2StreamWrapper {
[INFO] [stdout]    |        --------------------- field in this struct
[INFO] [stdout] 36 |     stream: String,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Binance2StreamWrapper` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CoinbaseCollector` is never constructed
[INFO] [stdout]   --> collector/src/exchanges/coinbase.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct CoinbaseCollector {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `current_millis` is never used
[INFO] [stdout]    --> collector/src/exchanges/coinbase.rs:450:4
[INFO] [stdout]     |
[INFO] [stdout] 450 | fn current_millis() -> u64 {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `lastUpdateId` should have a snake case name
[INFO] [stdout]   --> collector/src/exchange.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 47 |     pub lastUpdateId: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^ help: convert the identifier to snake case: `last_update_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `E` should have a snake case name
[INFO] [stdout]   --> collector/src/exchanges/binance2.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 |     pub E: u64,
[INFO] [stdout]    |         ^ help: convert the identifier to snake case: `e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 49.79s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: redis v0.24.0
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] running `Command { std: "docker" "inspect" "0aadd020f6a9ad1b3e0db04f20c13df4f10ce1c504efe85ed1e47f6de91fad9b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0aadd020f6a9ad1b3e0db04f20c13df4f10ce1c504efe85ed1e47f6de91fad9b", kill_on_drop: false }`
[INFO] [stdout] 0aadd020f6a9ad1b3e0db04f20c13df4f10ce1c504efe85ed1e47f6de91fad9b
