[INFO] cloning repository https://github.com/Siddid-Soni/rust-websocket
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Siddid-Soni/rust-websocket" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSiddid-Soni%2Frust-websocket", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSiddid-Soni%2Frust-websocket'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 52cfb5bbd1660724f7c42a6fffaaf5b7d40aa7ae
[INFO] checking Siddid-Soni/rust-websocket/52cfb5bbd1660724f7c42a6fffaaf5b7d40aa7ae against master#90b65889799733f21ebdf59d96411aa531c5900a for pr-148477
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSiddid-Soni%2Frust-websocket" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Siddid-Soni/rust-websocket
[INFO] finished tweaking git repo https://github.com/Siddid-Soni/rust-websocket
[INFO] tweaked toml for git repo https://github.com/Siddid-Soni/rust-websocket written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Siddid-Soni/rust-websocket on toolchain 90b65889799733f21ebdf59d96411aa531c5900a
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+90b65889799733f21ebdf59d96411aa531c5900a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Siddid-Soni/rust-websocket 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" "+90b65889799733f21ebdf59d96411aa531c5900a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded tokio-tungstenite v0.23.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+90b65889799733f21ebdf59d96411aa531c5900a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] f99a8275c7debe2f776458ff29bd89b31e39a313923a56c35f37e20d9bbd4111
[INFO] running `Command { std: "docker" "start" "-a" "f99a8275c7debe2f776458ff29bd89b31e39a313923a56c35f37e20d9bbd4111", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "f99a8275c7debe2f776458ff29bd89b31e39a313923a56c35f37e20d9bbd4111", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f99a8275c7debe2f776458ff29bd89b31e39a313923a56c35f37e20d9bbd4111", kill_on_drop: false }`
[INFO] [stdout] f99a8275c7debe2f776458ff29bd89b31e39a313923a56c35f37e20d9bbd4111
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+90b65889799733f21ebdf59d96411aa531c5900a" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1a5200d8306082b8c6f7c1a894276b85a3c2c214a8c67ac3e25feac2691e5aec
[INFO] running `Command { std: "docker" "start" "-a" "1a5200d8306082b8c6f7c1a894276b85a3c2c214a8c67ac3e25feac2691e5aec", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.172
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]    Compiling lock_api v0.4.13
[INFO] [stderr]     Checking smallvec v1.15.0
[INFO] [stderr]    Compiling zerocopy v0.8.25
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling syn v2.0.101
[INFO] [stderr]    Compiling cc v1.2.25
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]     Checking sync_wrapper v1.0.2
[INFO] [stderr]     Checking anstyle-parse v0.2.6
[INFO] [stderr]     Checking time v0.3.41
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking colorchoice v1.0.3
[INFO] [stderr]     Checking anstyle v1.0.10
[INFO] [stderr]     Checking anstyle-query v1.1.2
[INFO] [stderr]     Checking pem v3.0.5
[INFO] [stderr]     Checking jiff v0.2.14
[INFO] [stderr]     Checking tower-http v0.5.2
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking urlencoding v2.1.3
[INFO] [stderr]     Checking anstream v0.6.18
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking parking_lot_core v0.9.11
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]     Checking mio v1.0.4
[INFO] [stderr]     Checking signal-hook-registry v1.4.5
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]     Checking regex-automata v0.4.9
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking parking_lot v0.12.4
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking regex v1.11.1
[INFO] [stderr]     Checking env_filter v0.1.3
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling thiserror-impl v2.0.12
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling async-trait v0.1.88
[INFO] [stderr]     Checking tokio v1.45.1
[INFO] [stderr]     Checking env_logger v0.11.8
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking thiserror v2.0.12
[INFO] [stderr]     Checking simple_asn1 v0.6.3
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking tungstenite v0.23.0
[INFO] [stderr]     Checking serde v1.0.219
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking axum-core v0.4.5
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking hyper v1.6.0
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking tokio-tungstenite v0.23.1
[INFO] [stderr]     Checking hyper-util v0.1.13
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking serde_path_to_error v0.1.17
[INFO] [stderr]     Checking chrono v0.4.41
[INFO] [stderr]     Checking uuid v1.17.0
[INFO] [stderr]     Checking jsonwebtoken v9.3.1
[INFO] [stderr]     Checking axum v0.7.9
[INFO] [stderr]     Checking nse_socket v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `error`
[INFO] [stdout]  --> src/auth/session.rs:5:23
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{warn, info, error};
[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: `uuid::Uuid`
[INFO] [stdout]  --> src/auth/session.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use uuid::Uuid;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error`
[INFO] [stdout]  --> src/trading/order.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use log::{info, warn, error};
[INFO] [stdout]   |                       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error`
[INFO] [stdout]  --> src/data/pubsub.rs:5:23
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{info, warn, error};
[INFO] [stdout]   |                       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::broadcast`
[INFO] [stdout]  --> src/data/controller.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use tokio::sync::broadcast;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/data/controller.rs:6:17
[INFO] [stdout]   |
[INFO] [stdout] 6 | use log::{info, warn, error};
[INFO] [stdout]   |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MultiSymbolDataBroadcaster`
[INFO] [stdout]  --> src/data/controller.rs:8:31
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::data::{DataLoader, MultiSymbolDataBroadcaster, PubSubManager, StockData};
[INFO] [stdout]   |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DataBroadcaster`
[INFO] [stdout]  --> src/data/mod.rs:5:55
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub use loader::{StockData, StockMessage, DataLoader, DataBroadcaster, MultiSymbolDataBroadcaster};
[INFO] [stdout]   |                                                       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error`
[INFO] [stdout]  --> src/auth/session.rs:5:23
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{warn, info, error};
[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: `uuid::Uuid`
[INFO] [stdout]  --> src/auth/session.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use uuid::Uuid;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error`
[INFO] [stdout]  --> src/trading/order.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use log::{info, warn, error};
[INFO] [stdout]   |                       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error`
[INFO] [stdout]  --> src/data/pubsub.rs:5:23
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{info, warn, error};
[INFO] [stdout]   |                       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::broadcast`
[INFO] [stdout]  --> src/data/controller.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use tokio::sync::broadcast;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/data/controller.rs:6:17
[INFO] [stdout]   |
[INFO] [stdout] 6 | use log::{info, warn, error};
[INFO] [stdout]   |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MultiSymbolDataBroadcaster`
[INFO] [stdout]  --> src/data/controller.rs:8:31
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::data::{DataLoader, MultiSymbolDataBroadcaster, PubSubManager, StockData};
[INFO] [stdout]   |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DataBroadcaster`
[INFO] [stdout]  --> src/data/mod.rs:5:55
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub use loader::{StockData, StockMessage, DataLoader, DataBroadcaster, MultiSymbolDataBroadcaster};
[INFO] [stdout]   |                                                       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `msg`
[INFO] [stdout]    --> src/api/handlers.rs:124:28
[INFO] [stdout]     |
[INFO] [stdout] 124 |         .map_err(|(status, msg)| {
[INFO] [stdout]     |                            ^^^ help: if this is intentional, prefix it with an underscore: `_msg`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `msg`
[INFO] [stdout]    --> src/api/handlers.rs:124:28
[INFO] [stdout]     |
[INFO] [stdout] 124 |         .map_err(|(status, msg)| {
[INFO] [stdout]     |                            ^^^ help: if this is intentional, prefix it with an underscore: `_msg`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `admin_tx`
[INFO] [stdout]    --> src/main.rs:236:5
[INFO] [stdout]     |
[INFO] [stdout] 236 |     admin_tx: broadcast::Sender<AdminOrderEvent>
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_admin_tx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/websocket/handler.rs:32:18
[INFO] [stdout]     |
[INFO] [stdout]  24 | impl WebSocketHandler {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  32 |     pub async fn handle_connection(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  69 |     pub async fn handle_connection_with_pubsub(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     fn authenticate_request(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     fn create_error_response(&self, status: StatusCode, message: &str) -> ErrorResponse {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     async fn handle_websocket_connection(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 265 |     fn spawn_write_task(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 310 |     fn spawn_read_task(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `session_manager` is never read
[INFO] [stdout]   --> src/websocket/admin.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct AdminWebSocketHandler {
[INFO] [stdout]    |            --------------------- field in this struct
[INFO] [stdout] 22 |     session_manager: SessionManager,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `order_filled`, `order_partial_fill`, and `order_updated` are never used
[INFO] [stdout]    --> src/websocket/admin.rs:195:12
[INFO] [stdout]     |
[INFO] [stdout] 181 | impl AdminOrderEvent {
[INFO] [stdout]     | -------------------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 195 |     pub fn order_filled(order: Order, user_id: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 203 |     pub fn order_partial_fill(order: Order, user_id: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |     pub fn order_updated(order: Order, user_id: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `pubsub_manager` is never read
[INFO] [stdout]   --> src/api/handlers.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct ApiState {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub pubsub_manager: Arc<PubSubManager>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ApiState` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MAX_CONNECTIONS` is never used
[INFO] [stdout]   --> src/auth/session.rs:11:11
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub const MAX_CONNECTIONS: usize = 1000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `session_id`, `user_id`, `connected_at`, and `permissions` are never read
[INFO] [stdout]   --> src/auth/session.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct ConnectionInfo {
[INFO] [stdout]    |            -------------- fields in this struct
[INFO] [stdout] 18 |     pub session_id: String,     // JWT ID (jti)
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 19 |     pub user_id: String,        // User identifier
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 20 |     pub connected_at: Instant,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 21 |     pub last_heartbeat: Instant,
[INFO] [stdout] 22 |     pub permissions: Vec<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ConnectionInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/auth/session.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl ConnectionInfo {
[INFO] [stdout]    | ------------------- associated function in this implementation
[INFO] [stdout] 26 |     pub fn new(claims: &Claims) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `try_acquire_session`, `get_user_sessions`, `get_session_info`, and `log_session_stats` are never used
[INFO] [stdout]    --> src/auth/session.rs:61:12
[INFO] [stdout]     |
[INFO] [stdout]  53 | impl SessionManager {
[INFO] [stdout]     | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  61 |     pub fn try_acquire_session(&self, token: &str) -> Result<Claims, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn get_user_sessions(&self, user_id: &str) -> Vec<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     pub fn get_session_info(&self, session_id: &str) -> Option<ConnectionInfo> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub fn log_session_stats(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `fill` is never used
[INFO] [stdout]    --> src/trading/order.rs:153:12
[INFO] [stdout]     |
[INFO] [stdout] 128 | impl Order {
[INFO] [stdout]     | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn fill(&mut self, fill_price: f64, fill_quantity: u32) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `get_orders_by_symbol` are never used
[INFO] [stdout]    --> src/trading/order.rs:172:12
[INFO] [stdout]     |
[INFO] [stdout] 171 | impl OrderManager {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout] 172 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 284 |     pub fn get_orders_by_symbol(&self, symbol: &str) -> Vec<Order> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_json` is never used
[INFO] [stdout]   --> src/data/loader.rs:57:12
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl StockData {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub fn to_json(&self) -> Result<String, serde_json::Error> {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DataBroadcaster` is never constructed
[INFO] [stdout]    --> src/data/loader.rs:146:12
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub struct DataBroadcaster {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `start_broadcasting`, and `get_data_count` are never used
[INFO] [stdout]    --> src/data/loader.rs:152:12
[INFO] [stdout]     |
[INFO] [stdout] 151 | impl DataBroadcaster {
[INFO] [stdout]     | -------------------- associated items in this implementation
[INFO] [stdout] 152 |     pub fn new(data: Vec<StockData>, interval_secs: u64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 159 |     pub fn start_broadcasting(self, tx: broadcast::Sender<String>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn get_data_count(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MultiSymbolDataBroadcaster` is never constructed
[INFO] [stdout]    --> src/data/loader.rs:197:12
[INFO] [stdout]     |
[INFO] [stdout] 197 | pub struct MultiSymbolDataBroadcaster {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `start_broadcasting`, `get_symbol_count`, and `get_total_records` are never used
[INFO] [stdout]    --> src/data/loader.rs:204:12
[INFO] [stdout]     |
[INFO] [stdout] 203 | impl MultiSymbolDataBroadcaster {
[INFO] [stdout]     | ------------------------------- associated items in this implementation
[INFO] [stdout] 204 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 216 |     pub fn start_broadcasting(self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 253 |     pub fn get_symbol_count(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 257 |     pub fn get_total_records(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_subscriber_count`, `get_current_subscriptions`, `get_current_subscription`, `is_subscribed`, `get_subscription_count`, and `get_symbol_list` are never used
[INFO] [stdout]    --> src/data/pubsub.rs:126:12
[INFO] [stdout]     |
[INFO] [stdout]  28 | impl PubSubManager {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 126 |     pub fn get_subscriber_count(&self, symbol: &str) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn get_current_subscriptions(&self, session_id: &str) -> HashSet<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 143 |     pub fn get_current_subscription(&self, session_id: &str) -> Option<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub fn is_subscribed(&self, session_id: &str, symbol: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn get_subscription_count(&self, session_id: &str) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn get_symbol_list(&self) -> Vec<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_DATA_FILE` is never used
[INFO] [stdout]   --> src/config.rs:13:11
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub const DEFAULT_DATA_FILE: &str = "./data/NIFTY.csv";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `admin_tx`
[INFO] [stdout]    --> src/main.rs:236:5
[INFO] [stdout]     |
[INFO] [stdout] 236 |     admin_tx: broadcast::Sender<AdminOrderEvent>
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_admin_tx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/websocket/handler.rs:32:18
[INFO] [stdout]     |
[INFO] [stdout]  24 | impl WebSocketHandler {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  32 |     pub async fn handle_connection(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  69 |     pub async fn handle_connection_with_pubsub(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     fn authenticate_request(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     fn create_error_response(&self, status: StatusCode, message: &str) -> ErrorResponse {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     async fn handle_websocket_connection(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 265 |     fn spawn_write_task(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 310 |     fn spawn_read_task(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `session_manager` is never read
[INFO] [stdout]   --> src/websocket/admin.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct AdminWebSocketHandler {
[INFO] [stdout]    |            --------------------- field in this struct
[INFO] [stdout] 22 |     session_manager: SessionManager,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `order_filled`, `order_partial_fill`, and `order_updated` are never used
[INFO] [stdout]    --> src/websocket/admin.rs:195:12
[INFO] [stdout]     |
[INFO] [stdout] 181 | impl AdminOrderEvent {
[INFO] [stdout]     | -------------------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 195 |     pub fn order_filled(order: Order, user_id: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 203 |     pub fn order_partial_fill(order: Order, user_id: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |     pub fn order_updated(order: Order, user_id: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `pubsub_manager` is never read
[INFO] [stdout]   --> src/api/handlers.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct ApiState {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub pubsub_manager: Arc<PubSubManager>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ApiState` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MAX_CONNECTIONS` is never used
[INFO] [stdout]   --> src/auth/session.rs:11:11
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub const MAX_CONNECTIONS: usize = 1000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `session_id`, `user_id`, `connected_at`, and `permissions` are never read
[INFO] [stdout]   --> src/auth/session.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct ConnectionInfo {
[INFO] [stdout]    |            -------------- fields in this struct
[INFO] [stdout] 18 |     pub session_id: String,     // JWT ID (jti)
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 19 |     pub user_id: String,        // User identifier
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 20 |     pub connected_at: Instant,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 21 |     pub last_heartbeat: Instant,
[INFO] [stdout] 22 |     pub permissions: Vec<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ConnectionInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `try_acquire_session`, `get_user_sessions`, `get_session_info`, and `log_session_stats` are never used
[INFO] [stdout]    --> src/auth/session.rs:61:12
[INFO] [stdout]     |
[INFO] [stdout]  53 | impl SessionManager {
[INFO] [stdout]     | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  61 |     pub fn try_acquire_session(&self, token: &str) -> Result<Claims, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn get_user_sessions(&self, user_id: &str) -> Vec<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     pub fn get_session_info(&self, session_id: &str) -> Option<ConnectionInfo> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub fn log_session_stats(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `fill` is never used
[INFO] [stdout]    --> src/trading/order.rs:153:12
[INFO] [stdout]     |
[INFO] [stdout] 128 | impl Order {
[INFO] [stdout]     | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn fill(&mut self, fill_price: f64, fill_quantity: u32) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `get_orders_by_symbol` are never used
[INFO] [stdout]    --> src/trading/order.rs:172:12
[INFO] [stdout]     |
[INFO] [stdout] 171 | impl OrderManager {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout] 172 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 284 |     pub fn get_orders_by_symbol(&self, symbol: &str) -> Vec<Order> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_json` is never used
[INFO] [stdout]   --> src/data/loader.rs:57:12
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl StockData {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub fn to_json(&self) -> Result<String, serde_json::Error> {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DataBroadcaster` is never constructed
[INFO] [stdout]    --> src/data/loader.rs:146:12
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub struct DataBroadcaster {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `start_broadcasting`, and `get_data_count` are never used
[INFO] [stdout]    --> src/data/loader.rs:152:12
[INFO] [stdout]     |
[INFO] [stdout] 151 | impl DataBroadcaster {
[INFO] [stdout]     | -------------------- associated items in this implementation
[INFO] [stdout] 152 |     pub fn new(data: Vec<StockData>, interval_secs: u64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 159 |     pub fn start_broadcasting(self, tx: broadcast::Sender<String>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn get_data_count(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MultiSymbolDataBroadcaster` is never constructed
[INFO] [stdout]    --> src/data/loader.rs:197:12
[INFO] [stdout]     |
[INFO] [stdout] 197 | pub struct MultiSymbolDataBroadcaster {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `start_broadcasting`, `get_symbol_count`, and `get_total_records` are never used
[INFO] [stdout]    --> src/data/loader.rs:204:12
[INFO] [stdout]     |
[INFO] [stdout] 203 | impl MultiSymbolDataBroadcaster {
[INFO] [stdout]     | ------------------------------- associated items in this implementation
[INFO] [stdout] 204 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 216 |     pub fn start_broadcasting(self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 253 |     pub fn get_symbol_count(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 257 |     pub fn get_total_records(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_subscriber_count`, `get_current_subscriptions`, `get_current_subscription`, `is_subscribed`, `get_subscription_count`, and `get_symbol_list` are never used
[INFO] [stdout]    --> src/data/pubsub.rs:126:12
[INFO] [stdout]     |
[INFO] [stdout]  28 | impl PubSubManager {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 126 |     pub fn get_subscriber_count(&self, symbol: &str) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn get_current_subscriptions(&self, session_id: &str) -> HashSet<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 143 |     pub fn get_current_subscription(&self, session_id: &str) -> Option<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub fn is_subscribed(&self, session_id: &str, symbol: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn get_subscription_count(&self, session_id: &str) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn get_symbol_list(&self) -> Vec<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_DATA_FILE` is never used
[INFO] [stdout]   --> src/config.rs:13:11
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub const DEFAULT_DATA_FILE: &str = "./data/NIFTY.csv";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 25.24s
[INFO] running `Command { std: "docker" "inspect" "1a5200d8306082b8c6f7c1a894276b85a3c2c214a8c67ac3e25feac2691e5aec", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1a5200d8306082b8c6f7c1a894276b85a3c2c214a8c67ac3e25feac2691e5aec", kill_on_drop: false }`
[INFO] [stdout] 1a5200d8306082b8c6f7c1a894276b85a3c2c214a8c67ac3e25feac2691e5aec
