[INFO] cloning repository https://github.com/GH05T-97/hft-engine
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/GH05T-97/hft-engine" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGH05T-97%2Fhft-engine", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGH05T-97%2Fhft-engine'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 621ceff14fa97de985591e236b713f515ac851bb
[INFO] testing GH05T-97/hft-engine against try#bd7d74411512a3dd3b35d2f699c51dd2557c7e7e+cargoflags=-Zbuild-dir-new-layout for pr-149852-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGH05T-97%2Fhft-engine" "/workspace/builds/worker-4-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/GH05T-97/hft-engine
[INFO] removed 0 missing examples
[INFO] finished tweaking git repo https://github.com/GH05T-97/hft-engine
[INFO] tweaked toml for git repo https://github.com/GH05T-97/hft-engine written to /workspace/builds/worker-4-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/GH05T-97/hft-engine on toolchain bd7d74411512a3dd3b35d2f699c51dd2557c7e7e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/GH05T-97/hft-engine 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" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 6b6998d82d049d46e4ad72d1fbe33e3c872a983f9ce86c6a99f553ecea362fea
[INFO] running `Command { std: "docker" "start" "-a" "6b6998d82d049d46e4ad72d1fbe33e3c872a983f9ce86c6a99f553ecea362fea", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "6b6998d82d049d46e4ad72d1fbe33e3c872a983f9ce86c6a99f553ecea362fea", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6b6998d82d049d46e4ad72d1fbe33e3c872a983f9ce86c6a99f553ecea362fea", kill_on_drop: false }`
[INFO] [stdout] 6b6998d82d049d46e4ad72d1fbe33e3c872a983f9ce86c6a99f553ecea362fea
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "build" "--frozen" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 8f6de2280c5bf1e89cd231ac1eea51cd53450659770cebc7deb1cc1128bd1f26
[INFO] running `Command { std: "docker" "start" "-a" "8f6de2280c5bf1e89cd231ac1eea51cd53450659770cebc7deb1cc1128bd1f26", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.98
[INFO] [stderr]    Compiling smallvec v1.14.0
[INFO] [stderr]    Compiling log v0.4.25
[INFO] [stderr]    Compiling cc v1.2.14
[INFO] [stderr]    Compiling once_cell v1.20.3
[INFO] [stderr]    Compiling httparse v1.10.0
[INFO] [stderr]    Compiling signal-hook-registry v1.4.2
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling zerocopy v0.8.20
[INFO] [stderr]    Compiling getrandom v0.3.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling parking_lot v0.12.3
[INFO] [stderr]    Compiling openssl v0.10.71
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling http v1.2.0
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling serde v1.0.218
[INFO] [stderr]    Compiling data-encoding v2.8.0
[INFO] [stderr]    Compiling tracing-core v0.1.33
[INFO] [stderr]    Compiling openssl-probe v0.1.6
[INFO] [stderr]    Compiling indexmap v2.7.1
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling multer v2.1.0
[INFO] [stderr]    Compiling serde_json v1.0.139
[INFO] [stderr]    Compiling openssl-sys v0.9.106
[INFO] [stderr]    Compiling protobuf v2.28.0
[INFO] [stderr]    Compiling ryu v1.0.19
[INFO] [stderr]    Compiling headers-core v0.2.0
[INFO] [stderr]    Compiling http-body v0.4.6
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling prometheus v0.13.4
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling headers v0.3.9
[INFO] [stderr]    Compiling chrono v0.4.40
[INFO] [stderr]    Compiling rand_core v0.9.1
[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 zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tokio v1.43.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling zerocopy v0.7.35
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling serde_derive v1.0.218
[INFO] [stderr]    Compiling zerofrom v0.1.5
[INFO] [stderr]    Compiling yoke v0.7.5
[INFO] [stderr]    Compiling zerovec v0.10.4
[INFO] [stderr]    Compiling ppv-lite86 v0.2.20
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling tracing-attributes v0.1.28
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling tinystr v0.7.6
[INFO] [stderr]    Compiling icu_collections v1.5.0
[INFO] [stderr]    Compiling icu_locid v1.5.0
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling icu_provider v1.5.0
[INFO] [stderr]    Compiling thiserror-impl v2.0.11
[INFO] [stderr]    Compiling rand v0.9.0
[INFO] [stderr]    Compiling pin-project-internal v1.1.9
[INFO] [stderr]    Compiling icu_locid_transform v1.5.0
[INFO] [stderr]    Compiling thiserror v2.0.11
[INFO] [stderr]    Compiling tungstenite v0.26.2
[INFO] [stderr]    Compiling icu_properties v1.5.1
[INFO] [stderr]    Compiling tokio-util v0.7.13
[INFO] [stderr]    Compiling pin-project v1.1.9
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling async-trait v0.1.86
[INFO] [stderr]    Compiling tokio-tungstenite v0.26.2
[INFO] [stderr]    Compiling h2 v0.3.26
[INFO] [stderr]    Compiling icu_normalizer v1.5.0
[INFO] [stderr]    Compiling idna_adapter v1.2.0
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling tungstenite v0.21.0
[INFO] [stderr]    Compiling tokio-tungstenite v0.21.0
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling warp v0.3.7
[INFO] [stderr]    Compiling hft-engine v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Quote`
[INFO] [stdout]  --> src/venues/mod.rs:2:27
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::types::{Order, Quote};
[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: `ErrorExt`
[INFO] [stdout]  --> src/venues/binance.rs:1:42
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::error::{HftError, VenueError, ErrorExt};
[INFO] [stdout]   |                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `OrderSide` and `OrderType`
[INFO] [stdout]  --> src/venues/binance.rs:2:34
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::types::{Order, Quote, OrderSide, OrderType};
[INFO] [stdout]   |                                  ^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::any::Any`
[INFO] [stdout]  --> src/gateways/quote.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::any::Any;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::time::Duration`
[INFO] [stdout]  --> src/gateways/quote.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use tokio::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `OrderBook`
[INFO] [stdout]  --> src/services/mod.rs:6:32
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::book::{BookBuilder, OrderBook};
[INFO] [stdout]   |                                ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `binance`
[INFO] [stdout]   --> src/services/mod.rs:25:13
[INFO] [stdout]    |
[INFO] [stdout] 25 |         let binance = Arc::new(BinanceVenue::new(
[INFO] [stdout]    |             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_binance`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `api_key`, `api_secret`, and `rest_url` are never read
[INFO] [stdout]   --> src/venues/binance.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct BinanceVenue {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] 19 |     ws_url: String,
[INFO] [stdout] 20 |     api_key: String,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 21 |     api_secret: String,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 22 |     rest_url: String,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BinanceVenue` has a derived impl for the trait `Debug`, 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: field `time` is never read
[INFO] [stdout]   --> src/venues/binance.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | struct BinanceBookTicker {
[INFO] [stdout]    |        ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     time: u64,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BinanceBookTicker` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `venues` and `order_rx` are never read
[INFO] [stdout]  --> src/gateways/order.rs:7:16
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct OrderGateway {
[INFO] [stdout]   |            ------------ fields in this struct
[INFO] [stdout] 7 |     pub(crate) venues: Vec<Arc<dyn VenueAdapter>>,
[INFO] [stdout]   |                ^^^^^^
[INFO] [stdout] 8 |     pub(crate) order_rx: mpsc::Receiver<Order>,
[INFO] [stdout]   |                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `symbol` is never read
[INFO] [stdout]   --> src/book/mod.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct OrderBook {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] 35 |     symbol: String,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `books` and `order_tx` are never read
[INFO] [stdout]  --> src/strategy/mod.rs:8:16
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct Strategy {
[INFO] [stdout]   |            -------- fields in this struct
[INFO] [stdout] 8 |     pub(crate) books: Arc<RwLock<HashMap<String, OrderBook>>>,
[INFO] [stdout]   |                ^^^^^
[INFO] [stdout] 9 |     pub(crate) order_tx: mpsc::Sender<Order>,
[INFO] [stdout]   |                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `order_tx` is never read
[INFO] [stdout]  --> src/execution/mod.rs:7:16
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct ExecutionEngine {
[INFO] [stdout]   |            --------------- field in this struct
[INFO] [stdout] 7 |     pub(crate) order_tx: mpsc::Sender<Order>,
[INFO] [stdout]   |                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `execute_order` is never used
[INFO] [stdout]   --> src/execution/mod.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 10 | impl ExecutionEngine {
[INFO] [stdout]    | -------------------- method in this implementation
[INFO] [stdout] 11 |     async fn execute_order(&self, order: Order) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `quote_gateway`, `order_gateway`, `book_builder`, `strategy`, and `execution` are never read
[INFO] [stdout]   --> src/services/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct Services {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 12 |     quote_gateway: QuoteGateway,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 13 |     order_gateway: OrderGateway,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 14 |     book_builder: BookBuilder,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 15 |     strategy: Strategy,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 16 |     execution: ExecutionEngine,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout] 11 |     let mut services = Services::new().await;
[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: `venue`
[INFO] [stdout]   --> src/main.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |     let venue = Arc::new(BinanceVenue::new(
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_venue`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 54s
[INFO] running `Command { std: "docker" "inspect" "8f6de2280c5bf1e89cd231ac1eea51cd53450659770cebc7deb1cc1128bd1f26", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8f6de2280c5bf1e89cd231ac1eea51cd53450659770cebc7deb1cc1128bd1f26", kill_on_drop: false }`
[INFO] [stdout] 8f6de2280c5bf1e89cd231ac1eea51cd53450659770cebc7deb1cc1128bd1f26
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "--no-run" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] fcbb68b303a214acffbd4c1dc66377324361e2f6c57e44e6b25b8e968026e1cf
[INFO] running `Command { std: "docker" "start" "-a" "fcbb68b303a214acffbd4c1dc66377324361e2f6c57e44e6b25b8e968026e1cf", kill_on_drop: false }`
[INFO] [stderr]    Compiling hft-engine v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Quote`
[INFO] [stdout]  --> src/venues/mod.rs:2:27
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::types::{Order, Quote};
[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: `ErrorExt`
[INFO] [stdout]  --> src/venues/binance.rs:1:42
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::error::{HftError, VenueError, ErrorExt};
[INFO] [stdout]   |                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `OrderSide` and `OrderType`
[INFO] [stdout]  --> src/venues/binance.rs:2:34
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::types::{Order, Quote, OrderSide, OrderType};
[INFO] [stdout]   |                                  ^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::any::Any`
[INFO] [stdout]  --> src/gateways/quote.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::any::Any;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::time::Duration`
[INFO] [stdout]  --> src/gateways/quote.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use tokio::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `OrderBook`
[INFO] [stdout]  --> src/services/mod.rs:6:32
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::book::{BookBuilder, OrderBook};
[INFO] [stdout]   |                                ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `binance`
[INFO] [stdout]   --> src/services/mod.rs:25:13
[INFO] [stdout]    |
[INFO] [stdout] 25 |         let binance = Arc::new(BinanceVenue::new(
[INFO] [stdout]    |             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_binance`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `api_key`, `api_secret`, and `rest_url` are never read
[INFO] [stdout]   --> src/venues/binance.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct BinanceVenue {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] 19 |     ws_url: String,
[INFO] [stdout] 20 |     api_key: String,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 21 |     api_secret: String,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 22 |     rest_url: String,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BinanceVenue` has a derived impl for the trait `Debug`, 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: field `time` is never read
[INFO] [stdout]   --> src/venues/binance.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | struct BinanceBookTicker {
[INFO] [stdout]    |        ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     time: u64,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BinanceBookTicker` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `venues` and `order_rx` are never read
[INFO] [stdout]  --> src/gateways/order.rs:7:16
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct OrderGateway {
[INFO] [stdout]   |            ------------ fields in this struct
[INFO] [stdout] 7 |     pub(crate) venues: Vec<Arc<dyn VenueAdapter>>,
[INFO] [stdout]   |                ^^^^^^
[INFO] [stdout] 8 |     pub(crate) order_rx: mpsc::Receiver<Order>,
[INFO] [stdout]   |                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `symbol` is never read
[INFO] [stdout]   --> src/book/mod.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct OrderBook {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] 35 |     symbol: String,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `books` and `order_tx` are never read
[INFO] [stdout]  --> src/strategy/mod.rs:8:16
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct Strategy {
[INFO] [stdout]   |            -------- fields in this struct
[INFO] [stdout] 8 |     pub(crate) books: Arc<RwLock<HashMap<String, OrderBook>>>,
[INFO] [stdout]   |                ^^^^^
[INFO] [stdout] 9 |     pub(crate) order_tx: mpsc::Sender<Order>,
[INFO] [stdout]   |                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `order_tx` is never read
[INFO] [stdout]  --> src/execution/mod.rs:7:16
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct ExecutionEngine {
[INFO] [stdout]   |            --------------- field in this struct
[INFO] [stdout] 7 |     pub(crate) order_tx: mpsc::Sender<Order>,
[INFO] [stdout]   |                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `execute_order` is never used
[INFO] [stdout]   --> src/execution/mod.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 10 | impl ExecutionEngine {
[INFO] [stdout]    | -------------------- method in this implementation
[INFO] [stdout] 11 |     async fn execute_order(&self, order: Order) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `quote_gateway`, `order_gateway`, `book_builder`, `strategy`, and `execution` are never read
[INFO] [stdout]   --> src/services/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct Services {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 12 |     quote_gateway: QuoteGateway,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 13 |     order_gateway: OrderGateway,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 14 |     book_builder: BookBuilder,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 15 |     strategy: Strategy,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 16 |     execution: ExecutionEngine,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Quote`
[INFO] [stdout]  --> src/venues/mod.rs:2:27
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::types::{Order, Quote};
[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: `ErrorExt`
[INFO] [stdout]  --> src/venues/binance.rs:1:42
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::error::{HftError, VenueError, ErrorExt};
[INFO] [stdout]   |                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::any::Any`
[INFO] [stdout]  --> src/gateways/quote.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::any::Any;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::time::Duration`
[INFO] [stdout]  --> src/gateways/quote.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use tokio::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `OrderBook`
[INFO] [stdout]  --> src/services/mod.rs:6:32
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::book::{BookBuilder, OrderBook};
[INFO] [stdout]   |                                ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]    --> src/mocks/mock_venue.rs:161:17
[INFO] [stdout]     |
[INFO] [stdout] 161 |             use std::sync::Arc;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::Mutex`
[INFO] [stdout]    --> src/mocks/mock_venue.rs:162:17
[INFO] [stdout]     |
[INFO] [stdout] 162 |             use tokio::sync::Mutex;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: renamed to `rng`
[INFO] [stdout]   --> src/mocks/mock_venue.rs:93:29
[INFO] [stdout]    |
[INFO] [stdout] 93 |         let mut rng = rand::thread_rng();
[INFO] [stdout]    |                             ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: renamed to `rng`
[INFO] [stdout]    --> src/mocks/mock_venue.rs:181:45
[INFO] [stdout]     |
[INFO] [stdout] 181 |                         let mut rng = rand::thread_rng();
[INFO] [stdout]     |                                             ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: renamed to `rng`
[INFO] [stdout]    --> src/mocks/mock_venue.rs:302:33
[INFO] [stdout]     |
[INFO] [stdout] 302 |             let mut rng = rand::thread_rng();
[INFO] [stdout]     |                                 ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout] 11 |     let mut services = Services::new().await;
[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: `venue`
[INFO] [stdout]   --> src/main.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |     let venue = Arc::new(BinanceVenue::new(
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_venue`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stdout]   --> src/mocks/mock_venue.rs:96:16
[INFO] [stdout]    |
[INFO] [stdout] 96 |         if rng.gen::<f64>() < config.disconnect_probability {
[INFO] [stdout]    |                ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stdout]    --> src/mocks/mock_venue.rs:102:16
[INFO] [stdout]     |
[INFO] [stdout] 102 |         if rng.gen::<f64>() < config.error_probability {
[INFO] [stdout]     |                ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stdout]    --> src/mocks/mock_venue.rs:110:35
[INFO] [stdout]     |
[INFO] [stdout] 110 |         let price_movement = (rng.gen::<f64>() - 0.5) * 0.01 * base_price;
[INFO] [stdout]     |                                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]    --> src/mocks/mock_venue.rs:119:28
[INFO] [stdout]     |
[INFO] [stdout] 119 |         let bid_size = rng.gen_range(0.1..10.0);
[INFO] [stdout]     |                            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]    --> src/mocks/mock_venue.rs:120:28
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let ask_size = rng.gen_range(0.1..10.0);
[INFO] [stdout]     |                            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stdout]    --> src/mocks/mock_venue.rs:183:54
[INFO] [stdout]     |
[INFO] [stdout] 183 |                         should_skip_disconnect = rng.gen::<f64>() < config.disconnect_probability;
[INFO] [stdout]     |                                                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stdout]    --> src/mocks/mock_venue.rs:184:49
[INFO] [stdout]     |
[INFO] [stdout] 184 |                         should_skip_error = rng.gen::<f64>() < config.error_probability;
[INFO] [stdout]     |                                                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stdout]    --> src/mocks/mock_venue.rs:185:47
[INFO] [stdout]     |
[INFO] [stdout] 185 |                         price_movement = (rng.gen::<f64>() - 0.5) * 0.01;
[INFO] [stdout]     |                                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]    --> src/mocks/mock_venue.rs:186:40
[INFO] [stdout]     |
[INFO] [stdout] 186 |                         bid_size = rng.gen_range(0.1..10.0);
[INFO] [stdout]     |                                        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]    --> src/mocks/mock_venue.rs:187:40
[INFO] [stdout]     |
[INFO] [stdout] 187 |                         ask_size = rng.gen_range(0.1..10.0);
[INFO] [stdout]     |                                        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stdout]    --> src/mocks/mock_venue.rs:303:17
[INFO] [stdout]     |
[INFO] [stdout] 303 |             rng.gen::<f64>() < self.config.error_probability
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `binance`
[INFO] [stdout]   --> src/services/mod.rs:25:13
[INFO] [stdout]    |
[INFO] [stdout] 25 |         let binance = Arc::new(BinanceVenue::new(
[INFO] [stdout]    |             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_binance`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `api_key`, `api_secret`, and `rest_url` are never read
[INFO] [stdout]   --> src/venues/binance.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct BinanceVenue {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] 19 |     ws_url: String,
[INFO] [stdout] 20 |     api_key: String,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 21 |     api_secret: String,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 22 |     rest_url: String,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BinanceVenue` has a derived impl for the trait `Debug`, 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: field `time` is never read
[INFO] [stdout]   --> src/venues/binance.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | struct BinanceBookTicker {
[INFO] [stdout]    |        ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     time: u64,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BinanceBookTicker` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `venues` and `order_rx` are never read
[INFO] [stdout]  --> src/gateways/order.rs:7:16
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct OrderGateway {
[INFO] [stdout]   |            ------------ fields in this struct
[INFO] [stdout] 7 |     pub(crate) venues: Vec<Arc<dyn VenueAdapter>>,
[INFO] [stdout]   |                ^^^^^^
[INFO] [stdout] 8 |     pub(crate) order_rx: mpsc::Receiver<Order>,
[INFO] [stdout]   |                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `books` and `order_tx` are never read
[INFO] [stdout]  --> src/strategy/mod.rs:8:16
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct Strategy {
[INFO] [stdout]   |            -------- fields in this struct
[INFO] [stdout] 8 |     pub(crate) books: Arc<RwLock<HashMap<String, OrderBook>>>,
[INFO] [stdout]   |                ^^^^^
[INFO] [stdout] 9 |     pub(crate) order_tx: mpsc::Sender<Order>,
[INFO] [stdout]   |                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `order_tx` is never read
[INFO] [stdout]  --> src/execution/mod.rs:7:16
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct ExecutionEngine {
[INFO] [stdout]   |            --------------- field in this struct
[INFO] [stdout] 7 |     pub(crate) order_tx: mpsc::Sender<Order>,
[INFO] [stdout]   |                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `execute_order` is never used
[INFO] [stdout]   --> src/execution/mod.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 10 | impl ExecutionEngine {
[INFO] [stdout]    | -------------------- method in this implementation
[INFO] [stdout] 11 |     async fn execute_order(&self, order: Order) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `quote_gateway`, `order_gateway`, `book_builder`, `strategy`, and `execution` are never read
[INFO] [stdout]   --> src/services/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct Services {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 12 |     quote_gateway: QuoteGateway,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 13 |     order_gateway: OrderGateway,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 14 |     book_builder: BookBuilder,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 15 |     strategy: Strategy,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 16 |     execution: ExecutionEngine,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `generate_and_send_quote` is never used
[INFO] [stdout]   --> src/mocks/mock_venue.rs:86:14
[INFO] [stdout]    |
[INFO] [stdout] 61 | impl MockVenue {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 86 |     async fn generate_and_send_quote(
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 8.50s
[INFO] running `Command { std: "docker" "inspect" "fcbb68b303a214acffbd4c1dc66377324361e2f6c57e44e6b25b8e968026e1cf", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fcbb68b303a214acffbd4c1dc66377324361e2f6c57e44e6b25b8e968026e1cf", kill_on_drop: false }`
[INFO] [stdout] fcbb68b303a214acffbd4c1dc66377324361e2f6c57e44e6b25b8e968026e1cf
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] fd9092179b32a7264e9c713f02cff4fd54ebeeaf2ed943cbe0a19d314937c436
[INFO] running `Command { std: "docker" "start" "-a" "fd9092179b32a7264e9c713f02cff4fd54ebeeaf2ed943cbe0a19d314937c436", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `Quote`
[INFO] [stderr]  --> src/venues/mod.rs:2:27
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::types::{Order, Quote};
[INFO] [stderr]   |                           ^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ErrorExt`
[INFO] [stderr]  --> src/venues/binance.rs:1:42
[INFO] [stderr]   |
[INFO] [stderr] 1 | use crate::error::{HftError, VenueError, ErrorExt};
[INFO] [stderr]   |                                          ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `OrderSide` and `OrderType`
[INFO] [stderr]  --> src/venues/binance.rs:2:34
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::types::{Order, Quote, OrderSide, OrderType};
[INFO] [stderr]   |                                  ^^^^^^^^^  ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::any::Any`
[INFO] [stderr]  --> src/gateways/quote.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::any::Any;
[INFO] [stderr]   |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `tokio::time::Duration`
[INFO] [stderr]  --> src/gateways/quote.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use tokio::time::Duration;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `OrderBook`
[INFO] [stderr]  --> src/services/mod.rs:6:32
[INFO] [stderr]   |
[INFO] [stderr] 6 | use crate::book::{BookBuilder, OrderBook};
[INFO] [stderr]   |                                ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `binance`
[INFO] [stderr]   --> src/services/mod.rs:25:13
[INFO] [stderr]    |
[INFO] [stderr] 25 |         let binance = Arc::new(BinanceVenue::new(
[INFO] [stderr]    |             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_binance`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: fields `api_key`, `api_secret`, and `rest_url` are never read
[INFO] [stderr]   --> src/venues/binance.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub struct BinanceVenue {
[INFO] [stderr]    |            ------------ fields in this struct
[INFO] [stderr] 19 |     ws_url: String,
[INFO] [stderr] 20 |     api_key: String,
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] 21 |     api_secret: String,
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] 22 |     rest_url: String,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `BinanceVenue` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `time` is never read
[INFO] [stderr]   --> src/venues/binance.rs:39:5
[INFO] [stderr]    |
[INFO] [stderr] 27 | struct BinanceBookTicker {
[INFO] [stderr]    |        ----------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 39 |     time: u64,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `BinanceBookTicker` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `venues` and `order_rx` are never read
[INFO] [stderr]  --> src/gateways/order.rs:7:16
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub struct OrderGateway {
[INFO] [stderr]   |            ------------ fields in this struct
[INFO] [stderr] 7 |     pub(crate) venues: Vec<Arc<dyn VenueAdapter>>,
[INFO] [stderr]   |                ^^^^^^
[INFO] [stderr] 8 |     pub(crate) order_rx: mpsc::Receiver<Order>,
[INFO] [stderr]   |                ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `symbol` is never read
[INFO] [stderr]   --> src/book/mod.rs:35:5
[INFO] [stderr]    |
[INFO] [stderr] 34 | pub struct OrderBook {
[INFO] [stderr]    |            --------- field in this struct
[INFO] [stderr] 35 |     symbol: String,
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `books` and `order_tx` are never read
[INFO] [stderr]  --> src/strategy/mod.rs:8:16
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub struct Strategy {
[INFO] [stderr]   |            -------- fields in this struct
[INFO] [stderr] 8 |     pub(crate) books: Arc<RwLock<HashMap<String, OrderBook>>>,
[INFO] [stderr]   |                ^^^^^
[INFO] [stderr] 9 |     pub(crate) order_tx: mpsc::Sender<Order>,
[INFO] [stderr]   |                ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `order_tx` is never read
[INFO] [stderr]  --> src/execution/mod.rs:7:16
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub struct ExecutionEngine {
[INFO] [stderr]   |            --------------- field in this struct
[INFO] [stderr] 7 |     pub(crate) order_tx: mpsc::Sender<Order>,
[INFO] [stderr]   |                ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `execute_order` is never used
[INFO] [stderr]   --> src/execution/mod.rs:11:14
[INFO] [stderr]    |
[INFO] [stderr] 10 | impl ExecutionEngine {
[INFO] [stderr]    | -------------------- method in this implementation
[INFO] [stderr] 11 |     async fn execute_order(&self, order: Order) {
[INFO] [stderr]    |              ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `quote_gateway`, `order_gateway`, `book_builder`, `strategy`, and `execution` are never read
[INFO] [stderr]   --> src/services/mod.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub struct Services {
[INFO] [stderr]    |            -------- fields in this struct
[INFO] [stderr] 12 |     quote_gateway: QuoteGateway,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 13 |     order_gateway: OrderGateway,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 14 |     book_builder: BookBuilder,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 15 |     strategy: Strategy,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 16 |     execution: ExecutionEngine,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::sync::Arc`
[INFO] [stderr]    --> src/mocks/mock_venue.rs:161:17
[INFO] [stderr]     |
[INFO] [stderr] 161 |             use std::sync::Arc;
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `tokio::sync::Mutex`
[INFO] [stderr]    --> src/mocks/mock_venue.rs:162:17
[INFO] [stderr]     |
[INFO] [stderr] 162 |             use tokio::sync::Mutex;
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `rand::thread_rng`: renamed to `rng`
[INFO] [stderr]   --> src/mocks/mock_venue.rs:93:29
[INFO] [stderr]    |
[INFO] [stderr] 93 |         let mut rng = rand::thread_rng();
[INFO] [stderr]    |                             ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `rand::thread_rng`: renamed to `rng`
[INFO] [stderr]    --> src/mocks/mock_venue.rs:181:45
[INFO] [stderr]     |
[INFO] [stderr] 181 |                         let mut rng = rand::thread_rng();
[INFO] [stderr]     |                                             ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `rand::thread_rng`: renamed to `rng`
[INFO] [stderr]    --> src/mocks/mock_venue.rs:302:33
[INFO] [stderr]     |
[INFO] [stderr] 302 |             let mut rng = rand::thread_rng();
[INFO] [stderr]     |                                 ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stderr]   --> src/mocks/mock_venue.rs:96:16
[INFO] [stderr]    |
[INFO] [stderr] 96 |         if rng.gen::<f64>() < config.disconnect_probability {
[INFO] [stderr]    |                ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stderr]    --> src/mocks/mock_venue.rs:102:16
[INFO] [stderr]     |
[INFO] [stderr] 102 |         if rng.gen::<f64>() < config.error_probability {
[INFO] [stderr]     |                ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stderr]    --> src/mocks/mock_venue.rs:110:35
[INFO] [stderr]     |
[INFO] [stderr] 110 |         let price_movement = (rng.gen::<f64>() - 0.5) * 0.01 * base_price;
[INFO] [stderr]     |                                   ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stderr]    --> src/mocks/mock_venue.rs:119:28
[INFO] [stderr]     |
[INFO] [stderr] 119 |         let bid_size = rng.gen_range(0.1..10.0);
[INFO] [stderr]     |                            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stderr]    --> src/mocks/mock_venue.rs:120:28
[INFO] [stderr]     |
[INFO] [stderr] 120 |         let ask_size = rng.gen_range(0.1..10.0);
[INFO] [stderr]     |                            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stderr]    --> src/mocks/mock_venue.rs:183:54
[INFO] [stderr]     |
[INFO] [stderr] 183 |                         should_skip_disconnect = rng.gen::<f64>() < config.disconnect_probability;
[INFO] [stderr]     |                                                      ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stderr]    --> src/mocks/mock_venue.rs:184:49
[INFO] [stderr]     |
[INFO] [stderr] 184 |                         should_skip_error = rng.gen::<f64>() < config.error_probability;
[INFO] [stderr]     |                                                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stderr]    --> src/mocks/mock_venue.rs:185:47
[INFO] [stderr]     |
[INFO] [stderr] 185 |                         price_movement = (rng.gen::<f64>() - 0.5) * 0.01;
[INFO] [stderr]     |                                               ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stderr]    --> src/mocks/mock_venue.rs:186:40
[INFO] [stderr]     |
[INFO] [stderr] 186 |                         bid_size = rng.gen_range(0.1..10.0);
[INFO] [stderr]     |                                        ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stderr]    --> src/mocks/mock_venue.rs:187:40
[INFO] [stderr]     |
[INFO] [stderr] 187 |                         ask_size = rng.gen_range(0.1..10.0);
[INFO] [stderr]     |                                        ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen`: Renamed to `random` to avoid conflict with the new `gen` keyword in Rust 2024.
[INFO] [stderr]    --> src/mocks/mock_venue.rs:303:17
[INFO] [stderr]     |
[INFO] [stderr] 303 |             rng.gen::<f64>() < self.config.error_probability
[INFO] [stderr]     |                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `generate_and_send_quote` is never used
[INFO] [stderr]   --> src/mocks/mock_venue.rs:86:14
[INFO] [stderr]    |
[INFO] [stderr] 61 | impl MockVenue {
[INFO] [stderr]    | -------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 86 |     async fn generate_and_send_quote(
[INFO] [stderr]    |              ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `hft-engine` (lib) generated 15 warnings (run `cargo fix --lib -p hft-engine` to apply 7 suggestions)
[INFO] [stderr] warning: `hft-engine` (lib test) generated 30 warnings (13 duplicates) (run `cargo fix --lib -p hft-engine --tests` to apply 2 suggestions)
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/main.rs:11:9
[INFO] [stderr]    |
[INFO] [stderr] 11 |     let mut services = Services::new().await;
[INFO] [stderr]    |         ----^^^^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `venue`
[INFO] [stderr]   --> src/main.rs:14:9
[INFO] [stderr]    |
[INFO] [stderr] 14 |     let venue = Arc::new(BinanceVenue::new(
[INFO] [stderr]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_venue`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `hft-engine` (bin "hft_engine" test) generated 2 warnings (run `cargo fix --bin "hft_engine" -p hft-engine --tests` to apply 2 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.39s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/build/hft-engine/0fba23057f30d163/deps/hft_engine-0fba23057f30d163)
[INFO] [stdout] 
[INFO] [stdout] running 21 tests
[INFO] [stdout] test book::test::test_order_book_empty ... ok
[INFO] [stdout] test book::test::test_order_book_multiple_levels ... ok
[INFO] [stdout] test book::test::test_order_book_creation ... ok
[INFO] [stdout] test book::test::test_concurrent_book_updates ... ok
[INFO] [stdout] test book::test::test_order_book_update ... ok
[INFO] [stdout] test gateways::quote::tests::test_quote_gateway_add_venue ... ok
[INFO] [stdout] test book::test::test_order_book_update_existing_level ... ok
[INFO] [stdout] test gateways::quote::tests::test_quote_gateway_process_quote ... ok
[INFO] [stdout] test gateways::quote::tests::test_quote_gateway_remove_venue ... ok
[INFO] [stdout] test venues::binance::test_binance_invalid_limit_price ... ok
[INFO] [stdout] test venues::binance::test_binance_invalid_order_quantity ... ok
[INFO] [stdout] test venues::binance::test_binance_venue_name ... ok
[INFO] [stdout] test venues::binance::test_market_order_zero_price ... ok
[INFO] [stdout] test venues::binance::test_venue_with_quote_sender ... ok
[INFO] [stdout] test gateways::quote::tests::test_quote_gateway_subscribe ... ok
[INFO] [stdout] test mocks::mock_venue::tests::test_mock_venue_subscribe ... ok
[INFO] [stdout] test mocks::mock_venue::tests::test_mock_venue_order_response ... ok
[INFO] [stdout] test book::test::test_extreme_price_values ... FAILED
[INFO] [stdout] test book::test::test_order_book_remove_level ... FAILED
[INFO] [stdout] test book::test::test_price_normalization ... FAILED
[INFO] [stdout] test gateways::quote::tests::test_quote_gateway_multiple_venues ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- book::test::test_extreme_price_values stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'book::test::test_extreme_price_values' (17) panicked at src/book/mod.rs:415:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: 2e-8
[INFO] [stdout]  right: 1000001.0
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5d702ccb9a92 - std[840933623431fd06]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5d702ccb9a92 - std[840933623431fd06]::backtrace_rs::backtrace::trace_unsynchronized::<std[840933623431fd06]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5d702ccb9a92 - std[840933623431fd06]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5d702ccb9a92 - <<std[840933623431fd06]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[8f93d80df273fe75]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5d702ccd0b7a - <core[8f93d80df273fe75]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5d702ccd0b7a - core[8f93d80df273fe75]::fmt::write
[INFO] [stdout]    6:     0x5d702ccbea96 - std[840933623431fd06]::io::default_write_fmt::<alloc[40b2bae28975ac47]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5d702ccbea96 - <alloc[40b2bae28975ac47]::vec::Vec<u8> as std[840933623431fd06]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5d702cc97aff - <std[840933623431fd06]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5d702cc97aff - std[840933623431fd06]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5d702ccb1b89 - std[840933623431fd06]::panicking::default_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5d702ca4edee - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x5d702ca4edee - test[2f1252070343a163]::test_main_with_exit_callback::<test[2f1252070343a163]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5d702ccb1df2 - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5d702ccb1df2 - std[840933623431fd06]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5d702cc97bb8 - std[840933623431fd06]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x5d702cc8f559 - std[840933623431fd06]::sys::backtrace::__rust_end_short_backtrace::<std[840933623431fd06]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5d702cc98a0d - __rustc[5b4a0c6d8cc4a177]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5d702ccd12bc - core[8f93d80df273fe75]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5d702ccd1173 - core[8f93d80df273fe75]::panicking::assert_failed_inner
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:439:17
[INFO] [stdout]   20:     0x5d702c9ec957 - core[8f93d80df273fe75]::panicking::assert_failed::<f64, f64>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x5d702c9da16e - hft_engine[c29b958f0ee52795]::book::test::test_extreme_price_values::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/book/mod.rs:415:9
[INFO] [stdout]   22:     0x5d702ca1c692 - <core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>> as core[8f93d80df273fe75]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x5d702ca1c70d - <core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>> as core[8f93d80df273fe75]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x5d702ca0f90d - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:729:73
[INFO] [stdout]   25:     0x5d702ca0f80b - tokio[1c25c94d9b6a13d6]::runtime::coop::with_budget::<core[8f93d80df273fe75]::task::poll::Poll<()>, <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/coop.rs:107:5
[INFO] [stdout]   26:     0x5d702ca0f80b - tokio[1c25c94d9b6a13d6]::runtime::coop::budget::<core[8f93d80df273fe75]::task::poll::Poll<()>, <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/coop.rs:73:5
[INFO] [stdout]   27:     0x5d702ca0f80b - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:729:25
[INFO] [stdout]   28:     0x5d702ca0a4a0 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Context>::enter::<core[8f93d80df273fe75]::task::poll::Poll<()>, <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:428:19
[INFO] [stdout]   29:     0x5d702ca0ebd0 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:728:44
[INFO] [stdout]   30:     0x5d702ca0deb4 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:807:68
[INFO] [stdout]   31:     0x5d702ca20a9b - <tokio[1c25c94d9b6a13d6]::runtime::context::scoped::Scoped<tokio[1c25c94d9b6a13d6]::runtime::scheduler::Context>>::set::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}, (alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>)>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x5d702ca3b989 - tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler::<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context.rs:180:38
[INFO] [stdout]   33:     0x5d702ca41222 - <std[840933623431fd06]::thread::local::LocalKey<tokio[1c25c94d9b6a13d6]::runtime::context::Context>>::try_with::<tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/local.rs:513:12
[INFO] [stdout]   34:     0x5d702ca40dae - <std[840933623431fd06]::thread::local::LocalKey<tokio[1c25c94d9b6a13d6]::runtime::context::Context>>::with::<tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/local.rs:477:20
[INFO] [stdout]   35:     0x5d702ca3ac9d - tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler::<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context.rs:180:17
[INFO] [stdout]   36:     0x5d702ca0d040 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:807:27
[INFO] [stdout]   37:     0x5d702ca0d336 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:716:24
[INFO] [stdout]   38:     0x5d702ca0d9c3 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:196:33
[INFO] [stdout]   39:     0x5d702c9f62a3 - tokio[1c25c94d9b6a13d6]::runtime::context::runtime::enter_runtime::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CurrentThread>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>::{closure#0}, ()>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x5d702ca09fd1 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:184:9
[INFO] [stdout]   41:     0x5d702ca40824 - <tokio[1c25c94d9b6a13d6]::runtime::runtime::Runtime>::block_on_inner::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/runtime.rs:368:52
[INFO] [stdout]   42:     0x5d702ca409e7 - <tokio[1c25c94d9b6a13d6]::runtime::runtime::Runtime>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/runtime.rs:342:18
[INFO] [stdout]   43:     0x5d702c9de859 - hft_engine[c29b958f0ee52795]::book::test::test_extreme_price_values
[INFO] [stdout]                                at /opt/rustwide/workdir/src/book/mod.rs:415:43
[INFO] [stdout]   44:     0x5d702c9d8bf7 - hft_engine[c29b958f0ee52795]::book::test::test_extreme_price_values::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/book/mod.rs:376:41
[INFO] [stdout]   45:     0x5d702c9e8d96 - <hft_engine[c29b958f0ee52795]::book::test::test_extreme_price_values::{closure#0} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x5d702ca4319b - <fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x5d702ca4319b - test[2f1252070343a163]::__rust_begin_short_backtrace::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:663:18
[INFO] [stdout]   48:     0x5d702ca4f9fa - test[2f1252070343a163]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:74
[INFO] [stdout]   49:     0x5d702ca4f9fa - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   50:     0x5d702ca4f9fa - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   51:     0x5d702ca4f9fa - std[840933623431fd06]::panicking::catch_unwind::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   52:     0x5d702ca4f9fa - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   53:     0x5d702ca4f9fa - test[2f1252070343a163]::run_test_in_process
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:27
[INFO] [stdout]   54:     0x5d702ca4f9fa - test[2f1252070343a163]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:607:43
[INFO] [stdout]   55:     0x5d702ca49ec4 - test[2f1252070343a163]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:637:41
[INFO] [stdout]   56:     0x5d702ca49ec4 - std[840933623431fd06]::sys::backtrace::__rust_begin_short_backtrace::<test[2f1252070343a163]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   57:     0x5d702ca524f2 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   58:     0x5d702ca524f2 - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   59:     0x5d702ca524f2 - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   60:     0x5d702ca524f2 - std[840933623431fd06]::panicking::catch_unwind::<(), core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   61:     0x5d702ca524f2 - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   62:     0x5d702ca524f2 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   63:     0x5d702ca524f2 - <std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   64:     0x5d702ccb92ff - <alloc[40b2bae28975ac47]::boxed::Box<dyn core[8f93d80df273fe75]::ops::function::FnOnce<(), Output = ()> + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   65:     0x5d702ccb92ff - <std[840933623431fd06]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   66:     0x70339d3f9aa4 - <unknown>
[INFO] [stdout]   67:     0x70339d486a64 - clone
[INFO] [stdout]   68:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- book::test::test_order_book_remove_level stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'book::test::test_order_book_remove_level' (21) panicked at src/book/mod.rs:298:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: 2
[INFO] [stdout]  right: 1
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5d702ccb9a92 - std[840933623431fd06]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5d702ccb9a92 - std[840933623431fd06]::backtrace_rs::backtrace::trace_unsynchronized::<std[840933623431fd06]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5d702ccb9a92 - std[840933623431fd06]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5d702ccb9a92 - <<std[840933623431fd06]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[8f93d80df273fe75]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5d702ccd0b7a - <core[8f93d80df273fe75]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5d702ccd0b7a - core[8f93d80df273fe75]::fmt::write
[INFO] [stdout]    6:     0x5d702ccbea96 - std[840933623431fd06]::io::default_write_fmt::<alloc[40b2bae28975ac47]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5d702ccbea96 - <alloc[40b2bae28975ac47]::vec::Vec<u8> as std[840933623431fd06]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5d702cc97aff - <std[840933623431fd06]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5d702cc97aff - std[840933623431fd06]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5d702ccb1b89 - std[840933623431fd06]::panicking::default_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5d702ca4edee - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x5d702ca4edee - test[2f1252070343a163]::test_main_with_exit_callback::<test[2f1252070343a163]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5d702ccb1df2 - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5d702ccb1df2 - std[840933623431fd06]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5d702cc97bb8 - std[840933623431fd06]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x5d702cc8f559 - std[840933623431fd06]::sys::backtrace::__rust_end_short_backtrace::<std[840933623431fd06]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5d702cc98a0d - __rustc[5b4a0c6d8cc4a177]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5d702ccd12bc - core[8f93d80df273fe75]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5d702ccd1173 - core[8f93d80df273fe75]::panicking::assert_failed_inner
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:439:17
[INFO] [stdout]   20:     0x5d702cccc32d - core[8f93d80df273fe75]::panicking::assert_failed::<usize, usize>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x5d702c9db5ba - hft_engine[c29b958f0ee52795]::book::test::test_order_book_remove_level::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/book/mod.rs:298:9
[INFO] [stdout]   22:     0x5d702ca1c692 - <core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>> as core[8f93d80df273fe75]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x5d702ca1c70d - <core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>> as core[8f93d80df273fe75]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x5d702ca0f90d - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:729:73
[INFO] [stdout]   25:     0x5d702ca0f80b - tokio[1c25c94d9b6a13d6]::runtime::coop::with_budget::<core[8f93d80df273fe75]::task::poll::Poll<()>, <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/coop.rs:107:5
[INFO] [stdout]   26:     0x5d702ca0f80b - tokio[1c25c94d9b6a13d6]::runtime::coop::budget::<core[8f93d80df273fe75]::task::poll::Poll<()>, <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/coop.rs:73:5
[INFO] [stdout]   27:     0x5d702ca0f80b - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:729:25
[INFO] [stdout]   28:     0x5d702ca0a4a0 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Context>::enter::<core[8f93d80df273fe75]::task::poll::Poll<()>, <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:428:19
[INFO] [stdout]   29:     0x5d702ca0ebd0 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:728:44
[INFO] [stdout]   30:     0x5d702ca0deb4 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:807:68
[INFO] [stdout]   31:     0x5d702ca20a9b - <tokio[1c25c94d9b6a13d6]::runtime::context::scoped::Scoped<tokio[1c25c94d9b6a13d6]::runtime::scheduler::Context>>::set::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}, (alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>)>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x5d702ca3b989 - tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler::<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context.rs:180:38
[INFO] [stdout]   33:     0x5d702ca41222 - <std[840933623431fd06]::thread::local::LocalKey<tokio[1c25c94d9b6a13d6]::runtime::context::Context>>::try_with::<tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/local.rs:513:12
[INFO] [stdout]   34:     0x5d702ca40dae - <std[840933623431fd06]::thread::local::LocalKey<tokio[1c25c94d9b6a13d6]::runtime::context::Context>>::with::<tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/local.rs:477:20
[INFO] [stdout]   35:     0x5d702ca3ac9d - tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler::<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context.rs:180:17
[INFO] [stdout]   36:     0x5d702ca0d040 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:807:27
[INFO] [stdout]   37:     0x5d702ca0d336 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:716:24
[INFO] [stdout]   38:     0x5d702ca0d9c3 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:196:33
[INFO] [stdout]   39:     0x5d702c9f62a3 - tokio[1c25c94d9b6a13d6]::runtime::context::runtime::enter_runtime::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CurrentThread>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>::{closure#0}, ()>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x5d702ca09fd1 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:184:9
[INFO] [stdout]   41:     0x5d702ca40824 - <tokio[1c25c94d9b6a13d6]::runtime::runtime::Runtime>::block_on_inner::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/runtime.rs:368:52
[INFO] [stdout]   42:     0x5d702ca409e7 - <tokio[1c25c94d9b6a13d6]::runtime::runtime::Runtime>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/runtime.rs:342:18
[INFO] [stdout]   43:     0x5d702c9deba9 - hft_engine[c29b958f0ee52795]::book::test::test_order_book_remove_level
[INFO] [stdout]                                at /opt/rustwide/workdir/src/book/mod.rs:308:34
[INFO] [stdout]   44:     0x5d702c9d8c57 - hft_engine[c29b958f0ee52795]::book::test::test_order_book_remove_level::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/book/mod.rs:253:44
[INFO] [stdout]   45:     0x5d702c9e8e16 - <hft_engine[c29b958f0ee52795]::book::test::test_order_book_remove_level::{closure#0} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x5d702ca4319b - <fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x5d702ca4319b - test[2f1252070343a163]::__rust_begin_short_backtrace::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:663:18
[INFO] [stdout]   48:     0x5d702ca4f9fa - test[2f1252070343a163]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:74
[INFO] [stdout]   49:     0x5d702ca4f9fa - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   50:     0x5d702ca4f9fa - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   51:     0x5d702ca4f9fa - std[840933623431fd06]::panicking::catch_unwind::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   52:     0x5d702ca4f9fa - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   53:     0x5d702ca4f9fa - test[2f1252070343a163]::run_test_in_process
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:27
[INFO] [stdout]   54:     0x5d702ca4f9fa - test[2f1252070343a163]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:607:43
[INFO] [stdout]   55:     0x5d702ca49ec4 - test[2f1252070343a163]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:637:41
[INFO] [stdout]   56:     0x5d702ca49ec4 - std[840933623431fd06]::sys::backtrace::__rust_begin_short_backtrace::<test[2f1252070343a163]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   57:     0x5d702ca524f2 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   58:     0x5d702ca524f2 - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   59:     0x5d702ca524f2 - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   60:     0x5d702ca524f2 - std[840933623431fd06]::panicking::catch_unwind::<(), core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   61:     0x5d702ca524f2 - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   62:     0x5d702ca524f2 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   63:     0x5d702ca524f2 - <std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   64:     0x5d702ccb92ff - <alloc[40b2bae28975ac47]::boxed::Box<dyn core[8f93d80df273fe75]::ops::function::FnOnce<(), Output = ()> + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   65:     0x5d702ccb92ff - <std[840933623431fd06]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   66:     0x70339d3f9aa4 - <unknown>
[INFO] [stdout]   67:     0x70339d486a64 - clone
[INFO] [stdout]   68:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- book::test::test_price_normalization stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'book::test::test_price_normalization' (24) panicked at src/book/mod.rs:153:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: 50000.12345679
[INFO] [stdout]  right: 50000.123456789996
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5d702ccb9a92 - std[840933623431fd06]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5d702ccb9a92 - std[840933623431fd06]::backtrace_rs::backtrace::trace_unsynchronized::<std[840933623431fd06]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5d702ccb9a92 - std[840933623431fd06]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5d702ccb9a92 - <<std[840933623431fd06]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[8f93d80df273fe75]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5d702ccd0b7a - <core[8f93d80df273fe75]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5d702ccd0b7a - core[8f93d80df273fe75]::fmt::write
[INFO] [stdout]    6:     0x5d702ccbea96 - std[840933623431fd06]::io::default_write_fmt::<alloc[40b2bae28975ac47]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5d702ccbea96 - <alloc[40b2bae28975ac47]::vec::Vec<u8> as std[840933623431fd06]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5d702cc97aff - <std[840933623431fd06]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5d702cc97aff - std[840933623431fd06]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5d702ccb1b89 - std[840933623431fd06]::panicking::default_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5d702ca4edee - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x5d702ca4edee - test[2f1252070343a163]::test_main_with_exit_callback::<test[2f1252070343a163]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5d702ccb1df2 - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5d702ccb1df2 - std[840933623431fd06]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5d702cc97bb8 - std[840933623431fd06]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x5d702cc8f559 - std[840933623431fd06]::sys::backtrace::__rust_end_short_backtrace::<std[840933623431fd06]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5d702cc98a0d - __rustc[5b4a0c6d8cc4a177]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5d702ccd12bc - core[8f93d80df273fe75]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5d702ccd1173 - core[8f93d80df273fe75]::panicking::assert_failed_inner
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:439:17
[INFO] [stdout]   20:     0x5d702c9ec957 - core[8f93d80df273fe75]::panicking::assert_failed::<f64, f64>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x5d702c9d9abb - hft_engine[c29b958f0ee52795]::book::test::test_price_normalization::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/book/mod.rs:153:9
[INFO] [stdout]   22:     0x5d702ca1c692 - <core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>> as core[8f93d80df273fe75]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x5d702ca1c70d - <core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>> as core[8f93d80df273fe75]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x5d702ca0f90d - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:729:73
[INFO] [stdout]   25:     0x5d702ca0f80b - tokio[1c25c94d9b6a13d6]::runtime::coop::with_budget::<core[8f93d80df273fe75]::task::poll::Poll<()>, <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/coop.rs:107:5
[INFO] [stdout]   26:     0x5d702ca0f80b - tokio[1c25c94d9b6a13d6]::runtime::coop::budget::<core[8f93d80df273fe75]::task::poll::Poll<()>, <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/coop.rs:73:5
[INFO] [stdout]   27:     0x5d702ca0f80b - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:729:25
[INFO] [stdout]   28:     0x5d702ca0a4a0 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Context>::enter::<core[8f93d80df273fe75]::task::poll::Poll<()>, <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:428:19
[INFO] [stdout]   29:     0x5d702ca0ebd0 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:728:44
[INFO] [stdout]   30:     0x5d702ca0deb4 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:807:68
[INFO] [stdout]   31:     0x5d702ca20a9b - <tokio[1c25c94d9b6a13d6]::runtime::context::scoped::Scoped<tokio[1c25c94d9b6a13d6]::runtime::scheduler::Context>>::set::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}, (alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>)>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x5d702ca3b989 - tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler::<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context.rs:180:38
[INFO] [stdout]   33:     0x5d702ca41222 - <std[840933623431fd06]::thread::local::LocalKey<tokio[1c25c94d9b6a13d6]::runtime::context::Context>>::try_with::<tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/local.rs:513:12
[INFO] [stdout]   34:     0x5d702ca40dae - <std[840933623431fd06]::thread::local::LocalKey<tokio[1c25c94d9b6a13d6]::runtime::context::Context>>::with::<tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/local.rs:477:20
[INFO] [stdout]   35:     0x5d702ca3ac9d - tokio[1c25c94d9b6a13d6]::runtime::context::set_scheduler::<(alloc[40b2bae28975ac47]::boxed::Box<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::Core>, core[8f93d80df273fe75]::option::Option<()>), <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context.rs:180:17
[INFO] [stdout]   36:     0x5d702ca0d040 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>::{closure#0}, core[8f93d80df273fe75]::option::Option<()>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:807:27
[INFO] [stdout]   37:     0x5d702ca0d336 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:716:24
[INFO] [stdout]   38:     0x5d702ca0d9c3 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:196:33
[INFO] [stdout]   39:     0x5d702c9f62a3 - tokio[1c25c94d9b6a13d6]::runtime::context::runtime::enter_runtime::<<tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CurrentThread>::block_on<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>::{closure#0}, ()>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x5d702ca09fd1 - <tokio[1c25c94d9b6a13d6]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/scheduler/current_thread/mod.rs:184:9
[INFO] [stdout]   41:     0x5d702ca40824 - <tokio[1c25c94d9b6a13d6]::runtime::runtime::Runtime>::block_on_inner::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/runtime.rs:368:52
[INFO] [stdout]   42:     0x5d702ca409e7 - <tokio[1c25c94d9b6a13d6]::runtime::runtime::Runtime>::block_on::<core[8f93d80df273fe75]::pin::Pin<&mut dyn core[8f93d80df273fe75]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.43.0/src/runtime/runtime.rs:342:18
[INFO] [stdout]   43:     0x5d702c9de6c9 - hft_engine[c29b958f0ee52795]::book::test::test_price_normalization
[INFO] [stdout]                                at /opt/rustwide/workdir/src/book/mod.rs:153:50
[INFO] [stdout]   44:     0x5d702c9d8bc7 - hft_engine[c29b958f0ee52795]::book::test::test_price_normalization::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/book/mod.rs:123:40
[INFO] [stdout]   45:     0x5d702c9e8d56 - <hft_engine[c29b958f0ee52795]::book::test::test_price_normalization::{closure#0} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x5d702ca4319b - <fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x5d702ca4319b - test[2f1252070343a163]::__rust_begin_short_backtrace::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:663:18
[INFO] [stdout]   48:     0x5d702ca4f9fa - test[2f1252070343a163]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:74
[INFO] [stdout]   49:     0x5d702ca4f9fa - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   50:     0x5d702ca4f9fa - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   51:     0x5d702ca4f9fa - std[840933623431fd06]::panicking::catch_unwind::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   52:     0x5d702ca4f9fa - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   53:     0x5d702ca4f9fa - test[2f1252070343a163]::run_test_in_process
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:27
[INFO] [stdout]   54:     0x5d702ca4f9fa - test[2f1252070343a163]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:607:43
[INFO] [stdout]   55:     0x5d702ca49ec4 - test[2f1252070343a163]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:637:41
[INFO] [stdout]   56:     0x5d702ca49ec4 - std[840933623431fd06]::sys::backtrace::__rust_begin_short_backtrace::<test[2f1252070343a163]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   57:     0x5d702ca524f2 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   58:     0x5d702ca524f2 - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   59:     0x5d702ca524f2 - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   60:     0x5d702ca524f2 - std[840933623431fd06]::panicking::catch_unwind::<(), core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   61:     0x5d702ca524f2 - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   62:     0x5d702ca524f2 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   63:     0x5d702ca524f2 - <std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   64:     0x5d702ccb92ff - <alloc[40b2bae28975ac47]::boxed::Box<dyn core[8f93d80df273fe75]::ops::function::FnOnce<(), Output = ()> + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   65:     0x5d702ccb92ff - <std[840933623431fd06]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   66:     0x70339d3f9aa4 - <unknown>
[INFO] [stdout]   67:     0x70339d486a64 - clone
[INFO] [stdout]   68:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     book::test::test_extreme_price_values
[INFO] [stdout]     book::test::test_order_book_remove_level
[INFO] [stdout]     book::test::test_price_normalization
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 18 passed; 3 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.53s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "fd9092179b32a7264e9c713f02cff4fd54ebeeaf2ed943cbe0a19d314937c436", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fd9092179b32a7264e9c713f02cff4fd54ebeeaf2ed943cbe0a19d314937c436", kill_on_drop: false }`
[INFO] [stdout] fd9092179b32a7264e9c713f02cff4fd54ebeeaf2ed943cbe0a19d314937c436
