[INFO] cloning repository https://github.com/Agora-Build/Atem [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Agora-Build/Atem" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAgora-Build%2FAtem", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAgora-Build%2FAtem'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 878ab911d3047c49e5b1079718a63f1d65aceda1 [INFO] testing Agora-Build/Atem against beta-2026-04-21 for beta-1.96-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAgora-Build%2FAtem" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/Agora-Build/Atem [INFO] finished tweaking git repo https://github.com/Agora-Build/Atem [INFO] tweaked toml for git repo https://github.com/Agora-Build/Atem written to /workspace/builds/worker-1-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/Agora-Build/Atem on toolchain beta-2026-04-21 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/Agora-Build/Atem 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" "+beta-2026-04-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] warning: unused manifest key: dependencies.agora_token.subdirectory [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 6d73b3351e0607019f64dce4922285f9c172f7b4a73383c94440ec5953410843 [INFO] running `Command { std: "docker" "start" "-a" "6d73b3351e0607019f64dce4922285f9c172f7b4a73383c94440ec5953410843", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "6d73b3351e0607019f64dce4922285f9c172f7b4a73383c94440ec5953410843", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6d73b3351e0607019f64dce4922285f9c172f7b4a73383c94440ec5953410843", kill_on_drop: false }` [INFO] [stdout] 6d73b3351e0607019f64dce4922285f9c172f7b4a73383c94440ec5953410843 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 8c0e8c255c1029eace9e30dc6dd3770845012703530f9ed04949669c43cceacb [INFO] running `Command { std: "docker" "start" "-a" "8c0e8c255c1029eace9e30dc6dd3770845012703530f9ed04949669c43cceacb", kill_on_drop: false }` [INFO] [stderr] warning: unused manifest key: dependencies.agora_token.subdirectory [INFO] [stderr] Compiling proc-macro2 v1.0.101 [INFO] [stderr] Compiling libc v0.2.175 [INFO] [stderr] Compiling cfg-if v1.0.3 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling bitflags v2.9.4 [INFO] [stderr] Compiling log v0.4.28 [INFO] [stderr] Compiling typenum v1.18.0 [INFO] [stderr] Compiling stable_deref_trait v1.2.0 [INFO] [stderr] Compiling autocfg v1.5.0 [INFO] [stderr] Compiling parking_lot_core v0.9.11 [INFO] [stderr] Compiling zerocopy v0.8.27 [INFO] [stderr] Compiling writeable v0.6.1 [INFO] [stderr] Compiling litemap v0.8.0 [INFO] [stderr] Compiling lock_api v0.4.13 [INFO] [stderr] Compiling allocator-api2 v0.2.21 [INFO] [stderr] Compiling foldhash v0.1.5 [INFO] [stderr] Compiling icu_properties_data v2.0.1 [INFO] [stderr] Compiling cpufeatures v0.2.17 [INFO] [stderr] Compiling fs_extra v1.3.0 [INFO] [stderr] Compiling generic-array v0.14.7 [INFO] [stderr] Compiling dunce v1.0.5 [INFO] [stderr] Compiling hashbrown v0.15.5 [INFO] [stderr] Compiling icu_normalizer_data v2.0.0 [INFO] [stderr] Compiling quote v1.0.40 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling openssl v0.10.73 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling syn v2.0.106 [INFO] [stderr] Compiling slab v0.4.11 [INFO] [stderr] Compiling signal-hook v0.3.18 [INFO] [stderr] Compiling rustix v1.0.8 [INFO] [stderr] Compiling aws-lc-rs v1.16.0 [INFO] [stderr] Compiling block-buffer v0.10.4 [INFO] [stderr] Compiling tracing-core v0.1.34 [INFO] [stderr] Compiling ahash v0.8.12 [INFO] [stderr] Compiling indexmap v2.11.1 [INFO] [stderr] Compiling linux-raw-sys v0.9.4 [INFO] [stderr] Compiling ryu v1.0.20 [INFO] [stderr] Compiling getrandom v0.3.3 [INFO] [stderr] Compiling getrandom v0.2.16 [INFO] [stderr] Compiling signal-hook-registry v1.4.6 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling crypto-common v0.1.6 [INFO] [stderr] Compiling mio v1.0.4 [INFO] [stderr] Compiling parking_lot v0.12.4 [INFO] [stderr] Compiling cmake v0.1.57 [INFO] [stderr] Compiling socket2 v0.6.0 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling tracing v0.1.41 [INFO] [stderr] Compiling mio v0.8.11 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling nix v0.28.0 [INFO] [stderr] Compiling openssl-sys v0.9.109 [INFO] [stderr] Compiling aws-lc-sys v0.37.1 [INFO] [stderr] Compiling inout v0.1.4 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling nix v0.30.1 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling deranged v0.5.8 [INFO] [stderr] Compiling cipher v0.4.4 [INFO] [stderr] Compiling signal-hook-mio v0.2.4 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling libsqlite3-sys v0.30.1 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling universal-hash v0.5.1 [INFO] [stderr] Compiling socket2 v0.5.10 [INFO] [stderr] Compiling anstyle-parse v0.2.7 [INFO] [stderr] Compiling anstyle v1.0.11 [INFO] [stderr] Compiling anstyle-query v1.1.4 [INFO] [stderr] Compiling opaque-debug v0.3.1 [INFO] [stderr] Compiling num-conv v0.2.0 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Compiling anyhow v1.0.99 [INFO] [stderr] Compiling serde_json v1.0.143 [INFO] [stderr] Compiling linux-raw-sys v0.4.15 [INFO] [stderr] Compiling memchr v2.7.5 [INFO] [stderr] Compiling colorchoice v1.0.4 [INFO] [stderr] Compiling time-core v0.1.8 [INFO] [stderr] Compiling rustls v0.23.36 [INFO] [stderr] Compiling instability v0.3.9 [INFO] [stderr] Compiling anstream v0.6.20 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling time v0.3.47 [INFO] [stderr] Compiling itertools v0.13.0 [INFO] [stderr] Compiling polyval v0.6.2 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.20.11 [INFO] [stderr] Compiling hashbrown v0.14.5 [INFO] [stderr] Compiling crc32fast v1.5.0 [INFO] [stderr] Compiling sha1 v0.10.6 [INFO] [stderr] Compiling castaway v0.2.4 [INFO] [stderr] Compiling vte_generate_state_changes v0.1.2 [INFO] [stderr] Compiling nibble_vec v0.1.0 [INFO] [stderr] Compiling base64 v0.21.7 [INFO] [stderr] Compiling data-encoding v2.9.0 [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 zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.0 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling tokio-macros v2.5.0 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling zerotrie v0.2.2 [INFO] [stderr] Compiling tokio v1.47.1 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling zerovec v0.11.4 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling darling_macro v0.20.11 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling darling v0.20.11 [INFO] [stderr] Compiling strum_macros v0.26.4 [INFO] [stderr] Compiling tinystr v0.8.1 [INFO] [stderr] Compiling icu_locale_core v2.0.0 [INFO] [stderr] Compiling potential_utf v0.1.3 [INFO] [stderr] Compiling icu_collections v2.0.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling icu_provider v2.0.0 [INFO] [stderr] Compiling endian-type v0.1.2 [INFO] [stderr] Compiling clap_lex v0.7.5 [INFO] [stderr] Compiling icu_normalizer v2.0.0 [INFO] [stderr] Compiling icu_properties v2.0.1 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling toml_write v0.1.2 [INFO] [stderr] Compiling indoc v2.0.6 [INFO] [stderr] Compiling arrayvec v0.7.6 [INFO] [stderr] Compiling winnow v0.7.14 [INFO] [stderr] Compiling vte v0.11.1 [INFO] [stderr] Compiling tokio-util v0.7.16 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling h2 v0.3.27 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling dirs-sys v0.4.1 [INFO] [stderr] Compiling url v2.5.7 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling clap_builder v4.5.47 [INFO] [stderr] Compiling tempfile v3.21.0 [INFO] [stderr] Compiling toml_edit v0.22.27 [INFO] [stderr] Compiling tungstenite v0.20.1 [INFO] [stderr] Compiling radix_trie v0.2.1 [INFO] [stderr] Compiling compact_str v0.8.1 [INFO] [stderr] Compiling strum v0.26.3 [INFO] [stderr] Compiling filedescriptor v0.8.3 [INFO] [stderr] Compiling clap_derive v4.5.47 [INFO] [stderr] Compiling hyper v0.14.32 [INFO] [stderr] Compiling rustls-pemfile v1.0.4 [INFO] [stderr] Compiling unicode-truncate v1.1.0 [INFO] [stderr] Compiling flate2 v1.1.9 [INFO] [stderr] Compiling hashlink v0.9.1 [INFO] [stderr] Compiling yasna v0.5.2 [INFO] [stderr] Compiling ghash v0.5.1 [INFO] [stderr] Compiling crossterm v0.28.1 [INFO] [stderr] Compiling hyper-tls v0.5.0 [INFO] [stderr] Compiling fd-lock v4.0.4 [INFO] [stderr] Compiling console v0.15.11 [INFO] [stderr] Compiling pem v3.0.6 [INFO] [stderr] Compiling aes v0.8.4 [INFO] [stderr] Compiling ctr v0.9.2 [INFO] [stderr] Compiling atem v0.4.94 (/opt/rustwide/workdir) [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling hmac v0.12.1 [INFO] [stderr] Compiling aead v0.5.2 [INFO] [stderr] Compiling serial2 v0.2.34 [INFO] [stderr] Compiling lru v0.12.5 [INFO] [stderr] Compiling encoding_rs v0.8.35 [INFO] [stderr] Compiling home v0.5.12 [INFO] [stderr] Compiling md5 v0.7.0 [INFO] [stderr] Compiling fallible-streaming-iterator v0.1.9 [INFO] [stderr] Compiling fallible-iterator v0.3.0 [INFO] [stderr] Compiling portable-pty v0.9.0 [INFO] [stderr] Compiling agora_token v0.1.0 (https://github.com/AgoraIO/Tools.git#374cd21f) [INFO] [stderr] Compiling ratatui v0.29.0 [INFO] [stderr] Compiling rustyline v14.0.0 [INFO] [stderr] Compiling aes-gcm v0.10.3 [INFO] [stderr] Compiling rusqlite v0.32.1 [INFO] [stderr] Compiling dialoguer v0.11.0 [INFO] [stderr] Compiling rcgen v0.13.2 [INFO] [stderr] Compiling clap v4.5.47 [INFO] [stderr] Compiling reqwest v0.11.27 [INFO] [stderr] Compiling ctrlc v3.5.1 [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling tokio-tungstenite v0.20.1 [INFO] [stderr] Compiling dirs v5.0.1 [INFO] [stderr] Compiling vt100 v0.15.2 [INFO] [stderr] Compiling uuid v1.18.1 [INFO] [stderr] Compiling crossterm v0.27.0 [INFO] [stderr] Compiling hostname v0.4.2 [INFO] [stderr] Compiling rustls-pemfile v2.2.0 [INFO] [stderr] Compiling urlencoding v2.1.3 [INFO] [stderr] Compiling glob v0.3.3 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stdout] warning: unused variable: `pty_client` [INFO] [stdout] --> src/app.rs:1199:13 [INFO] [stdout] | [INFO] [stdout] 1199 | let pty_client = PtyAgentClient::new(&agent_id, session.sender, session.receiver); [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pty_client` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `format_unix_timestamp` is never used [INFO] [stdout] --> src/agora_api.rs:70:8 [INFO] [stdout] | [INFO] [stdout] 70 | pub fn format_unix_timestamp(secs: u64) -> String { [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 `is_leap_year` is never used [INFO] [stdout] --> src/agora_api.rs:99:8 [INFO] [stdout] | [INFO] [stdout] 99 | pub fn is_leap_year(y: i64) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `AGORA_RTM_TOKEN_TTL_SECS` is never used [INFO] [stdout] --> src/app.rs:36:11 [INFO] [stdout] | [INFO] [stdout] 36 | pub const AGORA_RTM_TOKEN_TTL_SECS: u32 = 3600; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `token`, `channel`, `uid`, and `expires_in` are never read [INFO] [stdout] --> src/app.rs:70:9 [INFO] [stdout] | [INFO] [stdout] 69 | pub struct TokenInfo { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 70 | pub token: String, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 71 | pub channel: String, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] 72 | pub uid: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 73 | pub expires_in: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `TokenInfo` 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 `rtm_client`, `rtm_client_id`, `rtm_token_expires_at`, and `pending_credential_save` are never read [INFO] [stdout] --> src/app.rs:118:9 [INFO] [stdout] | [INFO] [stdout] 76 | pub struct App { [INFO] [stdout] | --- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 118 | pub rtm_client: Option, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 119 | pub rtm_client_id: String, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 123 | pub rtm_token_expires_at: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 151 | pub pending_credential_save: Option<(String, String)>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `relay_url` is never read [INFO] [stdout] --> src/app.rs:180:9 [INFO] [stdout] | [INFO] [stdout] 178 | pub struct PendingVisualize { [INFO] [stdout] | ---------------- field in this struct [INFO] [stdout] 179 | pub session_id: String, [INFO] [stdout] 180 | pub relay_url: Option, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `PendingVisualize` 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 `ensure_rtm_client`, `handle_rtm_event`, `launch_claude_pty_agent`, and `try_connect_astation` are never used [INFO] [stdout] --> src/app.rs:817:18 [INFO] [stdout] | [INFO] [stdout] 198 | impl App { [INFO] [stdout] | -------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 817 | pub async fn ensure_rtm_client(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 855 | pub fn handle_rtm_event(&mut self, event: RtmEvent) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 1189 | pub async fn launch_claude_pty_agent(&mut self) -> anyhow::Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 1728 | pub async fn try_connect_astation(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `current_timestamp_ms` is never used [INFO] [stdout] --> src/app.rs:2578:8 [INFO] [stdout] | [INFO] [stdout] 2578 | pub fn current_timestamp_ms() -> u64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `has_pending` and `pending_count` are never used [INFO] [stdout] --> src/command.rs:46:12 [INFO] [stdout] | [INFO] [stdout] 10 | impl TaskQueue { [INFO] [stdout] | -------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 46 | pub fn has_pending(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 51 | pub fn pending_count(&self) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `clear` is never used [INFO] [stdout] --> src/command.rs:124:12 [INFO] [stdout] | [INFO] [stdout] 76 | impl StreamBuffer { [INFO] [stdout] | ----------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 124 | pub fn clear(&mut self) { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `received_at_ms` and `kind` are never read [INFO] [stdout] --> src/dispatch.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 19 | pub struct WorkItem { [INFO] [stdout] | -------- fields in this struct [INFO] [stdout] 20 | pub task_id: String, [INFO] [stdout] 21 | pub received_at_ms: u64, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 22 | pub kind: WorkKind, [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `WorkItem` 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: constant `DEFAULT_SERVER_URL` is never used [INFO] [stdout] --> src/auth.rs:6:7 [INFO] [stdout] | [INFO] [stdout] 6 | const DEFAULT_SERVER_URL: &str = "https://station.agora.build"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `age_seconds` is never used [INFO] [stdout] --> src/auth.rs:46:12 [INFO] [stdout] | [INFO] [stdout] 19 | impl AuthSession { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 46 | pub fn age_seconds(&self) -> u64 { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `remove`, `active_sessions`, and `cleanup_expired` are never used [INFO] [stdout] --> src/auth.rs:122:12 [INFO] [stdout] | [INFO] [stdout] 66 | impl SessionManager { [INFO] [stdout] | ------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 122 | pub fn remove(&mut self, astation_id: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 128 | pub fn active_sessions(&self) -> Vec<&AuthSession> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 133 | pub fn cleanup_expired(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_deep_link` is never used [INFO] [stdout] --> src/auth.rs:154:8 [INFO] [stdout] | [INFO] [stdout] 154 | pub fn build_deep_link(session_id: &str, hostname: &str, otp: &str) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_web_fallback_url` is never used [INFO] [stdout] --> src/auth.rs:162:8 [INFO] [stdout] | [INFO] [stdout] 162 | pub fn build_web_fallback_url(server_url: &str, session_id: &str, hostname: &str) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `open_url` is never used [INFO] [stdout] --> src/auth.rs:180:8 [INFO] [stdout] | [INFO] [stdout] 180 | pub fn open_url(url: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `create_server_session` is never used [INFO] [stdout] --> src/auth.rs:199:14 [INFO] [stdout] | [INFO] [stdout] 199 | pub async fn create_server_session( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `poll_session_status` is never used [INFO] [stdout] --> src/auth.rs:234:14 [INFO] [stdout] | [INFO] [stdout] 234 | pub async fn poll_session_status( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `run_login_flow` is never used [INFO] [stdout] --> src/auth.rs:303:14 [INFO] [stdout] | [INFO] [stdout] 303 | pub async fn run_login_flow(server_url: Option<&str>, astation_id: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `rtm_channel` is never used [INFO] [stdout] --> src/config.rs:270:12 [INFO] [stdout] | [INFO] [stdout] 31 | impl AtemConfig { [INFO] [stdout] | --------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 270 | pub fn rtm_channel(&self) -> &str { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `format_unix_timestamp_hhmm_pub` is never used [INFO] [stdout] --> src/config.rs:525:8 [INFO] [stdout] | [INFO] [stdout] 525 | pub fn format_unix_timestamp_hhmm_pub(secs: u64) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `format_unix_timestamp_hhmm` is never used [INFO] [stdout] --> src/config.rs:529:4 [INFO] [stdout] | [INFO] [stdout] 529 | fn format_unix_timestamp_hhmm(secs: u64) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `clear_saved` is never used [INFO] [stdout] --> src/config.rs:592:12 [INFO] [stdout] | [INFO] [stdout] 565 | impl crate::auth::AuthSession { [INFO] [stdout] | ----------------------------- associated function in this implementation [INFO] [stdout] ... [INFO] [stdout] 592 | pub fn clear_saved() -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `remove_paired` is never used [INFO] [stdout] --> src/credentials.rs:187:12 [INFO] [stdout] | [INFO] [stdout] 102 | impl CredentialStore { [INFO] [stdout] | -------------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 187 | pub fn remove_paired(&mut self, astation_id: &str) { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AtemRtmConfig` is never constructed [INFO] [stdout] --> src/rtm_client.rs:17:8 [INFO] [stdout] | [INFO] [stdout] 17 | struct AtemRtmConfig { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `AtemRtmMessageCallback` is never used [INFO] [stdout] --> src/rtm_client.rs:24:6 [INFO] [stdout] | [INFO] [stdout] 24 | type AtemRtmMessageCallback = unsafe extern "C" fn( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `from` and `payload` are never read [INFO] [stdout] --> src/rtm_client.rs:61:9 [INFO] [stdout] | [INFO] [stdout] 60 | pub struct RtmEvent { [INFO] [stdout] | -------- fields in this struct [INFO] [stdout] 61 | pub from: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] 62 | pub payload: String, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `sender` is never read [INFO] [stdout] --> src/rtm_client.rs:66:5 [INFO] [stdout] | [INFO] [stdout] 65 | struct CallbackState { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] 66 | sender: UnboundedSender, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new` and `as_ptr` are never used [INFO] [stdout] --> src/rtm_client.rs:72:8 [INFO] [stdout] | [INFO] [stdout] 71 | impl OwnedCString { [INFO] [stdout] | ----------------- associated items in this implementation [INFO] [stdout] 72 | fn new(value: CString) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 76 | fn as_ptr(&self) -> *const c_char { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `on_message` is never used [INFO] [stdout] --> src/rtm_client.rs:92:22 [INFO] [stdout] | [INFO] [stdout] 92 | unsafe extern "C" fn on_message( [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `inner`, `receiver`, and `owned_strings` are never read [INFO] [stdout] --> src/rtm_client.rs:121:5 [INFO] [stdout] | [INFO] [stdout] 120 | pub struct RtmClient { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 121 | inner: Arc>, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 122 | receiver: Mutex>, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 123 | _state: *mut CallbackState, [INFO] [stdout] 124 | owned_strings: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RtmConfig` is never constructed [INFO] [stdout] --> src/rtm_client.rs:154:12 [INFO] [stdout] | [INFO] [stdout] 154 | pub struct RtmConfig { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/rtm_client.rs:162:12 [INFO] [stdout] | [INFO] [stdout] 161 | impl RtmClient { [INFO] [stdout] | -------------- associated items in this implementation [INFO] [stdout] 162 | pub fn new(config: RtmConfig) -> Result { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 212 | pub async fn publish_channel(&self, payload: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 222 | pub async fn login_and_join(&self, token: &str, account: &str, channel: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 247 | pub async fn send_peer(&self, target: &str, payload: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 258 | pub async fn next_event(&self) -> Option { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 263 | pub async fn drain_events(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 276 | pub async fn set_token(&self, token: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 286 | pub async fn subscribe_topic(&self, channel: &str, topic: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 302 | pub async fn disconnect(&self) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_create` is never used [INFO] [stdout] --> src/rtm_client.rs:32:8 [INFO] [stdout] | [INFO] [stdout] 32 | fn atem_rtm_create( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_connect` is never used [INFO] [stdout] --> src/rtm_client.rs:38:8 [INFO] [stdout] | [INFO] [stdout] 38 | fn atem_rtm_connect(client: *mut AtemRtmClient) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_login` is never used [INFO] [stdout] --> src/rtm_client.rs:40:8 [INFO] [stdout] | [INFO] [stdout] 40 | fn atem_rtm_login( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_join_channel` is never used [INFO] [stdout] --> src/rtm_client.rs:45:8 [INFO] [stdout] | [INFO] [stdout] 45 | fn atem_rtm_join_channel(client: *mut AtemRtmClient, channel_id: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_publish_channel` is never used [INFO] [stdout] --> src/rtm_client.rs:46:8 [INFO] [stdout] | [INFO] [stdout] 46 | fn atem_rtm_publish_channel(client: *mut AtemRtmClient, payload: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_send_peer` is never used [INFO] [stdout] --> src/rtm_client.rs:47:8 [INFO] [stdout] | [INFO] [stdout] 47 | fn atem_rtm_send_peer( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_set_token` is never used [INFO] [stdout] --> src/rtm_client.rs:52:8 [INFO] [stdout] | [INFO] [stdout] 52 | fn atem_rtm_set_token(client: *mut AtemRtmClient, token: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_subscribe_topic` is never used [INFO] [stdout] --> src/rtm_client.rs:53:8 [INFO] [stdout] | [INFO] [stdout] 53 | fn atem_rtm_subscribe_topic( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `invalidate` is never used [INFO] [stdout] --> src/time_sync.rs:74:12 [INFO] [stdout] | [INFO] [stdout] 11 | impl TimeSync { [INFO] [stdout] | ------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 74 | pub fn invalidate(&mut self) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `salt` is never read [INFO] [stdout] --> src/token.rs:277:9 [INFO] [stdout] | [INFO] [stdout] 271 | pub struct TokenInfo { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 277 | pub salt: u32, [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `TokenInfo` 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 `format_timestamp` is never used [INFO] [stdout] --> src/token.rs:445:4 [INFO] [stdout] | [INFO] [stdout] 445 | fn format_timestamp(ts: u32) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `format_timestamp_u64` is never used [INFO] [stdout] --> src/token.rs:450:4 [INFO] [stdout] | [INFO] [stdout] 450 | fn format_timestamp_u64(ts: u64) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `generate_rtm_token` is never used [INFO] [stdout] --> src/token.rs:568:8 [INFO] [stdout] | [INFO] [stdout] 568 | pub fn generate_rtm_token( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `md5_simple` is never used [INFO] [stdout] --> src/token.rs:587:4 [INFO] [stdout] | [INFO] [stdout] 587 | fn md5_simple(data: &[u8]) -> u128 { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `border_chars` is never used [INFO] [stdout] --> src/tui/voice_fx.rs:11:8 [INFO] [stdout] | [INFO] [stdout] 11 | pub fn border_chars(volume: f32) -> (&'static str, &'static str) { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `border_jitter` is never used [INFO] [stdout] --> src/tui/voice_fx.rs:44:8 [INFO] [stdout] | [INFO] [stdout] 44 | pub fn border_jitter(volume: f32, tick: u64) -> i16 { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/websocket_client.rs:591:18 [INFO] [stdout] | [INFO] [stdout] 287 | impl AstationClient { [INFO] [stdout] | ------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 591 | pub async fn request_projects(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 595 | pub async fn request_token( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 609 | pub async fn launch_claude(&self, context: Option) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 614 | pub async fn send_user_command( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 626 | pub async fn send_status_update(&self, status: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 638 | pub async fn send_heartbeat(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 649 | pub fn is_connected(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 697 | pub async fn send_codex_task( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 773 | pub async fn send_agent_status( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `JsonRpcNotification` is never constructed [INFO] [stdout] --> src/acp_client.rs:38:12 [INFO] [stdout] | [INFO] [stdout] 38 | pub struct JsonRpcNotification { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_cancel_request` is never used [INFO] [stdout] --> src/acp_client.rs:103:8 [INFO] [stdout] | [INFO] [stdout] 103 | pub fn build_cancel_request(id: u64, session_id: &str) -> JsonRpcRequest { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `url` is never read [INFO] [stdout] --> src/acp_client.rs:250:5 [INFO] [stdout] | [INFO] [stdout] 249 | pub struct AcpClient { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] 250 | url: String, [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `url`, `is_connected`, and `cancel` are never used [INFO] [stdout] --> src/acp_client.rs:317:12 [INFO] [stdout] | [INFO] [stdout] 262 | impl AcpClient { [INFO] [stdout] | -------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 317 | pub fn url(&self) -> &str { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 325 | pub fn is_connected(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 429 | pub fn cancel(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `Disconnected` is never constructed [INFO] [stdout] --> src/agent_client.rs:111:5 [INFO] [stdout] | [INFO] [stdout] 95 | pub enum AgentEvent { [INFO] [stdout] | ---------- variant in this enum [INFO] [stdout] ... [INFO] [stdout] 111 | Disconnected, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AgentEvent` 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: struct `PtyAgentClient` is never constructed [INFO] [stdout] --> src/agent_client.rs:121:12 [INFO] [stdout] | [INFO] [stdout] 121 | pub struct PtyAgentClient { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new`, `send_prompt`, and `drain_events` are never used [INFO] [stdout] --> src/agent_client.rs:131:12 [INFO] [stdout] | [INFO] [stdout] 130 | impl PtyAgentClient { [INFO] [stdout] | ------------------- associated items in this implementation [INFO] [stdout] 131 | pub fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 144 | pub fn send_prompt(&self, prompt: &str) -> anyhow::Result<()> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 151 | pub fn drain_events(&mut self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `lockfile` is never read [INFO] [stdout] --> src/agent_detector.rs:44:9 [INFO] [stdout] | [INFO] [stdout] 36 | pub struct DetectedAgent { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 44 | pub lockfile: PathBuf, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DetectedAgent` 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: method `is_acp` is never used [INFO] [stdout] --> src/agent_detector.rs:168:12 [INFO] [stdout] | [INFO] [stdout] 167 | impl ProbeResult { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] 168 | pub fn is_acp(&self) -> bool { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `add_session`, `remove_session`, `remove`, `len`, `is_empty`, and `connected` are never used [INFO] [stdout] --> src/agent_registry.rs:57:12 [INFO] [stdout] | [INFO] [stdout] 24 | impl AgentRegistry { [INFO] [stdout] | ------------------ methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 57 | pub fn add_session(&self, agent_id: &str, session_id: &str) { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 66 | pub fn remove_session(&self, agent_id: &str, session_id: &str) { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 73 | pub fn remove(&self, id: &str) { [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] 97 | pub fn connected(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `id`, `topic`, and `created_at` are never read [INFO] [stdout] --> src/diagram_server.rs:23:9 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct DiagramEntry { [INFO] [stdout] | ------------ fields in this struct [INFO] [stdout] 23 | pub id: String, [INFO] [stdout] | ^^ [INFO] [stdout] 24 | pub topic: String, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 25 | pub html: Vec, [INFO] [stdout] 26 | pub created_at: i64, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 4m 01s [INFO] running `Command { std: "docker" "inspect" "8c0e8c255c1029eace9e30dc6dd3770845012703530f9ed04949669c43cceacb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8c0e8c255c1029eace9e30dc6dd3770845012703530f9ed04949669c43cceacb", kill_on_drop: false }` [INFO] [stdout] 8c0e8c255c1029eace9e30dc6dd3770845012703530f9ed04949669c43cceacb [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 2f7aa4b9683845798ccf3aaf5aa326da2e6a9bf80c2bc3701e8374b06c6b885e [INFO] running `Command { std: "docker" "start" "-a" "2f7aa4b9683845798ccf3aaf5aa326da2e6a9bf80c2bc3701e8374b06c6b885e", kill_on_drop: false }` [INFO] [stderr] warning: unused manifest key: dependencies.agora_token.subdirectory [INFO] [stderr] Compiling atem v0.4.94 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `StreamExt` [INFO] [stdout] --> src/acp_client.rs:958:37 [INFO] [stdout] | [INFO] [stdout] 958 | use futures_util::{SinkExt, StreamExt}; [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: `SinkExt` [INFO] [stdout] --> src/acp_client.rs:992:28 [INFO] [stdout] | [INFO] [stdout] 992 | use futures_util::{SinkExt, StreamExt}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `pty_client` [INFO] [stdout] --> src/app.rs:1199:13 [INFO] [stdout] | [INFO] [stdout] 1199 | let pty_client = PtyAgentClient::new(&agent_id, session.sender, session.receiver); [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pty_client` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/token.rs:1328:13 [INFO] [stdout] | [INFO] [stdout] 1328 | let mut token = access_token::new_access_token(&app_id, &app_cert, expire); [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: constant `AGORA_RTM_TOKEN_TTL_SECS` is never used [INFO] [stdout] --> src/app.rs:36:11 [INFO] [stdout] | [INFO] [stdout] 36 | pub const AGORA_RTM_TOKEN_TTL_SECS: u32 = 3600; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `token`, `channel`, `uid`, and `expires_in` are never read [INFO] [stdout] --> src/app.rs:70:9 [INFO] [stdout] | [INFO] [stdout] 69 | pub struct TokenInfo { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 70 | pub token: String, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 71 | pub channel: String, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] 72 | pub uid: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 73 | pub expires_in: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `TokenInfo` 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 `rtm_client`, `rtm_client_id`, `rtm_token_expires_at`, and `pending_credential_save` are never read [INFO] [stdout] --> src/app.rs:118:9 [INFO] [stdout] | [INFO] [stdout] 76 | pub struct App { [INFO] [stdout] | --- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 118 | pub rtm_client: Option, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 119 | pub rtm_client_id: String, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 123 | pub rtm_token_expires_at: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 151 | pub pending_credential_save: Option<(String, String)>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `ensure_rtm_client`, `handle_rtm_event`, `launch_claude_pty_agent`, and `try_connect_astation` are never used [INFO] [stdout] --> src/app.rs:817:18 [INFO] [stdout] | [INFO] [stdout] 198 | impl App { [INFO] [stdout] | -------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 817 | pub async fn ensure_rtm_client(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 855 | pub fn handle_rtm_event(&mut self, event: RtmEvent) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 1189 | pub async fn launch_claude_pty_agent(&mut self) -> anyhow::Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 1728 | pub async fn try_connect_astation(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `current_timestamp_ms` is never used [INFO] [stdout] --> src/app.rs:2578:8 [INFO] [stdout] | [INFO] [stdout] 2578 | pub fn current_timestamp_ms() -> u64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `received_at_ms` and `kind` are never read [INFO] [stdout] --> src/dispatch.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 19 | pub struct WorkItem { [INFO] [stdout] | -------- fields in this struct [INFO] [stdout] 20 | pub task_id: String, [INFO] [stdout] 21 | pub received_at_ms: u64, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 22 | pub kind: WorkKind, [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `WorkItem` 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: constant `DEFAULT_SERVER_URL` is never used [INFO] [stdout] --> src/auth.rs:6:7 [INFO] [stdout] | [INFO] [stdout] 6 | const DEFAULT_SERVER_URL: &str = "https://station.agora.build"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `remove` and `cleanup_expired` are never used [INFO] [stdout] --> src/auth.rs:122:12 [INFO] [stdout] | [INFO] [stdout] 66 | impl SessionManager { [INFO] [stdout] | ------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 122 | pub fn remove(&mut self, astation_id: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 133 | pub fn cleanup_expired(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `open_url` is never used [INFO] [stdout] --> src/auth.rs:180:8 [INFO] [stdout] | [INFO] [stdout] 180 | pub fn open_url(url: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `run_login_flow` is never used [INFO] [stdout] --> src/auth.rs:303:14 [INFO] [stdout] | [INFO] [stdout] 303 | pub async fn run_login_flow(server_url: Option<&str>, astation_id: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `now` is never used [INFO] [stdout] --> src/sso_auth.rs:458:8 [INFO] [stdout] | [INFO] [stdout] 458 | fn now() -> u64 { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `format_unix_timestamp_hhmm_pub` is never used [INFO] [stdout] --> src/config.rs:525:8 [INFO] [stdout] | [INFO] [stdout] 525 | pub fn format_unix_timestamp_hhmm_pub(secs: u64) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `clear_saved` is never used [INFO] [stdout] --> src/config.rs:592:12 [INFO] [stdout] | [INFO] [stdout] 565 | impl crate::auth::AuthSession { [INFO] [stdout] | ----------------------------- associated function in this implementation [INFO] [stdout] ... [INFO] [stdout] 592 | pub fn clear_saved() -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AtemRtmConfig` is never constructed [INFO] [stdout] --> src/rtm_client.rs:17:8 [INFO] [stdout] | [INFO] [stdout] 17 | struct AtemRtmConfig { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `AtemRtmMessageCallback` is never used [INFO] [stdout] --> src/rtm_client.rs:24:6 [INFO] [stdout] | [INFO] [stdout] 24 | type AtemRtmMessageCallback = unsafe extern "C" fn( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `from` and `payload` are never read [INFO] [stdout] --> src/rtm_client.rs:61:9 [INFO] [stdout] | [INFO] [stdout] 60 | pub struct RtmEvent { [INFO] [stdout] | -------- fields in this struct [INFO] [stdout] 61 | pub from: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] 62 | pub payload: String, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `sender` is never read [INFO] [stdout] --> src/rtm_client.rs:66:5 [INFO] [stdout] | [INFO] [stdout] 65 | struct CallbackState { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] 66 | sender: UnboundedSender, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new` and `as_ptr` are never used [INFO] [stdout] --> src/rtm_client.rs:72:8 [INFO] [stdout] | [INFO] [stdout] 71 | impl OwnedCString { [INFO] [stdout] | ----------------- associated items in this implementation [INFO] [stdout] 72 | fn new(value: CString) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 76 | fn as_ptr(&self) -> *const c_char { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `on_message` is never used [INFO] [stdout] --> src/rtm_client.rs:92:22 [INFO] [stdout] | [INFO] [stdout] 92 | unsafe extern "C" fn on_message( [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `inner`, `receiver`, and `owned_strings` are never read [INFO] [stdout] --> src/rtm_client.rs:121:5 [INFO] [stdout] | [INFO] [stdout] 120 | pub struct RtmClient { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 121 | inner: Arc>, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 122 | receiver: Mutex>, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 123 | _state: *mut CallbackState, [INFO] [stdout] 124 | owned_strings: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RtmConfig` is never constructed [INFO] [stdout] --> src/rtm_client.rs:154:12 [INFO] [stdout] | [INFO] [stdout] 154 | pub struct RtmConfig { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/rtm_client.rs:162:12 [INFO] [stdout] | [INFO] [stdout] 161 | impl RtmClient { [INFO] [stdout] | -------------- associated items in this implementation [INFO] [stdout] 162 | pub fn new(config: RtmConfig) -> Result { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 212 | pub async fn publish_channel(&self, payload: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 222 | pub async fn login_and_join(&self, token: &str, account: &str, channel: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 247 | pub async fn send_peer(&self, target: &str, payload: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 258 | pub async fn next_event(&self) -> Option { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 263 | pub async fn drain_events(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 276 | pub async fn set_token(&self, token: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 286 | pub async fn subscribe_topic(&self, channel: &str, topic: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 302 | pub async fn disconnect(&self) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_create` is never used [INFO] [stdout] --> src/rtm_client.rs:32:8 [INFO] [stdout] | [INFO] [stdout] 32 | fn atem_rtm_create( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_connect` is never used [INFO] [stdout] --> src/rtm_client.rs:38:8 [INFO] [stdout] | [INFO] [stdout] 38 | fn atem_rtm_connect(client: *mut AtemRtmClient) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_login` is never used [INFO] [stdout] --> src/rtm_client.rs:40:8 [INFO] [stdout] | [INFO] [stdout] 40 | fn atem_rtm_login( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_join_channel` is never used [INFO] [stdout] --> src/rtm_client.rs:45:8 [INFO] [stdout] | [INFO] [stdout] 45 | fn atem_rtm_join_channel(client: *mut AtemRtmClient, channel_id: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_publish_channel` is never used [INFO] [stdout] --> src/rtm_client.rs:46:8 [INFO] [stdout] | [INFO] [stdout] 46 | fn atem_rtm_publish_channel(client: *mut AtemRtmClient, payload: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_send_peer` is never used [INFO] [stdout] --> src/rtm_client.rs:47:8 [INFO] [stdout] | [INFO] [stdout] 47 | fn atem_rtm_send_peer( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_set_token` is never used [INFO] [stdout] --> src/rtm_client.rs:52:8 [INFO] [stdout] | [INFO] [stdout] 52 | fn atem_rtm_set_token(client: *mut AtemRtmClient, token: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_subscribe_topic` is never used [INFO] [stdout] --> src/rtm_client.rs:53:8 [INFO] [stdout] | [INFO] [stdout] 53 | fn atem_rtm_subscribe_topic( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `invalidate` is never used [INFO] [stdout] --> src/time_sync.rs:74:12 [INFO] [stdout] | [INFO] [stdout] 11 | impl TimeSync { [INFO] [stdout] | ------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 74 | pub fn invalidate(&mut self) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `salt` is never read [INFO] [stdout] --> src/token.rs:277:9 [INFO] [stdout] | [INFO] [stdout] 271 | pub struct TokenInfo { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 277 | pub salt: u32, [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `TokenInfo` 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 `format_timestamp` is never used [INFO] [stdout] --> src/token.rs:445:4 [INFO] [stdout] | [INFO] [stdout] 445 | fn format_timestamp(ts: u32) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `format_timestamp_u64` is never used [INFO] [stdout] --> src/token.rs:450:4 [INFO] [stdout] | [INFO] [stdout] 450 | fn format_timestamp_u64(ts: u64) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/websocket_client.rs:591:18 [INFO] [stdout] | [INFO] [stdout] 287 | impl AstationClient { [INFO] [stdout] | ------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 591 | pub async fn request_projects(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 595 | pub async fn request_token( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 609 | pub async fn launch_claude(&self, context: Option) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 614 | pub async fn send_user_command( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 626 | pub async fn send_status_update(&self, status: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 638 | pub async fn send_heartbeat(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 649 | pub fn is_connected(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 697 | pub async fn send_codex_task( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 773 | pub async fn send_agent_status( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `JsonRpcNotification` is never constructed [INFO] [stdout] --> src/acp_client.rs:38:12 [INFO] [stdout] | [INFO] [stdout] 38 | pub struct JsonRpcNotification { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `agent_id` is never read [INFO] [stdout] --> src/agent_client.rs:127:9 [INFO] [stdout] | [INFO] [stdout] 121 | pub struct PtyAgentClient { [INFO] [stdout] | -------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 127 | pub agent_id: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 24.88s [INFO] running `Command { std: "docker" "inspect" "2f7aa4b9683845798ccf3aaf5aa326da2e6a9bf80c2bc3701e8374b06c6b885e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2f7aa4b9683845798ccf3aaf5aa326da2e6a9bf80c2bc3701e8374b06c6b885e", kill_on_drop: false }` [INFO] [stdout] 2f7aa4b9683845798ccf3aaf5aa326da2e6a9bf80c2bc3701e8374b06c6b885e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 5a2a5acbefccbed094ba2de66b9f00302c7b8bbb7bd9bf7a680deeb736194684 [INFO] running `Command { std: "docker" "start" "-a" "5a2a5acbefccbed094ba2de66b9f00302c7b8bbb7bd9bf7a680deeb736194684", kill_on_drop: false }` [INFO] [stderr] warning: unused manifest key: dependencies.agora_token.subdirectory [INFO] [stderr] warning: unused import: `StreamExt` [INFO] [stderr] --> src/acp_client.rs:958:37 [INFO] [stderr] | [INFO] [stderr] 958 | use futures_util::{SinkExt, StreamExt}; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `SinkExt` [INFO] [stderr] --> src/acp_client.rs:992:28 [INFO] [stderr] | [INFO] [stderr] 992 | use futures_util::{SinkExt, StreamExt}; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `pty_client` [INFO] [stderr] --> src/app.rs:1199:13 [INFO] [stderr] | [INFO] [stderr] 1199 | let pty_client = PtyAgentClient::new(&agent_id, session.sender, session.receiver); [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pty_client` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/token.rs:1328:13 [INFO] [stderr] | [INFO] [stderr] 1328 | let mut token = access_token::new_access_token(&app_id, &app_cert, expire); [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 `AGORA_RTM_TOKEN_TTL_SECS` is never used [INFO] [stderr] --> src/app.rs:36:11 [INFO] [stderr] | [INFO] [stderr] 36 | pub const AGORA_RTM_TOKEN_TTL_SECS: u32 = 3600; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: fields `token`, `channel`, `uid`, and `expires_in` are never read [INFO] [stderr] --> src/app.rs:70:9 [INFO] [stderr] | [INFO] [stderr] 69 | pub struct TokenInfo { [INFO] [stderr] | --------- fields in this struct [INFO] [stderr] 70 | pub token: String, [INFO] [stderr] | ^^^^^ [INFO] [stderr] 71 | pub channel: String, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] 72 | pub uid: String, [INFO] [stderr] | ^^^ [INFO] [stderr] 73 | pub expires_in: String, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `TokenInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: fields `rtm_client`, `rtm_client_id`, `rtm_token_expires_at`, and `pending_credential_save` are never read [INFO] [stderr] --> src/app.rs:118:9 [INFO] [stderr] | [INFO] [stderr] 76 | pub struct App { [INFO] [stderr] | --- fields in this struct [INFO] [stderr] ... [INFO] [stderr] 118 | pub rtm_client: Option, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] 119 | pub rtm_client_id: String, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 123 | pub rtm_token_expires_at: Option, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 151 | pub pending_credential_save: Option<(String, String)>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `ensure_rtm_client`, `handle_rtm_event`, `launch_claude_pty_agent`, and `try_connect_astation` are never used [INFO] [stderr] --> src/app.rs:817:18 [INFO] [stderr] | [INFO] [stderr] 198 | impl App { [INFO] [stderr] | -------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 817 | pub async fn ensure_rtm_client(&mut self) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 855 | pub fn handle_rtm_event(&mut self, event: RtmEvent) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 1189 | pub async fn launch_claude_pty_agent(&mut self) -> anyhow::Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 1728 | pub async fn try_connect_astation(&mut self) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `current_timestamp_ms` is never used [INFO] [stderr] --> src/app.rs:2578:8 [INFO] [stderr] | [INFO] [stderr] 2578 | pub fn current_timestamp_ms() -> u64 { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `received_at_ms` and `kind` are never read [INFO] [stderr] --> src/dispatch.rs:21:9 [INFO] [stderr] | [INFO] [stderr] 19 | pub struct WorkItem { [INFO] [stderr] | -------- fields in this struct [INFO] [stderr] 20 | pub task_id: String, [INFO] [stderr] 21 | pub received_at_ms: u64, [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] 22 | pub kind: WorkKind, [INFO] [stderr] | ^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `WorkItem` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: constant `DEFAULT_SERVER_URL` is never used [INFO] [stderr] --> src/auth.rs:6:7 [INFO] [stderr] | [INFO] [stderr] 6 | const DEFAULT_SERVER_URL: &str = "https://station.agora.build"; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `remove` and `cleanup_expired` are never used [INFO] [stderr] --> src/auth.rs:122:12 [INFO] [stderr] | [INFO] [stderr] 66 | impl SessionManager { [INFO] [stderr] | ------------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 122 | pub fn remove(&mut self, astation_id: &str) -> Result<()> { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 133 | pub fn cleanup_expired(&mut self) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `open_url` is never used [INFO] [stderr] --> src/auth.rs:180:8 [INFO] [stderr] | [INFO] [stderr] 180 | pub fn open_url(url: &str) -> Result<()> { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `run_login_flow` is never used [INFO] [stderr] --> src/auth.rs:303:14 [INFO] [stderr] | [INFO] [stderr] 303 | pub async fn run_login_flow(server_url: Option<&str>, astation_id: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `now` is never used [INFO] [stderr] --> src/sso_auth.rs:458:8 [INFO] [stderr] | [INFO] [stderr] 458 | fn now() -> u64 { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: function `format_unix_timestamp_hhmm_pub` is never used [INFO] [stderr] --> src/config.rs:525:8 [INFO] [stderr] | [INFO] [stderr] 525 | pub fn format_unix_timestamp_hhmm_pub(secs: u64) -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `clear_saved` is never used [INFO] [stderr] --> src/config.rs:592:12 [INFO] [stderr] | [INFO] [stderr] 565 | impl crate::auth::AuthSession { [INFO] [stderr] | ----------------------------- associated function in this implementation [INFO] [stderr] ... [INFO] [stderr] 592 | pub fn clear_saved() -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `AtemRtmConfig` is never constructed [INFO] [stderr] --> src/rtm_client.rs:17:8 [INFO] [stderr] | [INFO] [stderr] 17 | struct AtemRtmConfig { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: type alias `AtemRtmMessageCallback` is never used [INFO] [stderr] --> src/rtm_client.rs:24:6 [INFO] [stderr] | [INFO] [stderr] 24 | type AtemRtmMessageCallback = unsafe extern "C" fn( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `from` and `payload` are never read [INFO] [stderr] --> src/rtm_client.rs:61:9 [INFO] [stderr] | [INFO] [stderr] 60 | pub struct RtmEvent { [INFO] [stderr] | -------- fields in this struct [INFO] [stderr] 61 | pub from: String, [INFO] [stderr] | ^^^^ [INFO] [stderr] 62 | pub payload: String, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `sender` is never read [INFO] [stderr] --> src/rtm_client.rs:66:5 [INFO] [stderr] | [INFO] [stderr] 65 | struct CallbackState { [INFO] [stderr] | ------------- field in this struct [INFO] [stderr] 66 | sender: UnboundedSender, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated items `new` and `as_ptr` are never used [INFO] [stderr] --> src/rtm_client.rs:72:8 [INFO] [stderr] | [INFO] [stderr] 71 | impl OwnedCString { [INFO] [stderr] | ----------------- associated items in this implementation [INFO] [stderr] 72 | fn new(value: CString) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 76 | fn as_ptr(&self) -> *const c_char { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `on_message` is never used [INFO] [stderr] --> src/rtm_client.rs:92:22 [INFO] [stderr] | [INFO] [stderr] 92 | unsafe extern "C" fn on_message( [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `inner`, `receiver`, and `owned_strings` are never read [INFO] [stderr] --> src/rtm_client.rs:121:5 [INFO] [stderr] | [INFO] [stderr] 120 | pub struct RtmClient { [INFO] [stderr] | --------- fields in this struct [INFO] [stderr] 121 | inner: Arc>, [INFO] [stderr] | ^^^^^ [INFO] [stderr] 122 | receiver: Mutex>, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] 123 | _state: *mut CallbackState, [INFO] [stderr] 124 | owned_strings: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `RtmConfig` is never constructed [INFO] [stderr] --> src/rtm_client.rs:154:12 [INFO] [stderr] | [INFO] [stderr] 154 | pub struct RtmConfig { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: multiple associated items are never used [INFO] [stderr] --> src/rtm_client.rs:162:12 [INFO] [stderr] | [INFO] [stderr] 161 | impl RtmClient { [INFO] [stderr] | -------------- associated items in this implementation [INFO] [stderr] 162 | pub fn new(config: RtmConfig) -> Result { [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 212 | pub async fn publish_channel(&self, payload: &str) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 222 | pub async fn login_and_join(&self, token: &str, account: &str, channel: &str) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 247 | pub async fn send_peer(&self, target: &str, payload: &str) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 258 | pub async fn next_event(&self) -> Option { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 263 | pub async fn drain_events(&self) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 276 | pub async fn set_token(&self, token: &str) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 286 | pub async fn subscribe_topic(&self, channel: &str, topic: &str) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 302 | pub async fn disconnect(&self) { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `atem_rtm_create` is never used [INFO] [stderr] --> src/rtm_client.rs:32:8 [INFO] [stderr] | [INFO] [stderr] 32 | fn atem_rtm_create( [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `atem_rtm_connect` is never used [INFO] [stderr] --> src/rtm_client.rs:38:8 [INFO] [stderr] | [INFO] [stderr] 38 | fn atem_rtm_connect(client: *mut AtemRtmClient) -> i32; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `atem_rtm_login` is never used [INFO] [stderr] --> src/rtm_client.rs:40:8 [INFO] [stderr] | [INFO] [stderr] 40 | fn atem_rtm_login( [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `atem_rtm_join_channel` is never used [INFO] [stderr] --> src/rtm_client.rs:45:8 [INFO] [stderr] | [INFO] [stderr] 45 | fn atem_rtm_join_channel(client: *mut AtemRtmClient, channel_id: *const c_char) -> i32; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `atem_rtm_publish_channel` is never used [INFO] [stderr] --> src/rtm_client.rs:46:8 [INFO] [stderr] | [INFO] [stderr] 46 | fn atem_rtm_publish_channel(client: *mut AtemRtmClient, payload: *const c_char) -> i32; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `atem_rtm_send_peer` is never used [INFO] [stderr] --> src/rtm_client.rs:47:8 [INFO] [stderr] | [INFO] [stderr] 47 | fn atem_rtm_send_peer( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `atem_rtm_set_token` is never used [INFO] [stderr] --> src/rtm_client.rs:52:8 [INFO] [stderr] | [INFO] [stderr] 52 | fn atem_rtm_set_token(client: *mut AtemRtmClient, token: *const c_char) -> i32; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `atem_rtm_subscribe_topic` is never used [INFO] [stderr] --> src/rtm_client.rs:53:8 [INFO] [stderr] | [INFO] [stderr] 53 | fn atem_rtm_subscribe_topic( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method `invalidate` is never used [INFO] [stderr] --> src/time_sync.rs:74:12 [INFO] [stderr] | [INFO] [stderr] 11 | impl TimeSync { [INFO] [stderr] | ------------- method in this implementation [INFO] [stderr] ... [INFO] [stderr] 74 | pub fn invalidate(&mut self) { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `salt` is never read [INFO] [stderr] --> src/token.rs:277:9 [INFO] [stderr] | [INFO] [stderr] 271 | pub struct TokenInfo { [INFO] [stderr] | --------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 277 | pub salt: u32, [INFO] [stderr] | ^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `TokenInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: function `format_timestamp` is never used [INFO] [stderr] --> src/token.rs:445:4 [INFO] [stderr] | [INFO] [stderr] 445 | fn format_timestamp(ts: u32) -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `format_timestamp_u64` is never used [INFO] [stderr] --> src/token.rs:450:4 [INFO] [stderr] | [INFO] [stderr] 450 | fn format_timestamp_u64(ts: u64) -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: multiple methods are never used [INFO] [stderr] --> src/websocket_client.rs:591:18 [INFO] [stderr] | [INFO] [stderr] 287 | impl AstationClient { [INFO] [stderr] | ------------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 591 | pub async fn request_projects(&self) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 595 | pub async fn request_token( [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 609 | pub async fn launch_claude(&self, context: Option) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 614 | pub async fn send_user_command( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 626 | pub async fn send_status_update(&self, status: &str) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 638 | pub async fn send_heartbeat(&self) -> Result<()> { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 649 | pub fn is_connected(&self) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 697 | pub async fn send_codex_task( [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 773 | pub async fn send_agent_status( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `JsonRpcNotification` is never constructed [INFO] [stderr] --> src/acp_client.rs:38:12 [INFO] [stderr] | [INFO] [stderr] 38 | pub struct JsonRpcNotification { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `agent_id` is never read [INFO] [stderr] --> src/agent_client.rs:127:9 [INFO] [stderr] | [INFO] [stderr] 121 | pub struct PtyAgentClient { [INFO] [stderr] | -------------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 127 | pub agent_id: String, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `atem` (bin "atem" test) generated 41 warnings (run `cargo fix --bin "atem" -p atem --tests` to apply 3 suggestions) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.32s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/atem-ba9043dd3f428a70) [INFO] [stdout] [INFO] [stdout] running 582 tests [INFO] [stdout] test acp_client::tests::test_build_initialize_includes_protocol_version ... ok [INFO] [stdout] test acp_client::tests::test_build_new_session ... ok [INFO] [stdout] test acp_client::tests::test_build_prompt ... ok [INFO] [stdout] test acp_client::tests::test_cancel_sends_cancel_method ... ok [INFO] [stdout] test acp_client::tests::test_cancel_without_session_errors ... ok [INFO] [stdout] test acp_client::tests::test_client_is_connected_false_by_default ... ok [INFO] [stdout] test acp_client::tests::test_build_cancel ... ok [INFO] [stdout] test acp_client::tests::test_client_next_request_id_increments ... ok [INFO] [stdout] test acp_client::tests::test_client_try_recv_empty_channel ... ok [INFO] [stdout] test acp_client::tests::test_client_try_recv_with_channel_events ... ok [INFO] [stdout] test acp_client::tests::test_client_url ... ok [INFO] [stdout] test acp_client::tests::test_drain_events_drains_pending_first ... ok [INFO] [stdout] test acp_client::tests::test_drain_events_returns_all ... ok [INFO] [stdout] test acp_client::tests::test_drain_events_skips_ack_responses ... ok [INFO] [stdout] test acp_client::tests::test_parse_initialize_codex ... ok [INFO] [stdout] test acp_client::tests::test_parse_initialize_no_result ... ok [INFO] [stdout] test acp_client::tests::test_parse_initialize_claude_code ... ok [INFO] [stdout] test acp_client::tests::test_parse_initialize_unknown_agent ... ok [INFO] [stdout] test acp_client::tests::test_parse_invalid_json_errors ... ok [INFO] [stdout] test acp_client::tests::test_parse_new_session_missing_field ... ok [INFO] [stdout] test acp_client::tests::test_parse_new_session_returns_id ... ok [INFO] [stdout] test acp_client::tests::test_parse_ordinary_response_returns_none ... ok [INFO] [stdout] test acp_client::tests::test_parse_rpc_error_response ... ok [INFO] [stdout] test acp_client::tests::test_parse_session_done ... ok [INFO] [stdout] test acp_client::tests::test_parse_session_error ... ok [INFO] [stdout] test acp_client::tests::test_parse_text_notification ... ok [INFO] [stdout] test acp_client::tests::test_parse_tool_result_notification ... ok [INFO] [stdout] test acp_client::tests::test_parse_tool_use_notification ... ok [INFO] [stdout] test acp_client::tests::test_parse_unknown_notification_returns_none ... ok [INFO] [stdout] test acp_client::tests::test_request_serializes_to_valid_json ... ok [INFO] [stdout] test acp_client::tests::test_send_prompt_increments_id ... ok [INFO] [stdout] test acp_client::tests::test_send_prompt_without_session_errors ... ok [INFO] [stdout] test acp_client::tests::test_send_raw_closed_sender_errors ... ok [INFO] [stdout] test acp_client::tests::test_send_raw_not_connected_errors ... ok [INFO] [stdout] test acp_client::tests::test_send_raw_sends_to_channel ... ok [INFO] [stdout] test agent_client::tests::test_agent_info_serialization_round_trip ... ok [INFO] [stdout] test agent_client::tests::test_kind_from_server_name_claude ... ok [INFO] [stdout] test agent_client::tests::test_kind_from_server_name_codex ... ok [INFO] [stdout] test agent_client::tests::test_kind_from_server_name_unknown ... ok [INFO] [stdout] test agent_client::tests::test_protocol_display ... ok [INFO] [stdout] test agent_client::tests::test_pty_drain_empty_returns_nothing ... ok [INFO] [stdout] test agent_client::tests::test_pty_drain_events_detects_exit_sentinel ... ok [INFO] [stdout] test agent_client::tests::test_pty_drain_events_disconnected_on_closed_channel ... ok [INFO] [stdout] test agent_client::tests::test_pty_drain_events_text_delta ... ok [INFO] [stdout] test agent_client::tests::test_pty_send_fails_when_receiver_dropped ... ok [INFO] [stdout] test agent_client::tests::test_pty_send_prompt_appends_newline ... ok [INFO] [stdout] test agent_detector::tests::test_claude_lockfile_patterns_non_empty ... ok [INFO] [stdout] test acp_client::tests::test_client_session_id_none_initially ... ok [INFO] [stdout] test agent_detector::tests::test_codex_lockfile_patterns_non_empty ... ok [INFO] [stdout] test agent_detector::tests::test_acp_url_format ... ok [INFO] [stdout] test agent_detector::tests::test_parse_lockfile_invalid_json_returns_none ... ok [INFO] [stdout] test acp_client::tests::test_send_prompt_sends_correct_method ... ok [INFO] [stdout] test acp_client::tests::test_parse_initialize_missing_server_info ... ok [INFO] [stdout] test agent_detector::tests::test_claude_patterns_contain_lock_extension ... ok [INFO] [stdout] test agent_detector::tests::test_parse_lockfile_nonexistent_file_returns_none ... ok [INFO] [stdout] test agent_detector::tests::test_parse_lockfile_missing_port_returns_none ... ok [INFO] [stdout] test agent_detector::tests::test_parse_lockfile_port_only ... ok [INFO] [stdout] test agent_detector::tests::test_parse_lockfile_records_path ... ok [INFO] [stdout] test agent_detector::tests::test_parse_lockfile_valid ... ok [INFO] [stdout] test agent_detector::tests::test_parse_lockfile_whitespace_trimmed ... ok [INFO] [stdout] test agent_detector::tests::test_probe_result_acp_available_is_acp ... ok [INFO] [stdout] test agent_detector::tests::test_probe_result_not_acp_is_not_acp ... ok [INFO] [stdout] test agent_detector::tests::test_probe_result_unreachable_is_not_acp ... ok [INFO] [stdout] test agent_detector::tests::test_probe_unreachable_on_closed_port ... ok [INFO] [stdout] test agent_detector::tests::test_scan_default_ports_detects_no_agents_when_none_running ... ok [INFO] [stdout] test acp_client::tests::test_send_raw_reaches_server ... ok [INFO] [stdout] test agent_detector::tests::test_scan_default_ports_no_duplicates ... ok [INFO] [stdout] test agent_detector::tests::test_scan_default_ports_produces_valid_urls ... ok [INFO] [stdout] test agent_detector::tests::test_scan_default_ports_has_expected_lockfile_placeholder ... ok [INFO] [stdout] test agent_detector::tests::test_scan_default_ports_returns_vec ... ok [INFO] [stdout] test agent_registry::tests::test_add_session_deduplicates ... ok [INFO] [stdout] test agent_detector::tests::test_scan_lockfiles_returns_vec ... ok [INFO] [stdout] test agent_registry::tests::test_add_session ... ok [INFO] [stdout] test agent_registry::tests::test_by_protocol_acp ... ok [INFO] [stdout] test agent_registry::tests::test_by_protocol_pty ... ok [INFO] [stdout] test agent_registry::tests::test_clone_shares_inner_state ... ok [INFO] [stdout] test agent_registry::tests::test_connected_includes_all_non_disconnected_states ... ok [INFO] [stdout] test agent_registry::tests::test_connected_excludes_disconnected ... ok [INFO] [stdout] test agent_registry::tests::test_all_empty ... ok [INFO] [stdout] test agent_registry::tests::test_get_nonexistent_returns_none ... ok [INFO] [stdout] test agent_registry::tests::test_has_acp_url_true ... ok [INFO] [stdout] test agent_registry::tests::test_concurrent_registrations ... ok [INFO] [stdout] test agent_registry::tests::test_register_and_get ... ok [INFO] [stdout] test agent_registry::tests::test_len_and_is_empty ... ok [INFO] [stdout] test agent_registry::tests::test_register_replaces_existing ... ok [INFO] [stdout] test agent_registry::tests::test_has_acp_url_empty_registry ... ok [INFO] [stdout] test agent_registry::tests::test_has_acp_url_false ... ok [INFO] [stdout] test agent_registry::tests::test_remove_existing ... ok [INFO] [stdout] test agent_registry::tests::test_register_returns_id ... ok [INFO] [stdout] test agent_registry::tests::test_remove_nonexistent_is_noop ... ok [INFO] [stdout] test agent_registry::tests::test_remove_session ... ok [INFO] [stdout] test agent_registry::tests::test_update_status ... ok [INFO] [stdout] test agent_registry::tests::test_update_status_nonexistent_is_noop ... ok [INFO] [stdout] test agent_visualize::tests::test_detect_ignores_deleted_files ... ok [INFO] [stdout] test agent_visualize::tests::test_detect_new_files_empty_when_unchanged ... ok [INFO] [stdout] test agent_visualize::tests::test_detect_new_files_finds_new_file ... ok [INFO] [stdout] test agent_visualize::tests::test_detect_returns_full_paths ... ok [INFO] [stdout] test agent_visualize::tests::test_detect_with_empty_pre_snapshot ... ok [INFO] [stdout] test agent_visualize::tests::test_diagrams_dir_ends_with_expected_path ... ok [INFO] [stdout] test agent_visualize::tests::test_diagrams_dir_is_absolute ... ok [INFO] [stdout] test agent_visualize::tests::test_prompt_contains_save_instruction ... ok [INFO] [stdout] test agent_visualize::tests::test_prompt_contains_topic ... ok [INFO] [stdout] test agent_visualize::tests::test_prompt_with_empty_topic ... ok [INFO] [stdout] test agent_visualize::tests::test_prompt_with_multiline_topic ... ok [INFO] [stdout] test agent_visualize::tests::test_resolve_agent_url_explicit ... ok [INFO] [stdout] test agent_visualize::tests::test_resolve_agent_url_none_falls_through ... ok [INFO] [stdout] test agent_visualize::tests::test_resolve_agent_url_preserves_explicit_url_verbatim ... ok [INFO] [stdout] test agent_visualize::tests::test_resolve_diagram_server_url_explicit_beats_relay ... ok [INFO] [stdout] test acp_client::tests::test_build_initialize_has_correct_method ... ok [INFO] [stdout] test agent_visualize::tests::test_resolve_diagram_server_url_relay ... ok [INFO] [stdout] test agent_visualize::tests::test_snapshot_creates_directory ... ok [INFO] [stdout] test agent_visualize::tests::test_snapshot_ignores_non_html_files ... ok [INFO] [stdout] test agent_visualize::tests::test_detect_new_files_sorted_newest_first ... ok [INFO] [stdout] test agent_visualize::tests::test_snapshot_is_idempotent ... ok [INFO] [stdout] test agent_detector::tests::test_codex_patterns_contain_lock_extension ... ok [INFO] [stdout] test agent_registry::tests::test_all_returns_every_agent ... ok [INFO] [stdout] test agent_visualize::tests::test_prompt_with_special_characters ... ok [INFO] [stdout] test agent_visualize::tests::test_resolve_diagram_server_url_explicit_config ... ok [INFO] [stdout] test acp_client::tests::test_connect_and_recv_event_via_mock_server ... ok [INFO] [stdout] test agora_api::tests::format_projects_shows_certs_when_requested ... ok [INFO] [stdout] test agora_api::tests::format_projects_shows_none_for_missing_cert ... ok [INFO] [stdout] test agora_api::tests::format_projects_shows_status_and_created ... ok [INFO] [stdout] test agora_api::tests::format_unix_timestamp_epoch ... ok [INFO] [stdout] test agora_api::tests::format_unix_timestamp_leap_year ... ok [INFO] [stdout] test ai_client::tests::client_requires_api_key ... ok [INFO] [stdout] test ai_client::tests::parse_invalid_json_fails ... ok [INFO] [stdout] test ai_client::tests::parse_intent_with_markdown_fences ... ok [INFO] [stdout] test agent_visualize::tests::test_detect_finds_modified_file ... ok [INFO] [stdout] test ai_client::tests::parse_empty_command_intent ... ok [INFO] [stdout] test ai_client::tests::parse_valid_intent ... ok [INFO] [stdout] test agora_api::tests::format_projects_hides_certs_by_default ... ok [INFO] [stdout] test agora_api::tests::format_unix_timestamp_known_date ... ok [INFO] [stdout] test app::tests::test_active_cli_default_is_claude ... ok [INFO] [stdout] test app::tests::test_active_cli_equality ... ok [INFO] [stdout] test app::tests::test_menu_connected_shows_all_items ... ok [INFO] [stdout] test app::tests::test_pending_visualize_clone ... ok [INFO] [stdout] test app::tests::test_pending_visualize_detected_file_overrides_snapshot ... ok [INFO] [stdout] test app::tests::test_pending_visualize_tracks_fields ... ok [INFO] [stdout] test app::tests::test_pending_visualize_with_pre_snapshot ... ok [INFO] [stdout] test app::tests::test_pending_visualize_with_relay_url ... ok [INFO] [stdout] test app::tests::test_pending_voice_request_clone ... ok [INFO] [stdout] test app::tests::test_pending_voice_request_default_is_none ... ok [INFO] [stdout] test app::tests::test_pending_visualize_default_is_none ... ok [INFO] [stdout] test app::tests::test_menu_disconnected_hides_agent_items ... ok [INFO] [stdout] test auth::tests::auth_session_serialization_roundtrip ... ok [INFO] [stdout] test app::tests::test_pending_voice_request_tracks_fields ... ok [INFO] [stdout] test app::tests::test_pending_visualize_clone_preserves_snapshot ... ok [INFO] [stdout] test auth::tests::multiple_sessions_independent ... ok [INFO] [stdout] test auth::tests::hostname_returns_non_empty ... ok [INFO] [stdout] test auth::tests::deep_link_format ... ok [INFO] [stdout] test auth::tests::otp_is_random ... ok [INFO] [stdout] test auth::tests::otp_is_8_digits ... ok [INFO] [stdout] test app::tests::test_menu_rebuild_clamps_selected_index ... ok [INFO] [stdout] test app::tests::test_pinned_cli_default_is_none ... ok [INFO] [stdout] test app::tests::test_pairing_code_default_is_none ... ok [INFO] [stdout] test auth::tests::session_age_calculation ... ok [INFO] [stdout] test auth::tests::session_is_valid_when_fresh ... ok [INFO] [stdout] test auth::tests::session_manager_cleanup_expired ... ok [INFO] [stdout] test auth::tests::session_manager_get_mut_allows_refresh ... ok [INFO] [stdout] test agora_api::tests::format_projects_empty_list ... ok [INFO] [stdout] test auth::tests::session_expires_after_7_days ... ok [INFO] [stdout] test auth::tests::session_manager_get_expired_session_returns_none ... ok [INFO] [stdout] test auth::tests::session_manager_multiple_astations ... ok [INFO] [stdout] test auth::tests::session_manager_get_nonexistent ... ok [INFO] [stdout] test auth::tests::session_manager_get_valid_session ... ok [INFO] [stdout] test auth::tests::session_refresh_extends_validity ... ok [INFO] [stdout] test auth::tests::session_manager_same_atem_different_endpoints ... ok [INFO] [stdout] test auth::tests::session_manager_save_and_load ... ok [INFO] [stdout] test auth::tests::session_manager_starts_empty ... ok [INFO] [stdout] test auth::tests::session_refresh_prevents_expiry ... ok [INFO] [stdout] test auth::tests::session_valid_just_before_expiry ... ok [INFO] [stdout] test auth::tests::web_fallback_url_format ... ok [INFO] [stdout] test auth::tests::web_fallback_url_strips_trailing_slash ... ok [INFO] [stdout] test claude_client::tests::client_default_binary_is_claude ... ok [INFO] [stdout] test claude_client::tests::client_struct_holds_binary_and_args ... ok [INFO] [stdout] test auth::tests::session_save_and_load_preserves_activity ... ok [INFO] [stdout] test claude_client::tests::nonexistent_binary_fails ... ok [INFO] [stdout] test claude_client::tests::session_with_cat_receives_sent_input ... ok [INFO] [stdout] test claude_client::tests::session_reports_exit_on_process_end ... ok [INFO] [stdout] test cli::tests::cli_agent_connect_custom_timeout ... ok [INFO] [stdout] test cli::tests::cli_agent_connect_parses ... ok [INFO] [stdout] test cli::tests::cli_agent_probe_custom_timeout ... ok [INFO] [stdout] test cli::tests::cli_agent_list_parses ... ok [INFO] [stdout] test cli::tests::cli_agent_probe_parses ... ok [INFO] [stdout] test cli::tests::cli_agent_prompt_parses ... ok [INFO] [stdout] test claude_client::tests::resize_handle_works ... ok [INFO] [stdout] test cli::tests::cli_agent_visualize_custom_timeout ... ok [INFO] [stdout] test cli::tests::cli_agent_visualize_all_flags ... ok [INFO] [stdout] test cli::tests::cli_agent_visualize_parses ... ok [INFO] [stdout] test cli::tests::cli_agent_visualize_topic_with_spaces ... ok [INFO] [stdout] test cli::tests::cli_agent_visualize_no_browser_flag ... ok [INFO] [stdout] test cli::tests::cli_agent_visualize_missing_topic_fails ... ok [INFO] [stdout] test cli::tests::cli_agent_visualize_with_url ... ok [INFO] [stdout] test cli::tests::cli_config_clear_parses ... ok [INFO] [stdout] test cli::tests::cli_config_set_astation_relay_url ... ok [INFO] [stdout] test cli::tests::cli_config_set_astation_ws ... ok [INFO] [stdout] test cli::tests::cli_config_show_parses ... ok [INFO] [stdout] test cli::tests::cli_list_project_parses ... ok [INFO] [stdout] test cli::tests::cli_list_project_with_show_certificates ... ok [INFO] [stdout] test cli::tests::cli_login_and_logout_still_parse ... ok [INFO] [stdout] test cli::tests::cli_no_args_returns_none_command ... ok [INFO] [stdout] test cli::tests::cli_pair_with_save_flag ... ok [INFO] [stdout] test cli::tests::cli_login_parses ... ok [INFO] [stdout] test cli::tests::cli_logout_parses ... ok [INFO] [stdout] test cli::tests::cli_project_show_parses ... ok [INFO] [stdout] test cli::tests::cli_pair_without_save ... ok [INFO] [stdout] test cli::tests::cli_project_use_parses ... ok [INFO] [stdout] test cli::tests::cli_project_use_with_app_id ... ok [INFO] [stdout] test cli::tests::cli_project_use_with_index ... ok [INFO] [stdout] test cli::tests::cli_repl_parses ... ok [INFO] [stdout] test cli::tests::cli_project_show_with_certificate ... ok [INFO] [stdout] test cli::tests::cli_serv_convo_parses_with_no_flags ... ok [INFO] [stdout] test cli::tests::cli_serv_convo_parses_all_flags ... ok [INFO] [stdout] test cli::tests::cli_serv_diagrams_background_flag ... ok [INFO] [stdout] test cli::tests::cli_serv_kill_parses ... ok [INFO] [stdout] test cli::tests::cli_serv_killall_parses ... ok [INFO] [stdout] test cli::tests::cli_serv_diagrams_defaults ... ok [INFO] [stdout] test cli::tests::cli_serv_list_parses ... ok [INFO] [stdout] test cli::tests::cli_serv_rtc_background_flag ... ok [INFO] [stdout] test cli::tests::cli_serv_rtc_defaults ... ok [INFO] [stdout] test cli::tests::cli_token_rtc_create_defaults ... ok [INFO] [stdout] test cli::tests::cli_serv_rtc_with_options ... ok [INFO] [stdout] test cli::tests::cli_token_rtc_create_rejects_old_uid_flag ... ok [INFO] [stdout] test cli::tests::cli_token_rtc_create_with_rtm_flag ... ok [INFO] [stdout] test cli::tests::cli_token_rtc_create_with_separate_rtm_user ... ok [INFO] [stdout] test cli::tests::cli_token_rtc_decode_parses ... ok [INFO] [stdout] test cli::tests::cli_token_rtm_create_accepts_rtm_user_id ... ok [INFO] [stdout] test cli::tests::cli_token_rtm_create_defaults ... ok [INFO] [stdout] test cli::tests::cli_serv_diagrams_with_port ... ok [INFO] [stdout] test cli::tests::cli_token_rtm_create_rejects_old_user_id_flag ... ok [INFO] [stdout] test cli::tests::cli_unpair ... ok [INFO] [stdout] test codex_client::tests::client_default_binary_is_codex ... ok [INFO] [stdout] test codex_client::tests::client_struct_holds_binary_and_args ... ok [INFO] [stdout] test codex_client::tests::nonexistent_binary_fails ... ok [INFO] [stdout] test codex_client::tests::resize_handle_works ... ok [INFO] [stdout] test codex_client::tests::session_reports_exit_on_process_end ... ok [INFO] [stdout] test command::tests::stream_buffer_clear ... ok [INFO] [stdout] test command::tests::stream_buffer_empty ... ok [INFO] [stdout] test command::tests::stream_buffer_no_match ... ok [INFO] [stdout] test codex_client::tests::session_with_cat_receives_sent_input ... ok [INFO] [stdout] test command::tests::stream_buffer_push_and_take ... ok [INFO] [stdout] test command::tests::stream_buffer_take_trims ... ok [INFO] [stdout] test command::tests::stream_buffer_trigger_case_insensitive ... ok [INFO] [stdout] test command::tests::stream_buffer_trigger_multi_word ... ok [INFO] [stdout] test command::tests::stream_buffer_trigger_strips ... ok [INFO] [stdout] test command::tests::task_queue_complete_active ... ok [INFO] [stdout] test command::tests::task_queue_complete_empty ... ok [INFO] [stdout] test command::tests::task_queue_enqueue ... ok [INFO] [stdout] test command::tests::task_queue_fifo_order ... ok [INFO] [stdout] test command::tests::task_queue_finalize_lifecycle ... ok [INFO] [stdout] test command::tests::task_queue_start_blocked_while_busy ... ok [INFO] [stdout] test command::tests::task_queue_start_next ... ok [INFO] [stdout] test config::tests::cleanup_legacy_files_removes_both ... ok [INFO] [stdout] test config::tests::config_defaults ... ok [INFO] [stdout] test config::tests::default_config_has_none_fields ... ok [INFO] [stdout] test config::tests::display_masked_shows_sso_section ... ok [INFO] [stdout] test config::tests::effective_bff_url_custom ... ok [INFO] [stdout] test config::tests::effective_bff_url_default ... ok [INFO] [stdout] test config::tests::effective_sso_url_custom ... ok [INFO] [stdout] test config::tests::effective_sso_url_default ... ok [INFO] [stdout] test config::tests::format_unix_timestamp_hhmm_known_date ... ok [INFO] [stdout] test config::tests::get_by_index_returns_projects_in_order ... ok [INFO] [stdout] test config::tests::load_returns_default_on_corrupt_file ... ok [INFO] [stdout] test config::tests::load_returns_default_on_missing_file ... ok [INFO] [stdout] test config::tests::project_cache_file_is_encrypted_not_plaintext ... ok [INFO] [stdout] test config::tests::project_cache_round_trip_via_temp_path ... ok [INFO] [stdout] test config::tests::resolve_app_id_cli_beats_env ... ok [INFO] [stdout] test config::tests::resolve_app_id_cli_takes_precedence ... ok [INFO] [stdout] test config::tests::save_clears_active_if_project_removed ... ok [INFO] [stdout] test config::tests::save_preserves_active_if_still_present ... ok [INFO] [stdout] test config::tests::set_active_and_get_active_round_trip ... ok [INFO] [stdout] test command::tests::task_queue_empty ... ok [INFO] [stdout] test config::tests::test_astation_relay_url_custom ... ok [INFO] [stdout] test config::tests::test_astation_relay_url_default ... ok [INFO] [stdout] test config::tests::test_display_masked_includes_astation_relay_url ... ok [INFO] [stdout] test convo_config::tests::avatar_mint_credentials_none_without_both ... ok [INFO] [stdout] test convo_config::tests::avatar_mint_credentials_reads_appid_and_cert ... ok [INFO] [stdout] test convo_config::tests::avatar_user_supplied_token_not_overridden_by_caller ... ok [INFO] [stdout] test convo_config::tests::build_join_payload_maps_toml_to_agora_shape ... ok [INFO] [stdout] test convo_config::tests::build_join_payload_omits_avatar_when_flag_false ... ok [INFO] [stdout] test convo_config::tests::empty_config_parses_to_all_none ... ok [INFO] [stdout] test convo_config::tests::join_payload_avatar_absent_when_checkbox_unchecked ... ok [INFO] [stdout] test convo_config::tests::join_payload_avatar_block_overrides_preset_when_fields_present ... ok [INFO] [stdout] test convo_config::tests::join_payload_avatar_emits_even_without_toml_block ... ok [INFO] [stdout] test convo_config::tests::join_payload_avatar_emits_skeleton_without_vendor ... ok [INFO] [stdout] test convo_config::tests::join_payload_avatar_params_agora_uid_override_wins ... ok [INFO] [stdout] test convo_config::tests::join_payload_avatar_strips_cert_and_injects_channel_token ... ok [INFO] [stdout] test convo_config::tests::join_payload_passes_through_top_level_tables ... ok [INFO] [stdout] test convo_config::tests::join_payload_runtime_preset_overrides_config ... ok [INFO] [stdout] test convo_config::tests::avatar_has_preset_token_detects_user_supplied_value ... ok [INFO] [stdout] test convo_config::tests::join_payload_uses_first_preset_from_list_when_no_runtime ... ok [INFO] [stdout] test convo_config::tests::nested_params_preserve_tables ... ok [INFO] [stdout] test convo_config::tests::parses_full_fixture ... ok [INFO] [stdout] test convo_config::tests::preset_list_empty_when_neither_set ... ok [INFO] [stdout] test convo_config::tests::preset_list_falls_back_to_single_preset ... ok [INFO] [stdout] test convo_config::tests::preset_list_from_presets_array ... ok [INFO] [stdout] test convo_config::tests::resolve_defaults_rtc_user_id_to_0 ... ok [INFO] [stdout] test convo_config::tests::resolve_errors_when_agent_user_id_missing ... ok [INFO] [stdout] test convo_config::tests::resolve_avatar_configured_false_when_section_absent ... ok [INFO] [stdout] test convo_config::tests::resolve_errors_when_channel_missing ... ok [INFO] [stdout] test convo_test_server::tests::convoai_base_url_defaults_to_agora ... ok [INFO] [stdout] test convo_test_server::tests::convoai_base_url_honours_env_override ... ok [INFO] [stdout] test convo_test_server::tests::default_config_path_ends_with_convo_toml ... ok [INFO] [stdout] test convo_test_server::tests::gen_agent_name_has_expected_shape ... ok [INFO] [stdout] test convo_test_server::tests::html_embeds_preset_list_as_js_array ... ok [INFO] [stdout] test convo_config::tests::resolve_uses_cli_over_toml ... ok [INFO] [stdout] test convo_test_server::tests::source_contains_api_token_route ... ok [INFO] [stdout] test credentials::tests::atem_falls_back_to_own_sso_when_paired_astation_different ... ok [INFO] [stdout] test credentials::tests::corrupted_file_returns_empty_store ... ok [INFO] [stdout] test convo_test_server::tests::html_has_expected_ids_and_scripts ... ok [INFO] [stdout] test credentials::tests::disconnect_then_reconnect_within_grace_period ... ok [INFO] [stdout] test credentials::tests::disconnect_sets_timestamp_and_grace_applies ... ok [INFO] [stdout] test credentials::tests::empty_store_saves_and_loads_cleanly ... ok [INFO] [stdout] test credentials::tests::load_returns_empty_when_file_missing ... ok [INFO] [stdout] test credentials::tests::multiple_astations_paired_simultaneously ... ok [INFO] [stdout] test credentials::tests::needs_refresh_false_when_plenty_of_time ... ok [INFO] [stdout] test credentials::tests::needs_refresh_true_when_near_expiry ... ok [INFO] [stdout] test credentials::tests::paired_entry_round_trip ... ok [INFO] [stdout] test credentials::tests::paired_source_respects_save_credentials_flag ... ok [INFO] [stdout] test credentials::tests::remove_paired_leaves_others_intact ... ok [INFO] [stdout] test credentials::tests::remove_sso_leaves_paired ... ok [INFO] [stdout] test credentials::tests::file_permissions_are_0600_on_unix ... ok [INFO] [stdout] test credentials::tests::resolve_errors_when_empty ... ok [INFO] [stdout] test credentials::tests::resolve_errors_when_non_saved_paired_grace_expired ... ok [INFO] [stdout] test credentials::tests::resolve_falls_back_to_sso_when_not_connected ... ok [INFO] [stdout] test credentials::tests::resolve_non_saved_paired_within_grace_period ... ok [INFO] [stdout] test credentials::tests::resolve_picks_paired_when_connected ... ok [INFO] [stdout] test credentials::tests::resolve_saved_paired_when_disconnected ... ok [INFO] [stdout] test credentials::tests::saved_paired_survives_disconnect_forever ... ok [INFO] [stdout] test credentials::tests::save_and_load_round_trip_encrypted ... ok [INFO] [stdout] test credentials::tests::sso_entry_round_trip ... ok [INFO] [stdout] test credentials::tests::sso_source_always_has_save_credentials_true ... ok [INFO] [stdout] test credentials::tests::upsert_replaces_by_source_and_astation_id ... ok [INFO] [stdout] test credentials::tests::user_logs_in_then_pairs_with_astation ... ok [INFO] [stdout] test diagram_server::tests::test_build_server_entry_fields ... ok [INFO] [stdout] test diagram_server::tests::test_chrono_lite ... ok [INFO] [stdout] test diagram_server::tests::test_build_server_entry_serializes ... ok [INFO] [stdout] test diagram_server::tests::test_chrono_lite_boundary_values ... ok [INFO] [stdout] test diagram_server::tests::test_db_path_under_config ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_binary_html ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_delete ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_delete_missing ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_empty_html ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_delete_removes_from_list ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_empty_topic ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_insert_multiple_same_topic ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_get_missing ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_large_html ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_list ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_list_contains_metadata ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_list_empty ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_list_newest_first ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_list_limit ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_reopen_persists ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_round_trip ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_special_chars_topic ... ok [INFO] [stdout] test diagram_server::tests::test_extract_body ... ok [INFO] [stdout] test diagram_server::tests::test_diagram_store_unicode_topic ... ok [INFO] [stdout] test diagram_server::tests::test_extract_body_empty_body ... ok [INFO] [stdout] test diagram_server::tests::test_extract_body_empty ... ok [INFO] [stdout] test diagram_server::tests::test_extract_body_lf_only ... ok [INFO] [stdout] test diagram_server::tests::test_generate_id_alphanumeric ... ok [INFO] [stdout] test diagram_server::tests::test_generate_id_length ... ok [INFO] [stdout] test diagram_server::tests::test_generate_id_uniqueness ... ok [INFO] [stdout] test diagram_server::tests::test_html_escape ... ok [INFO] [stdout] test diagram_server::tests::test_html_escape_empty ... ok [INFO] [stdout] test diagram_server::tests::test_html_escape_clean_string ... ok [INFO] [stdout] test auth::tests::poll_session_status_returns_error_on_404 ... ok [INFO] [stdout] test diagram_server::tests::test_http_404_unknown_route ... ok [INFO] [stdout] test diagram_server::tests::test_http_cors_headers_on_response ... ok [INFO] [stdout] test auth::tests::poll_session_status_returns_error_on_denied ... ok [INFO] [stdout] test auth::tests::create_server_session_parses_id_field ... ok [INFO] [stdout] test diagram_server::tests::test_http_delete_diagram ... ok [INFO] [stdout] test diagram_server::tests::test_http_delete_not_found ... ok [INFO] [stdout] test diagram_server::tests::test_http_favicon_returns_204 ... ok [INFO] [stdout] test auth::tests::poll_session_status_parses_granted ... ok [INFO] [stdout] test diagram_server::tests::test_http_get_diagram_not_found ... ok [INFO] [stdout] test diagram_server::tests::test_http_full_cycle_post_list_get_delete ... ok [INFO] [stdout] test diagram_server::tests::test_http_get_landing_page ... ok [INFO] [stdout] test diagram_server::tests::test_http_list_diagrams_empty ... ok [INFO] [stdout] test diagram_server::tests::test_http_list_diagrams_with_entries ... ok [INFO] [stdout] test diagram_server::tests::test_http_options_cors_preflight ... ok [INFO] [stdout] test diagram_server::tests::test_landing_page_empty_store ... ok [INFO] [stdout] test diagram_server::tests::test_http_post_and_get_diagram ... ok [INFO] [stdout] test diagram_server::tests::test_server_id_format ... ok [INFO] [stdout] test dispatch::tests::background_result_roundtrip ... ok [INFO] [stdout] test diagram_server::tests::test_landing_page_escapes_xss_topic ... ok [INFO] [stdout] test dispatch::tests::complete_main_returns_id ... ok [INFO] [stdout] test dispatch::tests::finalize_flag_lifecycle ... ok [INFO] [stdout] test dispatch::tests::parse_triage_response_case_insensitive ... ok [INFO] [stdout] test dispatch::tests::parse_triage_response_embedded_json ... ok [INFO] [stdout] test dispatch::tests::parse_triage_response_invalid_json ... ok [INFO] [stdout] test diagram_server::tests::test_landing_page_with_diagrams ... ok [INFO] [stdout] test dispatch::tests::parse_triage_response_valid_background ... ok [INFO] [stdout] test dispatch::tests::parse_triage_response_valid_main ... ok [INFO] [stdout] test dispatch::tests::poll_background_results_drains_channel ... ok [INFO] [stdout] test dispatch::tests::poll_triage_results_routes_to_background ... ok [INFO] [stdout] test dispatch::tests::poll_triage_results_routes_to_main ... ok [INFO] [stdout] test dispatch::tests::submit_when_busy_no_slots_routes_to_main ... ok [INFO] [stdout] test dispatch::tests::submit_when_busy_with_slots_triggers_triage ... ok [INFO] [stdout] test dispatch::tests::submit_when_idle_routes_to_main ... ok [INFO] [stdout] test repl::tests::command_to_args_strips_prefix ... ok [INFO] [stdout] test dispatch::tests::parse_triage_response_missing_target ... ok [INFO] [stdout] test repl::tests::command_to_args_without_prefix ... ok [INFO] [stdout] test repl::tests::exact_match_case_insensitive ... ok [INFO] [stdout] test repl::tests::exact_match_config_show ... ok [INFO] [stdout] test repl::tests::exact_match_list_project ... ok [INFO] [stdout] test repl::tests::exact_match_project_use ... ok [INFO] [stdout] test repl::tests::exact_match_token_rtc_create_with_args ... ok [INFO] [stdout] test repl::tests::exact_match_with_atem_prefix ... ok [INFO] [stdout] test repl::tests::exact_match_with_flags ... ok [INFO] [stdout] test repl::tests::no_match_for_unknown ... ok [INFO] [stdout] test repl::tests::shell_split_quoted ... ok [INFO] [stdout] test repl::tests::shell_split_simple ... ok [INFO] [stdout] test rtc_test_server::tests::html_page_contains_app_id_and_channel ... ok [INFO] [stdout] test rtc_test_server::tests::html_page_has_no_rtm_section_when_disabled ... ok [INFO] [stdout] test rtc_test_server::tests::server_id_format ... ok [INFO] [stdout] test rtc_test_server::tests::html_page_has_rtm_section_when_enabled ... ok [INFO] [stdout] test rtc_test_server::tests::servers_dir_under_config ... ok [INFO] [stdout] test diagram_server::tests::test_http_post_defaults_topic ... ok [INFO] [stdout] test sso_auth::tests::generate_state_produces_unique_values ... ok [INFO] [stdout] test sso_auth::tests::parse_callback_query_extracts_code_and_state ... ok [INFO] [stdout] test sso_auth::tests::parse_callback_query_extracts_login_id ... ok [INFO] [stdout] test sso_auth::tests::parse_callback_query_handles_extra_params ... ok [INFO] [stdout] test sso_auth::tests::parse_callback_query_handles_missing_params ... ok [INFO] [stdout] test sso_auth::tests::parse_callback_query_url_decodes_values ... ok [INFO] [stdout] test sso_auth::tests::generate_pkce_produces_unique_pairs ... ok [INFO] [stdout] test sso_auth::tests::pkce_challenge_is_base64url_of_sha256_verifier ... ok [INFO] [stdout] test sso_auth::tests::valid_token_returns_error_when_no_session ... ok [INFO] [stdout] test time_sync::tests::parse_http_date_invalid ... ok [INFO] [stdout] test time_sync::tests::parse_http_date_valid ... ok [INFO] [stdout] test time_sync::tests::days_from_civil_epoch ... ok [INFO] [stdout] test time_sync::tests::time_sync_new_has_zero_offset ... ok [INFO] [stdout] test diagram_server::tests::test_http_post_invalid_json ... ok [INFO] [stdout] test token::tests::build_and_decode_with_real_credentials ... ok [INFO] [stdout] test token::tests::build_token_rtc_int_uid_empty_cert_returns_empty ... ok [INFO] [stdout] test diagram_server::tests::test_http_post_missing_html_field ... ok [INFO] [stdout] test token::tests::build_token_rtc_with_rtm_separate_empty_cert_returns_empty ... ok [INFO] [stdout] test time_sync::tests::days_from_civil_known_date ... ok [INFO] [stdout] test token::tests::decode_handles_unpadded_base64 ... ok [INFO] [stdout] test token::tests::decode_invalid_token_fails ... ok [INFO] [stdout] test token::tests::channel_with_allowed_punctuation_survives_round_trip ... ok [INFO] [stdout] test token::tests::decoded_combined_token_surfaces_both_users_and_channel ... ok [INFO] [stdout] test token::tests::decoded_service_fields_are_preserved ... ok [INFO] [stdout] test token::tests::decoded_rtc_token_surfaces_channel_and_user ... ok [INFO] [stdout] test token::tests::display_flags_expired_token ... ok [INFO] [stdout] test token::tests::display_shows_version_validity_and_sections ... ok [INFO] [stdout] test token::tests::display_flags_not_yet_valid_token ... ok [INFO] [stdout] test token::tests::decoded_rtm_token_surfaces_user ... ok [INFO] [stdout] test token::tests::empty_certificate_returns_empty_rtc_token ... ok [INFO] [stdout] test token::tests::format_relative_duration_always_ends_in_seconds ... ok [INFO] [stdout] test token::tests::empty_certificate_returns_empty_rtm_token ... ok [INFO] [stdout] test token::tests::long_string_account_255_chars_round_trips ... ok [INFO] [stdout] test token::tests::legacy_token_starts_with_prefix ... ok [INFO] [stdout] test token::tests::privilege_values_are_relative_seconds ... ok [INFO] [stdout] test token::tests::int_uid_2233_and_string_2233_decode_identically ... ok [INFO] [stdout] test token::tests::legacy_empty_certificate_returns_empty_token ... ok [INFO] [stdout] test token::tests::publisher_has_more_privileges_than_subscriber ... ok [INFO] [stdout] test token::tests::rtc_account_as_str_roundtrips_int ... ok [INFO] [stdout] test token::tests::rtc_account_at_u32_boundary_fits ... ok [INFO] [stdout] test token::tests::rtc_account_mode_label_matches_variant ... ok [INFO] [stdout] test token::tests::rtc_account_empty_string_is_str ... ok [INFO] [stdout] test token::tests::rtc_account_just_over_u32_falls_back_to_str ... ok [INFO] [stdout] test token::tests::rtc_account_overflowing_digits_fall_back_to_str ... ok [INFO] [stdout] test token::tests::rtc_account_parses_digits_as_int ... ok [INFO] [stdout] test token::tests::rtc_account_s_slash_prefix_forces_str ... ok [INFO] [stdout] test token::tests::rtc_account_parses_non_digits_as_str ... ok [INFO] [stdout] test token::tests::rtc_int_uid_token_differs_from_string_account_token ... ok [INFO] [stdout] test token::tests::rtc_subscriber_token_has_only_join_channel ... ok [INFO] [stdout] test token::tests::rtc_token_starts_with_version ... ok [INFO] [stdout] test token::tests::rtc_publisher_token_has_all_four_privileges ... ok [INFO] [stdout] test token::tests::rtc_token_generate_then_decode_roundtrip ... ok [INFO] [stdout] test token::tests::rtc_with_rtm_empty_cert_returns_empty ... ok [INFO] [stdout] test token::tests::rtc_with_rtm_int_uid_same_account_for_both ... ok [INFO] [stdout] test token::tests::rtc_with_rtm_int_uid_and_separate_rtm_account ... ok [INFO] [stdout] test token::tests::rtc_with_rtm_token_carries_both_services ... ok [INFO] [stdout] test token::tests::rtc_with_rtm_separate_account_produces_different_token_than_same_account ... ok [INFO] [stdout] test token::tests::rtm_token_generate_then_decode_roundtrip ... ok [INFO] [stdout] test token::tests::rtc_with_rtm_separate_accounts_decodes ... ok [INFO] [stdout] test token::tests::rtm_token_starts_with_version ... ok [INFO] [stdout] test token::tests::rtc_with_rtm_subscriber_has_only_join_channel_on_rtc_side ... ok [INFO] [stdout] test token::tests::string_account_0_stores_literal_zero ... ok [INFO] [stdout] test token::tests::uid_0_stores_empty_string_in_token ... ok [INFO] [stdout] test tui::voice_fx::tests::border_chars_clamped ... ok [INFO] [stdout] test tui::voice_fx::tests::border_chars_high_volume ... ok [INFO] [stdout] test tui::voice_fx::tests::border_color_high_is_cyan ... ok [INFO] [stdout] test tui::voice_fx::tests::border_chars_low_volume ... ok [INFO] [stdout] test tui::voice_fx::tests::border_chars_medium_volume ... ok [INFO] [stdout] test tui::voice_fx::tests::border_color_low_is_gray ... ok [INFO] [stdout] test tui::voice_fx::tests::border_color_mid_is_interpolated ... ok [INFO] [stdout] test tui::voice_fx::tests::jitter_zero_at_low_volume ... ok [INFO] [stdout] test tui::voice_fx::tests::jitter_nonzero_at_high_volume ... ok [INFO] [stdout] test tui::voice_fx::tests::lerp_boundaries ... ok [INFO] [stdout] test web_server::cert::tests::generate_cert_accepts_extra_hostnames ... ok [INFO] [stdout] test web_server::html::tests::passes_through_unicode ... ok [INFO] [stdout] test web_server::net::tests::get_lan_ip_returns_non_unspecified ... ok [INFO] [stdout] test web_server::net::tests::sslip_host_formats_correctly ... ok [INFO] [stdout] test web_server::cert::tests::generate_cert_succeeds ... ok [INFO] [stdout] test web_server::html::tests::escapes_html_special_chars ... ok [INFO] [stdout] test web_server::request::tests::extract_body_from_http_request ... ok [INFO] [stdout] test web_server::request::tests::extract_body_empty_when_no_blank_line ... ok [INFO] [stdout] test websocket_client::tests::agent_event_done_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::agent_event_text_delta_roundtrip ... ok [INFO] [stdout] test web_server::cert::tests::generate_cert_ignores_empty_and_whitespace_entries ... ok [INFO] [stdout] test websocket_client::tests::agent_list_request_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::agent_list_response_empty ... ok [INFO] [stdout] test websocket_client::tests::agent_list_response_preserves_all_info_fields ... ok [INFO] [stdout] test websocket_client::tests::agent_list_response_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::agent_prompt_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::atem_instance_list_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::atem_instance_list_empty_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::agent_status_update_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::atem_instance_struct_serializes ... ok [INFO] [stdout] test websocket_client::tests::claude_launch_request_none_context ... ok [INFO] [stdout] test websocket_client::tests::claude_launch_request_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::command_response_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::credential_sync_deserialize_from_json ... ok [INFO] [stdout] test websocket_client::tests::credential_sync_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::deserialize_atem_instance_list_from_json ... ok [INFO] [stdout] test websocket_client::tests::deserialize_project_list_request_from_json ... ok [INFO] [stdout] test websocket_client::tests::codex_task_request_without_context ... ok [INFO] [stdout] test websocket_client::tests::deserialize_video_toggle_from_json ... ok [INFO] [stdout] test websocket_client::tests::deserialize_token_response_from_json ... ok [INFO] [stdout] test websocket_client::tests::deserialize_voice_command_without_is_final ... ok [INFO] [stdout] test websocket_client::tests::deserialize_voice_command_from_json ... ok [INFO] [stdout] test websocket_client::tests::deserialize_voice_toggle_from_json ... ok [INFO] [stdout] test websocket_client::tests::new_client_is_not_connected ... ok [INFO] [stdout] test websocket_client::tests::heartbeat_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::pair_save_preference_roundtrip_false ... ok [INFO] [stdout] test websocket_client::tests::invalid_type_fails_deserialization ... ok [INFO] [stdout] test websocket_client::tests::pair_save_preference_roundtrip_true ... ok [INFO] [stdout] test websocket_client::tests::pong_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::project_list_request_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::project_list_response_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::project_list_request_serializes ... ok [INFO] [stdout] test websocket_client::tests::sso_token_sync_deserialize_from_json ... ok [INFO] [stdout] test websocket_client::tests::sso_token_sync_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::sso_token_sync_without_login_id ... ok [INFO] [stdout] test websocket_client::tests::status_update_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::system_status_response_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::test_mark_task_assignment_deserialize ... ok [INFO] [stdout] test websocket_client::tests::test_mark_task_result_serialize ... ok [INFO] [stdout] test websocket_client::tests::test_mark_task_round_trip ... ok [INFO] [stdout] test websocket_client::tests::test_user_command_empty_context ... ok [INFO] [stdout] test websocket_client::tests::test_user_command_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::test_user_command_with_claude_input_action ... ok [INFO] [stdout] test websocket_client::tests::test_user_command_with_codex_input_action ... ok [INFO] [stdout] test websocket_client::tests::test_user_command_with_shell_action ... ok [INFO] [stdout] test websocket_client::tests::token_request_serializes_with_project_id ... ok [INFO] [stdout] test websocket_client::tests::token_request_serializes_without_project_id ... ok [INFO] [stdout] test websocket_client::tests::test_mark_task_assignment_backward_compat ... ok [INFO] [stdout] test websocket_client::tests::video_toggle_false_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::video_toggle_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::visualize_request_deserialize ... ok [INFO] [stdout] test websocket_client::tests::visualize_request_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::visualize_request_wire_format ... ok [INFO] [stdout] test websocket_client::tests::visualize_request_special_characters ... ok [INFO] [stdout] test websocket_client::tests::visualize_request_without_relay_url ... ok [INFO] [stdout] test websocket_client::tests::visualize_result_failure_case ... ok [INFO] [stdout] test websocket_client::tests::visualize_result_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::visualize_result_serialize ... ok [INFO] [stdout] test websocket_client::tests::visualize_result_wire_format ... ok [INFO] [stdout] test websocket_client::tests::visualize_result_without_file_path ... ok [INFO] [stdout] test websocket_client::tests::voice_command_final_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::voice_command_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::voice_request_deserialize ... ok [INFO] [stdout] test websocket_client::tests::voice_request_empty_text ... ok [INFO] [stdout] test websocket_client::tests::voice_request_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::voice_request_special_characters ... ok [INFO] [stdout] test websocket_client::tests::voice_request_wire_format_field_names ... ok [INFO] [stdout] test websocket_client::tests::voice_response_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::voice_response_serialize ... ok [INFO] [stdout] test websocket_client::tests::voice_response_wire_format_field_names ... ok [INFO] [stdout] test websocket_client::tests::test_user_command_with_cli_input_action ... ok [INFO] [stdout] test websocket_client::tests::voice_toggle_false_roundtrip ... ok [INFO] [stdout] test websocket_client::tests::voice_response_success_true ... ok [INFO] [stdout] test websocket_client::tests::voice_toggle_roundtrip ... ok [INFO] [stdout] test token::tests::rtc_subscriber_has_one_privilege ... ok [INFO] [stdout] test websocket_client::tests::token_response_roundtrip ... ok [INFO] [stdout] test token::tests::rtc_publisher_has_four_privileges ... ok [INFO] [stdout] test claude_client::tests::session_with_echo_produces_output ... ok [INFO] [stdout] test codex_client::tests::session_with_echo_produces_output ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 582 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 5.40s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "5a2a5acbefccbed094ba2de66b9f00302c7b8bbb7bd9bf7a680deeb736194684", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5a2a5acbefccbed094ba2de66b9f00302c7b8bbb7bd9bf7a680deeb736194684", kill_on_drop: false }` [INFO] [stdout] 5a2a5acbefccbed094ba2de66b9f00302c7b8bbb7bd9bf7a680deeb736194684