[INFO] cloning repository https://github.com/suwandre/tv-trading-bot
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/suwandre/tv-trading-bot" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsuwandre%2Ftv-trading-bot", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsuwandre%2Ftv-trading-bot'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 4cb65b24171da8889db5d875b4bb4ffc58299369
[INFO] building suwandre/tv-trading-bot against try#d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6 for pr-146237-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsuwandre%2Ftv-trading-bot" "/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/suwandre/tv-trading-bot
[INFO] finished tweaking git repo https://github.com/suwandre/tv-trading-bot
[INFO] tweaked toml for git repo https://github.com/suwandre/tv-trading-bot written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/suwandre/tv-trading-bot on toolchain d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/suwandre/tv-trading-bot 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" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2462588bba8b397b7bb31e1330a35ffd644d648cd09dda893c0ec724f3430855
[INFO] running `Command { std: "docker" "start" "-a" "2462588bba8b397b7bb31e1330a35ffd644d648cd09dda893c0ec724f3430855", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2462588bba8b397b7bb31e1330a35ffd644d648cd09dda893c0ec724f3430855", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2462588bba8b397b7bb31e1330a35ffd644d648cd09dda893c0ec724f3430855", kill_on_drop: false }`
[INFO] [stdout] 2462588bba8b397b7bb31e1330a35ffd644d648cd09dda893c0ec724f3430855
[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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 780860b156d957953224dc5b117d130d9fa8dbe500f8d4e3f5e9c9e5151a764c
[INFO] running `Command { std: "docker" "start" "-a" "780860b156d957953224dc5b117d130d9fa8dbe500f8d4e3f5e9c9e5151a764c", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.92
[INFO] [stderr]    Compiling unicode-ident v1.0.14
[INFO] [stderr]    Compiling libc v0.2.168
[INFO] [stderr]    Compiling smallvec v1.13.2
[INFO] [stderr]    Compiling cc v1.2.3
[INFO] [stderr]    Compiling bytes v1.9.0
[INFO] [stderr]    Compiling pin-project-lite v0.2.15
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling serde v1.0.215
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling subtle v2.6.1
[INFO] [stderr]    Compiling tracing-core v0.1.33
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling semver v1.0.23
[INFO] [stderr]    Compiling cpufeatures v0.2.16
[INFO] [stderr]    Compiling openssl v0.10.68
[INFO] [stderr]    Compiling serde_json v1.0.133
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling http v1.2.0
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]    Compiling indexmap v2.7.0
[INFO] [stderr]    Compiling match_cfg v0.1.0
[INFO] [stderr]    Compiling rustversion v1.0.18
[INFO] [stderr]    Compiling quote v1.0.37
[INFO] [stderr]    Compiling rustls v0.21.12
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling signal-hook-registry v1.4.2
[INFO] [stderr]    Compiling mio v1.0.3
[INFO] [stderr]    Compiling parking_lot v0.12.3
[INFO] [stderr]    Compiling syn v2.0.90
[INFO] [stderr]    Compiling socket2 v0.5.8
[INFO] [stderr]    Compiling openssl-sys v0.9.104
[INFO] [stderr]    Compiling ring v0.17.8
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling thiserror v2.0.8
[INFO] [stderr]    Compiling rustc_version_runtime v0.3.0
[INFO] [stderr]    Compiling hostname v0.3.1
[INFO] [stderr]    Compiling time-macros v0.2.19
[INFO] [stderr]    Compiling native-tls v0.2.12
[INFO] [stderr]    Compiling ipnet v2.10.1
[INFO] [stderr]    Compiling linked-hash-map v0.5.6
[INFO] [stderr]    Compiling resolv-conf v0.7.0
[INFO] [stderr]    Compiling lru-cache v0.1.2
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling sync_wrapper v0.1.2
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling sha-1 v0.10.1
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling pbkdf2 v0.11.0
[INFO] [stderr]    Compiling take_mut v0.2.2
[INFO] [stderr]    Compiling webpki-roots v0.25.4
[INFO] [stderr]    Compiling dotenvy v0.15.7
[INFO] [stderr]    Compiling time v0.3.37
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling darling_core v0.20.10
[INFO] [stderr]    Compiling derivative v2.2.0
[INFO] [stderr]    Compiling typed-builder v0.10.0
[INFO] [stderr]    Compiling sct v0.7.1
[INFO] [stderr]    Compiling rustls-webpki v0.101.7
[INFO] [stderr]    Compiling zerofrom-derive v0.1.5
[INFO] [stderr]    Compiling yoke-derive v0.7.5
[INFO] [stderr]    Compiling zerovec-derive v0.10.3
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tokio-macros v2.4.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tokio v1.42.0
[INFO] [stderr]    Compiling serde_derive v1.0.215
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.28
[INFO] [stderr]    Compiling zerofrom v0.1.5
[INFO] [stderr]    Compiling yoke v0.7.5
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling zerovec v0.10.4
[INFO] [stderr]    Compiling async-trait v0.1.83
[INFO] [stderr]    Compiling zerocopy v0.7.35
[INFO] [stderr]    Compiling tinystr v0.7.6
[INFO] [stderr]    Compiling icu_collections v1.5.0
[INFO] [stderr]    Compiling ppv-lite86 v0.2.20
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling icu_locid v1.5.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling darling_macro v0.20.10
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling icu_provider v1.5.0
[INFO] [stderr]    Compiling icu_locid_transform v1.5.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling darling v0.20.10
[INFO] [stderr]    Compiling enum-as-inner v0.6.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.8
[INFO] [stderr]    Compiling http-body-util v0.1.2
[INFO] [stderr]    Compiling icu_properties v1.5.1
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling serde_with_macros v3.11.0
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]    Compiling hyper v1.5.1
[INFO] [stderr]    Compiling serde_bytes v0.11.15
[INFO] [stderr]    Compiling uuid v1.11.0
[INFO] [stderr]    Compiling icu_normalizer v1.5.0
[INFO] [stderr]    Compiling tungstenite v0.26.1
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling bson v2.13.0
[INFO] [stderr]    Compiling idna_adapter v1.2.0
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling tokio-rustls v0.24.1
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling serde_with v3.11.0
[INFO] [stderr]    Compiling serde_path_to_error v0.1.16
[INFO] [stderr]    Compiling chrono v0.4.39
[INFO] [stderr]    Compiling hyper-util v0.1.10
[INFO] [stderr]    Compiling hickory-proto v0.24.2
[INFO] [stderr]    Compiling tokio-util v0.7.13
[INFO] [stderr]    Compiling tower v0.5.1
[INFO] [stderr]    Compiling axum-core v0.4.5
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling mongodb-internal-macros v3.1.0
[INFO] [stderr]    Compiling derive_more v0.99.18
[INFO] [stderr]    Compiling tokio-tungstenite v0.26.1
[INFO] [stderr]    Compiling axum v0.7.9
[INFO] [stderr]    Compiling hickory-resolver v0.24.2
[INFO] [stderr]    Compiling mongodb v3.1.0
[INFO] [stderr]    Compiling tv-trading-bot v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `TradeLeverage` and `TradeSignal`
[INFO] [stdout]  --> src/api/trade.rs:9:317
[INFO] [stdout]   |
[INFO] [stdout] 9 | ...onse, AppState, ClosedTrade, MongoDBState, TradeKind, TradeLeverage, TradeSignal}};
[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: `Receiver`
[INFO] [stdout]  --> src/api/websocket.rs:5:31
[INFO] [stdout]   |
[INFO] [stdout] 5 | use tokio::sync::mpsc::{self, Receiver};
[INFO] [stdout]   |                               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Value`
[INFO] [stdout]  --> src/api/websocket.rs:6:34
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde_json::{from_str, json, Value};
[INFO] [stdout]   |                                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::constants::ACCEPTED_SYMBOLS`
[INFO] [stdout]  --> src/api/websocket.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::constants::ACCEPTED_SYMBOLS;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `WsCommand`
[INFO] [stdout]  --> src/api/websocket.rs:9:66
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::models::{ActiveTrade, AppState, CoinbaseTickerUpdate, WsCommand};
[INFO] [stdout]   |                                                                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mongodb::bson::oid::ObjectId`
[INFO] [stdout]  --> src/api/state.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use mongodb::bson::oid::ObjectId;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ActiveTrade`
[INFO] [stdout]  --> src/api/state.rs:5:21
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::models::{ActiveTrade, AppState, MongoDBState};
[INFO] [stdout]   |                     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `state::*`
[INFO] [stdout]  --> src/api/mod.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use state::*;
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/tests/trade.rs:1:14
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dotenvy::dotenv`
[INFO] [stdout]  --> src/tests/trade.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use dotenvy::dotenv;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Client`, `bson::oid::ObjectId`, and `options::ClientOptions`
[INFO] [stdout]  --> src/tests/trade.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use mongodb::{bson::oid::ObjectId, options::ClientOptions, Client};
[INFO] [stdout]   |               ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ActiveTrade`, `MongoDBState`, `TradeDirection`, `TradeKind`, and `TradeLeverage`
[INFO] [stdout]  --> src/tests/trade.rs:5:21
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::models::{ActiveTrade, MongoDBState, TradeDirection, TradeKind, TradeLeverage};
[INFO] [stdout]   |                     ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `trade::*`
[INFO] [stdout]  --> src/tests/mod.rs:3:9
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub use trade::*;
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout] help: if this is a test module, consider adding a `#[cfg(test)]` to the containing module
[INFO] [stdout]  --> src/server.rs:6:1
[INFO] [stdout]   |
[INFO] [stdout] 6 | mod tests;
[INFO] [stdout]   | ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `websocket`
[INFO] [stdout]  --> src/server.rs:9:33
[INFO] [stdout]   |
[INFO] [stdout] 9 | use api::{start_price_listener, websocket};
[INFO] [stdout]   |                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::mpsc`
[INFO] [stdout]   --> src/server.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use tokio::sync::mpsc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `WsCommand` is never used
[INFO] [stdout]  --> src/models/websocket.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub enum WsCommand {
[INFO] [stdout]   |          ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TradeStatus` is never used
[INFO] [stdout]    --> src/models/trade.rs:144:10
[INFO] [stdout]     |
[INFO] [stdout] 144 | pub enum TradeStatus {
[INFO] [stdout]     |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `mongo_state` is never read
[INFO] [stdout]   --> src/models/state.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct AppState {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout]  9 |     /// The MongoDB data-access object.
[INFO] [stdout] 10 |     pub mongo_state: Arc<MongoDBState>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `fetch_active_trade`, `update_active_trade`, `fetch_closed_trades`, `fetch_closed_trade`, `update_closed_trade`, and `delete_closed_trade` are never used
[INFO] [stdout]    --> src/api/trade.rs:51:18
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl MongoDBState {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  51 |     pub async fn fetch_active_trade(&self, id: ObjectId) -> Result<Option<ActiveTrade>, mongodb::error::Error> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  69 |     pub async fn update_active_trade(&self, id: ObjectId, update: Document) -> Result<UpdateResult, mongodb::error::Error> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  84 |     pub async fn fetch_closed_trades(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 113 |     pub async fn fetch_closed_trade(&self, id: ObjectId) -> Result<Option<ClosedTrade>, mongodb::error::Error> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 118 |     pub async fn update_closed_trade(&self, id: ObjectId, update: Document) -> Result<UpdateResult, mongodb::error::Error> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub async fn delete_closed_trade(&self, id: ObjectId) -> Result<DeleteResult, mongodb::error::Error> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_TAKE_PROFIT_PERCENTAGE` is never used
[INFO] [stdout]   --> src/constants/trade.rs:43:11
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub const DEFAULT_TAKE_PROFIT_PERCENTAGE: f64 = 5.0;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_STOP_LOSS_PERCENTAGE` is never used
[INFO] [stdout]   --> src/constants/trade.rs:48:11
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub const DEFAULT_STOP_LOSS_PERCENTAGE: f64 = 2.0;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/models/websocket.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct CoinbaseTickerUpdate {
[INFO] [stdout]    |            -------------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub sequence: Option<u64>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub open_24h: Option<String>,    // "95393.55"
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 23 |     pub volume_24h: Option<String>,  // "11941.80121342"
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 24 |     pub low_24h: Option<String>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 25 |     pub high_24h: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 26 |     pub volume_30d: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 27 |     pub best_bid: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 28 |     pub best_bid_size: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 29 |     pub best_ask: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 30 |     pub best_ask_size: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 31 |     pub side: Option<String>,        // "buy" or "sell" in coinbase feed
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 32 |     pub time: Option<String>,        // "2024-12-27T10:50:33.372945Z"
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 33 |     pub trade_id: Option<u64>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 34 |     pub last_size: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CoinbaseTickerUpdate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 3m 20s
[INFO] running `Command { std: "docker" "inspect" "780860b156d957953224dc5b117d130d9fa8dbe500f8d4e3f5e9c9e5151a764c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "780860b156d957953224dc5b117d130d9fa8dbe500f8d4e3f5e9c9e5151a764c", kill_on_drop: false }`
[INFO] [stdout] 780860b156d957953224dc5b117d130d9fa8dbe500f8d4e3f5e9c9e5151a764c
[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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 950250d3646a251736e33bcc92ea9b9426ccde4cec6f7ef8c57de7a778484554
[INFO] running `Command { std: "docker" "start" "-a" "950250d3646a251736e33bcc92ea9b9426ccde4cec6f7ef8c57de7a778484554", kill_on_drop: false }`
[INFO] [stderr]    Compiling tv-trading-bot v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `TradeLeverage` and `TradeSignal`
[INFO] [stdout]  --> src/api/trade.rs:9:317
[INFO] [stdout]   |
[INFO] [stdout] 9 | ...onse, AppState, ClosedTrade, MongoDBState, TradeKind, TradeLeverage, TradeSignal}};
[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: `Receiver`
[INFO] [stdout]  --> src/api/websocket.rs:5:31
[INFO] [stdout]   |
[INFO] [stdout] 5 | use tokio::sync::mpsc::{self, Receiver};
[INFO] [stdout]   |                               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Value`
[INFO] [stdout]  --> src/api/websocket.rs:6:34
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde_json::{from_str, json, Value};
[INFO] [stdout]   |                                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::constants::ACCEPTED_SYMBOLS`
[INFO] [stdout]  --> src/api/websocket.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::constants::ACCEPTED_SYMBOLS;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `WsCommand`
[INFO] [stdout]  --> src/api/websocket.rs:9:66
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::models::{ActiveTrade, AppState, CoinbaseTickerUpdate, WsCommand};
[INFO] [stdout]   |                                                                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mongodb::bson::oid::ObjectId`
[INFO] [stdout]  --> src/api/state.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use mongodb::bson::oid::ObjectId;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ActiveTrade`
[INFO] [stdout]  --> src/api/state.rs:5:21
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::models::{ActiveTrade, AppState, MongoDBState};
[INFO] [stdout]   |                     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `state::*`
[INFO] [stdout]  --> src/api/mod.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use state::*;
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DateTime`
[INFO] [stdout]  --> src/tests/trade.rs:1:14
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `trade::*`
[INFO] [stdout]  --> src/tests/mod.rs:3:9
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub use trade::*;
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `websocket`
[INFO] [stdout]  --> src/server.rs:9:33
[INFO] [stdout]   |
[INFO] [stdout] 9 | use api::{start_price_listener, websocket};
[INFO] [stdout]   |                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::mpsc`
[INFO] [stdout]   --> src/server.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use tokio::sync::mpsc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TradeStatus` is never used
[INFO] [stdout]    --> src/models/trade.rs:144:10
[INFO] [stdout]     |
[INFO] [stdout] 144 | pub enum TradeStatus {
[INFO] [stdout]     |          ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `WsCommand` is never used
[INFO] [stdout]  --> src/models/websocket.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub enum WsCommand {
[INFO] [stdout]   |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/models/websocket.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct CoinbaseTickerUpdate {
[INFO] [stdout]    |            -------------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub sequence: Option<u64>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub open_24h: Option<String>,    // "95393.55"
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 23 |     pub volume_24h: Option<String>,  // "11941.80121342"
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 24 |     pub low_24h: Option<String>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 25 |     pub high_24h: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 26 |     pub volume_30d: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 27 |     pub best_bid: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 28 |     pub best_bid_size: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 29 |     pub best_ask: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 30 |     pub best_ask_size: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 31 |     pub side: Option<String>,        // "buy" or "sell" in coinbase feed
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 32 |     pub time: Option<String>,        // "2024-12-27T10:50:33.372945Z"
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 33 |     pub trade_id: Option<u64>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 34 |     pub last_size: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CoinbaseTickerUpdate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `mongo_state` is never read
[INFO] [stdout]   --> src/models/state.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct AppState {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout]  9 |     /// The MongoDB data-access object.
[INFO] [stdout] 10 |     pub mongo_state: Arc<MongoDBState>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `fetch_active_trade`, `update_active_trade`, `fetch_closed_trades`, `fetch_closed_trade`, `update_closed_trade`, and `delete_closed_trade` are never used
[INFO] [stdout]    --> src/api/trade.rs:51:18
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl MongoDBState {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  51 |     pub async fn fetch_active_trade(&self, id: ObjectId) -> Result<Option<ActiveTrade>, mongodb::error::Error> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  69 |     pub async fn update_active_trade(&self, id: ObjectId, update: Document) -> Result<UpdateResult, mongodb::error::Error> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  84 |     pub async fn fetch_closed_trades(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 113 |     pub async fn fetch_closed_trade(&self, id: ObjectId) -> Result<Option<ClosedTrade>, mongodb::error::Error> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 118 |     pub async fn update_closed_trade(&self, id: ObjectId, update: Document) -> Result<UpdateResult, mongodb::error::Error> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub async fn delete_closed_trade(&self, id: ObjectId) -> Result<DeleteResult, mongodb::error::Error> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_TAKE_PROFIT_PERCENTAGE` is never used
[INFO] [stdout]   --> src/constants/trade.rs:43:11
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub const DEFAULT_TAKE_PROFIT_PERCENTAGE: f64 = 5.0;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_STOP_LOSS_PERCENTAGE` is never used
[INFO] [stdout]   --> src/constants/trade.rs:48:11
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub const DEFAULT_STOP_LOSS_PERCENTAGE: f64 = 2.0;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 5.60s
[INFO] running `Command { std: "docker" "inspect" "950250d3646a251736e33bcc92ea9b9426ccde4cec6f7ef8c57de7a778484554", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "950250d3646a251736e33bcc92ea9b9426ccde4cec6f7ef8c57de7a778484554", kill_on_drop: false }`
[INFO] [stdout] 950250d3646a251736e33bcc92ea9b9426ccde4cec6f7ef8c57de7a778484554
