[INFO] cloning repository https://github.com/ernestoCruz05/fca
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/ernestoCruz05/fca" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FernestoCruz05%2Ffca", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FernestoCruz05%2Ffca'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 1a9c7bac1781fc353fe2d9d18be5d64fad83c53e
[INFO] testing ernestoCruz05/fca against master#ec6f9a5b4413f74386267ef8efc93712c2ce6db6 for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FernestoCruz05%2Ffca" "/workspace/builds/worker-5-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/ernestoCruz05/fca
[INFO] finished tweaking git repo https://github.com/ernestoCruz05/fca
[INFO] tweaked toml for git repo https://github.com/ernestoCruz05/fca written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/ernestoCruz05/fca on toolchain ec6f9a5b4413f74386267ef8efc93712c2ce6db6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/ernestoCruz05/fca 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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded sqlformat v0.2.6
[INFO] [stderr]   Downloaded sqlx-sqlite v0.7.4
[INFO] [stderr]   Downloaded sqlx-macros v0.7.4
[INFO] [stderr]   Downloaded instability v0.3.9
[INFO] [stderr]   Downloaded opus v0.3.0
[INFO] [stderr]   Downloaded ringbuf v0.4.8
[INFO] [stderr]   Downloaded sqlx-macros-core v0.7.4
[INFO] [stderr]   Downloaded objc2-core-audio v0.3.2
[INFO] [stderr]   Downloaded objc2-core-audio-types v0.3.2
[INFO] [stderr]   Downloaded sqlx-core v0.7.4
[INFO] [stderr]   Downloaded coreaudio-rs v0.13.0
[INFO] [stderr]   Downloaded sqlx-mysql v0.7.4
[INFO] [stderr]   Downloaded dispatch2 v0.3.0
[INFO] [stderr]   Downloaded sqlx-postgres v0.7.4
[INFO] [stderr]   Downloaded cpal v0.16.0
[INFO] [stderr]   Downloaded sqlx v0.7.4
[INFO] [stderr]   Downloaded serde_json v1.0.141
[INFO] [stderr]   Downloaded objc2-audio-toolbox v0.3.2
[INFO] [stderr]   Downloaded objc2 v0.6.3
[INFO] [stderr]   Downloaded audiopus_sys v0.2.2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 3d5d5557a12067a310714aa7840ad85c6f84110e612d5d329cbb3b3d8dac88d7
[INFO] running `Command { std: "docker" "start" "-a" "3d5d5557a12067a310714aa7840ad85c6f84110e612d5d329cbb3b3d8dac88d7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "3d5d5557a12067a310714aa7840ad85c6f84110e612d5d329cbb3b3d8dac88d7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3d5d5557a12067a310714aa7840ad85c6f84110e612d5d329cbb3b3d8dac88d7", kill_on_drop: false }`
[INFO] [stdout] 3d5d5557a12067a310714aa7840ad85c6f84110e612d5d329cbb3b3d8dac88d7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 448e928e9f9d8f4f792fdb59dc8764fec46fa749b9cbd0cdd92719a4be8bd4af
[INFO] running `Command { std: "docker" "start" "-a" "448e928e9f9d8f4f792fdb59dc8764fec46fa749b9cbd0cdd92719a4be8bd4af", kill_on_drop: false }`
[INFO] [stderr]    Compiling unicode-ident v1.0.18
[INFO] [stderr]    Compiling libc v0.2.174
[INFO] [stderr]    Compiling stable_deref_trait v1.2.0
[INFO] [stderr]    Compiling log v0.4.27
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling cc v1.2.31
[INFO] [stderr]    Compiling writeable v0.6.1
[INFO] [stderr]    Compiling typenum v1.18.0
[INFO] [stderr]    Compiling litemap v0.8.0
[INFO] [stderr]    Compiling icu_properties_data v2.0.1
[INFO] [stderr]    Compiling icu_normalizer_data v2.0.0
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling bytes v1.10.1
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling rustls v0.21.12
[INFO] [stderr]    Compiling bitflags v2.9.1
[INFO] [stderr]    Compiling iana-time-zone v0.1.63
[INFO] [stderr]    Compiling proc-macro2 v1.0.95
[INFO] [stderr]    Compiling serde_json v1.0.141
[INFO] [stderr]    Compiling form_urlencoded v1.2.1
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling cpufeatures v0.2.17
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling crc-catalog v2.4.0
[INFO] [stderr]    Compiling rustls-pemfile v1.0.4
[INFO] [stderr]    Compiling crc v3.3.0
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling webpki-roots v0.25.4
[INFO] [stderr]    Compiling rustversion v1.0.21
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling rustix v1.0.8
[INFO] [stderr]    Compiling urlencoding v2.1.3
[INFO] [stderr]    Compiling indexmap v2.12.1
[INFO] [stderr]    Compiling flume v0.11.1
[INFO] [stderr]    Compiling atoi v2.0.0
[INFO] [stderr]    Compiling chrono v0.4.41
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling fnv v1.0.7
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling linux-raw-sys v0.9.4
[INFO] [stderr]    Compiling cmake v0.1.54
[INFO] [stderr]    Compiling syn v2.0.104
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling heck v0.4.1
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]    Compiling dotenvy v0.15.7
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling socket2 v0.6.0
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling signal-hook-registry v1.4.5
[INFO] [stderr]    Compiling parking_lot v0.12.4
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling sqlformat v0.2.6
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling futures-intrusive v0.5.0
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling libsqlite3-sys v0.27.0
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling tokio v1.47.0
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling audiopus_sys v0.2.2
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling hashbrown v0.15.4
[INFO] [stderr]    Compiling signal-hook-mio v0.2.4
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling cpal v0.16.0
[INFO] [stderr]    Compiling indoc v2.0.6
[INFO] [stderr]    Compiling compact_str v0.8.1
[INFO] [stderr]    Compiling hashlink v0.8.4
[INFO] [stderr]    Compiling crossterm v0.28.1
[INFO] [stderr]    Compiling cassowary v0.3.0
[INFO] [stderr]    Compiling opus v0.3.0
[INFO] [stderr]    Compiling alsa v0.9.1
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling ringbuf v0.4.8
[INFO] [stderr]    Compiling lru v0.12.5
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling tempfile v3.20.0
[INFO] [stderr]    Compiling rustls-webpki v0.101.7
[INFO] [stderr]    Compiling sct v0.7.1
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling yoke v0.8.0
[INFO] [stderr]    Compiling zerovec v0.11.2
[INFO] [stderr]    Compiling zerotrie v0.2.2
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling tinystr v0.8.1
[INFO] [stderr]    Compiling potential_utf v0.1.2
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling icu_collections v2.0.0
[INFO] [stderr]    Compiling icu_locale_core v2.0.0
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling icu_provider v2.0.0
[INFO] [stderr]    Compiling icu_properties v2.0.1
[INFO] [stderr]    Compiling icu_normalizer v2.0.0
[INFO] [stderr]    Compiling unicode-truncate v1.1.0
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling ratatui v0.28.1
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling sqlx-core v0.7.4
[INFO] [stderr]    Compiling sqlx-sqlite v0.7.4
[INFO] [stderr]    Compiling sqlx-macros-core v0.7.4
[INFO] [stderr]    Compiling sqlx-macros v0.7.4
[INFO] [stderr]    Compiling sqlx v0.7.4
[INFO] [stderr]    Compiling agora v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: field `is_input` is never read
[INFO] [stdout]   --> src/audio.rs:70:9
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub struct AudioDeviceInfo {
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] 69 |     pub name: String,
[INFO] [stdout] 70 |     pub is_input: bool,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AudioDeviceInfo` 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: methods `snapshot` and `reset` are never used
[INFO] [stdout]    --> src/audio.rs:230:12
[INFO] [stdout]     |
[INFO] [stdout] 223 | impl AudioStats {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 230 |     pub fn snapshot(&self) -> AudioStatsSnapshot {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     pub fn reset(&self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AudioStatsSnapshot` is never constructed
[INFO] [stdout]    --> src/audio.rs:250:12
[INFO] [stdout]     |
[INFO] [stdout] 250 | pub struct AudioStatsSnapshot {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `stats`, `input_device_name`, and `output_device_name` are never read
[INFO] [stdout]    --> src/audio.rs:274:5
[INFO] [stdout]     |
[INFO] [stdout] 266 | pub struct AudioManager {
[INFO] [stdout]     |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 274 |     stats: Arc<AudioStats>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 275 |     /// Input device name
[INFO] [stdout] 276 |     pub input_device_name: String,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 277 |     /// Output device name
[INFO] [stdout] 278 |     pub output_device_name: String,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `stats` and `is_running` are never used
[INFO] [stdout]    --> src/audio.rs:440:12
[INFO] [stdout]     |
[INFO] [stdout] 281 | impl AudioManager {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 440 |     pub fn stats(&self) -> &Arc<AudioStats> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 445 |     pub fn is_running(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `pending` and `clear` are never used
[INFO] [stdout]    --> src/audio.rs:500:12
[INFO] [stdout]     |
[INFO] [stdout] 473 | impl FrameCollector {
[INFO] [stdout]     | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 500 |     pub fn pending(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 505 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `description` is never read
[INFO] [stdout]    --> src/tui_client.rs:120:51
[INFO] [stdout]     |
[INFO] [stdout] 120 |     ServerCreated { server_id: u16, name: String, description: String },
[INFO] [stdout]     |     ------------- field in this variant           ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `UIUpdate` 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: field `server_id` is never read
[INFO] [stdout]    --> src/tui_client.rs:151:24
[INFO] [stdout]     |
[INFO] [stdout] 151 |     ServerMemberList { server_id: u16, members: Vec<UserStatus> },
[INFO] [stdout]     |     ----------------   ^^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     field in this variant
[INFO] [stdout]     |
[INFO] [stdout]     = note: `UIUpdate` 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 `VoiceLevel` is never constructed
[INFO] [stdout]    --> src/tui_client.rs:150:5
[INFO] [stdout]     |
[INFO] [stdout] 117 | pub enum UIUpdate {
[INFO] [stdout]     |          -------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 150 |     VoiceLevel { level: f32 },
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `UIUpdate` 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: fields `id` and `description` are never read
[INFO] [stdout]    --> src/tui_client.rs:183:9
[INFO] [stdout]     |
[INFO] [stdout] 182 | pub struct ServerData {
[INFO] [stdout]     |            ---------- fields in this struct
[INFO] [stdout] 183 |     pub id: u16,
[INFO] [stdout]     |         ^^
[INFO] [stdout] 184 |     pub name: String,
[INFO] [stdout] 185 |     pub description: String,
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ServerData` 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: field `messages_list_state` is never read
[INFO] [stdout]    --> src/tui_client.rs:315:5
[INFO] [stdout]     |
[INFO] [stdout] 248 | pub struct TuiChatClient {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 315 |     messages_list_state: ListState,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `TuiChatClient` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHANNELS` is never used
[INFO] [stdout]   --> src/voice.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub const CHANNELS: usize = 1;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `is_speaking` and `get_energy` are never used
[INFO] [stdout]    --> src/voice.rs:266:12
[INFO] [stdout]     |
[INFO] [stdout] 221 | impl VoiceActivityDetector {
[INFO] [stdout]     | -------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 266 |     pub fn is_speaking(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 271 |     pub fn get_energy(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `estimated_jitter` is never read
[INFO] [stdout]    --> src/voice.rs:298:5
[INFO] [stdout]     |
[INFO] [stdout] 292 | pub struct JitterBuffer {
[INFO] [stdout]     |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 298 |     estimated_jitter: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `JitterBuffer` 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 `depth` and `clear` are never used
[INFO] [stdout]    --> src/voice.rs:381:12
[INFO] [stdout]     |
[INFO] [stdout] 309 | impl JitterBuffer {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 381 |     pub fn depth(&self) -> usize {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 391 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VoiceUserState` is never constructed
[INFO] [stdout]    --> src/voice.rs:403:12
[INFO] [stdout]     |
[INFO] [stdout] 403 | pub struct VoiceUserState {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `heartbeat`, `is_expired`, `next_sequence`, and `advance_timestamp` are never used
[INFO] [stdout]    --> src/voice.rs:418:12
[INFO] [stdout]     |
[INFO] [stdout] 416 | impl VoiceUserState {
[INFO] [stdout]     | ------------------- associated items in this implementation
[INFO] [stdout] 417 |     /// Create a new voice user state
[INFO] [stdout] 418 |     pub fn new(user_id: u16, username: String, room_id: u16, socket_addr: SocketAddr) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 434 |     pub fn heartbeat(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 439 |     pub fn is_expired(&self, timeout: Duration) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 444 |     pub fn next_sequence(&mut self) -> u16 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 451 |     pub fn advance_timestamp(&mut self, samples: u32) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VoiceRoom` is never constructed
[INFO] [stdout]    --> src/voice.rs:539:12
[INFO] [stdout]     |
[INFO] [stdout] 539 | pub struct VoiceRoom {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/voice.rs:546:12
[INFO] [stdout]     |
[INFO] [stdout] 544 | impl VoiceRoom {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] 545 |     /// Create a new voice room
[INFO] [stdout] 546 |     pub fn new(room_id: u16) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 554 |     pub fn add_user(&mut self, state: VoiceUserState) {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 559 |     pub fn remove_user(&mut self, user_id: u16) -> Option<VoiceUserState> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 564 |     pub fn get_user(&self, user_id: u16) -> Option<&VoiceUserState> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 569 |     pub fn get_user_mut(&mut self, user_id: u16) -> Option<&mut VoiceUserState> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 574 |     pub fn get_recipient_addrs(&self, exclude_user_id: u16) -> Vec<SocketAddr> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 585 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 590 |     pub fn user_count(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VoiceServerState` is never constructed
[INFO] [stdout]    --> src/voice.rs:600:12
[INFO] [stdout]     |
[INFO] [stdout] 600 | pub struct VoiceServerState {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `register_token`, and `validate_token` are never used
[INFO] [stdout]    --> src/voice.rs:611:12
[INFO] [stdout]     |
[INFO] [stdout] 609 | impl VoiceServerState {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 610 |     /// Create new voice server state
[INFO] [stdout] 611 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 620 |     pub fn register_token(&mut self, token: String, user_id: u16, room_id: u16) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 625 |     pub fn validate_token(&mut self, token: &str) -> Option<(u16, u16)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VoiceServer` is never constructed
[INFO] [stdout]    --> src/voice.rs:637:12
[INFO] [stdout]     |
[INFO] [stdout] 637 | pub struct VoiceServer {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `state`, `start`, `handle_packet`, and `cleanup_expired_sessions` are never used
[INFO] [stdout]    --> src/voice.rs:643:12
[INFO] [stdout]     |
[INFO] [stdout] 641 | impl VoiceServer {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 642 |     /// Create a new voice server
[INFO] [stdout] 643 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 650 |     pub fn state(&self) -> Arc<RwLock<VoiceServerState>> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 655 |     pub async fn start(
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 692 |     async fn handle_packet(
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 773 |     pub async fn cleanup_expired_sessions(&self, timeout: Duration) {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VoiceClient` is never constructed
[INFO] [stdout]    --> src/voice.rs:811:12
[INFO] [stdout]     |
[INFO] [stdout] 811 | pub struct VoiceClient {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/voice.rs:837:12
[INFO] [stdout]     |
[INFO] [stdout] 835 | impl VoiceClient {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 836 |     /// Create a new voice client
[INFO] [stdout] 837 |     pub fn new(user_id: u16, room_id: u16) -> Result<Self, opus::Error> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 857 |     pub fn process_outgoing(&mut self, samples: &[f32]) -> Option<VoicePacket> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 894 |     pub fn process_incoming(&mut self, packet: VoicePacket) -> Option<Vec<f32>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 911 |     pub fn is_speaking(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 916 |     fn next_sequence(&mut self) -> u16 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 923 |     pub fn get_stats(&self) -> (u64, u64) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 928 |     pub fn reset(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AudioMixer` is never constructed
[INFO] [stdout]    --> src/voice.rs:940:12
[INFO] [stdout]     |
[INFO] [stdout] 940 | pub struct AudioMixer {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `set_volume`, and `mix` are never used
[INFO] [stdout]    --> src/voice.rs:949:12
[INFO] [stdout]     |
[INFO] [stdout] 947 | impl AudioMixer {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 948 |     /// Create a new audio mixer
[INFO] [stdout] 949 |     pub fn new(max_streams: usize) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 957 |     pub fn set_volume(&mut self, volume: f32) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 964 |     pub fn mix(&self, streams: &[Vec<f32>]) -> Vec<f32> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 08s
[INFO] running `Command { std: "docker" "inspect" "448e928e9f9d8f4f792fdb59dc8764fec46fa749b9cbd0cdd92719a4be8bd4af", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "448e928e9f9d8f4f792fdb59dc8764fec46fa749b9cbd0cdd92719a4be8bd4af", kill_on_drop: false }`
[INFO] [stdout] 448e928e9f9d8f4f792fdb59dc8764fec46fa749b9cbd0cdd92719a4be8bd4af
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 12607a9e9781db8f803e86b1ba9d33c3a10078972b72476d872c286e177923d3
[INFO] running `Command { std: "docker" "start" "-a" "12607a9e9781db8f803e86b1ba9d33c3a10078972b72476d872c286e177923d3", kill_on_drop: false }`
[INFO] [stderr]    Compiling agora v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: field `is_input` is never read
[INFO] [stdout]   --> src/audio.rs:70:9
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub struct AudioDeviceInfo {
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] 69 |     pub name: String,
[INFO] [stdout] 70 |     pub is_input: bool,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AudioDeviceInfo` 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: methods `snapshot` and `reset` are never used
[INFO] [stdout]    --> src/audio.rs:230:12
[INFO] [stdout]     |
[INFO] [stdout] 223 | impl AudioStats {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 230 |     pub fn snapshot(&self) -> AudioStatsSnapshot {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     pub fn reset(&self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AudioStatsSnapshot` is never constructed
[INFO] [stdout]    --> src/audio.rs:250:12
[INFO] [stdout]     |
[INFO] [stdout] 250 | pub struct AudioStatsSnapshot {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `stats`, `input_device_name`, and `output_device_name` are never read
[INFO] [stdout]    --> src/audio.rs:274:5
[INFO] [stdout]     |
[INFO] [stdout] 266 | pub struct AudioManager {
[INFO] [stdout]     |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 274 |     stats: Arc<AudioStats>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 275 |     /// Input device name
[INFO] [stdout] 276 |     pub input_device_name: String,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 277 |     /// Output device name
[INFO] [stdout] 278 |     pub output_device_name: String,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `stats` and `is_running` are never used
[INFO] [stdout]    --> src/audio.rs:440:12
[INFO] [stdout]     |
[INFO] [stdout] 281 | impl AudioManager {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 440 |     pub fn stats(&self) -> &Arc<AudioStats> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 445 |     pub fn is_running(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `clear` is never used
[INFO] [stdout]    --> src/audio.rs:505:12
[INFO] [stdout]     |
[INFO] [stdout] 473 | impl FrameCollector {
[INFO] [stdout]     | ------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 505 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `description` is never read
[INFO] [stdout]    --> src/tui_client.rs:120:51
[INFO] [stdout]     |
[INFO] [stdout] 120 |     ServerCreated { server_id: u16, name: String, description: String },
[INFO] [stdout]     |     ------------- field in this variant           ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `UIUpdate` 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: field `server_id` is never read
[INFO] [stdout]    --> src/tui_client.rs:151:24
[INFO] [stdout]     |
[INFO] [stdout] 151 |     ServerMemberList { server_id: u16, members: Vec<UserStatus> },
[INFO] [stdout]     |     ----------------   ^^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     field in this variant
[INFO] [stdout]     |
[INFO] [stdout]     = note: `UIUpdate` 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 `VoiceLevel` is never constructed
[INFO] [stdout]    --> src/tui_client.rs:150:5
[INFO] [stdout]     |
[INFO] [stdout] 117 | pub enum UIUpdate {
[INFO] [stdout]     |          -------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 150 |     VoiceLevel { level: f32 },
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `UIUpdate` 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: fields `id` and `description` are never read
[INFO] [stdout]    --> src/tui_client.rs:183:9
[INFO] [stdout]     |
[INFO] [stdout] 182 | pub struct ServerData {
[INFO] [stdout]     |            ---------- fields in this struct
[INFO] [stdout] 183 |     pub id: u16,
[INFO] [stdout]     |         ^^
[INFO] [stdout] 184 |     pub name: String,
[INFO] [stdout] 185 |     pub description: String,
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ServerData` 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: field `messages_list_state` is never read
[INFO] [stdout]    --> src/tui_client.rs:315:5
[INFO] [stdout]     |
[INFO] [stdout] 248 | pub struct TuiChatClient {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 315 |     messages_list_state: ListState,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `TuiChatClient` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHANNELS` is never used
[INFO] [stdout]   --> src/voice.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub const CHANNELS: usize = 1;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_energy` is never used
[INFO] [stdout]    --> src/voice.rs:271:12
[INFO] [stdout]     |
[INFO] [stdout] 221 | impl VoiceActivityDetector {
[INFO] [stdout]     | -------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 271 |     pub fn get_energy(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `estimated_jitter` is never read
[INFO] [stdout]    --> src/voice.rs:298:5
[INFO] [stdout]     |
[INFO] [stdout] 292 | pub struct JitterBuffer {
[INFO] [stdout]     |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 298 |     estimated_jitter: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `JitterBuffer` 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 `depth` and `clear` are never used
[INFO] [stdout]    --> src/voice.rs:381:12
[INFO] [stdout]     |
[INFO] [stdout] 309 | impl JitterBuffer {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 381 |     pub fn depth(&self) -> usize {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 391 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VoiceUserState` is never constructed
[INFO] [stdout]    --> src/voice.rs:403:12
[INFO] [stdout]     |
[INFO] [stdout] 403 | pub struct VoiceUserState {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `heartbeat`, `is_expired`, `next_sequence`, and `advance_timestamp` are never used
[INFO] [stdout]    --> src/voice.rs:418:12
[INFO] [stdout]     |
[INFO] [stdout] 416 | impl VoiceUserState {
[INFO] [stdout]     | ------------------- associated items in this implementation
[INFO] [stdout] 417 |     /// Create a new voice user state
[INFO] [stdout] 418 |     pub fn new(user_id: u16, username: String, room_id: u16, socket_addr: SocketAddr) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 434 |     pub fn heartbeat(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 439 |     pub fn is_expired(&self, timeout: Duration) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 444 |     pub fn next_sequence(&mut self) -> u16 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 451 |     pub fn advance_timestamp(&mut self, samples: u32) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VoiceRoom` is never constructed
[INFO] [stdout]    --> src/voice.rs:539:12
[INFO] [stdout]     |
[INFO] [stdout] 539 | pub struct VoiceRoom {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/voice.rs:546:12
[INFO] [stdout]     |
[INFO] [stdout] 544 | impl VoiceRoom {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] 545 |     /// Create a new voice room
[INFO] [stdout] 546 |     pub fn new(room_id: u16) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 554 |     pub fn add_user(&mut self, state: VoiceUserState) {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 559 |     pub fn remove_user(&mut self, user_id: u16) -> Option<VoiceUserState> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 564 |     pub fn get_user(&self, user_id: u16) -> Option<&VoiceUserState> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 569 |     pub fn get_user_mut(&mut self, user_id: u16) -> Option<&mut VoiceUserState> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 574 |     pub fn get_recipient_addrs(&self, exclude_user_id: u16) -> Vec<SocketAddr> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 585 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 590 |     pub fn user_count(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VoiceServerState` is never constructed
[INFO] [stdout]    --> src/voice.rs:600:12
[INFO] [stdout]     |
[INFO] [stdout] 600 | pub struct VoiceServerState {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `register_token`, and `validate_token` are never used
[INFO] [stdout]    --> src/voice.rs:611:12
[INFO] [stdout]     |
[INFO] [stdout] 609 | impl VoiceServerState {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 610 |     /// Create new voice server state
[INFO] [stdout] 611 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 620 |     pub fn register_token(&mut self, token: String, user_id: u16, room_id: u16) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 625 |     pub fn validate_token(&mut self, token: &str) -> Option<(u16, u16)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VoiceServer` is never constructed
[INFO] [stdout]    --> src/voice.rs:637:12
[INFO] [stdout]     |
[INFO] [stdout] 637 | pub struct VoiceServer {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `state`, `start`, `handle_packet`, and `cleanup_expired_sessions` are never used
[INFO] [stdout]    --> src/voice.rs:643:12
[INFO] [stdout]     |
[INFO] [stdout] 641 | impl VoiceServer {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 642 |     /// Create a new voice server
[INFO] [stdout] 643 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 650 |     pub fn state(&self) -> Arc<RwLock<VoiceServerState>> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 655 |     pub async fn start(
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 692 |     async fn handle_packet(
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 773 |     pub async fn cleanup_expired_sessions(&self, timeout: Duration) {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `VoiceClient` is never constructed
[INFO] [stdout]    --> src/voice.rs:811:12
[INFO] [stdout]     |
[INFO] [stdout] 811 | pub struct VoiceClient {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/voice.rs:837:12
[INFO] [stdout]     |
[INFO] [stdout] 835 | impl VoiceClient {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 836 |     /// Create a new voice client
[INFO] [stdout] 837 |     pub fn new(user_id: u16, room_id: u16) -> Result<Self, opus::Error> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 857 |     pub fn process_outgoing(&mut self, samples: &[f32]) -> Option<VoicePacket> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 894 |     pub fn process_incoming(&mut self, packet: VoicePacket) -> Option<Vec<f32>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 911 |     pub fn is_speaking(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 916 |     fn next_sequence(&mut self) -> u16 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 923 |     pub fn get_stats(&self) -> (u64, u64) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 928 |     pub fn reset(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_volume` is never used
[INFO] [stdout]    --> src/voice.rs:957:12
[INFO] [stdout]     |
[INFO] [stdout] 947 | impl AudioMixer {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 957 |     pub fn set_volume(&mut self, volume: f32) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 5.45s
[INFO] running `Command { std: "docker" "inspect" "12607a9e9781db8f803e86b1ba9d33c3a10078972b72476d872c286e177923d3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "12607a9e9781db8f803e86b1ba9d33c3a10078972b72476d872c286e177923d3", kill_on_drop: false }`
[INFO] [stdout] 12607a9e9781db8f803e86b1ba9d33c3a10078972b72476d872c286e177923d3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] a273b7e3e306278206ecbf7053159dcd4d93b2adb71d33e32f8e147be6cca920
[INFO] running `Command { std: "docker" "start" "-a" "a273b7e3e306278206ecbf7053159dcd4d93b2adb71d33e32f8e147be6cca920", kill_on_drop: false }`
[INFO] [stderr] warning: field `is_input` is never read
[INFO] [stderr]   --> src/audio.rs:70:9
[INFO] [stderr]    |
[INFO] [stderr] 68 | pub struct AudioDeviceInfo {
[INFO] [stderr]    |            --------------- field in this struct
[INFO] [stderr] 69 |     pub name: String,
[INFO] [stderr] 70 |     pub is_input: bool,
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `AudioDeviceInfo` 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: methods `snapshot` and `reset` are never used
[INFO] [stderr]    --> src/audio.rs:230:12
[INFO] [stderr]     |
[INFO] [stderr] 223 | impl AudioStats {
[INFO] [stderr]     | --------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 230 |     pub fn snapshot(&self) -> AudioStatsSnapshot {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 240 |     pub fn reset(&self) {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `AudioStatsSnapshot` is never constructed
[INFO] [stderr]    --> src/audio.rs:250:12
[INFO] [stderr]     |
[INFO] [stderr] 250 | pub struct AudioStatsSnapshot {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `stats`, `input_device_name`, and `output_device_name` are never read
[INFO] [stderr]    --> src/audio.rs:274:5
[INFO] [stderr]     |
[INFO] [stderr] 266 | pub struct AudioManager {
[INFO] [stderr]     |            ------------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 274 |     stats: Arc<AudioStats>,
[INFO] [stderr]     |     ^^^^^
[INFO] [stderr] 275 |     /// Input device name
[INFO] [stderr] 276 |     pub input_device_name: String,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 277 |     /// Output device name
[INFO] [stderr] 278 |     pub output_device_name: String,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `stats` and `is_running` are never used
[INFO] [stderr]    --> src/audio.rs:440:12
[INFO] [stderr]     |
[INFO] [stderr] 281 | impl AudioManager {
[INFO] [stderr]     | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 440 |     pub fn stats(&self) -> &Arc<AudioStats> {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 445 |     pub fn is_running(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `clear` is never used
[INFO] [stderr]    --> src/audio.rs:505:12
[INFO] [stderr]     |
[INFO] [stderr] 473 | impl FrameCollector {
[INFO] [stderr]     | ------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 505 |     pub fn clear(&mut self) {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `description` is never read
[INFO] [stderr]    --> src/tui_client.rs:120:51
[INFO] [stderr]     |
[INFO] [stderr] 120 |     ServerCreated { server_id: u16, name: String, description: String },
[INFO] [stderr]     |     ------------- field in this variant           ^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `UIUpdate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `server_id` is never read
[INFO] [stderr]    --> src/tui_client.rs:151:24
[INFO] [stderr]     |
[INFO] [stderr] 151 |     ServerMemberList { server_id: u16, members: Vec<UserStatus> },
[INFO] [stderr]     |     ----------------   ^^^^^^^^^
[INFO] [stderr]     |     |
[INFO] [stderr]     |     field in this variant
[INFO] [stderr]     |
[INFO] [stderr]     = note: `UIUpdate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variant `VoiceLevel` is never constructed
[INFO] [stderr]    --> src/tui_client.rs:150:5
[INFO] [stderr]     |
[INFO] [stderr] 117 | pub enum UIUpdate {
[INFO] [stderr]     |          -------- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 150 |     VoiceLevel { level: f32 },
[INFO] [stderr]     |     ^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `UIUpdate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `id` and `description` are never read
[INFO] [stderr]    --> src/tui_client.rs:183:9
[INFO] [stderr]     |
[INFO] [stderr] 182 | pub struct ServerData {
[INFO] [stderr]     |            ---------- fields in this struct
[INFO] [stderr] 183 |     pub id: u16,
[INFO] [stderr]     |         ^^
[INFO] [stderr] 184 |     pub name: String,
[INFO] [stderr] 185 |     pub description: String,
[INFO] [stderr]     |         ^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `ServerData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `messages_list_state` is never read
[INFO] [stderr]    --> src/tui_client.rs:315:5
[INFO] [stderr]     |
[INFO] [stderr] 248 | pub struct TuiChatClient {
[INFO] [stderr]     |            ------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 315 |     messages_list_state: ListState,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `TuiChatClient` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: constant `CHANNELS` is never used
[INFO] [stderr]   --> src/voice.rs:31:11
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub const CHANNELS: usize = 1;
[INFO] [stderr]    |           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `get_energy` is never used
[INFO] [stderr]    --> src/voice.rs:271:12
[INFO] [stderr]     |
[INFO] [stderr] 221 | impl VoiceActivityDetector {
[INFO] [stderr]     | -------------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 271 |     pub fn get_energy(&self) -> f32 {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `estimated_jitter` is never read
[INFO] [stderr]    --> src/voice.rs:298:5
[INFO] [stderr]     |
[INFO] [stderr] 292 | pub struct JitterBuffer {
[INFO] [stderr]     |            ------------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 298 |     estimated_jitter: f32,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `JitterBuffer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `depth` and `clear` are never used
[INFO] [stderr]    --> src/voice.rs:381:12
[INFO] [stderr]     |
[INFO] [stderr] 309 | impl JitterBuffer {
[INFO] [stderr]     | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 381 |     pub fn depth(&self) -> usize {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 391 |     pub fn clear(&mut self) {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `VoiceUserState` is never constructed
[INFO] [stderr]    --> src/voice.rs:403:12
[INFO] [stderr]     |
[INFO] [stderr] 403 | pub struct VoiceUserState {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `heartbeat`, `is_expired`, `next_sequence`, and `advance_timestamp` are never used
[INFO] [stderr]    --> src/voice.rs:418:12
[INFO] [stderr]     |
[INFO] [stderr] 416 | impl VoiceUserState {
[INFO] [stderr]     | ------------------- associated items in this implementation
[INFO] [stderr] 417 |     /// Create a new voice user state
[INFO] [stderr] 418 |     pub fn new(user_id: u16, username: String, room_id: u16, socket_addr: SocketAddr) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 434 |     pub fn heartbeat(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 439 |     pub fn is_expired(&self, timeout: Duration) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 444 |     pub fn next_sequence(&mut self) -> u16 {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 451 |     pub fn advance_timestamp(&mut self, samples: u32) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `VoiceRoom` is never constructed
[INFO] [stderr]    --> src/voice.rs:539:12
[INFO] [stderr]     |
[INFO] [stderr] 539 | pub struct VoiceRoom {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/voice.rs:546:12
[INFO] [stderr]     |
[INFO] [stderr] 544 | impl VoiceRoom {
[INFO] [stderr]     | -------------- associated items in this implementation
[INFO] [stderr] 545 |     /// Create a new voice room
[INFO] [stderr] 546 |     pub fn new(room_id: u16) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 554 |     pub fn add_user(&mut self, state: VoiceUserState) {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 559 |     pub fn remove_user(&mut self, user_id: u16) -> Option<VoiceUserState> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 564 |     pub fn get_user(&self, user_id: u16) -> Option<&VoiceUserState> {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 569 |     pub fn get_user_mut(&mut self, user_id: u16) -> Option<&mut VoiceUserState> {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 574 |     pub fn get_recipient_addrs(&self, exclude_user_id: u16) -> Vec<SocketAddr> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 585 |     pub fn is_empty(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 590 |     pub fn user_count(&self) -> usize {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `VoiceServerState` is never constructed
[INFO] [stderr]    --> src/voice.rs:600:12
[INFO] [stderr]     |
[INFO] [stderr] 600 | pub struct VoiceServerState {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `register_token`, and `validate_token` are never used
[INFO] [stderr]    --> src/voice.rs:611:12
[INFO] [stderr]     |
[INFO] [stderr] 609 | impl VoiceServerState {
[INFO] [stderr]     | --------------------- associated items in this implementation
[INFO] [stderr] 610 |     /// Create new voice server state
[INFO] [stderr] 611 |     pub fn new() -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 620 |     pub fn register_token(&mut self, token: String, user_id: u16, room_id: u16) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 625 |     pub fn validate_token(&mut self, token: &str) -> Option<(u16, u16)> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `VoiceServer` is never constructed
[INFO] [stderr]    --> src/voice.rs:637:12
[INFO] [stderr]     |
[INFO] [stderr] 637 | pub struct VoiceServer {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `state`, `start`, `handle_packet`, and `cleanup_expired_sessions` are never used
[INFO] [stderr]    --> src/voice.rs:643:12
[INFO] [stderr]     |
[INFO] [stderr] 641 | impl VoiceServer {
[INFO] [stderr]     | ---------------- associated items in this implementation
[INFO] [stderr] 642 |     /// Create a new voice server
[INFO] [stderr] 643 |     pub fn new() -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 650 |     pub fn state(&self) -> Arc<RwLock<VoiceServerState>> {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 655 |     pub async fn start(
[INFO] [stderr]     |                  ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 692 |     async fn handle_packet(
[INFO] [stderr]     |              ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 773 |     pub async fn cleanup_expired_sessions(&self, timeout: Duration) {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `VoiceClient` is never constructed
[INFO] [stderr]    --> src/voice.rs:811:12
[INFO] [stderr]     |
[INFO] [stderr] 811 | pub struct VoiceClient {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/voice.rs:837:12
[INFO] [stderr]     |
[INFO] [stderr] 835 | impl VoiceClient {
[INFO] [stderr]     | ---------------- associated items in this implementation
[INFO] [stderr] 836 |     /// Create a new voice client
[INFO] [stderr] 837 |     pub fn new(user_id: u16, room_id: u16) -> Result<Self, opus::Error> {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 857 |     pub fn process_outgoing(&mut self, samples: &[f32]) -> Option<VoicePacket> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 894 |     pub fn process_incoming(&mut self, packet: VoicePacket) -> Option<Vec<f32>> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 911 |     pub fn is_speaking(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 916 |     fn next_sequence(&mut self) -> u16 {
[INFO] [stderr]     |        ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 923 |     pub fn get_stats(&self) -> (u64, u64) {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 928 |     pub fn reset(&mut self) {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `set_volume` is never used
[INFO] [stderr]    --> src/voice.rs:957:12
[INFO] [stderr]     |
[INFO] [stderr] 947 | impl AudioMixer {
[INFO] [stderr]     | --------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 957 |     pub fn set_volume(&mut self, volume: f32) {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `agora` (bin "agora" test) generated 26 warnings
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.20s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/agora-eb9e08f9d2980308)
[INFO] [stdout] 
[INFO] [stdout] running 6 tests
[INFO] [stdout] test audio::tests::test_frame_collector ... ok
[INFO] [stdout] test voice::tests::test_audio_mixer ... ok
[INFO] [stdout] test voice::tests::test_jitter_buffer ... ok
[INFO] [stdout] test voice::tests::test_packet_encode_decode ... ok
[INFO] [stdout] test voice::tests::test_vad ... ok
[INFO] [stderr] ALSA lib confmisc.c:855:(parse_card) cannot find card '0'
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_card_inum returned error: No such file or directory
[INFO] [stderr] ALSA lib confmisc.c:422:(snd_func_concat) error evaluating strings
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_concat returned error: No such file or directory
[INFO] [stderr] ALSA lib confmisc.c:1342:(snd_func_refer) error evaluating name
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_refer returned error: No such file or directory
[INFO] [stderr] ALSA lib conf.c:5727:(snd_config_expand) Evaluate error: No such file or directory
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM default
[INFO] [stderr] ALSA lib confmisc.c:855:(parse_card) cannot find card '0'
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_card_inum returned error: No such file or directory
[INFO] [stderr] ALSA lib confmisc.c:422:(snd_func_concat) error evaluating strings
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_concat returned error: No such file or directory
[INFO] [stderr] ALSA lib confmisc.c:1342:(snd_func_refer) error evaluating name
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_refer returned error: No such file or directory
[INFO] [stderr] ALSA lib conf.c:5727:(snd_config_expand) Evaluate error: No such file or directory
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM default
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM pipewire
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM pipewire
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM pulse
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM pulse
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM jack
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM jack
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM oss
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM oss
[INFO] [stderr] ALSA lib confmisc.c:855:(parse_card) cannot find card '0'
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_card_inum returned error: No such file or directory
[INFO] [stderr] ALSA lib confmisc.c:422:(snd_func_concat) error evaluating strings
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_concat returned error: No such file or directory
[INFO] [stderr] ALSA lib confmisc.c:1342:(snd_func_refer) error evaluating name
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_refer returned error: No such file or directory
[INFO] [stderr] ALSA lib conf.c:5727:(snd_config_expand) Evaluate error: No such file or directory
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM default
[INFO] [stderr] ALSA lib confmisc.c:855:(parse_card) cannot find card '0'
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_card_inum returned error: No such file or directory
[INFO] [stderr] ALSA lib confmisc.c:422:(snd_func_concat) error evaluating strings
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_concat returned error: No such file or directory
[INFO] [stderr] ALSA lib confmisc.c:1342:(snd_func_refer) error evaluating name
[INFO] [stderr] ALSA lib conf.c:5204:(_snd_config_evaluate) function snd_func_refer returned error: No such file or directory
[INFO] [stderr] ALSA lib conf.c:5727:(snd_config_expand) Evaluate error: No such file or directory
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM default
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM pipewire
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM pipewire
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM pulse
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM pulse
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM jack
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM jack
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM oss
[INFO] [stderr] ALSA lib pcm.c:2721:(snd_pcm_open_noupdate) Unknown PCM oss
[INFO] [stdout] test audio::tests::test_list_devices ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "a273b7e3e306278206ecbf7053159dcd4d93b2adb71d33e32f8e147be6cca920", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a273b7e3e306278206ecbf7053159dcd4d93b2adb71d33e32f8e147be6cca920", kill_on_drop: false }`
[INFO] [stdout] a273b7e3e306278206ecbf7053159dcd4d93b2adb71d33e32f8e147be6cca920
