[INFO] fetching crate rzmq 0.5.7...
[INFO] testing rzmq-0.5.7 against try#c2e32f1c9652b13ed99608599c1e855462f421f3 for pr-146098-8
[INFO] extracting crate rzmq 0.5.7 into /workspace/builds/worker-6-tc2/source
[INFO] started tweaking crates.io crate rzmq 0.5.7
[INFO] removed 0 missing examples
[INFO] removed 0 missing tests
[INFO] finished tweaking crates.io crate rzmq 0.5.7
[INFO] tweaked toml for crates.io crate rzmq 0.5.7 written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate rzmq 0.5.7 on toolchain c2e32f1c9652b13ed99608599c1e855462f421f3
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate rzmq 0.5.7 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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 18f1e3b396e6cbf8c4de459421b68337f5e03c7e8f43b470a4f200b73f49c4de
[INFO] running `Command { std: "docker" "start" "-a" "18f1e3b396e6cbf8c4de459421b68337f5e03c7e8f43b470a4f200b73f49c4de", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "18f1e3b396e6cbf8c4de459421b68337f5e03c7e8f43b470a4f200b73f49c4de", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "18f1e3b396e6cbf8c4de459421b68337f5e03c7e8f43b470a4f200b73f49c4de", kill_on_drop: false }`
[INFO] [stdout] 18f1e3b396e6cbf8c4de459421b68337f5e03c7e8f43b470a4f200b73f49c4de
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 590f0aa5386ef286cbdf2c257de0525765a4fdcfec0f3cd5755bf847280b8292
[INFO] running `Command { std: "docker" "start" "-a" "590f0aa5386ef286cbdf2c257de0525765a4fdcfec0f3cd5755bf847280b8292", kill_on_drop: false }`
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling linked-hash-map v0.5.6
[INFO] [stderr]    Compiling atomic_float v1.1.0
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling syn v2.0.109
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling seize v0.5.1
[INFO] [stderr]    Compiling futures-intrusive v0.5.0
[INFO] [stderr]    Compiling papaya v0.2.3
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling dashmap v5.5.3
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling async-recursion v1.1.1
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling tokio v1.48.0
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling fibre v0.5.0
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling tokio-util v0.7.17
[INFO] [stderr]    Compiling rzmq v0.5.7 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the usage of Script Group `Greek` in this crate consists solely of mixed script confusables
[INFO] [stdout]    --> src/throttle/mod.rs:129:11
[INFO] [stdout]     |
[INFO] [stdout] 129 |       let α = self.shared.config.adaptive_learning_rate;
[INFO] [stdout]     |           ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: the usage includes 'α' (U+03B1)
[INFO] [stdout]     = note: please recheck to make sure their usages are indeed what you want
[INFO] [stdout]     = note: `#[warn(mixed_script_confusables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SystemEvent`
[INFO] [stdout]  --> src/runtime/actor_drop_guard.rs:3:33
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::runtime::{ActorType, SystemEvent}; // Adjust imports as needed
[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 imports: `AtomicBool` and `Ordering`
[INFO] [stdout]  --> src/runtime/actor_drop_guard.rs:5:25
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::sync::atomic::{AtomicBool, Ordering};
[INFO] [stdout]   |                         ^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/runtime/actor_drop_guard.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `latch::CountDownLatch`
[INFO] [stdout]   --> src/runtime/mod.rs:20:16
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub(crate) use latch::CountDownLatch;
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `IDataCipher`
[INFO] [stdout]  --> src/security/mechanism.rs:1:13
[INFO] [stdout]   |
[INFO] [stdout] 1 | use super::{IDataCipher, ZmqError};
[INFO] [stdout]   |             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `IDataCipher` and `cipher::PassThroughDataCipher`
[INFO] [stdout]  --> src/security/null.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use super::{IDataCipher, Mechanism, MechanismStatus, cipher::PassThroughDataCipher};
[INFO] [stdout]   |             ^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `IDataCipher` and `cipher::PassThroughDataCipher`
[INFO] [stdout]  --> src/security/plain.rs:5:13
[INFO] [stdout]   |
[INFO] [stdout] 5 | use super::{IDataCipher, Mechanism, MechanismStatus, cipher::PassThroughDataCipher};
[INFO] [stdout]   |             ^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::message::Metadata`
[INFO] [stdout]   --> src/security/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::message::Metadata;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::os::fd::AsRawFd`
[INFO] [stdout]   --> src/sessionx/actor.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::os::fd::AsRawFd; // For AsRawFd bound if S needs it for cork_info init
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BufMut` and `BytesMut`
[INFO] [stdout]  --> src/sessionx/protocol_handler/data_io.rs:8:13
[INFO] [stdout]   |
[INFO] [stdout] 8 | use bytes::{BufMut, BytesMut};
[INFO] [stdout]   |             ^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `command_processor`
[INFO] [stdout]  --> src/socket/core/pipe_manager.rs:9:39
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::socket::core::{SocketCore, command_processor};
[INFO] [stdout]   |                                       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ActorType`
[INFO] [stdout]   --> src/socket/core/mod.rs:10:31
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::runtime::{mailbox, ActorType, MailboxSender};
[INFO] [stdout]    |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `pipe_manager::send_msg_with_timeout`
[INFO] [stdout]   --> src/socket/core/mod.rs:14:16
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub(crate) use pipe_manager::send_msg_with_timeout;
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Blob`
[INFO] [stdout]    --> src/socket/patterns/router.rs:173:24
[INFO] [stdout]     |
[INFO] [stdout] 173 |   use crate::message::{Blob, Msg, MsgFlags};
[INFO] [stdout]     |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fair_queue::FairQueue`
[INFO] [stdout]   --> src/socket/patterns/mod.rs:10:16
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub(crate) use fair_queue::FairQueue;
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `command::Command` and `mailbox::MailboxSender as SessionMailboxSender`
[INFO] [stdout]  --> src/socket/connection_iface.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::runtime::{command::Command, mailbox::MailboxSender as SessionMailboxSender};
[INFO] [stdout]   |                      ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]   --> src/socket/connection_iface.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use std::time::Duration;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::socket::core::pipe_manager::run_pipe_reader_task`
[INFO] [stdout]  --> src/transport/inproc.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::socket::core::pipe_manager::run_pipe_reader_task;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SocketAddr as StdSocketAddr`
[INFO] [stdout]   --> src/transport/tcp.rs:34:16
[INFO] [stdout]    |
[INFO] [stdout] 34 | use std::net::{SocketAddr as StdSocketAddr, ToSocketAddrs};
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug`, `error`, `info`, `trace`, and `warn`
[INFO] [stdout]   --> src/transport/tcp.rs:42:15
[INFO] [stdout]    |
[INFO] [stdout] 42 | use tracing::{debug, error, info, trace, warn};
[INFO] [stdout]    |               ^^^^^  ^^^^^  ^^^^  ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MailboxSender`
[INFO] [stdout]   --> src/lib.rs:42:43
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub(crate) use runtime::{MailboxReceiver, MailboxSender};
[INFO] [stdout]    |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/socket/core/command_processor.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 490 |     _ => bind_result = Err(ZmqError::UnsupportedTransport(endpoint.to_string())),
[INFO] [stdout]     |     ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/socket/core/command_processor.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 363 |     Ok(Endpoint::Tcp(_addr, ref uri_from_parse)) => {
[INFO] [stdout]     |     -------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 418 |     Ok(Endpoint::Ipc(ref path_buf, ref uri_from_parse)) => {
[INFO] [stdout]     |     --------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 469 |     Ok(Endpoint::Inproc(ref name)) => {
[INFO] [stdout]     |     ------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 489 |     Err(e) => bind_result = Err(e), // Error from parse_endpoint
[INFO] [stdout]     |     ------ matches some of the same values
[INFO] [stdout] 490 |     _ => bind_result = Err(ZmqError::UnsupportedTransport(endpoint.to_string())),
[INFO] [stdout]     |     ^ collectively making this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/socket/core/command_processor.rs:554:5
[INFO] [stdout]     |
[INFO] [stdout] 554 |     _ => {
[INFO] [stdout]     |     ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/socket/core/command_processor.rs:554:5
[INFO] [stdout]     |
[INFO] [stdout] 529 | /     Ok(Endpoint::Tcp(_, ref parsed_uri_for_connecter))
[INFO] [stdout] 530 | |     | Ok(Endpoint::Ipc(_, ref parsed_uri_for_connecter)) => {
[INFO] [stdout]     | |________________________________________________________- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 542 |       Ok(Endpoint::Inproc(ref name)) => {
[INFO] [stdout]     |       ------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 551 |       Err(e) => {
[INFO] [stdout]     |       ------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 554 |       _ => {
[INFO] [stdout]     |       ^ collectively making this unreachable
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/socket/core/command_processor.rs:633:5
[INFO] [stdout]     |
[INFO] [stdout] 633 |     _ => {
[INFO] [stdout]     |     ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/socket/core/command_processor.rs:633:5
[INFO] [stdout]     |
[INFO] [stdout] 575 |     Ok(Endpoint::Tcp(_, _)) => {
[INFO] [stdout]     |     ----------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 598 |     Ok(Endpoint::Ipc(path_buf, _)) => {
[INFO] [stdout]     |     ------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 618 |     Ok(Endpoint::Inproc(_)) => {
[INFO] [stdout]     |     ----------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 621 |     Err(err) => {
[INFO] [stdout]     |     -------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 633 |     _ => {
[INFO] [stdout]     |     ^ collectively making this unreachable
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/ipc.rs:277:19
[INFO] [stdout]     |
[INFO] [stdout] 277 |               let mut setup_successful = true;
[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: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/ipc.rs:467:9
[INFO] [stdout]     |
[INFO] [stdout] 467 |     let mut connection_outcome: Result<
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/tcp.rs:187:29
[INFO] [stdout]     |
[INFO] [stdout] 187 |   async fn run_command_loop(mut self, parent_socket_id: usize) {
[INFO] [stdout]     |                             ----^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/tcp.rs:354:19
[INFO] [stdout]     |
[INFO] [stdout] 354 |               let mut sca_or_session_join_handle_opt: Option<JoinHandle<()>> = None;
[INFO] [stdout]     |                   ----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                   |
[INFO] [stdout]     |                   help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `connection_instance_id`
[INFO] [stdout]    --> src/socket/core/event_processor.rs:269:7
[INFO] [stdout]     |
[INFO] [stdout] 269 |   let connection_instance_id = match &interaction_model_from_event {
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_connection_instance_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `final_connection_iface`
[INFO] [stdout]    --> src/socket/core/event_processor.rs:288:7
[INFO] [stdout]     |
[INFO] [stdout] 288 |   let final_connection_iface: Arc<dyn ISocketConnection>;
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_connection_iface`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `connector_context_clone`
[INFO] [stdout]    --> src/transport/inproc.rs:100:7
[INFO] [stdout]     |
[INFO] [stdout] 100 |   let connector_context_clone = core_arc.context.clone();
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_connector_context_clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `destination_identity_msg`
[INFO] [stdout]    --> src/socket/patterns/router.rs:248:7
[INFO] [stdout]     |
[INFO] [stdout] 248 |       destination_identity_msg: Msg,
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_destination_identity_msg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/socket/dealer_socket.rs:470:11
[INFO] [stdout]     |
[INFO] [stdout] 470 |       let mut transaction_guard = self.current_send_transaction.lock().await;
[INFO] [stdout]     |           ----^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |           |
[INFO] [stdout]     |           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `managing_actor_task_id_for_event` is never read
[INFO] [stdout]    --> src/transport/ipc.rs:276:74
[INFO] [stdout]     |
[INFO] [stdout] 276 |               let mut managing_actor_task_id_for_event: Option<TaskId> = None;
[INFO] [stdout]     |                                                                          ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sca_or_session_join_handle_opt`
[INFO] [stdout]    --> src/transport/tcp.rs:354:19
[INFO] [stdout]     |
[INFO] [stdout] 354 |               let mut sca_or_session_join_handle_opt: Option<JoinHandle<()>> = None;
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sca_or_session_join_handle_opt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `setup_successful` is never read
[INFO] [stdout]    --> src/transport/tcp.rs:485:19
[INFO] [stdout]     |
[INFO] [stdout] 485 |                   setup_successful = false;
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ISocketConnection` is more private than the item `SystemEvent::NewConnectionEstablished::connection_iface`
[INFO] [stdout]   --> src/runtime/system_events.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 |     connection_iface: Option<Arc<dyn ISocketConnection>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ field `SystemEvent::NewConnectionEstablished::connection_iface` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but trait `ISocketConnection` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/socket/connection_iface.rs:33:1
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub(crate) trait ISocketConnection: Send + Sync + fmt::Debug {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `ProcessTokenAction` is more private than the item `Mechanism::process_token`
[INFO] [stdout]   --> src/security/mechanism.rs:36:3
[INFO] [stdout]    |
[INFO] [stdout] 36 |   fn process_token(&mut self, token: &[u8]) -> Result<ProcessTokenAction, ZmqError>;
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Mechanism::process_token` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `ProcessTokenAction` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/security/mechanism.rs:16:1
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub(crate) enum ProcessTokenAction {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ISecureFramer` is more private than the item `Mechanism::into_framer`
[INFO] [stdout]   --> src/security/mechanism.rs:88:1
[INFO] [stdout]    |
[INFO] [stdout] 88 | fn into_framer(self: Box<Self>) -> Result<(Box<dyn ISecureFramer>, Option<Vec<u8>>), ZmqError>;
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Mechanism::into_framer` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but trait `ISecureFramer` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/security/framer.rs:9:1
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub(crate) trait ISecureFramer: Send + Sync + 'static {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `PipeState` is more private than the item `WritePipeCoordinator::remove_pipe`
[INFO] [stdout]   --> src/socket/patterns/pipe_coordinator.rs:46:3
[INFO] [stdout]    |
[INFO] [stdout] 46 |   pub async fn remove_pipe(&self, pipe_id: PipeId) -> Option<Arc<PipeState>> {
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `WritePipeCoordinator::remove_pipe` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `PipeState` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/socket/patterns/pipe_coordinator.rs:12:1
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct PipeState {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `binder_core_id` is never read
[INFO] [stdout]   --> src/context.rs:25:14
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub(crate) struct InprocBinding {
[INFO] [stdout]    |                   ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 25 |   pub(crate) binder_core_id: usize,
[INFO] [stdout]    |              ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `InprocBinding` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_socket_command_sender` is never used
[INFO] [stdout]    --> src/context.rs:220:17
[INFO] [stdout]     |
[INFO] [stdout]  55 | impl ContextInner {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 220 |   pub(crate) fn get_socket_command_sender(&self, handle: usize) -> Option<MailboxSender> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PeerAddress` is never constructed
[INFO] [stdout]   --> src/message/metadata.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub struct PeerAddress(pub SocketAddr);
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZapUserId` is never constructed
[INFO] [stdout]   --> src/message/metadata.rs:80:12
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub struct ZapUserId(pub String);
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `notify` is never read
[INFO] [stdout]  --> src/runtime/latch.rs:8:3
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub(crate) struct CountDownLatch {
[INFO] [stdout]   |                   -------------- field in this struct
[INFO] [stdout] 7 |   count: Arc<AtomicUsize>,
[INFO] [stdout] 8 |   notify: Arc<Notify>,
[INFO] [stdout]   |   ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `CountDownLatch` 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 items `new`, `count_down`, and `await_` are never used
[INFO] [stdout]   --> src/runtime/latch.rs:13:10
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl CountDownLatch {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 12 |   /// Creates a new latch initialized with the given count.
[INFO] [stdout] 13 |   pub fn new(count: usize) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |   pub async fn count_down(&self) {
[INFO] [stdout]    |                ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |   pub async fn await_(&self) {
[INFO] [stdout]    |                ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `IDataCipher` is never used
[INFO] [stdout]  --> src/security/cipher.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub trait IDataCipher: Send + Sync + 'static {
[INFO] [stdout]   |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PassThroughDataCipher` is never constructed
[INFO] [stdout]   --> src/security/cipher.rs:18:19
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub(crate) struct PassThroughDataCipher;
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LengthPrefixedFramer` is never constructed
[INFO] [stdout]   --> src/security/framer.rs:44:19
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub(crate) struct LengthPrefixedFramer {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/security/framer.rs:51:17
[INFO] [stdout]    |
[INFO] [stdout] 50 | impl LengthPrefixedFramer {
[INFO] [stdout]    | ------------------------- associated function in this implementation
[INFO] [stdout] 51 |   pub(crate) fn new(cipher: Box<dyn IDataCipher>) -> Self {
[INFO] [stdout]    |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ContinueWaiting` is never constructed
[INFO] [stdout]   --> src/security/mechanism.rs:18:3
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub(crate) enum ProcessTokenAction {
[INFO] [stdout]    |                 ------------------ variant in this enum
[INFO] [stdout] 17 |   /// No immediate action is required. The handler should wait for the next event.
[INFO] [stdout] 18 |   ContinueWaiting,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProcessTokenAction` 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: variant `Initializing` is never constructed
[INFO] [stdout]   --> src/security/plain.rs:10:3
[INFO] [stdout]    |
[INFO] [stdout]  9 | enum PlainState {
[INFO] [stdout]    |      ---------- variant in this enum
[INFO] [stdout] 10 |   Initializing, // Start state (not strictly used as we set initial state in new())
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PlainState` 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 `fd` and `is_expecting_first_frame` are never used
[INFO] [stdout]   --> src/sessionx/cork.rs:39:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl TcpCorkInfoX {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 39 |   pub(crate) fn fd(&self) -> RawFd {
[INFO] [stdout]    |                 ^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |   pub(crate) fn is_expecting_first_frame(&self) -> bool {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SourcePipeReadId` is never constructed
[INFO] [stdout]    --> src/socket/mod.rs:228:8
[INFO] [stdout]     |
[INFO] [stdout] 228 | struct SourcePipeReadId(usize);
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_pipe_reader_task` is never used
[INFO] [stdout]   --> src/socket/core/pipe_manager.rs:23:21
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub(crate) async fn run_pipe_reader_task(
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cleanup_session_state_by_uri` is never used
[INFO] [stdout]    --> src/socket/core/pipe_manager.rs:271:21
[INFO] [stdout]     |
[INFO] [stdout] 271 | pub(crate) async fn cleanup_session_state_by_uri(
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `send_msg_with_timeout` is never used
[INFO] [stdout]    --> src/socket/core/pipe_manager.rs:640:21
[INFO] [stdout]     |
[INFO] [stdout] 640 | pub(crate) async fn send_msg_with_timeout(
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `current_phase` is never used
[INFO] [stdout]   --> src/socket/core/shutdown.rs:14:17
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl ShutdownCoordinator {
[INFO] [stdout]    | ------------------------ method in this implementation
[INFO] [stdout] 14 |   pub(crate) fn current_phase(&self) -> ShutdownPhase {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_pipe_sender` is never used
[INFO] [stdout]    --> src/socket/core/state.rs:102:17
[INFO] [stdout]     |
[INFO] [stdout]  83 | impl CoreState {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 102 |   pub(crate) fn get_pipe_sender(&self, pipe_write_id: usize) -> Option<AsyncSender<Vec<Msg>>> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `use_send_zerocopy` and `use_recv_multishot` are never read
[INFO] [stdout]    --> src/socket/options.rs:214:7
[INFO] [stdout]     |
[INFO] [stdout] 202 | pub(crate) struct ZmtpEngineConfig {
[INFO] [stdout]     |                   ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 214 |   pub use_send_zerocopy: bool,
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 215 |   pub use_recv_multishot: bool,
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ZmtpEngineConfig` 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: function `parse_duration_ms_option` is never used
[INFO] [stdout]    --> src/socket/options.rs:300:15
[INFO] [stdout]     |
[INFO] [stdout] 300 | pub(crate) fn parse_duration_ms_option(value: &[u8]) -> Result<Option<Duration>, ZmqError> {
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_key_option` is never used
[INFO] [stdout]    --> src/socket/options.rs:443:15
[INFO] [stdout]     |
[INFO] [stdout] 443 | pub(crate) fn parse_key_option<const N: usize>(
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `hwm` is never read
[INFO] [stdout]   --> src/socket/patterns/fair_queue.rs:16:3
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub(crate) struct FairQueue<T: Send + 'static> {
[INFO] [stdout]    |                   --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 16 |   hwm: usize,
[INFO] [stdout]    |   ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FairQueue` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `pipe_attached`, `pipe_detached`, `capacity`, `len`, and `is_empty` are never used
[INFO] [stdout]   --> src/socket/patterns/fair_queue.rs:31:10
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl<T: Send + 'static> FairQueue<T> {
[INFO] [stdout]    | ------------------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |   pub fn pipe_attached(&self, pipe_read_id: usize) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |   pub fn pipe_detached(&self, pipe_read_id: usize) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 82 |   pub fn capacity(&self) -> usize {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 87 |   pub fn len(&self) -> usize {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 92 |   pub fn is_empty(&self) -> bool {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_identity_by_read_pipe` is never used
[INFO] [stdout]   --> src/socket/patterns/router.rs:97:16
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl RouterMap {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 97 |   pub async fn get_identity_by_read_pipe(&self, pipe_read_id: usize) -> Option<Blob> {
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_connection_id` and `as_any` are never used
[INFO] [stdout]   --> src/socket/connection_iface.rs:45:6
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub(crate) trait ISocketConnection: Send + Sync + fmt::Debug {
[INFO] [stdout]    |                  ----------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 45 |   fn get_connection_id(&self) -> usize;
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 46 |   fn as_any(&self) -> &dyn Any;
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `socket_logic` is never read
[INFO] [stdout]   --> src/transport/ipc.rs:36:3
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub(crate) struct IpcListener {
[INFO] [stdout]    |                   ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 36 |   socket_logic: Arc<dyn ISocket>,
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `socket_logic` is never read
[INFO] [stdout]   --> src/transport/tcp.rs:57:3
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub(crate) struct TcpListener {
[INFO] [stdout]    |                   ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 57 |   socket_logic: Arc<dyn ISocket>,
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_current_balance` is never used
[INFO] [stdout]    --> src/throttle/mod.rs:174:10
[INFO] [stdout]     |
[INFO] [stdout] 173 | impl ThrottleGuard {
[INFO] [stdout]     | ------------------ method in this implementation
[INFO] [stdout] 174 |   pub fn get_current_balance(&self) -> i32 {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `linear_strategy` is never used
[INFO] [stdout]   --> src/throttle/strategies.rs:35:8
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub fn linear_strategy(state: &ThrottleStateView) -> f64 {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SegmentTiming` is never constructed
[INFO] [stdout]   --> src/profiler.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct SegmentTiming {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LoopProfiler` is never constructed
[INFO] [stdout]   --> src/profiler.rs:19:19
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub(crate) struct LoopProfiler {
[INFO] [stdout]    |                   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `INITIAL_SEGMENT_LABEL`, `new`, `loop_start`, `mark_segment_end_and_start_new`, and `log_and_reset_for_next_loop` are never used
[INFO] [stdout]   --> src/profiler.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl LoopProfiler {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 31 |   const INITIAL_SEGMENT_LABEL: &'static str = "loop_setup";
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 32 |
[INFO] [stdout] 33 |   pub fn new(threshold: Duration, log_interval: usize) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |   pub fn loop_start(&mut self) {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |   pub fn mark_segment_end_and_start_new(&mut self, next_segment_label: &'static str) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |   pub fn log_and_reset_for_next_loop(&mut self) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/socket/patterns/fair_queue.rs:97:5
[INFO] [stdout]    |
[INFO] [stdout] 97 |     self.sender.close();
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 97 |     let _ = self.sender.close();
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 32.98s
[INFO] running `Command { std: "docker" "inspect" "590f0aa5386ef286cbdf2c257de0525765a4fdcfec0f3cd5755bf847280b8292", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "590f0aa5386ef286cbdf2c257de0525765a4fdcfec0f3cd5755bf847280b8292", kill_on_drop: false }`
[INFO] [stdout] 590f0aa5386ef286cbdf2c257de0525765a4fdcfec0f3cd5755bf847280b8292
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 4f4b7a2504c19d8c814487a66d10ec6decde8a58877464686639569c09097f98
[INFO] running `Command { std: "docker" "start" "-a" "4f4b7a2504c19d8c814487a66d10ec6decde8a58877464686639569c09097f98", kill_on_drop: false }`
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling ciborium-io v0.2.2
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling plotters-backend v0.3.7
[INFO] [stderr]    Compiling zerocopy-derive v0.8.27
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]    Compiling clap_builder v4.5.51
[INFO] [stderr]    Compiling tokio v1.48.0
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling cast v0.3.0
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling is-terminal v0.4.17
[INFO] [stderr]    Compiling anes v0.1.6
[INFO] [stderr]    Compiling sdd v3.0.10
[INFO] [stderr]    Compiling oorandom v11.1.5
[INFO] [stderr]    Compiling serial_test_derive v3.2.0
[INFO] [stderr]    Compiling itertools v0.12.1
[INFO] [stderr]    Compiling scc v2.4.0
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling nu-ansi-term v0.50.3
[INFO] [stderr]    Compiling plotters-svg v0.3.7
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]    Compiling criterion-plot v0.5.0
[INFO] [stderr]    Compiling plotters v0.3.7
[INFO] [stderr]    Compiling clap v4.5.51
[INFO] [stderr]    Compiling half v2.7.1
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling serial_test v3.2.0
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling ciborium-ll v0.2.2
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling tracing-subscriber v0.3.20
[INFO] [stderr]    Compiling tinytemplate v1.2.1
[INFO] [stderr]    Compiling ciborium v0.2.2
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling tokio-util v0.7.17
[INFO] [stderr]    Compiling criterion v0.5.1
[INFO] [stderr]    Compiling tokio-test v0.4.4
[INFO] [stderr]    Compiling rzmq v0.5.7 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the usage of Script Group `Greek` in this crate consists solely of mixed script confusables
[INFO] [stdout]    --> src/throttle/mod.rs:129:11
[INFO] [stdout]     |
[INFO] [stdout] 129 |       let α = self.shared.config.adaptive_learning_rate;
[INFO] [stdout]     |           ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: the usage includes 'α' (U+03B1)
[INFO] [stdout]     = note: please recheck to make sure their usages are indeed what you want
[INFO] [stdout]     = note: `#[warn(mixed_script_confusables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SystemEvent`
[INFO] [stdout]  --> src/runtime/actor_drop_guard.rs:3:33
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::runtime::{ActorType, SystemEvent}; // Adjust imports as needed
[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 imports: `AtomicBool` and `Ordering`
[INFO] [stdout]  --> src/runtime/actor_drop_guard.rs:5:25
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::sync::atomic::{AtomicBool, Ordering};
[INFO] [stdout]   |                         ^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/runtime/actor_drop_guard.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `latch::CountDownLatch`
[INFO] [stdout]   --> src/runtime/mod.rs:20:16
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub(crate) use latch::CountDownLatch;
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `IDataCipher`
[INFO] [stdout]  --> src/security/mechanism.rs:1:13
[INFO] [stdout]   |
[INFO] [stdout] 1 | use super::{IDataCipher, ZmqError};
[INFO] [stdout]   |             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `IDataCipher` and `cipher::PassThroughDataCipher`
[INFO] [stdout]  --> src/security/null.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use super::{IDataCipher, Mechanism, MechanismStatus, cipher::PassThroughDataCipher};
[INFO] [stdout]   |             ^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `IDataCipher` and `cipher::PassThroughDataCipher`
[INFO] [stdout]  --> src/security/plain.rs:5:13
[INFO] [stdout]   |
[INFO] [stdout] 5 | use super::{IDataCipher, Mechanism, MechanismStatus, cipher::PassThroughDataCipher};
[INFO] [stdout]   |             ^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::message::Metadata`
[INFO] [stdout]   --> src/security/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::message::Metadata;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::os::fd::AsRawFd`
[INFO] [stdout]   --> src/sessionx/actor.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::os::fd::AsRawFd; // For AsRawFd bound if S needs it for cork_info init
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BufMut` and `BytesMut`
[INFO] [stdout]  --> src/sessionx/protocol_handler/data_io.rs:8:13
[INFO] [stdout]   |
[INFO] [stdout] 8 | use bytes::{BufMut, BytesMut};
[INFO] [stdout]   |             ^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `command_processor`
[INFO] [stdout]  --> src/socket/core/pipe_manager.rs:9:39
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::socket::core::{SocketCore, command_processor};
[INFO] [stdout]   |                                       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ActorType`
[INFO] [stdout]   --> src/socket/core/mod.rs:10:31
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::runtime::{mailbox, ActorType, MailboxSender};
[INFO] [stdout]    |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `pipe_manager::send_msg_with_timeout`
[INFO] [stdout]   --> src/socket/core/mod.rs:14:16
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub(crate) use pipe_manager::send_msg_with_timeout;
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Blob`
[INFO] [stdout]    --> src/socket/patterns/router.rs:173:24
[INFO] [stdout]     |
[INFO] [stdout] 173 |   use crate::message::{Blob, Msg, MsgFlags};
[INFO] [stdout]     |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fair_queue::FairQueue`
[INFO] [stdout]   --> src/socket/patterns/mod.rs:10:16
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub(crate) use fair_queue::FairQueue;
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `command::Command` and `mailbox::MailboxSender as SessionMailboxSender`
[INFO] [stdout]  --> src/socket/connection_iface.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::runtime::{command::Command, mailbox::MailboxSender as SessionMailboxSender};
[INFO] [stdout]   |                      ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]   --> src/socket/connection_iface.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use std::time::Duration;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::socket::core::pipe_manager::run_pipe_reader_task`
[INFO] [stdout]  --> src/transport/inproc.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::socket::core::pipe_manager::run_pipe_reader_task;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SocketAddr as StdSocketAddr`
[INFO] [stdout]   --> src/transport/tcp.rs:34:16
[INFO] [stdout]    |
[INFO] [stdout] 34 | use std::net::{SocketAddr as StdSocketAddr, ToSocketAddrs};
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug`, `error`, `info`, `trace`, and `warn`
[INFO] [stdout]   --> src/transport/tcp.rs:42:15
[INFO] [stdout]    |
[INFO] [stdout] 42 | use tracing::{debug, error, info, trace, warn};
[INFO] [stdout]    |               ^^^^^  ^^^^^  ^^^^  ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MailboxSender`
[INFO] [stdout]   --> src/lib.rs:42:43
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub(crate) use runtime::{MailboxReceiver, MailboxSender};
[INFO] [stdout]    |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/socket/core/command_processor.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 490 |     _ => bind_result = Err(ZmqError::UnsupportedTransport(endpoint.to_string())),
[INFO] [stdout]     |     ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/socket/core/command_processor.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 363 |     Ok(Endpoint::Tcp(_addr, ref uri_from_parse)) => {
[INFO] [stdout]     |     -------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 418 |     Ok(Endpoint::Ipc(ref path_buf, ref uri_from_parse)) => {
[INFO] [stdout]     |     --------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 469 |     Ok(Endpoint::Inproc(ref name)) => {
[INFO] [stdout]     |     ------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 489 |     Err(e) => bind_result = Err(e), // Error from parse_endpoint
[INFO] [stdout]     |     ------ matches some of the same values
[INFO] [stdout] 490 |     _ => bind_result = Err(ZmqError::UnsupportedTransport(endpoint.to_string())),
[INFO] [stdout]     |     ^ collectively making this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling bench_matrix v0.2.0
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/socket/core/command_processor.rs:554:5
[INFO] [stdout]     |
[INFO] [stdout] 554 |     _ => {
[INFO] [stdout]     |     ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/socket/core/command_processor.rs:554:5
[INFO] [stdout]     |
[INFO] [stdout] 529 | /     Ok(Endpoint::Tcp(_, ref parsed_uri_for_connecter))
[INFO] [stdout] 530 | |     | Ok(Endpoint::Ipc(_, ref parsed_uri_for_connecter)) => {
[INFO] [stdout]     | |________________________________________________________- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 542 |       Ok(Endpoint::Inproc(ref name)) => {
[INFO] [stdout]     |       ------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 551 |       Err(e) => {
[INFO] [stdout]     |       ------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 554 |       _ => {
[INFO] [stdout]     |       ^ collectively making this unreachable
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/socket/core/command_processor.rs:633:5
[INFO] [stdout]     |
[INFO] [stdout] 633 |     _ => {
[INFO] [stdout]     |     ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/socket/core/command_processor.rs:633:5
[INFO] [stdout]     |
[INFO] [stdout] 575 |     Ok(Endpoint::Tcp(_, _)) => {
[INFO] [stdout]     |     ----------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 598 |     Ok(Endpoint::Ipc(path_buf, _)) => {
[INFO] [stdout]     |     ------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 618 |     Ok(Endpoint::Inproc(_)) => {
[INFO] [stdout]     |     ----------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 621 |     Err(err) => {
[INFO] [stdout]     |     -------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 633 |     _ => {
[INFO] [stdout]     |     ^ collectively making this unreachable
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/ipc.rs:277:19
[INFO] [stdout]     |
[INFO] [stdout] 277 |               let mut setup_successful = true;
[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: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/ipc.rs:467:9
[INFO] [stdout]     |
[INFO] [stdout] 467 |     let mut connection_outcome: Result<
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/tcp.rs:187:29
[INFO] [stdout]     |
[INFO] [stdout] 187 |   async fn run_command_loop(mut self, parent_socket_id: usize) {
[INFO] [stdout]     |                             ----^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/tcp.rs:354:19
[INFO] [stdout]     |
[INFO] [stdout] 354 |               let mut sca_or_session_join_handle_opt: Option<JoinHandle<()>> = None;
[INFO] [stdout]     |                   ----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                   |
[INFO] [stdout]     |                   help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the usage of Script Group `Greek` in this crate consists solely of mixed script confusables
[INFO] [stdout]    --> src/throttle/mod.rs:129:11
[INFO] [stdout]     |
[INFO] [stdout] 129 |       let α = self.shared.config.adaptive_learning_rate;
[INFO] [stdout]     |           ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: the usage includes 'α' (U+03B1)
[INFO] [stdout]     = note: please recheck to make sure their usages are indeed what you want
[INFO] [stdout]     = note: `#[warn(mixed_script_confusables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SystemEvent`
[INFO] [stdout]  --> src/runtime/actor_drop_guard.rs:3:33
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::runtime::{ActorType, SystemEvent}; // Adjust imports as needed
[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 imports: `AtomicBool` and `Ordering`
[INFO] [stdout]  --> src/runtime/actor_drop_guard.rs:5:25
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::sync::atomic::{AtomicBool, Ordering};
[INFO] [stdout]   |                         ^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/runtime/actor_drop_guard.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `latch::CountDownLatch`
[INFO] [stdout]   --> src/runtime/mod.rs:20:16
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub(crate) use latch::CountDownLatch;
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `IDataCipher`
[INFO] [stdout]  --> src/security/mechanism.rs:1:13
[INFO] [stdout]   |
[INFO] [stdout] 1 | use super::{IDataCipher, ZmqError};
[INFO] [stdout]   |             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `IDataCipher` and `cipher::PassThroughDataCipher`
[INFO] [stdout]  --> src/security/null.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use super::{IDataCipher, Mechanism, MechanismStatus, cipher::PassThroughDataCipher};
[INFO] [stdout]   |             ^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `IDataCipher` and `cipher::PassThroughDataCipher`
[INFO] [stdout]  --> src/security/plain.rs:5:13
[INFO] [stdout]   |
[INFO] [stdout] 5 | use super::{IDataCipher, Mechanism, MechanismStatus, cipher::PassThroughDataCipher};
[INFO] [stdout]   |             ^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::message::Metadata`
[INFO] [stdout]   --> src/security/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::message::Metadata;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::os::fd::AsRawFd`
[INFO] [stdout]   --> src/sessionx/actor.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::os::fd::AsRawFd; // For AsRawFd bound if S needs it for cork_info init
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BufMut` and `BytesMut`
[INFO] [stdout]  --> src/sessionx/protocol_handler/data_io.rs:8:13
[INFO] [stdout]   |
[INFO] [stdout] 8 | use bytes::{BufMut, BytesMut};
[INFO] [stdout]   |             ^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `command_processor`
[INFO] [stdout]  --> src/socket/core/pipe_manager.rs:9:39
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::socket::core::{SocketCore, command_processor};
[INFO] [stdout]   |                                       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ActorType`
[INFO] [stdout]   --> src/socket/core/mod.rs:10:31
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::runtime::{mailbox, ActorType, MailboxSender};
[INFO] [stdout]    |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `pipe_manager::send_msg_with_timeout`
[INFO] [stdout]   --> src/socket/core/mod.rs:14:16
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub(crate) use pipe_manager::send_msg_with_timeout;
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Blob`
[INFO] [stdout]    --> src/socket/patterns/router.rs:173:24
[INFO] [stdout]     |
[INFO] [stdout] 173 |   use crate::message::{Blob, Msg, MsgFlags};
[INFO] [stdout]     |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fair_queue::FairQueue`
[INFO] [stdout]   --> src/socket/patterns/mod.rs:10:16
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub(crate) use fair_queue::FairQueue;
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `command::Command` and `mailbox::MailboxSender as SessionMailboxSender`
[INFO] [stdout]  --> src/socket/connection_iface.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::runtime::{command::Command, mailbox::MailboxSender as SessionMailboxSender};
[INFO] [stdout]   |                      ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]   --> src/socket/connection_iface.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use std::time::Duration;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::socket::core::pipe_manager::run_pipe_reader_task`
[INFO] [stdout]  --> src/transport/inproc.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::socket::core::pipe_manager::run_pipe_reader_task;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SocketAddr as StdSocketAddr`
[INFO] [stdout]   --> src/transport/tcp.rs:34:16
[INFO] [stdout]    |
[INFO] [stdout] 34 | use std::net::{SocketAddr as StdSocketAddr, ToSocketAddrs};
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug`, `error`, `info`, `trace`, and `warn`
[INFO] [stdout]   --> src/transport/tcp.rs:42:15
[INFO] [stdout]    |
[INFO] [stdout] 42 | use tracing::{debug, error, info, trace, warn};
[INFO] [stdout]    |               ^^^^^  ^^^^^  ^^^^  ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MailboxSender`
[INFO] [stdout]   --> src/lib.rs:42:43
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub(crate) use runtime::{MailboxReceiver, MailboxSender};
[INFO] [stdout]    |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/socket/core/command_processor.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 490 |     _ => bind_result = Err(ZmqError::UnsupportedTransport(endpoint.to_string())),
[INFO] [stdout]     |     ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/socket/core/command_processor.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 363 |     Ok(Endpoint::Tcp(_addr, ref uri_from_parse)) => {
[INFO] [stdout]     |     -------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 418 |     Ok(Endpoint::Ipc(ref path_buf, ref uri_from_parse)) => {
[INFO] [stdout]     |     --------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 469 |     Ok(Endpoint::Inproc(ref name)) => {
[INFO] [stdout]     |     ------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 489 |     Err(e) => bind_result = Err(e), // Error from parse_endpoint
[INFO] [stdout]     |     ------ matches some of the same values
[INFO] [stdout] 490 |     _ => bind_result = Err(ZmqError::UnsupportedTransport(endpoint.to_string())),
[INFO] [stdout]     |     ^ collectively making this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/socket/core/command_processor.rs:554:5
[INFO] [stdout]     |
[INFO] [stdout] 554 |     _ => {
[INFO] [stdout]     |     ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/socket/core/command_processor.rs:554:5
[INFO] [stdout]     |
[INFO] [stdout] 529 | /     Ok(Endpoint::Tcp(_, ref parsed_uri_for_connecter))
[INFO] [stdout] 530 | |     | Ok(Endpoint::Ipc(_, ref parsed_uri_for_connecter)) => {
[INFO] [stdout]     | |________________________________________________________- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 542 |       Ok(Endpoint::Inproc(ref name)) => {
[INFO] [stdout]     |       ------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 551 |       Err(e) => {
[INFO] [stdout]     |       ------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 554 |       _ => {
[INFO] [stdout]     |       ^ collectively making this unreachable
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/socket/core/command_processor.rs:633:5
[INFO] [stdout]     |
[INFO] [stdout] 633 |     _ => {
[INFO] [stdout]     |     ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/socket/core/command_processor.rs:633:5
[INFO] [stdout]     |
[INFO] [stdout] 575 |     Ok(Endpoint::Tcp(_, _)) => {
[INFO] [stdout]     |     ----------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 598 |     Ok(Endpoint::Ipc(path_buf, _)) => {
[INFO] [stdout]     |     ------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 618 |     Ok(Endpoint::Inproc(_)) => {
[INFO] [stdout]     |     ----------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 621 |     Err(err) => {
[INFO] [stdout]     |     -------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 633 |     _ => {
[INFO] [stdout]     |     ^ collectively making this unreachable
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/ipc.rs:277:19
[INFO] [stdout]     |
[INFO] [stdout] 277 |               let mut setup_successful = true;
[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: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/ipc.rs:467:9
[INFO] [stdout]     |
[INFO] [stdout] 467 |     let mut connection_outcome: Result<
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/tcp.rs:187:29
[INFO] [stdout]     |
[INFO] [stdout] 187 |   async fn run_command_loop(mut self, parent_socket_id: usize) {
[INFO] [stdout]     |                             ----^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/transport/tcp.rs:354:19
[INFO] [stdout]     |
[INFO] [stdout] 354 |               let mut sca_or_session_join_handle_opt: Option<JoinHandle<()>> = None;
[INFO] [stdout]     |                   ----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                   |
[INFO] [stdout]     |                   help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `connection_instance_id`
[INFO] [stdout]    --> src/socket/core/event_processor.rs:269:7
[INFO] [stdout]     |
[INFO] [stdout] 269 |   let connection_instance_id = match &interaction_model_from_event {
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_connection_instance_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `final_connection_iface`
[INFO] [stdout]    --> src/socket/core/event_processor.rs:288:7
[INFO] [stdout]     |
[INFO] [stdout] 288 |   let final_connection_iface: Arc<dyn ISocketConnection>;
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_connection_iface`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `connector_context_clone`
[INFO] [stdout]    --> src/transport/inproc.rs:100:7
[INFO] [stdout]     |
[INFO] [stdout] 100 |   let connector_context_clone = core_arc.context.clone();
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_connector_context_clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `destination_identity_msg`
[INFO] [stdout]    --> src/socket/patterns/router.rs:248:7
[INFO] [stdout]     |
[INFO] [stdout] 248 |       destination_identity_msg: Msg,
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_destination_identity_msg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/socket/dealer_socket.rs:470:11
[INFO] [stdout]     |
[INFO] [stdout] 470 |       let mut transaction_guard = self.current_send_transaction.lock().await;
[INFO] [stdout]     |           ----^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |           |
[INFO] [stdout]     |           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `managing_actor_task_id_for_event` is never read
[INFO] [stdout]    --> src/transport/ipc.rs:276:74
[INFO] [stdout]     |
[INFO] [stdout] 276 |               let mut managing_actor_task_id_for_event: Option<TaskId> = None;
[INFO] [stdout]     |                                                                          ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sca_or_session_join_handle_opt`
[INFO] [stdout]    --> src/transport/tcp.rs:354:19
[INFO] [stdout]     |
[INFO] [stdout] 354 |               let mut sca_or_session_join_handle_opt: Option<JoinHandle<()>> = None;
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sca_or_session_join_handle_opt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `setup_successful` is never read
[INFO] [stdout]    --> src/transport/tcp.rs:485:19
[INFO] [stdout]     |
[INFO] [stdout] 485 |                   setup_successful = false;
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ISocketConnection` is more private than the item `SystemEvent::NewConnectionEstablished::connection_iface`
[INFO] [stdout]   --> src/runtime/system_events.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 |     connection_iface: Option<Arc<dyn ISocketConnection>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ field `SystemEvent::NewConnectionEstablished::connection_iface` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but trait `ISocketConnection` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/socket/connection_iface.rs:33:1
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub(crate) trait ISocketConnection: Send + Sync + fmt::Debug {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `ProcessTokenAction` is more private than the item `Mechanism::process_token`
[INFO] [stdout]   --> src/security/mechanism.rs:36:3
[INFO] [stdout]    |
[INFO] [stdout] 36 |   fn process_token(&mut self, token: &[u8]) -> Result<ProcessTokenAction, ZmqError>;
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Mechanism::process_token` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `ProcessTokenAction` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/security/mechanism.rs:16:1
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub(crate) enum ProcessTokenAction {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ISecureFramer` is more private than the item `Mechanism::into_framer`
[INFO] [stdout]   --> src/security/mechanism.rs:88:1
[INFO] [stdout]    |
[INFO] [stdout] 88 | fn into_framer(self: Box<Self>) -> Result<(Box<dyn ISecureFramer>, Option<Vec<u8>>), ZmqError>;
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Mechanism::into_framer` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but trait `ISecureFramer` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/security/framer.rs:9:1
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub(crate) trait ISecureFramer: Send + Sync + 'static {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `PipeState` is more private than the item `WritePipeCoordinator::remove_pipe`
[INFO] [stdout]   --> src/socket/patterns/pipe_coordinator.rs:46:3
[INFO] [stdout]    |
[INFO] [stdout] 46 |   pub async fn remove_pipe(&self, pipe_id: PipeId) -> Option<Arc<PipeState>> {
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `WritePipeCoordinator::remove_pipe` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `PipeState` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/socket/patterns/pipe_coordinator.rs:12:1
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct PipeState {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `binder_core_id` is never read
[INFO] [stdout]   --> src/context.rs:25:14
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub(crate) struct InprocBinding {
[INFO] [stdout]    |                   ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 25 |   pub(crate) binder_core_id: usize,
[INFO] [stdout]    |              ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `InprocBinding` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_socket_command_sender` is never used
[INFO] [stdout]    --> src/context.rs:220:17
[INFO] [stdout]     |
[INFO] [stdout]  55 | impl ContextInner {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 220 |   pub(crate) fn get_socket_command_sender(&self, handle: usize) -> Option<MailboxSender> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PeerAddress` is never constructed
[INFO] [stdout]   --> src/message/metadata.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub struct PeerAddress(pub SocketAddr);
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZapUserId` is never constructed
[INFO] [stdout]   --> src/message/metadata.rs:80:12
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub struct ZapUserId(pub String);
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `notify` is never read
[INFO] [stdout]  --> src/runtime/latch.rs:8:3
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub(crate) struct CountDownLatch {
[INFO] [stdout]   |                   -------------- field in this struct
[INFO] [stdout] 7 |   count: Arc<AtomicUsize>,
[INFO] [stdout] 8 |   notify: Arc<Notify>,
[INFO] [stdout]   |   ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `CountDownLatch` 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 items `new`, `count_down`, and `await_` are never used
[INFO] [stdout]   --> src/runtime/latch.rs:13:10
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl CountDownLatch {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 12 |   /// Creates a new latch initialized with the given count.
[INFO] [stdout] 13 |   pub fn new(count: usize) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |   pub async fn count_down(&self) {
[INFO] [stdout]    |                ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |   pub async fn await_(&self) {
[INFO] [stdout]    |                ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `IDataCipher` is never used
[INFO] [stdout]  --> src/security/cipher.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub trait IDataCipher: Send + Sync + 'static {
[INFO] [stdout]   |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PassThroughDataCipher` is never constructed
[INFO] [stdout]   --> src/security/cipher.rs:18:19
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub(crate) struct PassThroughDataCipher;
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LengthPrefixedFramer` is never constructed
[INFO] [stdout]   --> src/security/framer.rs:44:19
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub(crate) struct LengthPrefixedFramer {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/security/framer.rs:51:17
[INFO] [stdout]    |
[INFO] [stdout] 50 | impl LengthPrefixedFramer {
[INFO] [stdout]    | ------------------------- associated function in this implementation
[INFO] [stdout] 51 |   pub(crate) fn new(cipher: Box<dyn IDataCipher>) -> Self {
[INFO] [stdout]    |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ContinueWaiting` is never constructed
[INFO] [stdout]   --> src/security/mechanism.rs:18:3
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub(crate) enum ProcessTokenAction {
[INFO] [stdout]    |                 ------------------ variant in this enum
[INFO] [stdout] 17 |   /// No immediate action is required. The handler should wait for the next event.
[INFO] [stdout] 18 |   ContinueWaiting,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProcessTokenAction` 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: variant `Initializing` is never constructed
[INFO] [stdout]   --> src/security/plain.rs:10:3
[INFO] [stdout]    |
[INFO] [stdout]  9 | enum PlainState {
[INFO] [stdout]    |      ---------- variant in this enum
[INFO] [stdout] 10 |   Initializing, // Start state (not strictly used as we set initial state in new())
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PlainState` 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 `fd` and `is_expecting_first_frame` are never used
[INFO] [stdout]   --> src/sessionx/cork.rs:39:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl TcpCorkInfoX {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 39 |   pub(crate) fn fd(&self) -> RawFd {
[INFO] [stdout]    |                 ^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |   pub(crate) fn is_expecting_first_frame(&self) -> bool {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SourcePipeReadId` is never constructed
[INFO] [stdout]    --> src/socket/mod.rs:228:8
[INFO] [stdout]     |
[INFO] [stdout] 228 | struct SourcePipeReadId(usize);
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_pipe_reader_task` is never used
[INFO] [stdout]   --> src/socket/core/pipe_manager.rs:23:21
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub(crate) async fn run_pipe_reader_task(
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cleanup_session_state_by_uri` is never used
[INFO] [stdout]    --> src/socket/core/pipe_manager.rs:271:21
[INFO] [stdout]     |
[INFO] [stdout] 271 | pub(crate) async fn cleanup_session_state_by_uri(
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `send_msg_with_timeout` is never used
[INFO] [stdout]    --> src/socket/core/pipe_manager.rs:640:21
[INFO] [stdout]     |
[INFO] [stdout] 640 | pub(crate) async fn send_msg_with_timeout(
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `current_phase` is never used
[INFO] [stdout]   --> src/socket/core/shutdown.rs:14:17
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl ShutdownCoordinator {
[INFO] [stdout]    | ------------------------ method in this implementation
[INFO] [stdout] 14 |   pub(crate) fn current_phase(&self) -> ShutdownPhase {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_pipe_sender` is never used
[INFO] [stdout]    --> src/socket/core/state.rs:102:17
[INFO] [stdout]     |
[INFO] [stdout]  83 | impl CoreState {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 102 |   pub(crate) fn get_pipe_sender(&self, pipe_write_id: usize) -> Option<AsyncSender<Vec<Msg>>> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `use_send_zerocopy` and `use_recv_multishot` are never read
[INFO] [stdout]    --> src/socket/options.rs:214:7
[INFO] [stdout]     |
[INFO] [stdout] 202 | pub(crate) struct ZmtpEngineConfig {
[INFO] [stdout]     |                   ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 214 |   pub use_send_zerocopy: bool,
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 215 |   pub use_recv_multishot: bool,
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ZmtpEngineConfig` 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: function `parse_duration_ms_option` is never used
[INFO] [stdout]    --> src/socket/options.rs:300:15
[INFO] [stdout]     |
[INFO] [stdout] 300 | pub(crate) fn parse_duration_ms_option(value: &[u8]) -> Result<Option<Duration>, ZmqError> {
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_key_option` is never used
[INFO] [stdout]    --> src/socket/options.rs:443:15
[INFO] [stdout]     |
[INFO] [stdout] 443 | pub(crate) fn parse_key_option<const N: usize>(
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `hwm` is never read
[INFO] [stdout]   --> src/socket/patterns/fair_queue.rs:16:3
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub(crate) struct FairQueue<T: Send + 'static> {
[INFO] [stdout]    |                   --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 16 |   hwm: usize,
[INFO] [stdout]    |   ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FairQueue` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `pipe_attached`, `pipe_detached`, `capacity`, `len`, and `is_empty` are never used
[INFO] [stdout]   --> src/socket/patterns/fair_queue.rs:31:10
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl<T: Send + 'static> FairQueue<T> {
[INFO] [stdout]    | ------------------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |   pub fn pipe_attached(&self, pipe_read_id: usize) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |   pub fn pipe_detached(&self, pipe_read_id: usize) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 82 |   pub fn capacity(&self) -> usize {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 87 |   pub fn len(&self) -> usize {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 92 |   pub fn is_empty(&self) -> bool {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_identity_by_read_pipe` is never used
[INFO] [stdout]   --> src/socket/patterns/router.rs:97:16
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl RouterMap {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 97 |   pub async fn get_identity_by_read_pipe(&self, pipe_read_id: usize) -> Option<Blob> {
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_connection_id` and `as_any` are never used
[INFO] [stdout]   --> src/socket/connection_iface.rs:45:6
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub(crate) trait ISocketConnection: Send + Sync + fmt::Debug {
[INFO] [stdout]    |                  ----------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 45 |   fn get_connection_id(&self) -> usize;
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 46 |   fn as_any(&self) -> &dyn Any;
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `socket_logic` is never read
[INFO] [stdout]   --> src/transport/ipc.rs:36:3
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub(crate) struct IpcListener {
[INFO] [stdout]    |                   ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 36 |   socket_logic: Arc<dyn ISocket>,
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `socket_logic` is never read
[INFO] [stdout]   --> src/transport/tcp.rs:57:3
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub(crate) struct TcpListener {
[INFO] [stdout]    |                   ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 57 |   socket_logic: Arc<dyn ISocket>,
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_current_balance` is never used
[INFO] [stdout]    --> src/throttle/mod.rs:174:10
[INFO] [stdout]     |
[INFO] [stdout] 173 | impl ThrottleGuard {
[INFO] [stdout]     | ------------------ method in this implementation
[INFO] [stdout] 174 |   pub fn get_current_balance(&self) -> i32 {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `linear_strategy` is never used
[INFO] [stdout]   --> src/throttle/strategies.rs:35:8
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub fn linear_strategy(state: &ThrottleStateView) -> f64 {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SegmentTiming` is never constructed
[INFO] [stdout]   --> src/profiler.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct SegmentTiming {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LoopProfiler` is never constructed
[INFO] [stdout]   --> src/profiler.rs:19:19
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub(crate) struct LoopProfiler {
[INFO] [stdout]    |                   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `INITIAL_SEGMENT_LABEL`, `new`, `loop_start`, `mark_segment_end_and_start_new`, and `log_and_reset_for_next_loop` are never used
[INFO] [stdout]   --> src/profiler.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl LoopProfiler {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 31 |   const INITIAL_SEGMENT_LABEL: &'static str = "loop_setup";
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 32 |
[INFO] [stdout] 33 |   pub fn new(threshold: Duration, log_interval: usize) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |   pub fn loop_start(&mut self) {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |   pub fn mark_segment_end_and_start_new(&mut self, next_segment_label: &'static str) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |   pub fn log_and_reset_for_next_loop(&mut self) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/socket/patterns/fair_queue.rs:97:5
[INFO] [stdout]    |
[INFO] [stdout] 97 |     self.sender.close();
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 97 |     let _ = self.sender.close();
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `connection_instance_id`
[INFO] [stdout]    --> src/socket/core/event_processor.rs:269:7
[INFO] [stdout]     |
[INFO] [stdout] 269 |   let connection_instance_id = match &interaction_model_from_event {
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_connection_instance_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `final_connection_iface`
[INFO] [stdout]    --> src/socket/core/event_processor.rs:288:7
[INFO] [stdout]     |
[INFO] [stdout] 288 |   let final_connection_iface: Arc<dyn ISocketConnection>;
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_connection_iface`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `connector_context_clone`
[INFO] [stdout]    --> src/transport/inproc.rs:100:7
[INFO] [stdout]     |
[INFO] [stdout] 100 |   let connector_context_clone = core_arc.context.clone();
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_connector_context_clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `destination_identity_msg`
[INFO] [stdout]    --> src/socket/patterns/router.rs:248:7
[INFO] [stdout]     |
[INFO] [stdout] 248 |       destination_identity_msg: Msg,
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_destination_identity_msg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/socket/dealer_socket.rs:470:11
[INFO] [stdout]     |
[INFO] [stdout] 470 |       let mut transaction_guard = self.current_send_transaction.lock().await;
[INFO] [stdout]     |           ----^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |           |
[INFO] [stdout]     |           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `managing_actor_task_id_for_event` is never read
[INFO] [stdout]    --> src/transport/ipc.rs:276:74
[INFO] [stdout]     |
[INFO] [stdout] 276 |               let mut managing_actor_task_id_for_event: Option<TaskId> = None;
[INFO] [stdout]     |                                                                          ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sca_or_session_join_handle_opt`
[INFO] [stdout]    --> src/transport/tcp.rs:354:19
[INFO] [stdout]     |
[INFO] [stdout] 354 |               let mut sca_or_session_join_handle_opt: Option<JoinHandle<()>> = None;
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sca_or_session_join_handle_opt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `setup_successful` is never read
[INFO] [stdout]    --> src/transport/tcp.rs:485:19
[INFO] [stdout]     |
[INFO] [stdout] 485 |                   setup_successful = false;
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ISocketConnection` is more private than the item `SystemEvent::NewConnectionEstablished::connection_iface`
[INFO] [stdout]   --> src/runtime/system_events.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 |     connection_iface: Option<Arc<dyn ISocketConnection>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ field `SystemEvent::NewConnectionEstablished::connection_iface` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but trait `ISocketConnection` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/socket/connection_iface.rs:33:1
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub(crate) trait ISocketConnection: Send + Sync + fmt::Debug {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `ProcessTokenAction` is more private than the item `Mechanism::process_token`
[INFO] [stdout]   --> src/security/mechanism.rs:36:3
[INFO] [stdout]    |
[INFO] [stdout] 36 |   fn process_token(&mut self, token: &[u8]) -> Result<ProcessTokenAction, ZmqError>;
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Mechanism::process_token` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `ProcessTokenAction` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/security/mechanism.rs:16:1
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub(crate) enum ProcessTokenAction {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ISecureFramer` is more private than the item `Mechanism::into_framer`
[INFO] [stdout]   --> src/security/mechanism.rs:88:1
[INFO] [stdout]    |
[INFO] [stdout] 88 | fn into_framer(self: Box<Self>) -> Result<(Box<dyn ISecureFramer>, Option<Vec<u8>>), ZmqError>;
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Mechanism::into_framer` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but trait `ISecureFramer` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/security/framer.rs:9:1
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub(crate) trait ISecureFramer: Send + Sync + 'static {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `PipeState` is more private than the item `WritePipeCoordinator::remove_pipe`
[INFO] [stdout]   --> src/socket/patterns/pipe_coordinator.rs:46:3
[INFO] [stdout]    |
[INFO] [stdout] 46 |   pub async fn remove_pipe(&self, pipe_id: PipeId) -> Option<Arc<PipeState>> {
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `WritePipeCoordinator::remove_pipe` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `PipeState` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> src/socket/patterns/pipe_coordinator.rs:12:1
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct PipeState {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `binder_core_id` is never read
[INFO] [stdout]   --> src/context.rs:25:14
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub(crate) struct InprocBinding {
[INFO] [stdout]    |                   ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 25 |   pub(crate) binder_core_id: usize,
[INFO] [stdout]    |              ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `InprocBinding` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_socket_command_sender` is never used
[INFO] [stdout]    --> src/context.rs:220:17
[INFO] [stdout]     |
[INFO] [stdout]  55 | impl ContextInner {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 220 |   pub(crate) fn get_socket_command_sender(&self, handle: usize) -> Option<MailboxSender> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PeerAddress` is never constructed
[INFO] [stdout]   --> src/message/metadata.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub struct PeerAddress(pub SocketAddr);
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZapUserId` is never constructed
[INFO] [stdout]   --> src/message/metadata.rs:80:12
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub struct ZapUserId(pub String);
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `notify` is never read
[INFO] [stdout]  --> src/runtime/latch.rs:8:3
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub(crate) struct CountDownLatch {
[INFO] [stdout]   |                   -------------- field in this struct
[INFO] [stdout] 7 |   count: Arc<AtomicUsize>,
[INFO] [stdout] 8 |   notify: Arc<Notify>,
[INFO] [stdout]   |   ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `CountDownLatch` 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 items `new`, `count_down`, and `await_` are never used
[INFO] [stdout]   --> src/runtime/latch.rs:13:10
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl CountDownLatch {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 12 |   /// Creates a new latch initialized with the given count.
[INFO] [stdout] 13 |   pub fn new(count: usize) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |   pub async fn count_down(&self) {
[INFO] [stdout]    |                ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |   pub async fn await_(&self) {
[INFO] [stdout]    |                ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `IDataCipher` is never used
[INFO] [stdout]  --> src/security/cipher.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub trait IDataCipher: Send + Sync + 'static {
[INFO] [stdout]   |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PassThroughDataCipher` is never constructed
[INFO] [stdout]   --> src/security/cipher.rs:18:19
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub(crate) struct PassThroughDataCipher;
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LengthPrefixedFramer` is never constructed
[INFO] [stdout]   --> src/security/framer.rs:44:19
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub(crate) struct LengthPrefixedFramer {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/security/framer.rs:51:17
[INFO] [stdout]    |
[INFO] [stdout] 50 | impl LengthPrefixedFramer {
[INFO] [stdout]    | ------------------------- associated function in this implementation
[INFO] [stdout] 51 |   pub(crate) fn new(cipher: Box<dyn IDataCipher>) -> Self {
[INFO] [stdout]    |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ContinueWaiting` is never constructed
[INFO] [stdout]   --> src/security/mechanism.rs:18:3
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub(crate) enum ProcessTokenAction {
[INFO] [stdout]    |                 ------------------ variant in this enum
[INFO] [stdout] 17 |   /// No immediate action is required. The handler should wait for the next event.
[INFO] [stdout] 18 |   ContinueWaiting,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProcessTokenAction` 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: variant `Initializing` is never constructed
[INFO] [stdout]   --> src/security/plain.rs:10:3
[INFO] [stdout]    |
[INFO] [stdout]  9 | enum PlainState {
[INFO] [stdout]    |      ---------- variant in this enum
[INFO] [stdout] 10 |   Initializing, // Start state (not strictly used as we set initial state in new())
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PlainState` 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 `fd` and `is_expecting_first_frame` are never used
[INFO] [stdout]   --> src/sessionx/cork.rs:39:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl TcpCorkInfoX {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 39 |   pub(crate) fn fd(&self) -> RawFd {
[INFO] [stdout]    |                 ^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |   pub(crate) fn is_expecting_first_frame(&self) -> bool {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SourcePipeReadId` is never constructed
[INFO] [stdout]    --> src/socket/mod.rs:228:8
[INFO] [stdout]     |
[INFO] [stdout] 228 | struct SourcePipeReadId(usize);
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_pipe_reader_task` is never used
[INFO] [stdout]   --> src/socket/core/pipe_manager.rs:23:21
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub(crate) async fn run_pipe_reader_task(
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cleanup_session_state_by_uri` is never used
[INFO] [stdout]    --> src/socket/core/pipe_manager.rs:271:21
[INFO] [stdout]     |
[INFO] [stdout] 271 | pub(crate) async fn cleanup_session_state_by_uri(
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `send_msg_with_timeout` is never used
[INFO] [stdout]    --> src/socket/core/pipe_manager.rs:640:21
[INFO] [stdout]     |
[INFO] [stdout] 640 | pub(crate) async fn send_msg_with_timeout(
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `current_phase` is never used
[INFO] [stdout]   --> src/socket/core/shutdown.rs:14:17
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl ShutdownCoordinator {
[INFO] [stdout]    | ------------------------ method in this implementation
[INFO] [stdout] 14 |   pub(crate) fn current_phase(&self) -> ShutdownPhase {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_pipe_sender` is never used
[INFO] [stdout]    --> src/socket/core/state.rs:102:17
[INFO] [stdout]     |
[INFO] [stdout]  83 | impl CoreState {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 102 |   pub(crate) fn get_pipe_sender(&self, pipe_write_id: usize) -> Option<AsyncSender<Vec<Msg>>> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `use_send_zerocopy` and `use_recv_multishot` are never read
[INFO] [stdout]    --> src/socket/options.rs:214:7
[INFO] [stdout]     |
[INFO] [stdout] 202 | pub(crate) struct ZmtpEngineConfig {
[INFO] [stdout]     |                   ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 214 |   pub use_send_zerocopy: bool,
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 215 |   pub use_recv_multishot: bool,
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ZmtpEngineConfig` 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: function `parse_duration_ms_option` is never used
[INFO] [stdout]    --> src/socket/options.rs:300:15
[INFO] [stdout]     |
[INFO] [stdout] 300 | pub(crate) fn parse_duration_ms_option(value: &[u8]) -> Result<Option<Duration>, ZmqError> {
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_key_option` is never used
[INFO] [stdout]    --> src/socket/options.rs:443:15
[INFO] [stdout]     |
[INFO] [stdout] 443 | pub(crate) fn parse_key_option<const N: usize>(
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `hwm` is never read
[INFO] [stdout]   --> src/socket/patterns/fair_queue.rs:16:3
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub(crate) struct FairQueue<T: Send + 'static> {
[INFO] [stdout]    |                   --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 16 |   hwm: usize,
[INFO] [stdout]    |   ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FairQueue` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `pipe_attached`, `pipe_detached`, `capacity`, `len`, and `is_empty` are never used
[INFO] [stdout]   --> src/socket/patterns/fair_queue.rs:31:10
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl<T: Send + 'static> FairQueue<T> {
[INFO] [stdout]    | ------------------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |   pub fn pipe_attached(&self, pipe_read_id: usize) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |   pub fn pipe_detached(&self, pipe_read_id: usize) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 82 |   pub fn capacity(&self) -> usize {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 87 |   pub fn len(&self) -> usize {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 92 |   pub fn is_empty(&self) -> bool {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_identity_by_read_pipe` is never used
[INFO] [stdout]   --> src/socket/patterns/router.rs:97:16
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl RouterMap {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 97 |   pub async fn get_identity_by_read_pipe(&self, pipe_read_id: usize) -> Option<Blob> {
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_connection_id` and `as_any` are never used
[INFO] [stdout]   --> src/socket/connection_iface.rs:45:6
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub(crate) trait ISocketConnection: Send + Sync + fmt::Debug {
[INFO] [stdout]    |                  ----------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 45 |   fn get_connection_id(&self) -> usize;
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 46 |   fn as_any(&self) -> &dyn Any;
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `socket_logic` is never read
[INFO] [stdout]   --> src/transport/ipc.rs:36:3
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub(crate) struct IpcListener {
[INFO] [stdout]    |                   ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 36 |   socket_logic: Arc<dyn ISocket>,
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `socket_logic` is never read
[INFO] [stdout]   --> src/transport/tcp.rs:57:3
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub(crate) struct TcpListener {
[INFO] [stdout]    |                   ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 57 |   socket_logic: Arc<dyn ISocket>,
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_current_balance` is never used
[INFO] [stdout]    --> src/throttle/mod.rs:174:10
[INFO] [stdout]     |
[INFO] [stdout] 173 | impl ThrottleGuard {
[INFO] [stdout]     | ------------------ method in this implementation
[INFO] [stdout] 174 |   pub fn get_current_balance(&self) -> i32 {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `linear_strategy` is never used
[INFO] [stdout]   --> src/throttle/strategies.rs:35:8
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub fn linear_strategy(state: &ThrottleStateView) -> f64 {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SegmentTiming` is never constructed
[INFO] [stdout]   --> src/profiler.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct SegmentTiming {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LoopProfiler` is never constructed
[INFO] [stdout]   --> src/profiler.rs:19:19
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub(crate) struct LoopProfiler {
[INFO] [stdout]    |                   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `INITIAL_SEGMENT_LABEL`, `new`, `loop_start`, `mark_segment_end_and_start_new`, and `log_and_reset_for_next_loop` are never used
[INFO] [stdout]   --> src/profiler.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl LoopProfiler {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 31 |   const INITIAL_SEGMENT_LABEL: &'static str = "loop_setup";
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 32 |
[INFO] [stdout] 33 |   pub fn new(threshold: Duration, log_interval: usize) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |   pub fn loop_start(&mut self) {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |   pub fn mark_segment_end_and_start_new(&mut self, next_segment_label: &'static str) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |   pub fn log_and_reset_for_next_loop(&mut self) {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/socket/patterns/fair_queue.rs:97:5
[INFO] [stdout]    |
[INFO] [stdout] 97 |     self.sender.close();
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 97 |     let _ = self.sender.close();
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Context`, `LINGER`, `RCVHWM`, and `SNDHWM`
[INFO] [stdout]  --> tests/socket_options.rs:2:36
[INFO] [stdout]   |
[INFO] [stdout] 2 |   socket::options::{LAST_ENDPOINT, LINGER, RCVHWM, SNDHWM},
[INFO] [stdout]   |                                    ^^^^^^  ^^^^^^  ^^^^^^
[INFO] [stdout] 3 |   Context, Msg, SocketType, ZmqError,
[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: `Context`
[INFO] [stdout]  --> tests/dealer_router.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rzmq::{Context, Msg, MsgFlags, SocketType, ZmqError};
[INFO] [stdout]   |            ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashSet`
[INFO] [stdout]  --> tests/dealer_router.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::collections::HashSet;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Context`
[INFO] [stdout]  --> tests/req_rep_advanced.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | use rzmq::{Context, Msg, SocketType, ZmqError};
[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: `Context`
[INFO] [stdout]  --> tests/dealer_dealer.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rzmq::{Context, Msg, SocketType, ZmqError};
[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: `Context`
[INFO] [stdout]  --> tests/pub_sub.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stdout]   |            ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashSet`
[INFO] [stdout]  --> tests/pub_sub.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashSet;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RCVTIMEO`
[INFO] [stdout]  --> tests/dns.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 |     options::{RCVTIMEO, RECONNECT_IVL}, SocketEvent, SNDTIMEO
[INFO] [stdout]   |               ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stdout]  --> tests/tcp_corking.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | const SHORT_TIMEOUT: Duration = Duration::from_millis(500);
[INFO] [stdout]   |       ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `wait_for_handshake_events` is never used
[INFO] [stdout]   --> examples/common/mod.rs:33:14
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub async fn wait_for_handshake_events(
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `OwnedPermitGuard` is never constructed
[INFO] [stdout]  --> examples/common/capacity_gate.rs:8:19
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub(crate) struct OwnedPermitGuard {
[INFO] [stdout]   |                   ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CapacityGate` is never constructed
[INFO] [stdout]   --> examples/common/capacity_gate.rs:20:19
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub(crate) struct CapacityGate {
[INFO] [stdout]    |                   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `PermitGuard` is never used
[INFO] [stdout]   --> examples/common/capacity_gate.rs:25:17
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub(crate) type PermitGuard<'a> = GenericSemaphoreReleaser<'a, RawMutex>;
[INFO] [stdout]    |                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `acquire`, `acquire_owned`, `release`, `get_permits`, and `capacity` are never used
[INFO] [stdout]   --> examples/common/capacity_gate.rs:28:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | impl CapacityGate {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 28 |   pub fn new(capacity: usize) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |   pub fn acquire(&self) -> impl Future<Output = PermitGuard<'_>> {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |   pub fn acquire_owned(self: Arc<Self>) -> impl Future<Output = OwnedPermitGuard> {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 55 |   pub fn release(&self) {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |   pub fn get_permits(&self) -> usize {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 67 |   pub fn capacity(&self) -> usize {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> tests/plain_tests.rs:137:29
[INFO] [stdout]     |
[INFO] [stdout] 137 |   if let Ok((client_socket, mut client_monitor)) = client_setup_result {
[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: `expected_connections`
[INFO] [stdout]    --> tests/shutdown_race.rs:611:7
[INFO] [stdout]     |
[INFO] [stdout] 611 |   let expected_connections = Arc::new(tokio::sync::Semaphore::new(TCP_NUM_PUSHERS)); // To count connections
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_expected_connections`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NUM_PULLERS` is never used
[INFO] [stdout]   --> tests/shutdown_race.rs:26:7
[INFO] [stdout]    |
[INFO] [stdout] 26 | const NUM_PULLERS: usize = 2;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TCP_NUM_PULLERS` is never used
[INFO] [stdout]    --> tests/shutdown_race.rs:546:7
[INFO] [stdout]     |
[INFO] [stdout] 546 | const TCP_NUM_PULLERS: usize = 1; // Must be 1 for TCP bind
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> tests/shutdown_race.rs:486:3
[INFO] [stdout]     |
[INFO] [stdout] 486 |   pull_socket.close().await;
[INFO] [stdout]     |   ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 486 |   let _ = pull_socket.close().await;
[INFO] [stdout]     |   +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> tests/shutdown_race.rs:488:5
[INFO] [stdout]     |
[INFO] [stdout] 488 |     sck.close().await;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 488 |     let _ = sck.close().await;
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Off` and `Verbose` are never constructed
[INFO] [stdout]   --> examples/dealrtr_multitask.rs:30:3
[INFO] [stdout]    |
[INFO] [stdout] 29 | enum PrintLogLevel {
[INFO] [stdout]    |      ------------- variants in this enum
[INFO] [stdout] 30 |   Off,
[INFO] [stdout]    |   ^^^
[INFO] [stdout] 31 |   Info,
[INFO] [stdout] 32 |   Verbose,
[INFO] [stdout]    |   ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PrintLogLevel` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `id` is never read
[INFO] [stdout]    --> examples/dealrtr_multitask.rs:107:3
[INFO] [stdout]     |
[INFO] [stdout] 106 | struct DealerSenderStats {
[INFO] [stdout]     |        ----------------- field in this struct
[INFO] [stdout] 107 |   id: usize,
[INFO] [stdout]     |   ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `DealerSenderStats` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `wait_for_event` is never used
[INFO] [stdout]  --> examples/common/mod.rs:8:14
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub async fn wait_for_event(
[INFO] [stdout]   |              ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `wait_for_handshake_events` is never used
[INFO] [stdout]   --> examples/common/mod.rs:33:14
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub async fn wait_for_handshake_events(
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `capacity` is never read
[INFO] [stdout]   --> examples/common/capacity_gate.rs:21:3
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub(crate) struct CapacityGate {
[INFO] [stdout]    |                   ------------ field in this struct
[INFO] [stdout] 21 |   capacity: usize,
[INFO] [stdout]    |   ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CapacityGate` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `PermitGuard` is never used
[INFO] [stdout]   --> examples/common/capacity_gate.rs:25:17
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub(crate) type PermitGuard<'a> = GenericSemaphoreReleaser<'a, RawMutex>;
[INFO] [stdout]    |                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `acquire`, `get_permits`, and `capacity` are never used
[INFO] [stdout]   --> examples/common/capacity_gate.rs:36:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | impl CapacityGate {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 36 |   pub fn acquire(&self) -> impl Future<Output = PermitGuard<'_>> {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |   pub fn get_permits(&self) -> usize {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 67 |   pub fn capacity(&self) -> usize {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEST_TIMEOUT` is never used
[INFO] [stdout]   --> tests/plain_tests.rs:10:7
[INFO] [stdout]    |
[INFO] [stdout] 10 | const TEST_TIMEOUT: Duration = Duration::from_secs(5); // Timeout for async test operations
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> examples/dealrtr_multitask.rs:299:3
[INFO] [stdout]     |
[INFO] [stdout] 299 | /   tokio::time::timeout(SHUTDOWN_TIMEOUT, ctx.term())
[INFO] [stdout] 300 | |     .await
[INFO] [stdout] 301 | |     .expect("Context termination timed out!");
[INFO] [stdout]     | |_____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 299 |   let _ = tokio::time::timeout(SHUTDOWN_TIMEOUT, ctx.term())
[INFO] [stdout]     |   +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Context`
[INFO] [stdout]  --> tests/req_router.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stdout]   |            ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Off` and `Verbose` are never constructed
[INFO] [stdout]   --> examples/dealrtr_multiclient.rs:31:3
[INFO] [stdout]    |
[INFO] [stdout] 30 | enum PrintLogLevel {
[INFO] [stdout]    |      ------------- variants in this enum
[INFO] [stdout] 31 |   Off,
[INFO] [stdout]    |   ^^^
[INFO] [stdout] 32 |   Info,
[INFO] [stdout] 33 |   Verbose,
[INFO] [stdout]    |   ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PrintLogLevel` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `id` is never read
[INFO] [stdout]    --> examples/dealrtr_multiclient.rs:122:3
[INFO] [stdout]     |
[INFO] [stdout] 121 | struct DealerSenderStats {
[INFO] [stdout]     |        ----------------- field in this struct
[INFO] [stdout] 122 |   id: usize,
[INFO] [stdout]     |   ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `DealerSenderStats` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `wait_for_event` is never used
[INFO] [stdout]  --> examples/common/mod.rs:8:14
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub async fn wait_for_event(
[INFO] [stdout]   |              ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `wait_for_handshake_events` is never used
[INFO] [stdout]   --> examples/common/mod.rs:33:14
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub async fn wait_for_handshake_events(
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `capacity` is never read
[INFO] [stdout]   --> examples/common/capacity_gate.rs:21:3
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub(crate) struct CapacityGate {
[INFO] [stdout]    |                   ------------ field in this struct
[INFO] [stdout] 21 |   capacity: usize,
[INFO] [stdout]    |   ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CapacityGate` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `PermitGuard` is never used
[INFO] [stdout]   --> examples/common/capacity_gate.rs:25:17
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub(crate) type PermitGuard<'a> = GenericSemaphoreReleaser<'a, RawMutex>;
[INFO] [stdout]    |                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `acquire`, `get_permits`, and `capacity` are never used
[INFO] [stdout]   --> examples/common/capacity_gate.rs:36:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | impl CapacityGate {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 36 |   pub fn acquire(&self) -> impl Future<Output = PermitGuard<'_>> {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |   pub fn get_permits(&self) -> usize {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 67 |   pub fn capacity(&self) -> usize {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> examples/dealrtr_multiclient.rs:330:3
[INFO] [stdout]     |
[INFO] [stdout] 330 | /   tokio::time::timeout(SHUTDOWN_TIMEOUT, ctx.term())
[INFO] [stdout] 331 | |     .await
[INFO] [stdout] 332 | |     .expect("Context termination timed out!");
[INFO] [stdout]     | |_____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 330 |   let _ = tokio::time::timeout(SHUTDOWN_TIMEOUT, ctx.term())
[INFO] [stdout]     |   +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stdout]   --> tests/req_router.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const SHORT_TIMEOUT: Duration = Duration::from_millis(200);
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Context` and `Socket`
[INFO] [stdout]  --> tests/push_pull.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | use rzmq::{Context, Msg, Socket, SocketType, ZmqError};
[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: `Context`
[INFO] [stdout]  --> tests/dealer_rep.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stdout]   |            ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stdout]  --> tests/dealer_rep.rs:6:7
[INFO] [stdout]   |
[INFO] [stdout] 6 | const SHORT_TIMEOUT: Duration = Duration::from_millis(200);
[INFO] [stdout]   |       ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Blob` and `Context`
[INFO] [stdout]  --> tests/reconnect_tests.rs:8:3
[INFO] [stdout]   |
[INFO] [stdout] 8 |   Blob, Context, Msg, MsgFlags, Socket, SocketType, ZmqError,
[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: `Instant`
[INFO] [stdout]   --> tests/reconnect_tests.rs:11:27
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::time::{Duration, Instant};
[INFO] [stdout]    |                           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Context`
[INFO] [stdout]  --> tests/push_pull_lifecycle.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stdout]   |            ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stdout]  --> tests/push_pull_lifecycle.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | const SHORT_TIMEOUT: Duration = Duration::from_millis(250);
[INFO] [stdout]   |       ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Context`
[INFO] [stdout]  --> tests/inproc_minimal.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rzmq::{Context, Msg, SocketType, ZmqError};
[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: `Context`
[INFO] [stdout]  --> tests/router_router.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rzmq::{Context, Msg, MsgFlags, SocketType, ZmqError, socket::options::ROUTING_ID};
[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: `Context`
[INFO] [stdout]  --> tests/req_rep.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rzmq::{Context, Msg, SocketType, ZmqError};
[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: `Context`
[INFO] [stdout]  --> tests/transport_failures.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stdout]   |            ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> tests/transport_failures.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stdout]  --> tests/req_rep.rs:7:7
[INFO] [stdout]   |
[INFO] [stdout] 7 | const SHORT_TIMEOUT: Duration = Duration::from_millis(200);
[INFO] [stdout]   |       ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LONG_TIMEOUT` is never used
[INFO] [stdout]  --> tests/router_router.rs:6:7
[INFO] [stdout]   |
[INFO] [stdout] 6 | const LONG_TIMEOUT: Duration = Duration::from_secs(2);
[INFO] [stdout]   |       ^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stdout]   --> tests/transport_failures.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const SHORT_TIMEOUT: Duration = Duration::from_millis(250);
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 10s
[INFO] running `Command { std: "docker" "inspect" "4f4b7a2504c19d8c814487a66d10ec6decde8a58877464686639569c09097f98", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4f4b7a2504c19d8c814487a66d10ec6decde8a58877464686639569c09097f98", kill_on_drop: false }`
[INFO] [stdout] 4f4b7a2504c19d8c814487a66d10ec6decde8a58877464686639569c09097f98
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 80e28147b2b8851129d12147bf44dc44e1aadb3ca2dc3727426bac13b43351a6
[INFO] running `Command { std: "docker" "start" "-a" "80e28147b2b8851129d12147bf44dc44e1aadb3ca2dc3727426bac13b43351a6", kill_on_drop: false }`
[INFO] [stderr] warning: the usage of Script Group `Greek` in this crate consists solely of mixed script confusables
[INFO] [stderr]    --> src/throttle/mod.rs:129:11
[INFO] [stderr]     |
[INFO] [stderr] 129 |       let α = self.shared.config.adaptive_learning_rate;
[INFO] [stderr]     |           ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: the usage includes 'α' (U+03B1)
[INFO] [stderr]     = note: please recheck to make sure their usages are indeed what you want
[INFO] [stderr]     = note: `#[warn(mixed_script_confusables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `SystemEvent`
[INFO] [stderr]  --> src/runtime/actor_drop_guard.rs:3:33
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::runtime::{ActorType, SystemEvent}; // Adjust imports as needed
[INFO] [stderr]   |                                 ^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `AtomicBool` and `Ordering`
[INFO] [stderr]  --> src/runtime/actor_drop_guard.rs:5:25
[INFO] [stderr]   |
[INFO] [stderr] 5 | use std::sync::atomic::{AtomicBool, Ordering};
[INFO] [stderr]   |                         ^^^^^^^^^^  ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::sync::Arc`
[INFO] [stderr]  --> src/runtime/actor_drop_guard.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use std::sync::Arc;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `latch::CountDownLatch`
[INFO] [stderr]   --> src/runtime/mod.rs:20:16
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub(crate) use latch::CountDownLatch;
[INFO] [stderr]    |                ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `IDataCipher`
[INFO] [stderr]  --> src/security/mechanism.rs:1:13
[INFO] [stderr]   |
[INFO] [stderr] 1 | use super::{IDataCipher, ZmqError};
[INFO] [stderr]   |             ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `IDataCipher` and `cipher::PassThroughDataCipher`
[INFO] [stderr]  --> src/security/null.rs:3:13
[INFO] [stderr]   |
[INFO] [stderr] 3 | use super::{IDataCipher, Mechanism, MechanismStatus, cipher::PassThroughDataCipher};
[INFO] [stderr]   |             ^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `IDataCipher` and `cipher::PassThroughDataCipher`
[INFO] [stderr]  --> src/security/plain.rs:5:13
[INFO] [stderr]   |
[INFO] [stderr] 5 | use super::{IDataCipher, Mechanism, MechanismStatus, cipher::PassThroughDataCipher};
[INFO] [stderr]   |             ^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::message::Metadata`
[INFO] [stderr]   --> src/security/mod.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | use crate::message::Metadata;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::os::fd::AsRawFd`
[INFO] [stderr]   --> src/sessionx/actor.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | use std::os::fd::AsRawFd; // For AsRawFd bound if S needs it for cork_info init
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `BufMut` and `BytesMut`
[INFO] [stderr]  --> src/sessionx/protocol_handler/data_io.rs:8:13
[INFO] [stderr]   |
[INFO] [stderr] 8 | use bytes::{BufMut, BytesMut};
[INFO] [stderr]   |             ^^^^^^  ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `command_processor`
[INFO] [stderr]  --> src/socket/core/pipe_manager.rs:9:39
[INFO] [stderr]   |
[INFO] [stderr] 9 | use crate::socket::core::{SocketCore, command_processor};
[INFO] [stderr]   |                                       ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ActorType`
[INFO] [stderr]   --> src/socket/core/mod.rs:10:31
[INFO] [stderr]    |
[INFO] [stderr] 10 | use crate::runtime::{mailbox, ActorType, MailboxSender};
[INFO] [stderr]    |                               ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `pipe_manager::send_msg_with_timeout`
[INFO] [stderr]   --> src/socket/core/mod.rs:14:16
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub(crate) use pipe_manager::send_msg_with_timeout;
[INFO] [stderr]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Blob`
[INFO] [stderr]    --> src/socket/patterns/router.rs:173:24
[INFO] [stderr]     |
[INFO] [stderr] 173 |   use crate::message::{Blob, Msg, MsgFlags};
[INFO] [stderr]     |                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `fair_queue::FairQueue`
[INFO] [stderr]   --> src/socket/patterns/mod.rs:10:16
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub(crate) use fair_queue::FairQueue;
[INFO] [stderr]    |                ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `command::Command` and `mailbox::MailboxSender as SessionMailboxSender`
[INFO] [stderr]  --> src/socket/connection_iface.rs:8:22
[INFO] [stderr]   |
[INFO] [stderr] 8 | use crate::runtime::{command::Command, mailbox::MailboxSender as SessionMailboxSender};
[INFO] [stderr]   |                      ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::time::Duration`
[INFO] [stderr]   --> src/socket/connection_iface.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 21 | use std::time::Duration;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::socket::core::pipe_manager::run_pipe_reader_task`
[INFO] [stderr]  --> src/transport/inproc.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::socket::core::pipe_manager::run_pipe_reader_task;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `SocketAddr as StdSocketAddr`
[INFO] [stderr]   --> src/transport/tcp.rs:34:16
[INFO] [stderr]    |
[INFO] [stderr] 34 | use std::net::{SocketAddr as StdSocketAddr, ToSocketAddrs};
[INFO] [stderr]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `debug`, `error`, `info`, `trace`, and `warn`
[INFO] [stderr]   --> src/transport/tcp.rs:42:15
[INFO] [stderr]    |
[INFO] [stderr] 42 | use tracing::{debug, error, info, trace, warn};
[INFO] [stderr]    |               ^^^^^  ^^^^^  ^^^^  ^^^^^  ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `MailboxSender`
[INFO] [stderr]   --> src/lib.rs:42:43
[INFO] [stderr]    |
[INFO] [stderr] 42 | pub(crate) use runtime::{MailboxReceiver, MailboxSender};
[INFO] [stderr]    |                                           ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]    --> src/socket/core/command_processor.rs:490:5
[INFO] [stderr]     |
[INFO] [stderr] 490 |     _ => bind_result = Err(ZmqError::UnsupportedTransport(endpoint.to_string())),
[INFO] [stderr]     |     ^ no value can reach this
[INFO] [stderr]     |
[INFO] [stderr] note: multiple earlier patterns match some of the same values
[INFO] [stderr]    --> src/socket/core/command_processor.rs:490:5
[INFO] [stderr]     |
[INFO] [stderr] 363 |     Ok(Endpoint::Tcp(_addr, ref uri_from_parse)) => {
[INFO] [stderr]     |     -------------------------------------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 418 |     Ok(Endpoint::Ipc(ref path_buf, ref uri_from_parse)) => {
[INFO] [stderr]     |     --------------------------------------------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 469 |     Ok(Endpoint::Inproc(ref name)) => {
[INFO] [stderr]     |     ------------------------------ matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 489 |     Err(e) => bind_result = Err(e), // Error from parse_endpoint
[INFO] [stderr]     |     ------ matches some of the same values
[INFO] [stderr] 490 |     _ => bind_result = Err(ZmqError::UnsupportedTransport(endpoint.to_string())),
[INFO] [stderr]     |     ^ collectively making this unreachable
[INFO] [stderr]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]    --> src/socket/core/command_processor.rs:554:5
[INFO] [stderr]     |
[INFO] [stderr] 554 |     _ => {
[INFO] [stderr]     |     ^ no value can reach this
[INFO] [stderr]     |
[INFO] [stderr] note: multiple earlier patterns match some of the same values
[INFO] [stderr]    --> src/socket/core/command_processor.rs:554:5
[INFO] [stderr]     |
[INFO] [stderr] 529 | /     Ok(Endpoint::Tcp(_, ref parsed_uri_for_connecter))
[INFO] [stderr] 530 | |     | Ok(Endpoint::Ipc(_, ref parsed_uri_for_connecter)) => {
[INFO] [stderr]     | |________________________________________________________- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 542 |       Ok(Endpoint::Inproc(ref name)) => {
[INFO] [stderr]     |       ------------------------------ matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 551 |       Err(e) => {
[INFO] [stderr]     |       ------ matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 554 |       _ => {
[INFO] [stderr]     |       ^ collectively making this unreachable
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]    --> src/socket/core/command_processor.rs:633:5
[INFO] [stderr]     |
[INFO] [stderr] 633 |     _ => {
[INFO] [stderr]     |     ^ no value can reach this
[INFO] [stderr]     |
[INFO] [stderr] note: multiple earlier patterns match some of the same values
[INFO] [stderr]    --> src/socket/core/command_processor.rs:633:5
[INFO] [stderr]     |
[INFO] [stderr] 575 |     Ok(Endpoint::Tcp(_, _)) => {
[INFO] [stderr]     |     ----------------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 598 |     Ok(Endpoint::Ipc(path_buf, _)) => {
[INFO] [stderr]     |     ------------------------------ matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 618 |     Ok(Endpoint::Inproc(_)) => {
[INFO] [stderr]     |     ----------------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 621 |     Err(err) => {
[INFO] [stderr]     |     -------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 633 |     _ => {
[INFO] [stderr]     |     ^ collectively making this unreachable
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/transport/ipc.rs:277:19
[INFO] [stderr]     |
[INFO] [stderr] 277 |               let mut setup_successful = true;
[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: variable does not need to be mutable
[INFO] [stderr]    --> src/transport/ipc.rs:467:9
[INFO] [stderr]     |
[INFO] [stderr] 467 |     let mut connection_outcome: Result<
[INFO] [stderr]     |         ----^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/transport/tcp.rs:187:29
[INFO] [stderr]     |
[INFO] [stderr] 187 |   async fn run_command_loop(mut self, parent_socket_id: usize) {
[INFO] [stderr]     |                             ----^^^^
[INFO] [stderr]     |                             |
[INFO] [stderr]     |                             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/transport/tcp.rs:354:19
[INFO] [stderr]     |
[INFO] [stderr] 354 |               let mut sca_or_session_join_handle_opt: Option<JoinHandle<()>> = None;
[INFO] [stderr]     |                   ----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |                   |
[INFO] [stderr]     |                   help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `connection_instance_id`
[INFO] [stderr]    --> src/socket/core/event_processor.rs:269:7
[INFO] [stderr]     |
[INFO] [stderr] 269 |   let connection_instance_id = match &interaction_model_from_event {
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_connection_instance_id`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `final_connection_iface`
[INFO] [stderr]    --> src/socket/core/event_processor.rs:288:7
[INFO] [stderr]     |
[INFO] [stderr] 288 |   let final_connection_iface: Arc<dyn ISocketConnection>;
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_connection_iface`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `connector_context_clone`
[INFO] [stderr]    --> src/transport/inproc.rs:100:7
[INFO] [stderr]     |
[INFO] [stderr] 100 |   let connector_context_clone = core_arc.context.clone();
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_connector_context_clone`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `destination_identity_msg`
[INFO] [stderr]    --> src/socket/patterns/router.rs:248:7
[INFO] [stderr]     |
[INFO] [stderr] 248 |       destination_identity_msg: Msg,
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_destination_identity_msg`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/socket/dealer_socket.rs:470:11
[INFO] [stderr]     |
[INFO] [stderr] 470 |       let mut transaction_guard = self.current_send_transaction.lock().await;
[INFO] [stderr]     |           ----^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |           |
[INFO] [stderr]     |           help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `managing_actor_task_id_for_event` is never read
[INFO] [stderr]    --> src/transport/ipc.rs:276:74
[INFO] [stderr]     |
[INFO] [stderr] 276 |               let mut managing_actor_task_id_for_event: Option<TaskId> = None;
[INFO] [stderr]     |                                                                          ^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `sca_or_session_join_handle_opt`
[INFO] [stderr]    --> src/transport/tcp.rs:354:19
[INFO] [stderr]     |
[INFO] [stderr] 354 |               let mut sca_or_session_join_handle_opt: Option<JoinHandle<()>> = None;
[INFO] [stderr]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sca_or_session_join_handle_opt`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `setup_successful` is never read
[INFO] [stderr]    --> src/transport/tcp.rs:485:19
[INFO] [stderr]     |
[INFO] [stderr] 485 |                   setup_successful = false;
[INFO] [stderr]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: trait `ISocketConnection` is more private than the item `SystemEvent::NewConnectionEstablished::connection_iface`
[INFO] [stderr]   --> src/runtime/system_events.rs:93:5
[INFO] [stderr]    |
[INFO] [stderr] 93 |     connection_iface: Option<Arc<dyn ISocketConnection>>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ field `SystemEvent::NewConnectionEstablished::connection_iface` is reachable at visibility `pub`
[INFO] [stderr]    |
[INFO] [stderr] note: but trait `ISocketConnection` is only usable at visibility `pub(crate)`
[INFO] [stderr]   --> src/socket/connection_iface.rs:33:1
[INFO] [stderr]    |
[INFO] [stderr] 33 | pub(crate) trait ISocketConnection: Send + Sync + fmt::Debug {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: type `ProcessTokenAction` is more private than the item `Mechanism::process_token`
[INFO] [stderr]   --> src/security/mechanism.rs:36:3
[INFO] [stderr]    |
[INFO] [stderr] 36 |   fn process_token(&mut self, token: &[u8]) -> Result<ProcessTokenAction, ZmqError>;
[INFO] [stderr]    |   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Mechanism::process_token` is reachable at visibility `pub`
[INFO] [stderr]    |
[INFO] [stderr] note: but type `ProcessTokenAction` is only usable at visibility `pub(crate)`
[INFO] [stderr]   --> src/security/mechanism.rs:16:1
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub(crate) enum ProcessTokenAction {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `ISecureFramer` is more private than the item `Mechanism::into_framer`
[INFO] [stderr]   --> src/security/mechanism.rs:88:1
[INFO] [stderr]    |
[INFO] [stderr] 88 | fn into_framer(self: Box<Self>) -> Result<(Box<dyn ISecureFramer>, Option<Vec<u8>>), ZmqError>;
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Mechanism::into_framer` is reachable at visibility `pub`
[INFO] [stderr]    |
[INFO] [stderr] note: but trait `ISecureFramer` is only usable at visibility `pub(crate)`
[INFO] [stderr]   --> src/security/framer.rs:9:1
[INFO] [stderr]    |
[INFO] [stderr]  9 | pub(crate) trait ISecureFramer: Send + Sync + 'static {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type `PipeState` is more private than the item `WritePipeCoordinator::remove_pipe`
[INFO] [stderr]   --> src/socket/patterns/pipe_coordinator.rs:46:3
[INFO] [stderr]    |
[INFO] [stderr] 46 |   pub async fn remove_pipe(&self, pipe_id: PipeId) -> Option<Arc<PipeState>> {
[INFO] [stderr]    |   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `WritePipeCoordinator::remove_pipe` is reachable at visibility `pub`
[INFO] [stderr]    |
[INFO] [stderr] note: but type `PipeState` is only usable at visibility `pub(crate)`
[INFO] [stderr]   --> src/socket/patterns/pipe_coordinator.rs:12:1
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub(crate) struct PipeState {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `binder_core_id` is never read
[INFO] [stderr]   --> src/context.rs:25:14
[INFO] [stderr]    |
[INFO] [stderr] 21 | pub(crate) struct InprocBinding {
[INFO] [stderr]    |                   ------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 25 |   pub(crate) binder_core_id: usize,
[INFO] [stderr]    |              ^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `InprocBinding` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: method `get_socket_command_sender` is never used
[INFO] [stderr]    --> src/context.rs:220:17
[INFO] [stderr]     |
[INFO] [stderr]  55 | impl ContextInner {
[INFO] [stderr]     | ----------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 220 |   pub(crate) fn get_socket_command_sender(&self, handle: usize) -> Option<MailboxSender> {
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PeerAddress` is never constructed
[INFO] [stderr]   --> src/message/metadata.rs:76:12
[INFO] [stderr]    |
[INFO] [stderr] 76 | pub struct PeerAddress(pub SocketAddr);
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ZapUserId` is never constructed
[INFO] [stderr]   --> src/message/metadata.rs:80:12
[INFO] [stderr]    |
[INFO] [stderr] 80 | pub struct ZapUserId(pub String);
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `notify` is never read
[INFO] [stderr]  --> src/runtime/latch.rs:8:3
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub(crate) struct CountDownLatch {
[INFO] [stderr]   |                   -------------- field in this struct
[INFO] [stderr] 7 |   count: Arc<AtomicUsize>,
[INFO] [stderr] 8 |   notify: Arc<Notify>,
[INFO] [stderr]   |   ^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `CountDownLatch` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `count_down`, and `await_` are never used
[INFO] [stderr]   --> src/runtime/latch.rs:13:10
[INFO] [stderr]    |
[INFO] [stderr] 11 | impl CountDownLatch {
[INFO] [stderr]    | ------------------- associated items in this implementation
[INFO] [stderr] 12 |   /// Creates a new latch initialized with the given count.
[INFO] [stderr] 13 |   pub fn new(count: usize) -> Self {
[INFO] [stderr]    |          ^^^
[INFO] [stderr] ...
[INFO] [stderr] 27 |   pub async fn count_down(&self) {
[INFO] [stderr]    |                ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 37 |   pub async fn await_(&self) {
[INFO] [stderr]    |                ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `IDataCipher` is never used
[INFO] [stderr]  --> src/security/cipher.rs:5:11
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub trait IDataCipher: Send + Sync + 'static {
[INFO] [stderr]   |           ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PassThroughDataCipher` is never constructed
[INFO] [stderr]   --> src/security/cipher.rs:18:19
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub(crate) struct PassThroughDataCipher;
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `LengthPrefixedFramer` is never constructed
[INFO] [stderr]   --> src/security/framer.rs:44:19
[INFO] [stderr]    |
[INFO] [stderr] 44 | pub(crate) struct LengthPrefixedFramer {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/security/framer.rs:51:17
[INFO] [stderr]    |
[INFO] [stderr] 50 | impl LengthPrefixedFramer {
[INFO] [stderr]    | ------------------------- associated function in this implementation
[INFO] [stderr] 51 |   pub(crate) fn new(cipher: Box<dyn IDataCipher>) -> Self {
[INFO] [stderr]    |                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `ContinueWaiting` is never constructed
[INFO] [stderr]   --> src/security/mechanism.rs:18:3
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub(crate) enum ProcessTokenAction {
[INFO] [stderr]    |                 ------------------ variant in this enum
[INFO] [stderr] 17 |   /// No immediate action is required. The handler should wait for the next event.
[INFO] [stderr] 18 |   ContinueWaiting,
[INFO] [stderr]    |   ^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProcessTokenAction` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Initializing` is never constructed
[INFO] [stderr]   --> src/security/plain.rs:10:3
[INFO] [stderr]    |
[INFO] [stderr]  9 | enum PlainState {
[INFO] [stderr]    |      ---------- variant in this enum
[INFO] [stderr] 10 |   Initializing, // Start state (not strictly used as we set initial state in new())
[INFO] [stderr]    |   ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `PlainState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `fd` and `is_expecting_first_frame` are never used
[INFO] [stderr]   --> src/sessionx/cork.rs:39:17
[INFO] [stderr]    |
[INFO] [stderr] 17 | impl TcpCorkInfoX {
[INFO] [stderr]    | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 39 |   pub(crate) fn fd(&self) -> RawFd {
[INFO] [stderr]    |                 ^^
[INFO] [stderr] ...
[INFO] [stderr] 49 |   pub(crate) fn is_expecting_first_frame(&self) -> bool {
[INFO] [stderr]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SourcePipeReadId` is never constructed
[INFO] [stderr]    --> src/socket/mod.rs:228:8
[INFO] [stderr]     |
[INFO] [stderr] 228 | struct SourcePipeReadId(usize);
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `run_pipe_reader_task` is never used
[INFO] [stderr]   --> src/socket/core/pipe_manager.rs:23:21
[INFO] [stderr]    |
[INFO] [stderr] 23 | pub(crate) async fn run_pipe_reader_task(
[INFO] [stderr]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `cleanup_session_state_by_uri` is never used
[INFO] [stderr]    --> src/socket/core/pipe_manager.rs:271:21
[INFO] [stderr]     |
[INFO] [stderr] 271 | pub(crate) async fn cleanup_session_state_by_uri(
[INFO] [stderr]     |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `send_msg_with_timeout` is never used
[INFO] [stderr]    --> src/socket/core/pipe_manager.rs:640:21
[INFO] [stderr]     |
[INFO] [stderr] 640 | pub(crate) async fn send_msg_with_timeout(
[INFO] [stderr]     |                     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `current_phase` is never used
[INFO] [stderr]   --> src/socket/core/shutdown.rs:14:17
[INFO] [stderr]    |
[INFO] [stderr] 13 | impl ShutdownCoordinator {
[INFO] [stderr]    | ------------------------ method in this implementation
[INFO] [stderr] 14 |   pub(crate) fn current_phase(&self) -> ShutdownPhase {
[INFO] [stderr]    |                 ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `get_pipe_sender` is never used
[INFO] [stderr]    --> src/socket/core/state.rs:102:17
[INFO] [stderr]     |
[INFO] [stderr]  83 | impl CoreState {
[INFO] [stderr]     | -------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 102 |   pub(crate) fn get_pipe_sender(&self, pipe_write_id: usize) -> Option<AsyncSender<Vec<Msg>>> {
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `use_send_zerocopy` and `use_recv_multishot` are never read
[INFO] [stderr]    --> src/socket/options.rs:214:7
[INFO] [stderr]     |
[INFO] [stderr] 202 | pub(crate) struct ZmtpEngineConfig {
[INFO] [stderr]     |                   ---------------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 214 |   pub use_send_zerocopy: bool,
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 215 |   pub use_recv_multishot: bool,
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `ZmtpEngineConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_duration_ms_option` is never used
[INFO] [stderr]    --> src/socket/options.rs:300:15
[INFO] [stderr]     |
[INFO] [stderr] 300 | pub(crate) fn parse_duration_ms_option(value: &[u8]) -> Result<Option<Duration>, ZmqError> {
[INFO] [stderr]     |               ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_key_option` is never used
[INFO] [stderr]    --> src/socket/options.rs:443:15
[INFO] [stderr]     |
[INFO] [stderr] 443 | pub(crate) fn parse_key_option<const N: usize>(
[INFO] [stderr]     |               ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `hwm` is never read
[INFO] [stderr]   --> src/socket/patterns/fair_queue.rs:16:3
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub(crate) struct FairQueue<T: Send + 'static> {
[INFO] [stderr]    |                   --------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 16 |   hwm: usize,
[INFO] [stderr]    |   ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `FairQueue` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `pipe_attached`, `pipe_detached`, `capacity`, `len`, and `is_empty` are never used
[INFO] [stderr]   --> src/socket/patterns/fair_queue.rs:31:10
[INFO] [stderr]    |
[INFO] [stderr] 19 | impl<T: Send + 'static> FairQueue<T> {
[INFO] [stderr]    | ------------------------------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 31 |   pub fn pipe_attached(&self, pipe_read_id: usize) {
[INFO] [stderr]    |          ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 36 |   pub fn pipe_detached(&self, pipe_read_id: usize) {
[INFO] [stderr]    |          ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 82 |   pub fn capacity(&self) -> usize {
[INFO] [stderr]    |          ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 87 |   pub fn len(&self) -> usize {
[INFO] [stderr]    |          ^^^
[INFO] [stderr] ...
[INFO] [stderr] 92 |   pub fn is_empty(&self) -> bool {
[INFO] [stderr]    |          ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `get_identity_by_read_pipe` is never used
[INFO] [stderr]   --> src/socket/patterns/router.rs:97:16
[INFO] [stderr]    |
[INFO] [stderr] 24 | impl RouterMap {
[INFO] [stderr]    | -------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 97 |   pub async fn get_identity_by_read_pipe(&self, pipe_read_id: usize) -> Option<Blob> {
[INFO] [stderr]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `get_connection_id` and `as_any` are never used
[INFO] [stderr]   --> src/socket/connection_iface.rs:45:6
[INFO] [stderr]    |
[INFO] [stderr] 33 | pub(crate) trait ISocketConnection: Send + Sync + fmt::Debug {
[INFO] [stderr]    |                  ----------------- methods in this trait
[INFO] [stderr] ...
[INFO] [stderr] 45 |   fn get_connection_id(&self) -> usize;
[INFO] [stderr]    |      ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 46 |   fn as_any(&self) -> &dyn Any;
[INFO] [stderr]    |      ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `socket_logic` is never read
[INFO] [stderr]   --> src/transport/ipc.rs:36:3
[INFO] [stderr]    |
[INFO] [stderr] 28 | pub(crate) struct IpcListener {
[INFO] [stderr]    |                   ----------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 36 |   socket_logic: Arc<dyn ISocket>,
[INFO] [stderr]    |   ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `socket_logic` is never read
[INFO] [stderr]   --> src/transport/tcp.rs:57:3
[INFO] [stderr]    |
[INFO] [stderr] 50 | pub(crate) struct TcpListener {
[INFO] [stderr]    |                   ----------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 57 |   socket_logic: Arc<dyn ISocket>,
[INFO] [stderr]    |   ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `get_current_balance` is never used
[INFO] [stderr]    --> src/throttle/mod.rs:174:10
[INFO] [stderr]     |
[INFO] [stderr] 173 | impl ThrottleGuard {
[INFO] [stderr]     | ------------------ method in this implementation
[INFO] [stderr] 174 |   pub fn get_current_balance(&self) -> i32 {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `linear_strategy` is never used
[INFO] [stderr]   --> src/throttle/strategies.rs:35:8
[INFO] [stderr]    |
[INFO] [stderr] 35 | pub fn linear_strategy(state: &ThrottleStateView) -> f64 {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SegmentTiming` is never constructed
[INFO] [stderr]   --> src/profiler.rs:12:19
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub(crate) struct SegmentTiming {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `LoopProfiler` is never constructed
[INFO] [stderr]   --> src/profiler.rs:19:19
[INFO] [stderr]    |
[INFO] [stderr] 19 | pub(crate) struct LoopProfiler {
[INFO] [stderr]    |                   ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `INITIAL_SEGMENT_LABEL`, `new`, `loop_start`, `mark_segment_end_and_start_new`, and `log_and_reset_for_next_loop` are never used
[INFO] [stderr]   --> src/profiler.rs:31:9
[INFO] [stderr]    |
[INFO] [stderr] 30 | impl LoopProfiler {
[INFO] [stderr]    | ----------------- associated items in this implementation
[INFO] [stderr] 31 |   const INITIAL_SEGMENT_LABEL: &'static str = "loop_setup";
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 32 |
[INFO] [stderr] 33 |   pub fn new(threshold: Duration, log_interval: usize) -> Self {
[INFO] [stderr]    |          ^^^
[INFO] [stderr] ...
[INFO] [stderr] 46 |   pub fn loop_start(&mut self) {
[INFO] [stderr]    |          ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 53 |   pub fn mark_segment_end_and_start_new(&mut self, next_segment_label: &'static str) {
[INFO] [stderr]    |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 64 |   pub fn log_and_reset_for_next_loop(&mut self) {
[INFO] [stderr]    |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]   --> src/socket/patterns/fair_queue.rs:97:5
[INFO] [stderr]    |
[INFO] [stderr] 97 |     self.sender.close();
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]    |
[INFO] [stderr] 97 |     let _ = self.sender.close();
[INFO] [stderr]    |     +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `rzmq` (lib) generated 75 warnings (run `cargo fix --lib -p rzmq` to apply 31 suggestions)
[INFO] [stderr] warning: unused import: `RCVTIMEO`
[INFO] [stderr]  --> tests/dns.rs:3:15
[INFO] [stderr]   |
[INFO] [stderr] 3 |     options::{RCVTIMEO, RECONNECT_IVL}, SocketEvent, SNDTIMEO
[INFO] [stderr]   |               ^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/dealer_router.rs:3:12
[INFO] [stderr]   |
[INFO] [stderr] 3 | use rzmq::{Context, Msg, MsgFlags, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::collections::HashSet`
[INFO] [stderr]  --> tests/dealer_router.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use std::collections::HashSet;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> tests/plain_tests.rs:137:29
[INFO] [stderr]     |
[INFO] [stderr] 137 |   if let Ok((client_socket, mut client_monitor)) = client_setup_result {
[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: constant `TEST_TIMEOUT` is never used
[INFO] [stderr]   --> tests/plain_tests.rs:10:7
[INFO] [stderr]    |
[INFO] [stderr] 10 | const TEST_TIMEOUT: Duration = Duration::from_secs(5); // Timeout for async test operations
[INFO] [stderr]    |       ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/transport_failures.rs:4:12
[INFO] [stderr]   |
[INFO] [stderr] 4 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::path::Path`
[INFO] [stderr]  --> tests/transport_failures.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use std::path::Path;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stderr]   --> tests/transport_failures.rs:11:7
[INFO] [stderr]    |
[INFO] [stderr] 11 | const SHORT_TIMEOUT: Duration = Duration::from_millis(250);
[INFO] [stderr]    |       ^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/dealer_rep.rs:3:12
[INFO] [stderr]   |
[INFO] [stderr] 3 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stderr]  --> tests/dealer_rep.rs:6:7
[INFO] [stderr]   |
[INFO] [stderr] 6 | const SHORT_TIMEOUT: Duration = Duration::from_millis(200);
[INFO] [stderr]   |       ^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/req_rep_advanced.rs:1:12
[INFO] [stderr]   |
[INFO] [stderr] 1 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stderr]  --> tests/tcp_corking.rs:9:7
[INFO] [stderr]   |
[INFO] [stderr] 9 | const SHORT_TIMEOUT: Duration = Duration::from_millis(500);
[INFO] [stderr]   |       ^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Off` and `Verbose` are never constructed
[INFO] [stderr]   --> examples/dealrtr_multitask.rs:30:3
[INFO] [stderr]    |
[INFO] [stderr] 29 | enum PrintLogLevel {
[INFO] [stderr]    |      ------------- variants in this enum
[INFO] [stderr] 30 |   Off,
[INFO] [stderr]    |   ^^^
[INFO] [stderr] 31 |   Info,
[INFO] [stderr] 32 |   Verbose,
[INFO] [stderr]    |   ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `PrintLogLevel` has derived impls for the traits `Clone` and `Debug`, but these are 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 `id` is never read
[INFO] [stderr]    --> examples/dealrtr_multitask.rs:107:3
[INFO] [stderr]     |
[INFO] [stderr] 106 | struct DealerSenderStats {
[INFO] [stderr]     |        ----------------- field in this struct
[INFO] [stderr] 107 |   id: usize,
[INFO] [stderr]     |   ^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `DealerSenderStats` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: function `wait_for_event` is never used
[INFO] [stderr]  --> examples/common/mod.rs:8:14
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub async fn wait_for_event(
[INFO] [stderr]   |              ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `wait_for_handshake_events` is never used
[INFO] [stderr]   --> examples/common/mod.rs:33:14
[INFO] [stderr]    |
[INFO] [stderr] 33 | pub async fn wait_for_handshake_events(
[INFO] [stderr]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `capacity` is never read
[INFO] [stderr]   --> examples/common/capacity_gate.rs:21:3
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub(crate) struct CapacityGate {
[INFO] [stderr]    |                   ------------ field in this struct
[INFO] [stderr] 21 |   capacity: usize,
[INFO] [stderr]    |   ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `CapacityGate` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `PermitGuard` is never used
[INFO] [stderr]   --> examples/common/capacity_gate.rs:25:17
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub(crate) type PermitGuard<'a> = GenericSemaphoreReleaser<'a, RawMutex>;
[INFO] [stderr]    |                 ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `acquire`, `get_permits`, and `capacity` are never used
[INFO] [stderr]   --> examples/common/capacity_gate.rs:36:10
[INFO] [stderr]    |
[INFO] [stderr] 27 | impl CapacityGate {
[INFO] [stderr]    | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 36 |   pub fn acquire(&self) -> impl Future<Output = PermitGuard<'_>> {
[INFO] [stderr]    |          ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 62 |   pub fn get_permits(&self) -> usize {
[INFO] [stderr]    |          ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 67 |   pub fn capacity(&self) -> usize {
[INFO] [stderr]    |          ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> examples/dealrtr_multitask.rs:299:3
[INFO] [stderr]     |
[INFO] [stderr] 299 | /   tokio::time::timeout(SHUTDOWN_TIMEOUT, ctx.term())
[INFO] [stderr] 300 | |     .await
[INFO] [stderr] 301 | |     .expect("Context termination timed out!");
[INFO] [stderr]     | |_____________________________________________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 299 |   let _ = tokio::time::timeout(SHUTDOWN_TIMEOUT, ctx.term())
[INFO] [stderr]     |   +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: function `wait_for_handshake_events` is never used
[INFO] [stderr]   --> examples/common/mod.rs:33:14
[INFO] [stderr]    |
[INFO] [stderr] 33 | pub async fn wait_for_handshake_events(
[INFO] [stderr]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: struct `OwnedPermitGuard` is never constructed
[INFO] [stderr]  --> examples/common/capacity_gate.rs:8:19
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub(crate) struct OwnedPermitGuard {
[INFO] [stderr]   |                   ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CapacityGate` is never constructed
[INFO] [stderr]   --> examples/common/capacity_gate.rs:20:19
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub(crate) struct CapacityGate {
[INFO] [stderr]    |                   ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `acquire`, `acquire_owned`, `release`, `get_permits`, and `capacity` are never used
[INFO] [stderr]   --> examples/common/capacity_gate.rs:28:10
[INFO] [stderr]    |
[INFO] [stderr] 27 | impl CapacityGate {
[INFO] [stderr]    | ----------------- associated items in this implementation
[INFO] [stderr] 28 |   pub fn new(capacity: usize) -> Self {
[INFO] [stderr]    |          ^^^
[INFO] [stderr] ...
[INFO] [stderr] 36 |   pub fn acquire(&self) -> impl Future<Output = PermitGuard<'_>> {
[INFO] [stderr]    |          ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 42 |   pub fn acquire_owned(self: Arc<Self>) -> impl Future<Output = OwnedPermitGuard> {
[INFO] [stderr]    |          ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 55 |   pub fn release(&self) {
[INFO] [stderr]    |          ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 62 |   pub fn get_permits(&self) -> usize {
[INFO] [stderr]    |          ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 67 |   pub fn capacity(&self) -> usize {
[INFO] [stderr]    |          ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/req_router.rs:7:12
[INFO] [stderr]   |
[INFO] [stderr] 7 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stderr]   --> tests/req_router.rs:11:7
[INFO] [stderr]    |
[INFO] [stderr] 11 | const SHORT_TIMEOUT: Duration = Duration::from_millis(200);
[INFO] [stderr]    |       ^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/dealer_dealer.rs:3:12
[INFO] [stderr]   |
[INFO] [stderr] 3 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `rzmq` (test "dns") generated 1 warning (run `cargo fix --test "dns" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (test "dealer_router") generated 2 warnings (run `cargo fix --test "dealer_router" -p rzmq` to apply 2 suggestions)
[INFO] [stderr] warning: `rzmq` (test "plain_tests") generated 2 warnings (run `cargo fix --test "plain_tests" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (test "transport_failures") generated 3 warnings (run `cargo fix --test "transport_failures" -p rzmq` to apply 2 suggestions)
[INFO] [stderr] warning: `rzmq` (test "dealer_rep") generated 2 warnings (run `cargo fix --test "dealer_rep" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (test "req_rep_advanced") generated 1 warning (run `cargo fix --test "req_rep_advanced" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (test "tcp_corking") generated 1 warning
[INFO] [stderr] warning: `rzmq` (example "dealrtr_multitask") generated 8 warnings
[INFO] [stderr] warning: `rzmq` (example "req_rep_flurry") generated 5 warnings (1 duplicate)
[INFO] [stderr] warning: `rzmq` (test "req_router") generated 2 warnings (run `cargo fix --test "req_router" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (test "dealer_dealer") generated 1 warning (run `cargo fix --test "dealer_dealer" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/push_pull_lifecycle.rs:1:12
[INFO] [stderr]   |
[INFO] [stderr] 1 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stderr]  --> tests/push_pull_lifecycle.rs:9:7
[INFO] [stderr]   |
[INFO] [stderr] 9 | const SHORT_TIMEOUT: Duration = Duration::from_millis(250);
[INFO] [stderr]   |       ^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Context`, `LINGER`, `RCVHWM`, and `SNDHWM`
[INFO] [stderr]  --> tests/socket_options.rs:2:36
[INFO] [stderr]   |
[INFO] [stderr] 2 |   socket::options::{LAST_ENDPOINT, LINGER, RCVHWM, SNDHWM},
[INFO] [stderr]   |                                    ^^^^^^  ^^^^^^  ^^^^^^
[INFO] [stderr] 3 |   Context, Msg, SocketType, ZmqError,
[INFO] [stderr]   |   ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/router_router.rs:3:12
[INFO] [stderr]   |
[INFO] [stderr] 3 | use rzmq::{Context, Msg, MsgFlags, SocketType, ZmqError, socket::options::ROUTING_ID};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `LONG_TIMEOUT` is never used
[INFO] [stderr]  --> tests/router_router.rs:6:7
[INFO] [stderr]   |
[INFO] [stderr] 6 | const LONG_TIMEOUT: Duration = Duration::from_secs(2);
[INFO] [stderr]   |       ^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `expected_connections`
[INFO] [stderr]    --> tests/shutdown_race.rs:611:7
[INFO] [stderr]     |
[INFO] [stderr] 611 |   let expected_connections = Arc::new(tokio::sync::Semaphore::new(TCP_NUM_PUSHERS)); // To count connections
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_expected_connections`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NUM_PULLERS` is never used
[INFO] [stderr]   --> tests/shutdown_race.rs:26:7
[INFO] [stderr]    |
[INFO] [stderr] 26 | const NUM_PULLERS: usize = 2;
[INFO] [stderr]    |       ^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `TCP_NUM_PULLERS` is never used
[INFO] [stderr]    --> tests/shutdown_race.rs:546:7
[INFO] [stderr]     |
[INFO] [stderr] 546 | const TCP_NUM_PULLERS: usize = 1; // Must be 1 for TCP bind
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> tests/shutdown_race.rs:486:3
[INFO] [stderr]     |
[INFO] [stderr] 486 |   pull_socket.close().await;
[INFO] [stderr]     |   ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 486 |   let _ = pull_socket.close().await;
[INFO] [stderr]     |   +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> tests/shutdown_race.rs:488:5
[INFO] [stderr]     |
[INFO] [stderr] 488 |     sck.close().await;
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 488 |     let _ = sck.close().await;
[INFO] [stderr]     |     +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Context` and `Socket`
[INFO] [stderr]  --> tests/push_pull.rs:4:12
[INFO] [stderr]   |
[INFO] [stderr] 4 | use rzmq::{Context, Msg, Socket, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^       ^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Blob` and `Context`
[INFO] [stderr]  --> tests/reconnect_tests.rs:8:3
[INFO] [stderr]   |
[INFO] [stderr] 8 |   Blob, Context, Msg, MsgFlags, Socket, SocketType, ZmqError,
[INFO] [stderr]   |   ^^^^  ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Instant`
[INFO] [stderr]   --> tests/reconnect_tests.rs:11:27
[INFO] [stderr]    |
[INFO] [stderr] 11 | use std::time::{Duration, Instant};
[INFO] [stderr]    |                           ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/pub_sub.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::collections::HashSet`
[INFO] [stderr]  --> tests/pub_sub.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use std::collections::HashSet;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/req_rep.rs:3:12
[INFO] [stderr]   |
[INFO] [stderr] 3 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `SHORT_TIMEOUT` is never used
[INFO] [stderr]  --> tests/req_rep.rs:7:7
[INFO] [stderr]   |
[INFO] [stderr] 7 | const SHORT_TIMEOUT: Duration = Duration::from_millis(200);
[INFO] [stderr]   |       ^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Off` and `Verbose` are never constructed
[INFO] [stderr]   --> examples/dealrtr_multiclient.rs:31:3
[INFO] [stderr]    |
[INFO] [stderr] 30 | enum PrintLogLevel {
[INFO] [stderr]    |      ------------- variants in this enum
[INFO] [stderr] 31 |   Off,
[INFO] [stderr]    |   ^^^
[INFO] [stderr] 32 |   Info,
[INFO] [stderr] 33 |   Verbose,
[INFO] [stderr]    |   ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `PrintLogLevel` has derived impls for the traits `Clone` and `Debug`, but these are 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 `id` is never read
[INFO] [stderr]    --> examples/dealrtr_multiclient.rs:122:3
[INFO] [stderr]     |
[INFO] [stderr] 121 | struct DealerSenderStats {
[INFO] [stderr]     |        ----------------- field in this struct
[INFO] [stderr] 122 |   id: usize,
[INFO] [stderr]     |   ^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `DealerSenderStats` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> examples/dealrtr_multiclient.rs:330:3
[INFO] [stderr]     |
[INFO] [stderr] 330 | /   tokio::time::timeout(SHUTDOWN_TIMEOUT, ctx.term())
[INFO] [stderr] 331 | |     .await
[INFO] [stderr] 332 | |     .expect("Context termination timed out!");
[INFO] [stderr]     | |_____________________________________________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 330 |   let _ = tokio::time::timeout(SHUTDOWN_TIMEOUT, ctx.term())
[INFO] [stderr]     |   +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]  --> tests/inproc_minimal.rs:3:12
[INFO] [stderr]   |
[INFO] [stderr] 3 | use rzmq::{Context, Msg, SocketType, ZmqError};
[INFO] [stderr]   |            ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `rzmq` (test "push_pull_lifecycle") generated 2 warnings (run `cargo fix --test "push_pull_lifecycle" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (test "socket_options") generated 1 warning (run `cargo fix --test "socket_options" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (lib test) generated 75 warnings (75 duplicates)
[INFO] [stderr] warning: `rzmq` (test "router_router") generated 2 warnings (run `cargo fix --test "router_router" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (test "shutdown_race") generated 5 warnings (run `cargo fix --test "shutdown_race" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (test "push_pull") generated 1 warning (run `cargo fix --test "push_pull" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (test "reconnect_tests") generated 2 warnings (run `cargo fix --test "reconnect_tests" -p rzmq` to apply 2 suggestions)
[INFO] [stderr] warning: `rzmq` (test "pub_sub") generated 2 warnings (run `cargo fix --test "pub_sub" -p rzmq` to apply 2 suggestions)
[INFO] [stderr] warning: `rzmq` (test "req_rep") generated 2 warnings (run `cargo fix --test "req_rep" -p rzmq` to apply 1 suggestion)
[INFO] [stderr] warning: `rzmq` (example "dealrtr_multiclient") generated 8 warnings (5 duplicates)
[INFO] [stderr] warning: `rzmq` (test "inproc_minimal") generated 1 warning (run `cargo fix --test "inproc_minimal" -p rzmq` to apply 1 suggestion)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.33s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/rzmq-ecb0fb1a9996864e)
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test runtime::waitgroup::tests::test_waitgroup_wait_on_zero ... ok
[INFO] [stdout] test runtime::waitgroup::tests::test_waitgroup_add_done_wait ... ok
[INFO] [stdout] test runtime::waitgroup::tests::test_waitgroup_add_after_wait_starts ... ok
[INFO] [stdout] test runtime::waitgroup::tests::test_waitgroup_done_panic_on_zero - should panic ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.09s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/common.rs (/opt/rustwide/target/debug/deps/common-7a5be023af07daec)
[INFO] [stdout] 
[INFO] [stderr]      Running tests/dealer_dealer.rs (/opt/rustwide/target/debug/deps/dealer_dealer-08d494de17ea70c4)
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test test_dealer_dealer_tcp_bidirectional ... ok
[INFO] [stderr]      Running tests/dealer_rep.rs (/opt/rustwide/target/debug/deps/dealer_rep-a9f3594dbb3ab003)
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.18s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test test_dealer_rep_tcp_basic ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.19s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/dealer_router.rs (/opt/rustwide/target/debug/deps/dealer_router-9d89662ac5f5a7d0)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test test_dealer_router_inproc_basic ... ok
[INFO] [stdout] test test_dealer_router_tcp_basic ... ok
[INFO] [stdout] test test_dealer_router_ipc_basic ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.18s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/dealer_router_advanced.rs (/opt/rustwide/target/debug/deps/dealer_router_advanced-c00dd4b263a6691c)
[INFO] [stdout] 
[INFO] [stdout] running 6 tests
[INFO] [stdout] test test_dealer_router_multi_part_dealer_to_router ... ok
[INFO] [stdout] test test_dealer_router_multiple_dealers ... ok
[INFO] [stdout] test test_dealer_router_multi_part_router_to_dealer ... ok
[INFO] [stdout] test test_dealer_router_router_sends_to_unknown_mandatory_false ... ok
[INFO] [stdout] test test_dealer_router_router_sends_to_unknown_mandatory_true ... ok
[INFO] [stderr]      Running tests/dns.rs (/opt/rustwide/target/debug/deps/dns-c70c3075effd0a9b)
[INFO] [stdout] test test_dealer_router_dealer_disconnects_router_sends ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.33s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test test_dns_bind_to_localhost_succeeds ... ok
[INFO] [stdout] test test_dns_connect_to_localhost_succeeds ... ok
[INFO] [stdout] test test_dns_bind_to_non_existent_host_fails ... ok
[INFO] [stdout] test test_dns_connect_to_non_existent_host_fails ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.48s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/inproc_minimal.rs (/opt/rustwide/target/debug/deps/inproc_minimal-be904fcaf48fc358)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test test_inproc_minimal_pipe ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.14s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/lifecycle.rs (/opt/rustwide/target/debug/deps/lifecycle-d45b6138bc656585)
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test test_context_term_closes_sockets ... ok
[INFO] [stdout] test test_concurrent_term_and_op ... ok
[INFO] [stdout] test test_socket_explicit_close_triggers_disconnect_event ... ok
[INFO] [stdout] test test_socket_close_stops_connection ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.43s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/plain_tests.rs (/opt/rustwide/target/debug/deps/plain_tests-1d2f48ef342b7abf)
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test test_plain_client_no_credentials ... ok
[INFO] [stdout] test test_plain_client_to_null_server_fails ... ok
[INFO] [stdout] test test_null_client_to_plain_server_fails ... ok
[INFO] [stdout] test test_plain_successful_handshake ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.07s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/pub_sub.rs (/opt/rustwide/target/debug/deps/pub_sub-556b89fe9946ad79)
[INFO] [stdout] 
[INFO] [stdout] running 8 tests
[INFO] [stdout] test test_pub_sub_ipc_basic ... ok
[INFO] [stdout] test test_pub_sub_subscriber_disconnects ... ok
[INFO] [stdout] test test_pub_sub_tcp_multiple_subs ... ok
[INFO] [stdout] test test_pub_sub_tcp_topic_filter ... ok
[INFO] [stdout] test test_pub_sub_tcp_basic ... ok
[INFO] [stdout] test test_pub_sub_unsubscribe ... ok
[INFO] [stdout] test test_pub_sub_inproc_basic ... ok
[INFO] [stdout] test test_pub_sub_late_subscriber ... ok
[INFO] [stderr]      Running tests/push_pull.rs (/opt/rustwide/target/debug/deps/push_pull-3e53f762e88a3b9d)
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 8 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 5.71s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 9 tests
[INFO] [stdout] test test_push_pull_inproc_basic_messaging ... ok
[INFO] [stdout] test test_push_pull_inproc_multiple_clients ... ok
[INFO] [stdout] test test_push_pull_ipc_basic_messaging ... ok
[INFO] [stdout] test test_push_pull_tcp_basic_messaging ... ok
[INFO] [stdout] test test_push_pull_tcp_connect_before_bind ... ok
[INFO] [stdout] test test_push_pull_hwm_sndtimeo_0 ... ok
[INFO] [stdout] test test_push_pull_tcp_multiple_messages ... ok
[INFO] [stdout] test test_pull_rcvtimeo ... ok
[INFO] [stdout] test test_push_sndtimeo_positive_no_peer ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 9 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.65s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/push_pull_lifecycle.rs (/opt/rustwide/target/debug/deps/push_pull_lifecycle-d53e61946b5ffb9b)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stderr]      Running tests/reconnect_tests.rs (/opt/rustwide/target/debug/deps/reconnect_tests-6cc231d46a4f89ea)
[INFO] [stdout] test test_push_pull_explicit_close_then_term ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.26s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test test_push_pull_reconnect_advanced_style ... ok
[INFO] [stdout] test test_req_rep_reconnect_advanced_style ... ok
[INFO] [stdout] test test_dealer_router_multiple_disconnect_reconnect_cycle ... ok
[INFO] [stderr]      Running tests/req_rep.rs (/opt/rustwide/target/debug/deps/req_rep-8885bd2868cb1f8d)
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.81s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test test_req_rep_inproc_basic ... ok
[INFO] [stdout] test test_req_rep_ipc_basic ... ok
[INFO] [stdout] test test_req_rep_tcp_basic ... ok
[INFO] [stdout] test test_req_rep_tcp_connect_before_bind ... ok
[INFO] [stderr]      Running tests/req_rep_advanced.rs (/opt/rustwide/target/debug/deps/req_rep_advanced-9f4f39ca8e3602f8)
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.26s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 5 tests
[INFO] [stdout] test test_req_rep_rep_send_without_request ... ok
[INFO] [stdout] test test_req_rep_req_send_without_recv ... ok
[INFO] [stdout] test test_req_rep_rep_recv_without_request ... ok
[INFO] [stdout] test test_req_rep_req_disconnects_before_reply ... ok
[INFO] [stdout] test test_req_rep_rep_disconnects_while_req_waiting ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.85s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/req_router.rs (/opt/rustwide/target/debug/deps/req_router-d5f22b6995c1d24c)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test test_req_router_multiple_req_clients ... ok
[INFO] [stdout] test test_req_router_rzmq_to_rzmq ... ok
[INFO] [stderr]      Running tests/router_router.rs (/opt/rustwide/target/debug/deps/router_router-907d4df99346f207)
[INFO] [stdout] test test_req_router_req_disconnects_before_reply ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.39s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test test_router_chain_forwarding ... ok
[INFO] [stdout] test test_router_router_tcp_forwarding ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.28s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/shutdown_race.rs (/opt/rustwide/target/debug/deps/shutdown_race-fcb6fa2fc9da04fe)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test test_chaotic_shutdown_tcp ... ok
[INFO] [stdout] test test_chaotic_shutdown ... ok
[INFO] [stdout] test test_push_pull_concurrent_shutdown_race ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 5.90s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/socket_options.rs (/opt/rustwide/target/debug/deps/socket_options-c683ede85fbb37ec)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test test_option_last_endpoint_inproc ... ok
[INFO] [stdout] test test_option_last_endpoint_tcp_ephemeral_port ... ok
[INFO] [stdout] test test_option_last_endpoint_ipc ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.19s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/tcp_corking.rs (/opt/rustwide/target/debug/deps/tcp_corking-f2daf0e6a9096f53)
[INFO] [stdout] 
[INFO] [stdout] running 6 tests
[INFO] [stdout] test test_tcp_cork_state_management_with_more_flag ... ok
[INFO] [stdout] test test_tcp_cork_single_part_message_cork_enabled ... ok
[INFO] [stdout] test test_tcp_cork_multi_part_message_cork_enabled ... ok
[INFO] [stdout] test test_tcp_cork_single_part_message_cork_disabled ... ok
[INFO] [stdout] test test_tcp_cork_multi_part_message_cork_disabled ... ok
[INFO] [stderr]      Running tests/transport_failures.rs (/opt/rustwide/target/debug/deps/transport_failures-d0bbd03b864f7e13)
[INFO] [stdout] test test_tcp_cork_ping_pong_interaction ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.87s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test test_ipc_bind_fail_directory_exists ... ok
[INFO] [stdout] test test_ipc_bind_succeeds_over_existing_file ... ok
[INFO] [stdout] test test_tcp_connect_fail_no_listener ... ok
[INFO] [stdout] test test_ipc_connect_fail_no_listener ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.35s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests rzmq
[INFO] [stderr] warning: the usage of Script Group `Greek` in this crate consists solely of mixed script confusables
[INFO] [stderr]    --> src/throttle/mod.rs:129:11
[INFO] [stderr]     |
[INFO] [stderr] 129 |       let α = self.shared.config.adaptive_learning_rate;
[INFO] [stderr]     |           ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: the usage includes 'α' (U+03B1)
[INFO] [stderr]     = note: please recheck to make sure their usages are indeed what you want
[INFO] [stderr]     = note: `#[warn(mixed_script_confusables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: 1 warning emitted
[INFO] [stderr] 
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test src/throttle/mod.rs - throttle (line 27) ... ignored
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] all doctests ran in 0.51s; merged doctests compilation took 0.50s
[INFO] running `Command { std: "docker" "inspect" "80e28147b2b8851129d12147bf44dc44e1aadb3ca2dc3727426bac13b43351a6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "80e28147b2b8851129d12147bf44dc44e1aadb3ca2dc3727426bac13b43351a6", kill_on_drop: false }`
[INFO] [stdout] 80e28147b2b8851129d12147bf44dc44e1aadb3ca2dc3727426bac13b43351a6
