[INFO] cloning repository https://github.com/HaroldRobson/MEV_JUNE
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/HaroldRobson/MEV_JUNE" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FHaroldRobson%2FMEV_JUNE", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FHaroldRobson%2FMEV_JUNE'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] fdd539c4462ce7b08ee5ea1fb863be517826a628
[INFO] checking HaroldRobson/MEV_JUNE against master#42f4793e5a514858221b07ac379029d90353913e for pr-148952
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FHaroldRobson%2FMEV_JUNE" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] [stderr] Updating files:  60% (1526/2502)
Updating files:  61% (1527/2502)
Updating files:  62% (1552/2502)
Updating files:  63% (1577/2502)
Updating files:  64% (1602/2502)
Updating files:  65% (1627/2502)
Updating files:  66% (1652/2502)
Updating files:  67% (1677/2502)
Updating files:  68% (1702/2502)
Updating files:  69% (1727/2502)
Updating files:  70% (1752/2502)
Updating files:  71% (1777/2502)
Updating files:  72% (1802/2502)
Updating files:  73% (1827/2502)
Updating files:  74% (1852/2502)
Updating files:  75% (1877/2502)
Updating files:  76% (1902/2502)
Updating files:  77% (1927/2502)
Updating files:  78% (1952/2502)
Updating files:  79% (1977/2502)
Updating files:  80% (2002/2502)
Updating files:  81% (2027/2502)
Updating files:  82% (2052/2502)
Updating files:  83% (2077/2502)
Updating files:  84% (2102/2502)
Updating files:  85% (2127/2502)
Updating files:  86% (2152/2502)
Updating files:  87% (2177/2502)
Updating files:  88% (2202/2502)
Updating files:  89% (2227/2502)
Updating files:  90% (2252/2502)
Updating files:  91% (2277/2502)
Updating files:  92% (2302/2502)
Updating files:  93% (2327/2502)
Updating files:  94% (2352/2502)
Updating files:  95% (2377/2502)
Updating files:  96% (2402/2502)
Updating files:  97% (2427/2502)
Updating files:  98% (2452/2502)
Updating files:  99% (2477/2502)
Updating files: 100% (2502/2502)
Updating files: 100% (2502/2502), done.
[INFO] started tweaking git repo https://github.com/HaroldRobson/MEV_JUNE
[INFO] finished tweaking git repo https://github.com/HaroldRobson/MEV_JUNE
[INFO] tweaked toml for git repo https://github.com/HaroldRobson/MEV_JUNE written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/HaroldRobson/MEV_JUNE on toolchain 42f4793e5a514858221b07ac379029d90353913e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+42f4793e5a514858221b07ac379029d90353913e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/HaroldRobson/MEV_JUNE 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" "+42f4793e5a514858221b07ac379029d90353913e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded message v0.1.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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+42f4793e5a514858221b07ac379029d90353913e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 140fb82c4a999c6c0454b038d67750c651faf6a7c03b1dad390a8664b23e1c56
[INFO] running `Command { std: "docker" "start" "-a" "140fb82c4a999c6c0454b038d67750c651faf6a7c03b1dad390a8664b23e1c56", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "140fb82c4a999c6c0454b038d67750c651faf6a7c03b1dad390a8664b23e1c56", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "140fb82c4a999c6c0454b038d67750c651faf6a7c03b1dad390a8664b23e1c56", kill_on_drop: false }`
[INFO] [stdout] 140fb82c4a999c6c0454b038d67750c651faf6a7c03b1dad390a8664b23e1c56
[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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+42f4793e5a514858221b07ac379029d90353913e" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 03d47dde593eff13934bfddec0224776cec96834a4aaa8ce1211bfa9481b9772
[INFO] running `Command { std: "docker" "start" "-a" "03d47dde593eff13934bfddec0224776cec96834a4aaa8ce1211bfa9481b9772", kill_on_drop: false }`
[INFO] [stderr]    Compiling cc v1.2.25
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking smallvec v1.15.0
[INFO] [stderr]    Compiling syn v2.0.101
[INFO] [stderr]     Checking mio v1.0.4
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]     Checking simdutf8 v0.1.5
[INFO] [stderr]     Checking fastrand v2.3.0
[INFO] [stderr]     Checking message v0.1.0
[INFO] [stderr]     Checking json v0.12.4
[INFO] [stderr]     Checking parking_lot_core v0.9.11
[INFO] [stderr]     Checking parking_lot v0.12.4
[INFO] [stderr]     Checking ordered-float v2.10.1
[INFO] [stderr]     Checking chrono v0.4.41
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]     Checking tokio v1.45.1
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking serde v1.0.219
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking tokio-util v0.7.15
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking tokio-websockets v0.11.4
[INFO] [stderr]     Checking serde_json v1.0.140
[INFO] [stderr]     Checking serde-value v0.7.0
[INFO] [stderr]     Checking serde-aux v4.7.0
[INFO] [stderr]     Checking lesson5 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `tokio::*`
[INFO] [stdout]  --> src/main.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tokio::*;
[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: `Error`
[INFO] [stdout]  --> src/main.rs:7:39
[INFO] [stdout]   |
[INFO] [stdout] 7 | use tokio_websockets::{ClientBuilder, Error, Message};
[INFO] [stdout]   |                                       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_aux::prelude::*`
[INFO] [stdout]  --> src/market_data.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_aux::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::string`
[INFO] [stdout]  --> src/market_data.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::string;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AskMarketQuote`, `BidMarketQuote`, `CoinBaseBookTicker`, and `ExchangeName`
[INFO] [stdout]   --> src/main.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     AskMarketQuote, BidMarketQuote, CoinBaseBookTicker, CoinBaseMessage, ExchangeName,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^                   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::Utc`
[INFO] [stdout]  --> src/ATOMIC_SP_MATRIX.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use chrono::Utc;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Deserialize`, `Deserializer`, and `Serialize`
[INFO] [stdout]  --> src/ATOMIC_SP_MATRIX.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]   |             ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_aux::prelude::*`
[INFO] [stdout]  --> src/ATOMIC_SP_MATRIX.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_aux::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/ATOMIC_SP_MATRIX.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::mpsc`
[INFO] [stdout]   --> src/main.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use tokio::sync::mpsc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::*`
[INFO] [stdout]  --> src/main.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tokio::*;
[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: `Error`
[INFO] [stdout]  --> src/main.rs:7:39
[INFO] [stdout]   |
[INFO] [stdout] 7 | use tokio_websockets::{ClientBuilder, Error, Message};
[INFO] [stdout]   |                                       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_aux::prelude::*`
[INFO] [stdout]  --> src/market_data.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_aux::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::string`
[INFO] [stdout]  --> src/market_data.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::string;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AskMarketQuote`, `BidMarketQuote`, `CoinBaseBookTicker`, and `ExchangeName`
[INFO] [stdout]   --> src/main.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     AskMarketQuote, BidMarketQuote, CoinBaseBookTicker, CoinBaseMessage, ExchangeName,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^                   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::Utc`
[INFO] [stdout]  --> src/ATOMIC_SP_MATRIX.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use chrono::Utc;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Deserialize`, `Deserializer`, and `Serialize`
[INFO] [stdout]  --> src/ATOMIC_SP_MATRIX.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]   |             ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_aux::prelude::*`
[INFO] [stdout]  --> src/ATOMIC_SP_MATRIX.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_aux::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/ATOMIC_SP_MATRIX.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::mpsc`
[INFO] [stdout]   --> src/main.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use tokio::sync::mpsc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:116:13
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let mut handle = tokio::spawn(async move {
[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: `response`
[INFO] [stdout]   --> src/main.rs:38:33
[INFO] [stdout]    |
[INFO] [stdout] 38 |             let (mut ws_stream, response) = match ClientBuilder::from_uri(uri).connect().await {
[INFO] [stdout]    |                                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_response`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `response`
[INFO] [stdout]    --> src/main.rs:118:33
[INFO] [stdout]     |
[INFO] [stdout] 118 |             let (mut ws_stream, response) = match ClientBuilder::from_uri(uri).connect().await {
[INFO] [stdout]     |                                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_response`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `arb_opp_finder`
[INFO] [stdout]    --> src/main.rs:195:9
[INFO] [stdout]     |
[INFO] [stdout] 195 |     let arb_opp_finder = tokio::spawn(async move {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arb_opp_finder`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `quantity` and `timestamp_ms` are never read
[INFO] [stdout]   --> src/market_data.rs:72:9
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub struct AskMarketQuote {
[INFO] [stdout]    |            -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 72 |     pub quantity: f64,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 73 |     pub timestamp_ms: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AskMarketQuote` 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: fields `quantity` and `timestamp_ms` are never read
[INFO] [stdout]   --> src/market_data.rs:81:9
[INFO] [stdout]    |
[INFO] [stdout] 77 | pub struct BidMarketQuote {
[INFO] [stdout]    |            -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 81 |     pub quantity: f64,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 82 |     pub timestamp_ms: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BidMarketQuote` 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: module `ATOMIC_SP_MATRIX` should have a snake case name
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | mod ATOMIC_SP_MATRIX;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `atomic_sp_matrix`
[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 `Result` that must be used
[INFO] [stdout]   --> src/main.rs:56:13
[INFO] [stdout]    |
[INFO] [stdout] 56 | /             ws_stream
[INFO] [stdout] 57 | |                 .send(Message::text(subscribe_msg.to_string()))
[INFO] [stdout] 58 | |                 .await;
[INFO] [stdout]    | |______________________^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 56 |             let _ = ws_stream
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `CBstreams` should have a snake case name
[INFO] [stdout]    --> src/main.rs:110:9
[INFO] [stdout]     |
[INFO] [stdout] 110 |     let CBstreams = vec![("", "wss://advanced-trade-ws.coinbase.com")];
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `cbstreams`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/main.rs:131:13
[INFO] [stdout]     |
[INFO] [stdout] 131 | /             ws_stream
[INFO] [stdout] 132 | |                 .send(Message::text(subscribe_msg.to_string()))
[INFO] [stdout] 133 | |                 .await;
[INFO] [stdout]     | |______________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 131 |             let _ = ws_stream
[INFO] [stdout]     |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `asToken` should have a snake case name
[INFO] [stdout]   --> src/market_data.rs:48:8
[INFO] [stdout]    |
[INFO] [stdout] 48 |     fn asToken(symbol: String) -> Token {
[INFO] [stdout]    |        ^^^^^^^ help: convert the identifier to snake case: `as_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `getAskMarketQuotes` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout] 111 |     pub fn getAskMarketQuotes(&self) -> Vec<AskMarketQuote> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_ask_market_quotes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `AskMarketQuoteVec` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:112:17
[INFO] [stdout]     |
[INFO] [stdout] 112 |         let mut AskMarketQuoteVec: Vec<AskMarketQuote> = Vec::new();
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `askMarketQuote` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:116:13
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let askMarketQuote = AskMarketQuote {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `getBidMarketQuotes` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:129:12
[INFO] [stdout]     |
[INFO] [stdout] 129 |     pub fn getBidMarketQuotes(&self) -> Vec<BidMarketQuote> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_bid_market_quotes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `bidMarketQuoteVec` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:130:17
[INFO] [stdout]     |
[INFO] [stdout] 130 |         let mut bidMarketQuoteVec: Vec<BidMarketQuote> = Vec::new();
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `bidMarketQuote` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:134:13
[INFO] [stdout]     |
[INFO] [stdout] 134 |         let bidMarketQuote = BidMarketQuote {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `getBidMarketQuotes` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:181:12
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub fn getBidMarketQuotes(&self) -> BidMarketQuote {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_bid_market_quotes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `bidMarketQuote` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:184:13
[INFO] [stdout]     |
[INFO] [stdout] 184 |         let bidMarketQuote = BidMarketQuote {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `getAskMarketQuotes` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:195:12
[INFO] [stdout]     |
[INFO] [stdout] 195 |     pub fn getAskMarketQuotes(&self) -> AskMarketQuote {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_ask_market_quotes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `askMarketQuote` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:198:13
[INFO] [stdout]     |
[INFO] [stdout] 198 |         let askMarketQuote = AskMarketQuote {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:116:13
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let mut handle = tokio::spawn(async move {
[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: `response`
[INFO] [stdout]   --> src/main.rs:38:33
[INFO] [stdout]    |
[INFO] [stdout] 38 |             let (mut ws_stream, response) = match ClientBuilder::from_uri(uri).connect().await {
[INFO] [stdout]    |                                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_response`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `response`
[INFO] [stdout]    --> src/main.rs:118:33
[INFO] [stdout]     |
[INFO] [stdout] 118 |             let (mut ws_stream, response) = match ClientBuilder::from_uri(uri).connect().await {
[INFO] [stdout]     |                                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_response`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `arb_opp_finder`
[INFO] [stdout]    --> src/main.rs:195:9
[INFO] [stdout]     |
[INFO] [stdout] 195 |     let arb_opp_finder = tokio::spawn(async move {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arb_opp_finder`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `quantity` and `timestamp_ms` are never read
[INFO] [stdout]   --> src/market_data.rs:72:9
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub struct AskMarketQuote {
[INFO] [stdout]    |            -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 72 |     pub quantity: f64,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 73 |     pub timestamp_ms: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AskMarketQuote` 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: fields `quantity` and `timestamp_ms` are never read
[INFO] [stdout]   --> src/market_data.rs:81:9
[INFO] [stdout]    |
[INFO] [stdout] 77 | pub struct BidMarketQuote {
[INFO] [stdout]    |            -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 81 |     pub quantity: f64,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 82 |     pub timestamp_ms: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BidMarketQuote` 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: module `ATOMIC_SP_MATRIX` should have a snake case name
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | mod ATOMIC_SP_MATRIX;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `atomic_sp_matrix`
[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 `Result` that must be used
[INFO] [stdout]   --> src/main.rs:56:13
[INFO] [stdout]    |
[INFO] [stdout] 56 | /             ws_stream
[INFO] [stdout] 57 | |                 .send(Message::text(subscribe_msg.to_string()))
[INFO] [stdout] 58 | |                 .await;
[INFO] [stdout]    | |______________________^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 56 |             let _ = ws_stream
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `CBstreams` should have a snake case name
[INFO] [stdout]    --> src/main.rs:110:9
[INFO] [stdout]     |
[INFO] [stdout] 110 |     let CBstreams = vec![("", "wss://advanced-trade-ws.coinbase.com")];
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `cbstreams`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/main.rs:131:13
[INFO] [stdout]     |
[INFO] [stdout] 131 | /             ws_stream
[INFO] [stdout] 132 | |                 .send(Message::text(subscribe_msg.to_string()))
[INFO] [stdout] 133 | |                 .await;
[INFO] [stdout]     | |______________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 131 |             let _ = ws_stream
[INFO] [stdout]     |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `asToken` should have a snake case name
[INFO] [stdout]   --> src/market_data.rs:48:8
[INFO] [stdout]    |
[INFO] [stdout] 48 |     fn asToken(symbol: String) -> Token {
[INFO] [stdout]    |        ^^^^^^^ help: convert the identifier to snake case: `as_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `getAskMarketQuotes` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout] 111 |     pub fn getAskMarketQuotes(&self) -> Vec<AskMarketQuote> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_ask_market_quotes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `AskMarketQuoteVec` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:112:17
[INFO] [stdout]     |
[INFO] [stdout] 112 |         let mut AskMarketQuoteVec: Vec<AskMarketQuote> = Vec::new();
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `askMarketQuote` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:116:13
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let askMarketQuote = AskMarketQuote {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `getBidMarketQuotes` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:129:12
[INFO] [stdout]     |
[INFO] [stdout] 129 |     pub fn getBidMarketQuotes(&self) -> Vec<BidMarketQuote> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_bid_market_quotes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `bidMarketQuoteVec` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:130:17
[INFO] [stdout]     |
[INFO] [stdout] 130 |         let mut bidMarketQuoteVec: Vec<BidMarketQuote> = Vec::new();
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `bidMarketQuote` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:134:13
[INFO] [stdout]     |
[INFO] [stdout] 134 |         let bidMarketQuote = BidMarketQuote {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `getBidMarketQuotes` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:181:12
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub fn getBidMarketQuotes(&self) -> BidMarketQuote {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_bid_market_quotes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `bidMarketQuote` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:184:13
[INFO] [stdout]     |
[INFO] [stdout] 184 |         let bidMarketQuote = BidMarketQuote {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `getAskMarketQuotes` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:195:12
[INFO] [stdout]     |
[INFO] [stdout] 195 |     pub fn getAskMarketQuotes(&self) -> AskMarketQuote {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_ask_market_quotes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `askMarketQuote` should have a snake case name
[INFO] [stdout]    --> src/market_data.rs:198:13
[INFO] [stdout]     |
[INFO] [stdout] 198 |         let askMarketQuote = AskMarketQuote {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 35.55s
[INFO] running `Command { std: "docker" "inspect" "03d47dde593eff13934bfddec0224776cec96834a4aaa8ce1211bfa9481b9772", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "03d47dde593eff13934bfddec0224776cec96834a4aaa8ce1211bfa9481b9772", kill_on_drop: false }`
[INFO] [stdout] 03d47dde593eff13934bfddec0224776cec96834a4aaa8ce1211bfa9481b9772
