[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] 2629b4a7778ba3a7a1574585411742a3b20ca086
[INFO] testing Agora-Build/Atem against try#33835004928d3bf65db4d4712e1330766263b0bd for pr-155739-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 33835004928d3bf65db4d4712e1330766263b0bd
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "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" "+33835004928d3bf65db4d4712e1330766263b0bd" "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" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 333abbbfc21f022c16fefd85779ac58a2d638144c7c08d047bedbdf6b3f20ca3
[INFO] running `Command { std: "docker" "start" "-a" "333abbbfc21f022c16fefd85779ac58a2d638144c7c08d047bedbdf6b3f20ca3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "333abbbfc21f022c16fefd85779ac58a2d638144c7c08d047bedbdf6b3f20ca3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "333abbbfc21f022c16fefd85779ac58a2d638144c7c08d047bedbdf6b3f20ca3", kill_on_drop: false }`
[INFO] [stdout] 333abbbfc21f022c16fefd85779ac58a2d638144c7c08d047bedbdf6b3f20ca3
[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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 9d1059ee8f7d400fc0ecc107bc16c52cd2f861637386d28cb0bb45dba8592405
[INFO] running `Command { std: "docker" "start" "-a" "9d1059ee8f7d400fc0ecc107bc16c52cd2f861637386d28cb0bb45dba8592405", 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 unicode-ident v1.0.18
[INFO] [stderr]    Compiling libc v0.2.175
[INFO] [stderr]    Compiling cfg-if v1.0.3
[INFO] [stderr]    Compiling shlex v1.3.0
[INFO] [stderr]    Compiling find-msvc-tools v0.1.9
[INFO] [stderr]    Compiling version_check v0.9.5
[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 once_cell v1.21.3
[INFO] [stderr]    Compiling vcpkg v0.2.15
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling stable_deref_trait v1.2.0
[INFO] [stderr]    Compiling pkg-config v0.3.32
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling scopeguard v1.2.0
[INFO] [stderr]    Compiling fnv v1.0.7
[INFO] [stderr]    Compiling subtle v2.6.1
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling itoa v1.0.15
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]    Compiling bytes v1.10.1
[INFO] [stderr]    Compiling pin-project-lite v0.2.16
[INFO] [stderr]    Compiling allocator-api2 v0.2.21
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling writeable v0.6.1
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling litemap v0.8.0
[INFO] [stderr]    Compiling equivalent v1.0.2
[INFO] [stderr]    Compiling lock_api v0.4.13
[INFO] [stderr]    Compiling icu_properties_data v2.0.1
[INFO] [stderr]    Compiling cpufeatures v0.2.17
[INFO] [stderr]    Compiling dunce v1.0.5
[INFO] [stderr]    Compiling fs_extra v1.3.0
[INFO] [stderr]    Compiling futures-core v0.3.31
[INFO] [stderr]    Compiling icu_normalizer_data v2.0.0
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling foreign-types-shared v0.1.1
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling foreign-types v0.3.2
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling utf8parse v0.2.2
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]    Compiling pin-utils v0.1.0
[INFO] [stderr]    Compiling percent-encoding v2.3.2
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling slab v0.4.11
[INFO] [stderr]    Compiling futures-task v0.3.31
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling rustix v1.0.8
[INFO] [stderr]    Compiling aws-lc-rs v1.16.0
[INFO] [stderr]    Compiling openssl-probe v0.1.6
[INFO] [stderr]    Compiling form_urlencoded v1.2.2
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]    Compiling rustls-pki-types v1.14.0
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling untrusted v0.9.0
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling heck v0.5.0
[INFO] [stderr]    Compiling ryu v1.0.20
[INFO] [stderr]    Compiling ident_case v1.0.1
[INFO] [stderr]    Compiling indexmap v2.11.1
[INFO] [stderr]    Compiling linux-raw-sys v0.9.4
[INFO] [stderr]    Compiling cfg_aliases v0.1.1
[INFO] [stderr]    Compiling cc v1.2.56
[INFO] [stderr]    Compiling utf8_iter v1.0.4
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling inout v0.1.4
[INFO] [stderr]    Compiling nix v0.28.0
[INFO] [stderr]    Compiling memchr v2.7.5
[INFO] [stderr]    Compiling try-lock v0.2.5
[INFO] [stderr]    Compiling unicode-width v0.1.14
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling cfg_aliases v0.2.1
[INFO] [stderr]    Compiling powerfmt v0.2.0
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling deranged v0.5.8
[INFO] [stderr]    Compiling http-body v0.4.6
[INFO] [stderr]    Compiling nix v0.30.1
[INFO] [stderr]    Compiling want v0.3.1
[INFO] [stderr]    Compiling anstyle-parse v0.2.7
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling cmake v0.1.57
[INFO] [stderr]    Compiling socket2 v0.6.0
[INFO] [stderr]    Compiling mio v0.8.11
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling parking_lot v0.12.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling universal-hash v0.5.1
[INFO] [stderr]    Compiling cipher v0.4.4
[INFO] [stderr]    Compiling colorchoice v1.0.4
[INFO] [stderr]    Compiling signal-hook-mio v0.2.4
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling rustls v0.23.36
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]    Compiling serde_json v1.0.143
[INFO] [stderr]    Compiling is_terminal_polyfill v1.70.1
[INFO] [stderr]    Compiling unicode-width v0.2.0
[INFO] [stderr]    Compiling base64 v0.22.1
[INFO] [stderr]    Compiling simd-adler32 v0.3.8
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling num-conv v0.2.0
[INFO] [stderr]    Compiling anstyle-query v1.1.4
[INFO] [stderr]    Compiling opaque-debug v0.3.1
[INFO] [stderr]    Compiling paste v1.0.15
[INFO] [stderr]    Compiling anstyle v1.0.11
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]    Compiling aws-lc-sys v0.37.1
[INFO] [stderr]    Compiling libsqlite3-sys v0.30.1
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling httpdate v1.0.3
[INFO] [stderr]    Compiling adler2 v2.0.1
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling time-core v0.1.8
[INFO] [stderr]    Compiling anyhow v1.0.99
[INFO] [stderr]    Compiling tower-service v0.3.3
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling anstream v0.6.20
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling polyval v0.6.2
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling vte_generate_state_changes v0.1.2
[INFO] [stderr]    Compiling nibble_vec v0.1.0
[INFO] [stderr]    Compiling shell-words v1.1.0
[INFO] [stderr]    Compiling time v0.3.47
[INFO] [stderr]    Compiling utf-8 v0.7.6
[INFO] [stderr]    Compiling data-encoding v2.9.0
[INFO] [stderr]    Compiling option-ext v0.2.0
[INFO] [stderr]    Compiling base64 v0.21.7
[INFO] [stderr]    Compiling endian-type v0.1.2
[INFO] [stderr]    Compiling pulldown-cmark v0.10.3
[INFO] [stderr]    Compiling indoc v2.0.6
[INFO] [stderr]    Compiling toml_write v0.1.2
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling static_assertions v1.1.0
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling clap_lex v0.7.5
[INFO] [stderr]    Compiling arrayvec v0.7.6
[INFO] [stderr]    Compiling tempfile v3.21.0
[INFO] [stderr]    Compiling compact_str v0.8.1
[INFO] [stderr]    Compiling vte v0.11.1
[INFO] [stderr]    Compiling clap_builder v4.5.47
[INFO] [stderr]    Compiling rustls-pemfile v1.0.4
[INFO] [stderr]    Compiling hashlink v0.9.1
[INFO] [stderr]    Compiling yasna v0.5.2
[INFO] [stderr]    Compiling unicode-truncate v1.1.0
[INFO] [stderr]    Compiling radix_trie v0.2.1
[INFO] [stderr]    Compiling dirs-sys v0.4.1
[INFO] [stderr]    Compiling crossterm v0.28.1
[INFO] [stderr]    Compiling fd-lock v4.0.4
[INFO] [stderr]    Compiling flate2 v1.1.9
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling ghash v0.5.1
[INFO] [stderr]    Compiling pem v3.0.6
[INFO] [stderr]    Compiling console v0.15.11
[INFO] [stderr]    Compiling atem v0.5.16 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling ctr v0.9.2
[INFO] [stderr]    Compiling aes v0.8.4
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling sha2 v0.10.9
[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 fallible-iterator v0.3.0
[INFO] [stderr]    Compiling mime v0.3.17
[INFO] [stderr]    Compiling downcast-rs v1.2.1
[INFO] [stderr]    Compiling sync_wrapper v0.1.2
[INFO] [stderr]    Compiling pulldown-cmark-escape v0.10.1
[INFO] [stderr]    Compiling cassowary v0.3.0
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling unicase v2.9.0
[INFO] [stderr]    Compiling fallible-streaming-iterator v0.1.9
[INFO] [stderr]    Compiling home v0.5.12
[INFO] [stderr]    Compiling md5 v0.7.0
[INFO] [stderr]    Compiling aes-gcm v0.10.3
[INFO] [stderr]    Compiling rustyline v14.0.0
[INFO] [stderr]    Compiling ctrlc v3.5.1
[INFO] [stderr]    Compiling agora_token v0.1.0 (https://github.com/AgoraIO/Tools.git#374cd21f)
[INFO] [stderr]    Compiling vt100 v0.15.2
[INFO] [stderr]    Compiling dirs v5.0.1
[INFO] [stderr]    Compiling crossterm v0.27.0
[INFO] [stderr]    Compiling uuid v1.18.1
[INFO] [stderr]    Compiling hostname v0.4.2
[INFO] [stderr]    Compiling rustls-pemfile v2.2.0
[INFO] [stderr]    Compiling glob v0.3.3
[INFO] [stderr]    Compiling urlencoding v2.1.3
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling clap_derive v4.5.47
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling rcgen v0.13.2
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.0
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling zerovec v0.11.4
[INFO] [stderr]    Compiling zerotrie v0.2.2
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling filedescriptor v0.8.3
[INFO] [stderr]    Compiling portable-pty v0.9.0
[INFO] [stderr]    Compiling dialoguer v0.11.0
[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 strum v0.26.3
[INFO] [stderr]    Compiling clap v4.5.47
[INFO] [stderr]    Compiling ratatui v0.29.0
[INFO] [stderr]    Compiling icu_collections v2.0.0
[INFO] [stderr]    Compiling icu_provider v2.0.0
[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 serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling rusqlite v0.32.1
[INFO] [stderr]    Compiling url v2.5.7
[INFO] [stderr]    Compiling tungstenite v0.20.1
[INFO] [stderr]    Compiling tokio-util v0.7.16
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling tokio-tungstenite v0.20.1
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling hyper-tls v0.5.0
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling rustls-webpki v0.103.9
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/webhook_server.rs:345:9
[INFO] [stdout]     |
[INFO] [stdout] 345 |     let mut cmd = std::process::Command::new("ngrok");
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pty_client`
[INFO] [stdout]     --> src/app.rs:1194:13
[INFO] [stdout]      |
[INFO] [stdout] 1194 |         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: unused variable: `cmd`
[INFO] [stdout]    --> src/webhook_server.rs:345:9
[INFO] [stdout]     |
[INFO] [stdout] 345 |     let mut cmd = std::process::Command::new("ngrok");
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cmd`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `do_cascaded` is never read
[INFO] [stdout]    --> src/convo_wizard.rs:469:27
[INFO] [stdout]     |
[INFO] [stdout] 469 |     let mut do_cascaded = false;
[INFO] [stdout]     |                           ^^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 486 |         do_cascaded = chosen == 0;
[INFO] [stdout]     |         ------------------------- `do_cascaded` is overwritten here before the previous value is read
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `do_mllm` is never read
[INFO] [stdout]    --> src/convo_wizard.rs:470:23
[INFO] [stdout]     |
[INFO] [stdout] 470 |     let mut do_mllm = false;
[INFO] [stdout]     |                       ^^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 487 |         do_mllm     = chosen == 1;
[INFO] [stdout]     |         ------------------------- `do_mllm` is overwritten here before the previous value is read
[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<RtmClient>,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 119 |     pub rtm_client_id: String,
[INFO] [stdout]     |         ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub rtm_token_expires_at: Option<Instant>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 148 |     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:177:9
[INFO] [stdout]     |
[INFO] [stdout] 175 | pub struct PendingVisualize {
[INFO] [stdout]     |            ---------------- field in this struct
[INFO] [stdout] 176 |     pub session_id: String,
[INFO] [stdout] 177 |     pub relay_url: Option<String>,
[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:812:18
[INFO] [stdout]      |
[INFO] [stdout]  195 | impl App {
[INFO] [stdout]      | -------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  812 |     pub async fn ensure_rtm_client(&mut self) -> Result<()> {
[INFO] [stdout]      |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  850 |     pub fn handle_rtm_event(&mut self, event: RtmEvent) {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1184 |     pub async fn launch_claude_pty_agent(&mut self) -> anyhow::Result<String> {
[INFO] [stdout]      |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1723 |     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:2554:8
[INFO] [stdout]      |
[INFO] [stdout] 2554 | 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<AuthSession> {
[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 `as_str` is never used
[INFO] [stdout]    --> src/convo_config.rs:701:12
[INFO] [stdout]     |
[INFO] [stdout] 700 | impl Pipeline {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] 701 |     pub fn as_str(self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NUMERIC_KEYS` is never used
[INFO] [stdout]    --> src/convo_wizard.rs:961:7
[INFO] [stdout]     |
[INFO] [stdout] 961 | const NUMERIC_KEYS: &[&str] = &[
[INFO] [stdout]     |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_param` is never used
[INFO] [stdout]    --> src/convo_wizard.rs:968:4
[INFO] [stdout]     |
[INFO] [stdout] 968 | fn write_param(t: &mut String, section: &str, key: &str, value: &str) {
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_toml` is never used
[INFO] [stdout]    --> src/convo_wizard.rs:994:4
[INFO] [stdout]     |
[INFO] [stdout] 994 | fn build_toml(a: &WizardAnswers) -> String {
[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<RtmEvent>,
[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<Mutex<RtmInner>>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 122 |     receiver: Mutex<UnboundedReceiver<RtmEvent>>,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 123 |     _state: *mut CallbackState,
[INFO] [stdout] 124 |     owned_strings: Vec<OwnedCString>,
[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<Self> {
[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<RtmEvent> {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     pub async fn drain_events(&self) -> Vec<RtmEvent> {
[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:580:18
[INFO] [stdout]     |
[INFO] [stdout] 276 | impl AstationClient {
[INFO] [stdout]     | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 580 |     pub async fn request_projects(&self) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub async fn request_token(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 598 |     pub async fn launch_claude(&self, context: Option<String>) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 603 |     pub async fn send_user_command(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 615 |     pub async fn send_status_update(&self, status: &str) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 627 |     pub async fn send_heartbeat(&self) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 638 |     pub fn is_connected(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 686 |     pub async fn send_codex_task(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 762 |     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<AgentEvent> {
[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<AgentInfo> {
[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<u8>,
[INFO] [stdout] 26 |     pub created_at: i64,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `name` is never used
[INFO] [stdout]    --> src/webhook_server.rs:168:8
[INFO] [stdout]     |
[INFO] [stdout] 157 | impl TunnelProvider {
[INFO] [stdout]     | ------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 168 |     fn name(self) -> &'static str {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 05s
[INFO] running `Command { std: "docker" "inspect" "9d1059ee8f7d400fc0ecc107bc16c52cd2f861637386d28cb0bb45dba8592405", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9d1059ee8f7d400fc0ecc107bc16c52cd2f861637386d28cb0bb45dba8592405", kill_on_drop: false }`
[INFO] [stdout] 9d1059ee8f7d400fc0ecc107bc16c52cd2f861637386d28cb0bb45dba8592405
[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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1e9aa6c34a42948c250ad070d54449c42867d306524a91f1b3ac325b8b4821fd
[INFO] running `Command { std: "docker" "start" "-a" "1e9aa6c34a42948c250ad070d54449c42867d306524a91f1b3ac325b8b4821fd", kill_on_drop: false }`
[INFO] [stderr] warning: unused manifest key: dependencies.agora_token.subdirectory
[INFO] [stderr]    Compiling atem v0.5.16 (/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: variable does not need to be mutable
[INFO] [stdout]    --> src/webhook_server.rs:345:9
[INFO] [stdout]     |
[INFO] [stdout] 345 |     let mut cmd = std::process::Command::new("ngrok");
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused 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:1194:13
[INFO] [stdout]      |
[INFO] [stdout] 1194 |         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: unused variable: `cmd`
[INFO] [stdout]    --> src/webhook_server.rs:345:9
[INFO] [stdout]     |
[INFO] [stdout] 345 |     let mut cmd = std::process::Command::new("ngrok");
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cmd`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `do_cascaded` is never read
[INFO] [stdout]    --> src/convo_wizard.rs:469:27
[INFO] [stdout]     |
[INFO] [stdout] 469 |     let mut do_cascaded = false;
[INFO] [stdout]     |                           ^^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 486 |         do_cascaded = chosen == 0;
[INFO] [stdout]     |         ------------------------- `do_cascaded` is overwritten here before the previous value is read
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `do_mllm` is never read
[INFO] [stdout]    --> src/convo_wizard.rs:470:23
[INFO] [stdout]     |
[INFO] [stdout] 470 |     let mut do_mllm = false;
[INFO] [stdout]     |                       ^^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 487 |         do_mllm     = chosen == 1;
[INFO] [stdout]     |         ------------------------- `do_mllm` is overwritten here before the previous value is read
[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] 
[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<RtmClient>,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 119 |     pub rtm_client_id: String,
[INFO] [stdout]     |         ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub rtm_token_expires_at: Option<Instant>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 148 |     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:812:18
[INFO] [stdout]      |
[INFO] [stdout]  195 | impl App {
[INFO] [stdout]      | -------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  812 |     pub async fn ensure_rtm_client(&mut self) -> Result<()> {
[INFO] [stdout]      |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  850 |     pub fn handle_rtm_event(&mut self, event: RtmEvent) {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1184 |     pub async fn launch_claude_pty_agent(&mut self) -> anyhow::Result<String> {
[INFO] [stdout]      |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1723 |     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:2554:8
[INFO] [stdout]      |
[INFO] [stdout] 2554 | 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<AuthSession> {
[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: method `as_str` is never used
[INFO] [stdout]    --> src/convo_config.rs:701:12
[INFO] [stdout]     |
[INFO] [stdout] 700 | impl Pipeline {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] 701 |     pub fn as_str(self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NUMERIC_KEYS` is never used
[INFO] [stdout]    --> src/convo_wizard.rs:961:7
[INFO] [stdout]     |
[INFO] [stdout] 961 | const NUMERIC_KEYS: &[&str] = &[
[INFO] [stdout]     |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_param` is never used
[INFO] [stdout]    --> src/convo_wizard.rs:968:4
[INFO] [stdout]     |
[INFO] [stdout] 968 | fn write_param(t: &mut String, section: &str, key: &str, value: &str) {
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_toml` is never used
[INFO] [stdout]    --> src/convo_wizard.rs:994:4
[INFO] [stdout]     |
[INFO] [stdout] 994 | fn build_toml(a: &WizardAnswers) -> String {
[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<RtmEvent>,
[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<Mutex<RtmInner>>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 122 |     receiver: Mutex<UnboundedReceiver<RtmEvent>>,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 123 |     _state: *mut CallbackState,
[INFO] [stdout] 124 |     owned_strings: Vec<OwnedCString>,
[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<Self> {
[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<RtmEvent> {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     pub async fn drain_events(&self) -> Vec<RtmEvent> {
[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:580:18
[INFO] [stdout]     |
[INFO] [stdout] 276 | impl AstationClient {
[INFO] [stdout]     | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 580 |     pub async fn request_projects(&self) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub async fn request_token(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 598 |     pub async fn launch_claude(&self, context: Option<String>) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 603 |     pub async fn send_user_command(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 615 |     pub async fn send_status_update(&self, status: &str) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 627 |     pub async fn send_heartbeat(&self) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 638 |     pub fn is_connected(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 686 |     pub async fn send_codex_task(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 762 |     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] [stdout] warning: method `name` is never used
[INFO] [stdout]    --> src/webhook_server.rs:168:8
[INFO] [stdout]     |
[INFO] [stdout] 157 | impl TunnelProvider {
[INFO] [stdout]     | ------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 168 |     fn name(self) -> &'static str {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 27.68s
[INFO] running `Command { std: "docker" "inspect" "1e9aa6c34a42948c250ad070d54449c42867d306524a91f1b3ac325b8b4821fd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1e9aa6c34a42948c250ad070d54449c42867d306524a91f1b3ac325b8b4821fd", kill_on_drop: false }`
[INFO] [stdout] 1e9aa6c34a42948c250ad070d54449c42867d306524a91f1b3ac325b8b4821fd
[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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 252f5da0791a3aaecc9e19306891a045529e3f8069bdc7de77744ee5b19bb637
[INFO] running `Command { std: "docker" "start" "-a" "252f5da0791a3aaecc9e19306891a045529e3f8069bdc7de77744ee5b19bb637", 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: variable does not need to be mutable
[INFO] [stderr]    --> src/webhook_server.rs:345:9
[INFO] [stderr]     |
[INFO] [stderr] 345 |     let mut cmd = std::process::Command::new("ngrok");
[INFO] [stderr]     |         ----^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused 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:1194:13
[INFO] [stderr]      |
[INFO] [stderr] 1194 |         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: unused variable: `cmd`
[INFO] [stderr]    --> src/webhook_server.rs:345:9
[INFO] [stderr]     |
[INFO] [stderr] 345 |     let mut cmd = std::process::Command::new("ngrok");
[INFO] [stderr]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cmd`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `do_cascaded` is never read
[INFO] [stderr]    --> src/convo_wizard.rs:469:27
[INFO] [stderr]     |
[INFO] [stderr] 469 |     let mut do_cascaded = false;
[INFO] [stderr]     |                           ^^^^^ this value is reassigned later and never used
[INFO] [stderr] ...
[INFO] [stderr] 486 |         do_cascaded = chosen == 0;
[INFO] [stderr]     |         ------------------------- `do_cascaded` is overwritten here before the previous value is read
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `do_mllm` is never read
[INFO] [stderr]    --> src/convo_wizard.rs:470:23
[INFO] [stderr]     |
[INFO] [stderr] 470 |     let mut do_mllm = false;
[INFO] [stderr]     |                       ^^^^^ this value is reassigned later and never used
[INFO] [stderr] ...
[INFO] [stderr] 487 |         do_mllm     = chosen == 1;
[INFO] [stderr]     |         ------------------------- `do_mllm` is overwritten here before the previous value is read
[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] 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<RtmClient>,
[INFO] [stderr]     |         ^^^^^^^^^^
[INFO] [stderr] 119 |     pub rtm_client_id: String,
[INFO] [stderr]     |         ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 123 |     pub rtm_token_expires_at: Option<Instant>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 148 |     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:812:18
[INFO] [stderr]      |
[INFO] [stderr]  195 | impl App {
[INFO] [stderr]      | -------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  812 |     pub async fn ensure_rtm_client(&mut self) -> Result<()> {
[INFO] [stderr]      |                  ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  850 |     pub fn handle_rtm_event(&mut self, event: RtmEvent) {
[INFO] [stderr]      |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1184 |     pub async fn launch_claude_pty_agent(&mut self) -> anyhow::Result<String> {
[INFO] [stderr]      |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1723 |     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:2554:8
[INFO] [stderr]      |
[INFO] [stderr] 2554 | 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<AuthSession> {
[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: method `as_str` is never used
[INFO] [stderr]    --> src/convo_config.rs:701:12
[INFO] [stderr]     |
[INFO] [stderr] 700 | impl Pipeline {
[INFO] [stderr]     | ------------- method in this implementation
[INFO] [stderr] 701 |     pub fn as_str(self) -> &'static str {
[INFO] [stderr]     |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NUMERIC_KEYS` is never used
[INFO] [stderr]    --> src/convo_wizard.rs:961:7
[INFO] [stderr]     |
[INFO] [stderr] 961 | const NUMERIC_KEYS: &[&str] = &[
[INFO] [stderr]     |       ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `write_param` is never used
[INFO] [stderr]    --> src/convo_wizard.rs:968:4
[INFO] [stderr]     |
[INFO] [stderr] 968 | fn write_param(t: &mut String, section: &str, key: &str, value: &str) {
[INFO] [stderr]     |    ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_toml` is never used
[INFO] [stderr]    --> src/convo_wizard.rs:994:4
[INFO] [stderr]     |
[INFO] [stderr] 994 | fn build_toml(a: &WizardAnswers) -> String {
[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<RtmEvent>,
[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<Mutex<RtmInner>>,
[INFO] [stderr]     |     ^^^^^
[INFO] [stderr] 122 |     receiver: Mutex<UnboundedReceiver<RtmEvent>>,
[INFO] [stderr]     |     ^^^^^^^^
[INFO] [stderr] 123 |     _state: *mut CallbackState,
[INFO] [stderr] 124 |     owned_strings: Vec<OwnedCString>,
[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<Self> {
[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<RtmEvent> {
[INFO] [stderr]     |                  ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 263 |     pub async fn drain_events(&self) -> Vec<RtmEvent> {
[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:580:18
[INFO] [stderr]     |
[INFO] [stderr] 276 | impl AstationClient {
[INFO] [stderr]     | ------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 580 |     pub async fn request_projects(&self) -> Result<()> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 584 |     pub async fn request_token(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 598 |     pub async fn launch_claude(&self, context: Option<String>) -> Result<()> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 603 |     pub async fn send_user_command(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 615 |     pub async fn send_status_update(&self, status: &str) -> Result<()> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 627 |     pub async fn send_heartbeat(&self) -> Result<()> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 638 |     pub fn is_connected(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 686 |     pub async fn send_codex_task(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 762 |     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: method `name` is never used
[INFO] [stderr]    --> src/webhook_server.rs:168:8
[INFO] [stderr]     |
[INFO] [stderr] 157 | impl TunnelProvider {
[INFO] [stderr]     | ------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 168 |     fn name(self) -> &'static str {
[INFO] [stderr]     |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `atem` (bin "atem" test) generated 50 warnings (run `cargo fix --bin "atem" -p atem --tests` to apply 5 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.70s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/atem-08a2e07760773f1b)
[INFO] [stdout] 
[INFO] [stdout] running 646 tests
[INFO] [stdout] test acp_client::tests::test_build_initialize_has_correct_method ... ok
[INFO] [stdout] test acp_client::tests::test_build_initialize_includes_protocol_version ... ok
[INFO] [stdout] test acp_client::tests::test_build_cancel ... ok
[INFO] [stdout] test acp_client::tests::test_client_session_id_none_initially ... ok
[INFO] [stdout] test acp_client::tests::test_client_is_connected_false_by_default ... ok
[INFO] [stdout] test acp_client::tests::test_client_try_recv_empty_channel ... 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_url ... ok
[INFO] [stdout] test acp_client::tests::test_client_try_recv_with_channel_events ... ok
[INFO] [stdout] test acp_client::tests::test_build_new_session ... ok
[INFO] [stdout] test acp_client::tests::test_drain_events_drains_pending_first ... ok
[INFO] [stdout] test acp_client::tests::test_parse_initialize_claude_code ... ok
[INFO] [stdout] test acp_client::tests::test_parse_initialize_missing_server_info ... ok
[INFO] [stdout] test acp_client::tests::test_drain_events_skips_ack_responses ... ok
[INFO] [stdout] test acp_client::tests::test_parse_invalid_json_errors ... ok
[INFO] [stdout] test acp_client::tests::test_parse_initialize_no_result ... ok
[INFO] [stdout] test acp_client::tests::test_build_prompt ... ok
[INFO] [stdout] test acp_client::tests::test_client_next_request_id_increments ... ok
[INFO] [stdout] test acp_client::tests::test_parse_initialize_unknown_agent ... ok
[INFO] [stdout] test acp_client::tests::test_parse_new_session_missing_field ... ok
[INFO] [stdout] test acp_client::tests::test_send_prompt_increments_id ... 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_drain_events_returns_all ... ok
[INFO] [stdout] test acp_client::tests::test_send_prompt_sends_correct_method ... 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_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_send_raw_sends_to_channel ... ok
[INFO] [stdout] test acp_client::tests::test_request_serializes_to_valid_json ... ok
[INFO] [stdout] test acp_client::tests::test_parse_unknown_notification_returns_none ... ok
[INFO] [stdout] test acp_client::tests::test_parse_initialize_codex ... ok
[INFO] [stdout] test agent_detector::tests::test_claude_lockfile_patterns_non_empty ... ok
[INFO] [stdout] test agent_detector::tests::test_claude_patterns_contain_lock_extension ... 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_detector::tests::test_codex_lockfile_patterns_non_empty ... ok
[INFO] [stdout] test agent_detector::tests::test_codex_patterns_contain_lock_extension ... 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_parse_lockfile_nonexistent_file_returns_none ... 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 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_scan_default_ports_no_duplicates ... ok
[INFO] [stdout] test agent_client::tests::test_pty_send_prompt_appends_newline ... ok
[INFO] [stdout] test agent_detector::tests::test_scan_default_ports_detects_no_agents_when_none_running ... 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_add_session_deduplicates ... ok
[INFO] [stdout] test agent_registry::tests::test_all_empty ... ok
[INFO] [stdout] test agent_registry::tests::test_clone_shares_inner_state ... ok
[INFO] [stdout] test agent_registry::tests::test_connected_excludes_disconnected ... ok
[INFO] [stdout] test agent_detector::tests::test_scan_lockfiles_returns_vec ... ok
[INFO] [stdout] test agent_registry::tests::test_len_and_is_empty ... ok
[INFO] [stdout] test agent_registry::tests::test_connected_includes_all_non_disconnected_states ... ok
[INFO] [stdout] test agent_registry::tests::test_register_returns_id ... ok
[INFO] [stdout] test agent_registry::tests::test_has_acp_url_false ... ok
[INFO] [stdout] test agent_registry::tests::test_all_returns_every_agent ... ok
[INFO] [stdout] test agent_registry::tests::test_has_acp_url_true ... 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_has_acp_url_empty_registry ... ok
[INFO] [stdout] test agent_registry::tests::test_register_replaces_existing ... ok
[INFO] [stdout] test agent_registry::tests::test_get_nonexistent_returns_none ... ok
[INFO] [stdout] test acp_client::tests::test_send_raw_reaches_server ... ok
[INFO] [stdout] test agent_registry::tests::test_update_status_nonexistent_is_noop ... ok
[INFO] [stdout] test agent_registry::tests::test_remove_existing ... ok
[INFO] [stdout] test agent_registry::tests::test_remove_session ... ok
[INFO] [stdout] test agent_registry::tests::test_remove_nonexistent_is_noop ... ok
[INFO] [stdout] test agent_registry::tests::test_register_and_get ... ok
[INFO] [stdout] test agent_registry::tests::test_by_protocol_pty ... ok
[INFO] [stdout] test agent_registry::tests::test_update_status ... 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_registry::tests::test_concurrent_registrations ... 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_prompt_with_special_characters ... ok
[INFO] [stdout] test agent_visualize::tests::test_detect_new_files_empty_when_unchanged ... ok
[INFO] [stdout] test agent_visualize::tests::test_resolve_agent_url_preserves_explicit_url_verbatim ... ok
[INFO] [stdout] test agent_visualize::tests::test_resolve_agent_url_explicit ... ok
[INFO] [stdout] test agent_visualize::tests::test_resolve_diagram_server_url_explicit_beats_relay ... ok
[INFO] [stdout] test agent_visualize::tests::test_resolve_diagram_server_url_explicit_config ... ok
[INFO] [stdout] test agent_visualize::tests::test_detect_returns_full_paths ... ok
[INFO] [stdout] test agent_visualize::tests::test_detect_ignores_deleted_files ... ok
[INFO] [stdout] test agora_api::tests::format_projects_empty_list ... ok
[INFO] [stdout] test agora_api::tests::format_projects_hides_certs_by_default ... ok
[INFO] [stdout] test agent_visualize::tests::test_resolve_agent_url_none_falls_through ... ok
[INFO] [stdout] test agent_visualize::tests::test_detect_new_files_finds_new_file ... ok
[INFO] [stdout] test agent_visualize::tests::test_detect_with_empty_pre_snapshot ... ok
[INFO] [stdout] test agora_api::tests::format_projects_shows_certs_when_requested ... ok
[INFO] [stdout] test agent_visualize::tests::test_snapshot_ignores_non_html_files ... ok
[INFO] [stdout] test agora_api::tests::format_projects_shows_none_for_missing_cert ... ok
[INFO] [stdout] test agora_api::tests::format_unix_timestamp_known_date ... ok
[INFO] [stdout] test agora_api::tests::format_unix_timestamp_leap_year ... ok
[INFO] [stdout] test ai_client::tests::parse_intent_with_markdown_fences ... ok
[INFO] [stdout] test ai_client::tests::parse_empty_command_intent ... ok
[INFO] [stdout] test ai_client::tests::parse_invalid_json_fails ... ok
[INFO] [stdout] test ai_client::tests::parse_valid_intent ... ok
[INFO] [stdout] test agora_api::tests::format_unix_timestamp_epoch ... ok
[INFO] [stdout] test agent_detector::tests::test_probe_unreachable_on_closed_port ... ok
[INFO] [stdout] test agora_api::tests::format_projects_shows_status_and_created ... ok
[INFO] [stdout] test app::tests::test_active_cli_equality ... ok
[INFO] [stdout] test agent_visualize::tests::test_resolve_diagram_server_url_relay ... ok
[INFO] [stdout] test app::tests::test_pending_visualize_clone_preserves_snapshot ... ok
[INFO] [stdout] test app::tests::test_pending_visualize_clone ... ok
[INFO] [stdout] test ai_client::tests::client_requires_api_key ... ok
[INFO] [stdout] test agent_visualize::tests::test_snapshot_creates_directory ... ok
[INFO] [stdout] test app::tests::test_pending_visualize_tracks_fields ... 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_visualize_detected_file_overrides_snapshot ... ok
[INFO] [stdout] test app::tests::test_pending_visualize_with_pre_snapshot ... ok
[INFO] [stdout] test app::tests::test_menu_rebuild_clamps_selected_index ... ok
[INFO] [stdout] test app::tests::test_pending_voice_request_tracks_fields ... ok
[INFO] [stdout] test app::tests::test_menu_connected_shows_all_items ... ok
[INFO] [stdout] test app::tests::test_active_cli_default_is_claude ... ok
[INFO] [stdout] test auth::tests::hostname_returns_non_empty ... ok
[INFO] [stdout] test auth::tests::auth_session_serialization_roundtrip ... ok
[INFO] [stdout] test auth::tests::deep_link_format ... ok
[INFO] [stdout] test app::tests::test_menu_disconnected_hides_agent_items ... ok
[INFO] [stdout] test app::tests::test_pending_voice_request_default_is_none ... ok
[INFO] [stdout] test auth::tests::multiple_sessions_independent ... ok
[INFO] [stdout] test auth::tests::otp_is_8_digits ... ok
[INFO] [stdout] test app::tests::test_pairing_code_default_is_none ... ok
[INFO] [stdout] test auth::tests::session_manager_cleanup_expired ... ok
[INFO] [stdout] test auth::tests::session_manager_get_expired_session_returns_none ... ok
[INFO] [stdout] test auth::tests::session_manager_get_mut_allows_refresh ... 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_manager_multiple_astations ... ok
[INFO] [stdout] test auth::tests::otp_is_random ... ok
[INFO] [stdout] test auth::tests::session_expires_after_7_days ... ok
[INFO] [stdout] test auth::tests::session_age_calculation ... ok
[INFO] [stdout] test auth::tests::session_refresh_extends_validity ... ok
[INFO] [stdout] test auth::tests::session_save_and_load_preserves_activity ... ok
[INFO] [stdout] test auth::tests::session_valid_just_before_expiry ... ok
[INFO] [stdout] test auth::tests::session_is_valid_when_fresh ... ok
[INFO] [stdout] test auth::tests::web_fallback_url_strips_trailing_slash ... ok
[INFO] [stdout] test app::tests::test_pinned_cli_default_is_none ... 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_manager_starts_empty ... ok
[INFO] [stdout] test auth::tests::session_refresh_prevents_expiry ... ok
[INFO] [stdout] test auth::tests::web_fallback_url_format ... ok
[INFO] [stdout] test auth::tests::session_manager_save_and_load ... ok
[INFO] [stdout] test auth::tests::session_manager_same_atem_different_endpoints ... ok
[INFO] [stdout] test cli::tests::cli_agent_connect_custom_timeout ... ok
[INFO] [stdout] test claude_client::tests::session_with_cat_receives_sent_input ... ok
[INFO] [stdout] test app::tests::test_pending_visualize_default_is_none ... ok
[INFO] [stdout] test cli::tests::cli_agent_list_parses ... ok
[INFO] [stdout] test cli::tests::cli_agent_connect_parses ... ok
[INFO] [stdout] test cli::tests::cli_agent_visualize_all_flags ... ok
[INFO] [stdout] test cli::tests::cli_agent_probe_custom_timeout ... ok
[INFO] [stdout] test cli::tests::cli_agent_prompt_parses ... ok
[INFO] [stdout] test cli::tests::cli_agent_probe_parses ... ok
[INFO] [stdout] test cli::tests::cli_agent_visualize_custom_timeout ... ok
[INFO] [stdout] test cli::tests::cli_agent_visualize_no_browser_flag ... ok
[INFO] [stdout] test cli::tests::cli_agent_visualize_topic_with_spaces ... ok
[INFO] [stdout] test claude_client::tests::nonexistent_binary_fails ... ok
[INFO] [stdout] test claude_client::tests::resize_handle_works ... ok
[INFO] [stdout] test agent_visualize::tests::test_detect_new_files_sorted_newest_first ... ok
[INFO] [stdout] test cli::tests::cli_agent_visualize_parses ... ok
[INFO] [stdout] test cli::tests::cli_agent_visualize_with_url ... ok
[INFO] [stdout] test agent_visualize::tests::test_snapshot_is_idempotent ... ok
[INFO] [stdout] test cli::tests::cli_agent_visualize_missing_topic_fails ... ok
[INFO] [stdout] test cli::tests::cli_config_clear_parses ... ok
[INFO] [stdout] test cli::tests::cli_list_project_parses ... ok
[INFO] [stdout] test cli::tests::cli_login_parses ... ok
[INFO] [stdout] test agent_visualize::tests::test_detect_finds_modified_file ... ok
[INFO] [stdout] test cli::tests::cli_login_and_logout_still_parse ... ok
[INFO] [stdout] test cli::tests::cli_config_set_astation_relay_url ... ok
[INFO] [stdout] test cli::tests::cli_list_project_with_show_certificates ... ok
[INFO] [stdout] test claude_client::tests::session_reports_exit_on_process_end ... ok
[INFO] [stdout] test cli::tests::cli_project_show_with_certificate ... ok
[INFO] [stdout] test cli::tests::cli_pair_with_save_flag ... ok
[INFO] [stdout] test cli::tests::cli_config_show_parses ... ok
[INFO] [stdout] test cli::tests::cli_pair_without_save ... ok
[INFO] [stdout] test acp_client::tests::test_connect_and_recv_event_via_mock_server ... ok
[INFO] [stdout] test cli::tests::cli_project_use_with_index ... ok
[INFO] [stdout] test cli::tests::cli_project_use_parses ... ok
[INFO] [stdout] test cli::tests::cli_no_args_returns_none_command ... ok
[INFO] [stdout] test cli::tests::cli_project_show_parses ... ok
[INFO] [stdout] test cli::tests::cli_project_use_with_app_id ... ok
[INFO] [stdout] test cli::tests::cli_config_set_astation_ws ... ok
[INFO] [stdout] test cli::tests::cli_repl_parses ... ok
[INFO] [stdout] test cli::tests::cli_serv_killall_parses ... ok
[INFO] [stdout] test cli::tests::cli_serv_convo_parses_with_no_flags ... ok
[INFO] [stdout] test cli::tests::cli_serv_diagrams_with_port ... ok
[INFO] [stdout] test cli::tests::cli_serv_rtc_with_options ... 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_token_rtc_create_defaults ... ok
[INFO] [stdout] test cli::tests::cli_serv_convo_parses_all_flags ... ok
[INFO] [stdout] test cli::tests::cli_serv_diagrams_defaults ... ok
[INFO] [stdout] test cli::tests::cli_logout_parses ... ok
[INFO] [stdout] test cli::tests::cli_serv_kill_parses ... ok
[INFO] [stdout] test cli::tests::cli_token_rtc_create_rejects_old_uid_flag ... ok
[INFO] [stdout] test cli::tests::cli_serv_diagrams_background_flag ... 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 cli::tests::cli_serv_rtc_defaults ... ok
[INFO] [stdout] test cli::tests::cli_token_rtc_create_with_rtm_flag ... ok
[INFO] [stdout] test cli::tests::cli_unpair ... ok
[INFO] [stdout] test cli::tests::cli_token_rtm_create_defaults ... ok
[INFO] [stdout] test cli::tests::cli_token_rtm_create_rejects_old_user_id_flag ... ok
[INFO] [stdout] test cli::tests::cli_token_rtm_create_accepts_rtm_user_id ... ok
[INFO] [stdout] test codex_client::tests::nonexistent_binary_fails ... ok
[INFO] [stdout] test command::tests::stream_buffer_clear ... ok
[INFO] [stdout] test cli::tests::cli_token_rtc_create_with_separate_rtm_user ... ok
[INFO] [stdout] test command::tests::stream_buffer_no_match ... ok
[INFO] [stdout] test command::tests::stream_buffer_empty ... 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::stream_buffer_push_and_take ... ok
[INFO] [stdout] test command::tests::stream_buffer_take_trims ... ok
[INFO] [stdout] test command::tests::task_queue_empty ... ok
[INFO] [stdout] test command::tests::task_queue_complete_active ... ok
[INFO] [stdout] test command::tests::task_queue_enqueue ... ok
[INFO] [stdout] test command::tests::task_queue_complete_empty ... ok
[INFO] [stdout] test command::tests::task_queue_fifo_order ... ok
[INFO] [stdout] test config::tests::default_config_has_none_fields ... ok
[INFO] [stdout] test config::tests::config_defaults ... ok
[INFO] [stdout] test command::tests::task_queue_start_next ... 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 config::tests::display_masked_shows_sso_section ... ok
[INFO] [stdout] test cli::tests::cli_token_rtc_decode_parses ... ok
[INFO] [stdout] test codex_client::tests::session_reports_exit_on_process_end ... ok
[INFO] [stdout] test config::tests::cleanup_legacy_files_removes_both ... ok
[INFO] [stdout] test config::tests::effective_bff_url_custom ... ok
[INFO] [stdout] test codex_client::tests::session_with_cat_receives_sent_input ... ok
[INFO] [stdout] test config::tests::effective_bff_url_default ... 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::effective_sso_url_custom ... ok
[INFO] [stdout] test config::tests::load_returns_default_on_missing_file ... 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::project_cache_file_is_encrypted_not_plaintext ... ok
[INFO] [stdout] test config::tests::load_returns_default_on_corrupt_file ... ok
[INFO] [stdout] test config::tests::project_cache_round_trip_via_temp_path ... ok
[INFO] [stdout] test config::tests::get_by_index_returns_projects_in_order ... 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 codex_client::tests::resize_handle_works ... ok
[INFO] [stdout] test convo_config::tests::avatar_has_preset_token_detects_user_supplied_value ... ok
[INFO] [stdout] test convo_config::tests::avatar_user_supplied_token_not_overridden_by_caller ... ok
[INFO] [stdout] test convo_config::tests::avatar_mint_credentials_none_without_both ... ok
[INFO] [stdout] test config::tests::save_preserves_active_if_still_present ... ok
[INFO] [stdout] test convo_config::tests::avatar_mint_credentials_reads_appid_and_cert ... ok
[INFO] [stdout] test convo_config::tests::join_payload_avatar_absent_when_checkbox_unchecked ... ok
[INFO] [stdout] test config::tests::save_clears_active_if_project_removed ... ok
[INFO] [stdout] test config::tests::test_astation_relay_url_custom ... ok
[INFO] [stdout] test convo_config::tests::join_payload_avatar_block_overrides_preset_when_fields_present ... ok
[INFO] [stdout] test convo_config::tests::cascaded_pipeline_does_not_emit_mllm_block ... ok
[INFO] [stdout] test convo_config::tests::build_join_payload_maps_toml_to_agora_shape ... ok
[INFO] [stdout] test convo_config::tests::join_payload_emits_geofence_when_area_set ... 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_strips_cert_and_injects_channel_token ... ok
[INFO] [stdout] test convo_config::tests::join_payload_avatar_params_agora_uid_override_wins ... ok
[INFO] [stdout] test convo_config::tests::join_payload_emits_preset_from_agent_section_when_no_runtime ... ok
[INFO] [stdout] test convo_config::tests::join_payload_emits_mcp_servers_under_llm_and_auto_enables_tools ... ok
[INFO] [stdout] test convo_config::tests::join_payload_emits_rtc_encryption_when_key_set ... ok
[INFO] [stdout] test config::tests::set_active_and_get_active_round_trip ... 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_injects_enable_dump_into_parameters ... ok
[INFO] [stdout] test convo_config::tests::join_payload_merges_enable_dump_with_existing_parameters ... ok
[INFO] [stdout] test convo_config::tests::join_payload_omits_geofence_for_global_or_none ... ok
[INFO] [stdout] test convo_config::tests::join_payload_omits_rtc_encryption_when_key_empty ... ok
[INFO] [stdout] test convo_config::tests::join_payload_runtime_preset_overrides_config ... ok
[INFO] [stdout] test convo_config::tests::mcp_auto_enable_tools_does_not_clobber_explicit_value ... ok
[INFO] [stdout] test convo_config::tests::mcp_servers_not_emitted_in_mllm_mode ... ok
[INFO] [stdout] test convo_config::tests::parses_atem_encryption_subtable ... ok
[INFO] [stdout] test convo_config::tests::join_payload_passes_through_top_level_tables ... ok
[INFO] [stdout] test convo_config::tests::mllm_pipeline_emits_only_mllm_block ... ok
[INFO] [stdout] test convo_config::tests::preset_list_empty_when_neither_set ... ok
[INFO] [stdout] test convo_config::tests::preset_list_splits_comma_separated_string ... ok
[INFO] [stdout] test convo_config::tests::parses_atem_section_hipaa_and_geofence ... ok
[INFO] [stdout] test convo_config::tests::resolve_defaults_rtc_user_id_to_0 ... ok
[INFO] [stdout] test convo_config::tests::preset_list_returns_single_when_no_comma ... ok
[INFO] [stdout] test convo_config::tests::nested_params_preserve_tables ... ok
[INFO] [stdout] test convo_config::tests::resolve_defaults_when_atem_section_missing ... ok
[INFO] [stdout] test convo_config::tests::parses_full_fixture ... ok
[INFO] [stdout] test convo_config::tests::resolve_propagates_atem_section_into_resolved ... ok
[INFO] [stdout] test convo_config::tests::resolve_honors_poll_interval_secs_with_floor ... ok
[INFO] [stdout] test convo_config::tests::resolve_errors_when_channel_missing ... ok
[INFO] [stdout] test convo_config::tests::resolve_uses_cli_over_toml ... ok
[INFO] [stdout] test convo_test_server::tests::convoai_base_url_defaults_to_agora ... ok
[INFO] [stdout] test convo_config::tests::user_id_fields_accept_bare_int_in_toml ... ok
[INFO] [stdout] test convo_config::tests::resolve_errors_when_agent_user_id_missing ... ok
[INFO] [stdout] test convo_config::tests::user_id_fields_accept_quoted_string_in_toml ... ok
[INFO] [stdout] test convo_test_server::tests::convoai_url_hipaa_uses_hipaa_prefix ... 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::convoai_url_default_uses_api_prefix ... ok
[INFO] [stdout] test convo_config::tests::resolve_avatar_configured_false_when_section_absent ... ok
[INFO] [stdout] test convo_test_server::tests::mask_secrets_replaces_sensitive_keys_keeps_others ... 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_test_server::tests::source_contains_api_token_route ... ok
[INFO] [stdout] test convo_test_server::tests::html_attach_mode_flag_propagates ... ok
[INFO] [stdout] test convo_test_server::tests::html_emits_toml_default_constants ... ok
[INFO] [stdout] test convo_test_server::tests::html_has_expected_ids_and_scripts ... ok
[INFO] [stdout] test convo_wizard::validate_tests::apply_to_doc_preserves_unrelated_sections_and_comments ... ok
[INFO] [stdout] test convo_wizard::validate_tests::validate_picks_pipeline_when_explicit ... ok
[INFO] [stdout] test convo_wizard::validate_tests::validate_rejects_encryption_mode_without_key ... ok
[INFO] [stdout] test convo_wizard::validate_tests::validate_accepts_well_formed_config ... ok
[INFO] [stdout] test convo_wizard::validate_tests::validate_accepts_mllm_alone ... ok
[INFO] [stdout] test convo_wizard::validate_tests::backup_rotation_keeps_at_most_max_generations ... ok
[INFO] [stdout] test convo_wizard::validate_tests::validate_rejects_unknown_geofence ... ok
[INFO] [stdout] test credentials::tests::atem_falls_back_to_own_sso_when_paired_astation_different ... ok
[INFO] [stdout] test convo_wizard::validate_tests::validate_rejects_gcm2_mode_without_salt ... ok
[INFO] [stdout] test credentials::tests::corrupted_file_returns_empty_store ... ok
[INFO] [stdout] test credentials::tests::disconnect_sets_timestamp_and_grace_applies ... ok
[INFO] [stdout] test convo_wizard::validate_tests::validate_requires_explicit_pipeline_when_both_present ... ok
[INFO] [stdout] test credentials::tests::disconnect_then_reconnect_within_grace_period ... 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::remove_sso_leaves_paired ... ok
[INFO] [stdout] test credentials::tests::paired_entry_round_trip ... ok
[INFO] [stdout] test credentials::tests::remove_paired_leaves_others_intact ... ok
[INFO] [stdout] test credentials::tests::resolve_errors_when_empty ... ok
[INFO] [stdout] test credentials::tests::multiple_astations_paired_simultaneously ... ok
[INFO] [stdout] test credentials::tests::load_returns_empty_when_file_missing ... ok
[INFO] [stdout] test credentials::tests::empty_store_saves_and_loads_cleanly ... ok
[INFO] [stdout] test credentials::tests::file_permissions_are_0600_on_unix ... ok
[INFO] [stdout] test credentials::tests::resolve_falls_back_to_sso_when_not_connected ... 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::sso_entry_round_trip ... ok
[INFO] [stdout] test credentials::tests::upsert_replaces_by_source_and_astation_id ... ok
[INFO] [stdout] test credentials::tests::sso_source_always_has_save_credentials_true ... ok
[INFO] [stdout] test credentials::tests::paired_source_respects_save_credentials_flag ... ok
[INFO] [stdout] test credentials::tests::resolve_errors_when_non_saved_paired_grace_expired ... ok
[INFO] [stdout] test credentials::tests::save_and_load_round_trip_encrypted ... ok
[INFO] [stdout] test diagram_server::tests::test_chrono_lite ... ok
[INFO] [stdout] test diagram_server::tests::test_db_path_under_config ... ok
[INFO] [stdout] test diagram_server::tests::test_chrono_lite_boundary_values ... ok
[INFO] [stdout] test diagram_server::tests::test_build_server_entry_fields ... ok
[INFO] [stdout] test credentials::tests::resolve_non_saved_paired_within_grace_period ... ok
[INFO] [stdout] test diagram_server::tests::test_build_server_entry_serializes ... ok
[INFO] [stdout] test credentials::tests::user_logs_in_then_pairs_with_astation ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_delete_missing ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_get_missing ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_empty_topic ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_list_contains_metadata ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_delete ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_delete_removes_from_list ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_list_empty ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_insert_multiple_same_topic ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_empty_html ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_list ... ok
[INFO] [stdout] test diagram_server::tests::test_extract_body_empty ... ok
[INFO] [stdout] test diagram_server::tests::test_extract_body ... ok
[INFO] [stdout] test diagram_server::tests::test_extract_body_empty_body ... 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_html_escape ... ok
[INFO] [stdout] test diagram_server::tests::test_generate_id_uniqueness ... ok
[INFO] [stdout] test diagram_server::tests::test_html_escape_clean_string ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_large_html ... ok
[INFO] [stdout] test diagram_server::tests::test_html_escape_empty ... ok
[INFO] [stdout] test auth::tests::poll_session_status_returns_error_on_404 ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_list_newest_first ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_special_chars_topic ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_round_trip ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_reopen_persists ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_unicode_topic ... ok
[INFO] [stdout] test auth::tests::poll_session_status_returns_error_on_denied ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_list_limit ... ok
[INFO] [stdout] test diagram_server::tests::test_http_cors_headers_on_response ... ok
[INFO] [stdout] test diagram_server::tests::test_http_404_unknown_route ... 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 diagram_server::tests::test_http_get_landing_page ... ok
[INFO] [stdout] test diagram_server::tests::test_http_get_diagram_not_found ... ok
[INFO] [stdout] test diagram_server::tests::test_http_list_diagrams_empty ... ok
[INFO] [stdout] test diagram_server::tests::test_http_options_cors_preflight ... ok
[INFO] [stdout] test diagram_server::tests::test_server_id_format ... ok
[INFO] [stdout] test dispatch::tests::background_result_roundtrip ... 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 dispatch::tests::parse_triage_response_missing_target ... 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 diagram_server::tests::test_http_delete_diagram ... ok
[INFO] [stdout] test files_server::tests::render_markdown_wraps_in_html_with_raw_link ... ok
[INFO] [stdout] test files_server::tests::resolve_path_accepts_files_under_root ... ok
[INFO] [stdout] test files_server::tests::resolve_path_decodes_percent_encoding ... ok
[INFO] [stdout] test files_server::tests::resolve_path_rejects_traversal ... ok
[INFO] [stdout] test files_server::tests::serve_file_md_raw_returns_text ... ok
[INFO] [stdout] test files_server::tests::serve_file_md_renders_to_html_by_default ... ok
[INFO] [stdout] test files_server::tests::serve_file_picks_content_type_by_extension ... ok
[INFO] [stdout] test files_server::tests::single_file_path_resolves_to_parent_with_target ... ok
[INFO] [stdout] test diagram_server::tests::test_http_post_and_get_diagram ... ok
[INFO] [stdout] test repl::tests::command_to_args_strips_prefix ... ok
[INFO] [stdout] test diagram_server::tests::test_diagram_store_binary_html ... ok
[INFO] [stdout] test repl::tests::command_to_args_without_prefix ... ok
[INFO] [stdout] test files_server::tests::single_file_with_spaces_url_encoded ... ok
[INFO] [stdout] test files_server::tests::render_directory_skips_dotfiles ... ok
[INFO] [stdout] test diagram_server::tests::test_landing_page_with_diagrams ... ok
[INFO] [stdout] test diagram_server::tests::test_http_post_defaults_topic ... ok
[INFO] [stdout] test repl::tests::exact_match_case_insensitive ... ok
[INFO] [stdout] test repl::tests::exact_match_project_use ... ok
[INFO] [stdout] test repl::tests::exact_match_config_show ... ok
[INFO] [stdout] test repl::tests::exact_match_token_rtc_create_with_args ... ok
[INFO] [stdout] test repl::tests::exact_match_list_project ... ok
[INFO] [stdout] test repl::tests::exact_match_with_flags ... ok
[INFO] [stdout] test repl::tests::no_match_for_unknown ... ok
[INFO] [stdout] test rtc_test_server::tests::html_page_contains_app_id_and_channel ... ok
[INFO] [stdout] test repl::tests::shell_split_simple ... ok
[INFO] [stdout] test repl::tests::shell_split_quoted ... ok
[INFO] [stdout] test repl::tests::exact_match_with_atem_prefix ... ok
[INFO] [stdout] test rtc_test_server::tests::resolve_id_or_index_rejects_invalid_index ... ok
[INFO] [stdout] test rtc_test_server::tests::server_entry_round_trip_with_status_field ... ok
[INFO] [stdout] test rtc_test_server::tests::server_id_format ... ok
[INFO] [stdout] test rtc_test_server::tests::servers_dir_under_config ... ok
[INFO] [stdout] test rtc_test_server::tests::html_page_has_rtm_section_when_enabled ... ok
[INFO] [stdout] test sso_auth::tests::generate_pkce_produces_unique_pairs ... 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_missing_params ... ok
[INFO] [stdout] test sso_auth::tests::parse_callback_query_handles_extra_params ... ok
[INFO] [stdout] test rtc_test_server::tests::html_page_has_no_rtm_section_when_disabled ... ok
[INFO] [stdout] test rtc_test_server::tests::resolve_id_or_index_passes_through_literal_id ... ok
[INFO] [stdout] test sso_auth::tests::pkce_challenge_is_base64url_of_sha256_verifier ... ok
[INFO] [stdout] test sso_auth::tests::parse_callback_query_url_decodes_values ... ok
[INFO] [stdout] test time_sync::tests::parse_http_date_valid ... ok
[INFO] [stdout] test time_sync::tests::time_sync_new_has_zero_offset ... ok
[INFO] [stdout] test token::tests::build_and_decode_with_real_credentials ... ok
[INFO] [stdout] test time_sync::tests::days_from_civil_known_date ... ok
[INFO] [stdout] test token::tests::build_token_rtc_int_uid_empty_cert_returns_empty ... ok
[INFO] [stdout] test time_sync::tests::parse_http_date_invalid ... 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_epoch ... ok
[INFO] [stdout] test token::tests::decode_invalid_token_fails ... ok
[INFO] [stdout] test diagram_server::tests::test_landing_page_escapes_xss_topic ... ok
[INFO] [stdout] test token::tests::channel_with_allowed_punctuation_survives_round_trip ... ok
[INFO] [stdout] test token::tests::decoded_rtc_token_surfaces_channel_and_user ... ok
[INFO] [stdout] test token::tests::decode_handles_unpadded_base64 ... ok
[INFO] [stdout] test token::tests::decoded_combined_token_surfaces_both_users_and_channel ... ok
[INFO] [stdout] test token::tests::decoded_rtm_token_surfaces_user ... ok
[INFO] [stdout] test token::tests::display_flags_not_yet_valid_token ... ok
[INFO] [stdout] test token::tests::decoded_service_fields_are_preserved ... ok
[INFO] [stdout] test token::tests::display_flags_expired_token ... ok
[INFO] [stdout] test token::tests::empty_certificate_returns_empty_rtm_token ... ok
[INFO] [stdout] test token::tests::format_relative_duration_always_ends_in_seconds ... ok
[INFO] [stdout] test token::tests::legacy_empty_certificate_returns_empty_token ... ok
[INFO] [stdout] test token::tests::privilege_values_are_relative_seconds ... ok
[INFO] [stdout] test token::tests::legacy_token_starts_with_prefix ... ok
[INFO] [stdout] test token::tests::long_string_account_255_chars_round_trips ... ok
[INFO] [stdout] test token::tests::publisher_has_more_privileges_than_subscriber ... ok
[INFO] [stdout] test token::tests::empty_certificate_returns_empty_rtc_token ... ok
[INFO] [stdout] test diagram_server::tests::test_http_full_cycle_post_list_get_delete ... ok
[INFO] [stdout] test token::tests::rtc_account_just_over_u32_falls_back_to_str ... ok
[INFO] [stdout] test token::tests::rtc_account_at_u32_boundary_fits ... ok
[INFO] [stdout] test token::tests::int_uid_2233_and_string_2233_decode_identically ... ok
[INFO] [stdout] test diagram_server::tests::test_http_list_diagrams_with_entries ... ok
[INFO] [stdout] test sso_auth::tests::valid_token_returns_error_when_no_session ... ok
[INFO] [stdout] test token::tests::rtc_account_as_str_roundtrips_int ... ok
[INFO] [stdout] test token::tests::rtc_account_empty_string_is_str ... ok
[INFO] [stdout] test token::tests::rtc_account_mode_label_matches_variant ... ok
[INFO] [stdout] test token::tests::rtc_account_parses_digits_as_int ... ok
[INFO] [stdout] test token::tests::rtc_account_parses_non_digits_as_str ... ok
[INFO] [stdout] test token::tests::rtc_account_s_slash_prefix_forces_str ... ok
[INFO] [stdout] test token::tests::rtc_account_overflowing_digits_fall_back_to_str ... ok
[INFO] [stdout] test token::tests::display_shows_version_validity_and_sections ... 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_publisher_token_has_all_four_privileges ... ok
[INFO] [stdout] test token::tests::rtc_publisher_has_four_privileges ... ok
[INFO] [stdout] test diagram_server::tests::test_landing_page_empty_store ... ok
[INFO] [stdout] test token::tests::rtc_subscriber_has_one_privilege ... ok
[INFO] [stdout] test token::tests::rtc_with_rtm_int_uid_and_separate_rtm_account ... ok
[INFO] [stdout] test token::tests::rtc_int_uid_token_differs_from_string_account_token ... ok
[INFO] [stdout] test token::tests::rtc_with_rtm_int_uid_same_account_for_both ... ok
[INFO] [stdout] test token::tests::rtc_subscriber_token_has_only_join_channel ... ok
[INFO] [stdout] test token::tests::rtc_with_rtm_separate_accounts_decodes ... ok
[INFO] [stdout] test token::tests::rtc_with_rtm_separate_account_produces_different_token_than_same_account ... ok
[INFO] [stdout] test token::tests::rtc_with_rtm_token_carries_both_services ... ok
[INFO] [stdout] test token::tests::rtm_token_starts_with_version ... ok
[INFO] [stdout] test token::tests::string_account_0_stores_literal_zero ... ok
[INFO] [stdout] test token::tests::rtc_token_starts_with_version ... ok
[INFO] [stdout] test token::tests::rtm_token_generate_then_decode_roundtrip ... ok
[INFO] [stdout] test token::tests::uid_0_stores_empty_string_in_token ... ok
[INFO] [stdout] test auth::tests::poll_session_status_parses_granted ... ok
[INFO] [stdout] test tui::voice_fx::tests::border_chars_high_volume ... ok
[INFO] [stdout] test tui::voice_fx::tests::jitter_zero_at_low_volume ... ok
[INFO] [stdout] test tui::voice_fx::tests::border_chars_medium_volume ... ok
[INFO] [stdout] test tui::voice_fx::tests::lerp_boundaries ... ok
[INFO] [stdout] test diagram_server::tests::test_http_post_invalid_json ... ok
[INFO] [stdout] test tui::voice_fx::tests::border_color_low_is_gray ... ok
[INFO] [stdout] test tui::voice_fx::tests::border_chars_clamped ... ok
[INFO] [stdout] test tui::voice_fx::tests::jitter_nonzero_at_high_volume ... ok
[INFO] [stdout] test tui::voice_fx::tests::border_chars_low_volume ... ok
[INFO] [stdout] test tui::voice_fx::tests::border_color_high_is_cyan ... ok
[INFO] [stdout] test tui::voice_fx::tests::border_color_mid_is_interpolated ... ok
[INFO] [stdout] test web_server::html::tests::escapes_html_special_chars ... ok
[INFO] [stdout] test web_server::html::tests::passes_through_unicode ... ok
[INFO] [stdout] test web_server::net::tests::expand_channel_template_substitutes_ts_with_digits ... ok
[INFO] [stdout] test web_server::net::tests::expand_channel_template_substitutes_appid ... ok
[INFO] [stdout] test web_server::net::tests::sslip_host_formats_correctly ... ok
[INFO] [stdout] test web_server::request::tests::extract_body_from_http_request ... ok
[INFO] [stdout] test web_server::net::tests::get_lan_ip_returns_non_unspecified ... ok
[INFO] [stdout] test web_server::net::tests::expand_channel_template_passes_through_when_no_placeholders ... ok
[INFO] [stdout] test webhook_server::tests::constant_time_eq_basic ... ok
[INFO] [stdout] test web_server::cert::tests::generate_cert_succeeds ... ok
[INFO] [stdout] test web_server::cert::tests::generate_cert_accepts_extra_hostnames ... ok
[INFO] [stdout] test token::tests::rtc_with_rtm_subscriber_has_only_join_channel_on_rtc_side ... ok
[INFO] [stdout] test web_server::cert::tests::generate_cert_ignores_empty_and_whitespace_entries ... ok
[INFO] [stdout] test diagram_server::tests::test_http_post_missing_html_field ... ok
[INFO] [stdout] test webhook_server::tests::extract_trycloudflare_url_from_typical_log_line ... ok
[INFO] [stdout] test web_server::request::tests::extract_body_empty_when_no_blank_line ... ok
[INFO] [stdout] test webhook_server::tests::header_value_is_case_insensitive ... ok
[INFO] [stdout] test webhook_server::tests::extract_trycloudflare_url_ignores_non_cloudflare_https ... ok
[INFO] [stdout] test webhook_server::tests::label_for_collisions_first_match_wins ... ok
[INFO] [stdout] test webhook_server::tests::label_for_known_codes ... ok
[INFO] [stdout] test webhook_server::tests::verify_signature_matches_known_hmac ... ok
[INFO] [stdout] test webhook_server::tests::verify_signature_rejects_wrong_sig ... ok
[INFO] [stdout] test webhook_server::tests::extract_trycloudflare_url_returns_none_when_no_https ... ok
[INFO] [stdout] test webhook_server::tests::webhooks_file_parses_empty_with_defaults ... ok
[INFO] [stdout] test webhook_server::tests::forwarded_remote_falls_back_to_x_real_ip_then_peer ... ok
[INFO] [stdout] test webhook_server::tests::forwarded_remote_falls_back_to_xff_first_address ... ok
[INFO] [stdout] test webhook_server::tests::forwarded_remote_prefers_cf_connecting_ip ... ok
[INFO] [stdout] test webhook_server::tests::webhooks_example_toml_is_valid ... ok
[INFO] [stdout] test webhook_server::tests::tunnel_provider_parse_accepts_known_aliases ... ok
[INFO] [stdout] test webhook_server::tests::webhooks_file_parses_full_example ... ok
[INFO] [stdout] test websocket_client::tests::agent_list_request_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::agent_status_update_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::agent_list_response_empty ... 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 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::atem_instance_struct_serializes ... ok
[INFO] [stdout] test websocket_client::tests::claude_launch_request_none_context ... ok
[INFO] [stdout] test websocket_client::tests::credential_sync_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::agent_prompt_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::claude_launch_request_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::atem_instance_list_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::credential_sync_without_login_id ... ok
[INFO] [stdout] test websocket_client::tests::codex_task_request_without_context ... ok
[INFO] [stdout] test webhook_server::tests::verify_signature_returns_false_when_header_missing ... ok
[INFO] [stdout] test websocket_client::tests::command_response_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::atem_instance_list_empty_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::deserialize_atem_instance_list_from_json ... ok
[INFO] [stdout] test websocket_client::tests::credential_sync_deserialize_from_json ... ok
[INFO] [stdout] test websocket_client::tests::deserialize_project_list_request_from_json ... ok
[INFO] [stdout] test websocket_client::tests::deserialize_voice_command_from_json ... ok
[INFO] [stdout] test websocket_client::tests::deserialize_voice_command_without_is_final ... ok
[INFO] [stdout] test websocket_client::tests::deserialize_voice_toggle_from_json ... ok
[INFO] [stdout] test websocket_client::tests::heartbeat_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::invalid_type_fails_deserialization ... ok
[INFO] [stdout] test websocket_client::tests::pair_save_preference_roundtrip_false ... ok
[INFO] [stdout] test websocket_client::tests::new_client_is_not_connected ... 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_request_serializes ... ok
[INFO] [stdout] test websocket_client::tests::project_list_response_roundtrip ... 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_assignment_backward_compat ... 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_with_claude_input_action ... ok
[INFO] [stdout] test websocket_client::tests::deserialize_token_response_from_json ... ok
[INFO] [stdout] test websocket_client::tests::test_user_command_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::test_user_command_with_codex_input_action ... ok
[INFO] [stdout] test websocket_client::tests::token_request_serializes_without_project_id ... ok
[INFO] [stdout] test websocket_client::tests::deserialize_video_toggle_from_json ... ok
[INFO] [stdout] test websocket_client::tests::token_response_roundtrip ... 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::test_user_command_with_cli_input_action ... ok
[INFO] [stdout] test websocket_client::tests::visualize_request_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::visualize_request_deserialize ... ok
[INFO] [stdout] test websocket_client::tests::visualize_request_special_characters ... ok
[INFO] [stdout] test websocket_client::tests::visualize_request_wire_format ... ok
[INFO] [stdout] test websocket_client::tests::test_user_command_with_shell_action ... ok
[INFO] [stdout] test websocket_client::tests::visualize_result_failure_case ... ok
[INFO] [stdout] test websocket_client::tests::token_request_serializes_with_project_id ... ok
[INFO] [stdout] test websocket_client::tests::visualize_result_serialize ... ok
[INFO] [stdout] test websocket_client::tests::visualize_request_without_relay_url ... ok
[INFO] [stdout] test websocket_client::tests::visualize_result_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::voice_command_final_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::visualize_result_wire_format ... 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::visualize_result_without_file_path ... 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_success_true ... ok
[INFO] [stdout] test websocket_client::tests::voice_response_wire_format_field_names ... ok
[INFO] [stdout] test websocket_client::tests::voice_toggle_false_roundtrip ... ok
[INFO] [stdout] test websocket_client::tests::voice_toggle_roundtrip ... ok
[INFO] [stdout] test auth::tests::create_server_session_parses_id_field ... ok
[INFO] [stdout] test webhook_server::tests::end_to_end_post_webhook_returns_200_and_broadcasts_sse ... 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. 646 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 5.16s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "252f5da0791a3aaecc9e19306891a045529e3f8069bdc7de77744ee5b19bb637", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "252f5da0791a3aaecc9e19306891a045529e3f8069bdc7de77744ee5b19bb637", kill_on_drop: false }`
[INFO] [stdout] 252f5da0791a3aaecc9e19306891a045529e3f8069bdc7de77744ee5b19bb637
