[INFO] cloning repository https://github.com/rafalbujak/spot_grid_bot
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/rafalbujak/spot_grid_bot" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frafalbujak%2Fspot_grid_bot", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frafalbujak%2Fspot_grid_bot'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] ed47406b4fdac61601ad3d59b307bcd145fe6c7b
[INFO] checking rafalbujak/spot_grid_bot against master#779e19d8baa3e3625bd4fc5c85cbb2ad47b43155 for pr-147589-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frafalbujak%2Fspot_grid_bot" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/rafalbujak/spot_grid_bot
[INFO] finished tweaking git repo https://github.com/rafalbujak/spot_grid_bot
[INFO] tweaked toml for git repo https://github.com/rafalbujak/spot_grid_bot written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/rafalbujak/spot_grid_bot on toolchain 779e19d8baa3e3625bd4fc5c85cbb2ad47b43155
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/rafalbujak/spot_grid_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" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded hybrid-array v0.2.3
[INFO] [stderr]   Downloaded const-oid v0.10.0-rc.3
[INFO] [stderr]   Downloaded sha2 v0.11.0-pre.4
[INFO] [stderr]   Downloaded crypto-common v0.2.0-rc.1
[INFO] [stderr]   Downloaded native-tls v0.2.13
[INFO] [stderr]   Downloaded clap v4.5.28
[INFO] [stderr]   Downloaded hmac v0.13.0-pre.4
[INFO] [stderr]   Downloaded openssl-sys v0.9.105
[INFO] [stderr]   Downloaded digest v0.11.0-pre.9
[INFO] [stderr]   Downloaded openssl v0.10.70
[INFO] [stderr]   Downloaded block-buffer v0.11.0-rc.3
[INFO] [stderr]   Downloaded rusqlite v0.27.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 6a2374147840aee2d22f834b73ce4c1042fae8a928fe5bb6b5a1f16a4b39b9a1
[INFO] running `Command { std: "docker" "start" "-a" "6a2374147840aee2d22f834b73ce4c1042fae8a928fe5bb6b5a1f16a4b39b9a1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "6a2374147840aee2d22f834b73ce4c1042fae8a928fe5bb6b5a1f16a4b39b9a1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6a2374147840aee2d22f834b73ce4c1042fae8a928fe5bb6b5a1f16a4b39b9a1", kill_on_drop: false }`
[INFO] [stdout] 6a2374147840aee2d22f834b73ce4c1042fae8a928fe5bb6b5a1f16a4b39b9a1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 3355073122aece6883c3cbb45c2620974834dcb9446af164bd0c48a4ad36ca24
[INFO] running `Command { std: "docker" "start" "-a" "3355073122aece6883c3cbb45c2620974834dcb9446af164bd0c48a4ad36ca24", kill_on_drop: false }`
[INFO] [stderr]     Checking smallvec v1.13.2
[INFO] [stderr]    Compiling cc v1.2.13
[INFO] [stderr]    Compiling syn v2.0.98
[INFO] [stderr]     Checking litemap v0.7.4
[INFO] [stderr]    Compiling typenum v1.17.0
[INFO] [stderr]     Checking icu_locid_transform_data v1.5.0
[INFO] [stderr]     Checking icu_properties_data v1.5.0
[INFO] [stderr]    Compiling openssl v0.10.70
[INFO] [stderr]     Checking http v0.2.12
[INFO] [stderr]     Checking tracing-core v0.1.33
[INFO] [stderr]    Compiling httparse v1.10.0
[INFO] [stderr]    Compiling native-tls v0.2.13
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking bitflags v2.8.0
[INFO] [stderr]     Checking icu_normalizer_data v1.5.0
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking indexmap v2.7.1
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking ahash v0.7.8
[INFO] [stderr]     Checking const-oid v0.10.0-rc.3
[INFO] [stderr]     Checking anstream v0.6.18
[INFO] [stderr]     Checking hashbrown v0.11.2
[INFO] [stderr]     Checking clap_lex v0.7.4
[INFO] [stderr]     Checking fallible-iterator v0.2.0
[INFO] [stderr]     Checking fallible-streaming-iterator v0.1.9
[INFO] [stderr]     Checking http-body v0.4.6
[INFO] [stderr]     Checking clap_builder v4.5.27
[INFO] [stderr]     Checking hashlink v0.7.0
[INFO] [stderr]    Compiling openssl-sys v0.9.105
[INFO] [stderr]    Compiling libsqlite3-sys v0.24.2
[INFO] [stderr]     Checking hybrid-array v0.2.3
[INFO] [stderr]     Checking block-buffer v0.11.0-rc.3
[INFO] [stderr]     Checking crypto-common v0.2.0-rc.1
[INFO] [stderr]     Checking digest v0.11.0-pre.9
[INFO] [stderr]     Checking sha2 v0.11.0-pre.4
[INFO] [stderr]     Checking hmac v0.13.0-pre.4
[INFO] [stderr]    Compiling synstructure v0.13.1
[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 icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling serde_derive v1.0.217
[INFO] [stderr]     Checking tokio v1.43.0
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]    Compiling clap_derive v4.5.28
[INFO] [stderr]     Checking zerofrom v0.1.5
[INFO] [stderr]     Checking yoke v0.7.5
[INFO] [stderr]     Checking zerovec v0.10.4
[INFO] [stderr]     Checking tinystr v0.7.6
[INFO] [stderr]     Checking icu_collections v1.5.0
[INFO] [stderr]     Checking clap v4.5.28
[INFO] [stderr]     Checking icu_locid v1.5.0
[INFO] [stderr]     Checking serde v1.0.217
[INFO] [stderr]     Checking icu_provider v1.5.0
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking icu_locid_transform v1.5.0
[INFO] [stderr]     Checking icu_properties v1.5.1
[INFO] [stderr]     Checking tokio-util v0.7.13
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking h2 v0.3.26
[INFO] [stderr]     Checking rusqlite v0.27.0
[INFO] [stderr]     Checking icu_normalizer v1.5.0
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking serde_json v1.0.138
[INFO] [stderr]     Checking idna_adapter v1.2.0
[INFO] [stderr]     Checking idna v1.0.3
[INFO] [stderr]     Checking url v2.5.4
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking spot_grid_bot_v3 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `sleep`
[INFO] [stdout]  --> src/main.rs:2:19
[INFO] [stdout]   |
[INFO] [stdout] 2 | use tokio::time::{sleep, Duration};
[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: `std::env`
[INFO] [stdout]  --> src/main.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::env;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arg` and `Command`
[INFO] [stdout]  --> src/main.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | use clap::{Command, Arg};
[INFO] [stdout]   |            ^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::future::join_all`
[INFO] [stdout]   --> src/main.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use futures::future::join_all;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `SystemTime` and `UNIX_EPOCH`
[INFO] [stdout]   --> src/main.rs:15:17
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::time::{SystemTime, UNIX_EPOCH};
[INFO] [stdout]    |                 ^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::json`
[INFO] [stdout]   --> src/main.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use serde_json::json;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/main.rs:41:30
[INFO] [stdout]    |
[INFO] [stdout] 41 |         adjusted_quantity *= (1.0 - TRADING_FEE_RATE);
[INFO] [stdout]    |                              ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 41 -         adjusted_quantity *= (1.0 - TRADING_FEE_RATE);
[INFO] [stdout] 41 +         adjusted_quantity *= 1.0 - TRADING_FEE_RATE ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sleep`
[INFO] [stdout]  --> src/main.rs:2:19
[INFO] [stdout]   |
[INFO] [stdout] 2 | use tokio::time::{sleep, Duration};
[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: `std::env`
[INFO] [stdout]  --> src/main.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::env;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arg` and `Command`
[INFO] [stdout]  --> src/main.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | use clap::{Command, Arg};
[INFO] [stdout]   |            ^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::future::join_all`
[INFO] [stdout]   --> src/main.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use futures::future::join_all;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `SystemTime` and `UNIX_EPOCH`
[INFO] [stdout]   --> src/main.rs:15:17
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::time::{SystemTime, UNIX_EPOCH};
[INFO] [stdout]    |                 ^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::json`
[INFO] [stdout]   --> src/main.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use serde_json::json;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/main.rs:41:30
[INFO] [stdout]    |
[INFO] [stdout] 41 |         adjusted_quantity *= (1.0 - TRADING_FEE_RATE);
[INFO] [stdout]    |                              ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 41 -         adjusted_quantity *= (1.0 - TRADING_FEE_RATE);
[INFO] [stdout] 41 +         adjusted_quantity *= 1.0 - TRADING_FEE_RATE ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:785:10
[INFO] [stdout]     |
[INFO] [stdout] 785 |     let (mut capital, min_price, max_price): (f64, f64, f64) = db.query_row(
[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: `db`
[INFO] [stdout]    --> src/main.rs:643:33
[INFO] [stdout]     |
[INFO] [stdout] 643 | async fn get_filled_sell_orders(db: &mut Connection) -> Vec<(String, f64, f64)> {
[INFO] [stdout]     |                                 ^^ help: if this is intentional, prefix it with an underscore: `_db`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_price`
[INFO] [stdout]    --> src/main.rs:785:23
[INFO] [stdout]     |
[INFO] [stdout] 785 |     let (mut capital, min_price, max_price): (f64, f64, f64) = db.query_row(
[INFO] [stdout]     |                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_min_price`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `max_price`
[INFO] [stdout]    --> src/main.rs:785:34
[INFO] [stdout]     |
[INFO] [stdout] 785 |     let (mut capital, min_price, max_price): (f64, f64, f64) = db.query_row(
[INFO] [stdout]     |                                  ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_max_price`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> src/main.rs:820:10
[INFO] [stdout]     |
[INFO] [stdout] 820 |     for (i, &sell_offset) in sell_levels.iter().enumerate() {
[INFO] [stdout]     |          ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `OrderResponse` is never constructed
[INFO] [stdout]    --> src/main.rs:177:8
[INFO] [stdout]     |
[INFO] [stdout] 177 | struct OrderResponse {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_min_notional` is never used
[INFO] [stdout]    --> src/main.rs:187:10
[INFO] [stdout]     |
[INFO] [stdout] 187 | async fn get_min_notional(symbol: &str) -> Result<f64, reqwest::Error> {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `has_open_positions` is never used
[INFO] [stdout]    --> src/main.rs:584:4
[INFO] [stdout]     |
[INFO] [stdout] 584 | fn has_open_positions(db: &Connection, symbol: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_account_balance` is never used
[INFO] [stdout]    --> src/main.rs:594:10
[INFO] [stdout]     |
[INFO] [stdout] 594 | async fn get_account_balance(asset: &str, api_key: &str, secret_key: &str) -> Result<f64, String> {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `orderId` should have a snake case name
[INFO] [stdout]    --> src/main.rs:178:5
[INFO] [stdout]     |
[INFO] [stdout] 178 |     orderId: u64,
[INFO] [stdout]     |     ^^^^^^^ help: convert the identifier to snake case: `order_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: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:785:10
[INFO] [stdout]     |
[INFO] [stdout] 785 |     let (mut capital, min_price, max_price): (f64, f64, f64) = db.query_row(
[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 implementer of `futures::Future` that must be used
[INFO] [stdout]     --> src/main.rs:1009:9
[INFO] [stdout]      |
[INFO] [stdout] 1009 |         monitor_and_reinvest(&mut db);
[INFO] [stdout]      |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout]      = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `db`
[INFO] [stdout]    --> src/main.rs:643:33
[INFO] [stdout]     |
[INFO] [stdout] 643 | async fn get_filled_sell_orders(db: &mut Connection) -> Vec<(String, f64, f64)> {
[INFO] [stdout]     |                                 ^^ help: if this is intentional, prefix it with an underscore: `_db`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_price`
[INFO] [stdout]    --> src/main.rs:785:23
[INFO] [stdout]     |
[INFO] [stdout] 785 |     let (mut capital, min_price, max_price): (f64, f64, f64) = db.query_row(
[INFO] [stdout]     |                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_min_price`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `max_price`
[INFO] [stdout]    --> src/main.rs:785:34
[INFO] [stdout]     |
[INFO] [stdout] 785 |     let (mut capital, min_price, max_price): (f64, f64, f64) = db.query_row(
[INFO] [stdout]     |                                  ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_max_price`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> src/main.rs:820:10
[INFO] [stdout]     |
[INFO] [stdout] 820 |     for (i, &sell_offset) in sell_levels.iter().enumerate() {
[INFO] [stdout]     |          ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `OrderResponse` is never constructed
[INFO] [stdout]    --> src/main.rs:177:8
[INFO] [stdout]     |
[INFO] [stdout] 177 | struct OrderResponse {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_min_notional` is never used
[INFO] [stdout]    --> src/main.rs:187:10
[INFO] [stdout]     |
[INFO] [stdout] 187 | async fn get_min_notional(symbol: &str) -> Result<f64, reqwest::Error> {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `has_open_positions` is never used
[INFO] [stdout]    --> src/main.rs:584:4
[INFO] [stdout]     |
[INFO] [stdout] 584 | fn has_open_positions(db: &Connection, symbol: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_account_balance` is never used
[INFO] [stdout]    --> src/main.rs:594:10
[INFO] [stdout]     |
[INFO] [stdout] 594 | async fn get_account_balance(asset: &str, api_key: &str, secret_key: &str) -> Result<f64, String> {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `orderId` should have a snake case name
[INFO] [stdout]    --> src/main.rs:178:5
[INFO] [stdout]     |
[INFO] [stdout] 178 |     orderId: u64,
[INFO] [stdout]     |     ^^^^^^^ help: convert the identifier to snake case: `order_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: unused implementer of `futures::Future` that must be used
[INFO] [stdout]     --> src/main.rs:1009:9
[INFO] [stdout]      |
[INFO] [stdout] 1009 |         monitor_and_reinvest(&mut db);
[INFO] [stdout]      |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout]      = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 05s
[INFO] running `Command { std: "docker" "inspect" "3355073122aece6883c3cbb45c2620974834dcb9446af164bd0c48a4ad36ca24", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3355073122aece6883c3cbb45c2620974834dcb9446af164bd0c48a4ad36ca24", kill_on_drop: false }`
[INFO] [stdout] 3355073122aece6883c3cbb45c2620974834dcb9446af164bd0c48a4ad36ca24
