[INFO] cloning repository https://github.com/voloshyn/signal-tty
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/voloshyn/signal-tty" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fvoloshyn%2Fsignal-tty", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fvoloshyn%2Fsignal-tty'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 59229a228c4cadd33d1e451b2909a7233ef49203
[INFO] checking voloshyn/signal-tty against master#57f772f25c5ce2bd870d6f8c3ab318eaee5a3326 for pr-133502-22
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fvoloshyn%2Fsignal-tty" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/voloshyn/signal-tty
[INFO] finished tweaking git repo https://github.com/voloshyn/signal-tty
[INFO] tweaked toml for git repo https://github.com/voloshyn/signal-tty written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/voloshyn/signal-tty on toolchain 57f772f25c5ce2bd870d6f8c3ab318eaee5a3326
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/voloshyn/signal-tty 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" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded time-core v0.1.7
[INFO] [stderr]   Downloaded zmij v1.0.14
[INFO] [stderr]   Downloaded time v0.3.45
[INFO] [stderr]   Downloaded pest_generator v2.8.4
[INFO] [stderr]   Downloaded pest_derive v2.8.4
[INFO] [stderr]   Downloaded pest_meta v2.8.4
[INFO] [stderr]   Downloaded zune-jpeg v0.5.9
[INFO] [stderr]   Downloaded rand_xoshiro v0.7.0
[INFO] [stderr]   Downloaded quantette v0.5.1
[INFO] [stderr]   Downloaded safe_arch v0.9.3
[INFO] [stderr]   Downloaded wide v0.8.3
[INFO] [stderr]   Downloaded outref v0.5.2
[INFO] [stderr]   Downloaded directories v6.0.0
[INFO] [stderr]   Downloaded icy_sixel v0.5.0
[INFO] [stderr]   Downloaded sqlite-wasm-rs v0.5.1
[INFO] [stderr]   Downloaded ratatui-image v10.0.2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c5dec81d6c3fa947ff3c751a11e5ea0b81ef02e15c84a8af4fa08eded12a4270
[INFO] running `Command { std: "docker" "start" "-a" "c5dec81d6c3fa947ff3c751a11e5ea0b81ef02e15c84a8af4fa08eded12a4270", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c5dec81d6c3fa947ff3c751a11e5ea0b81ef02e15c84a8af4fa08eded12a4270", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c5dec81d6c3fa947ff3c751a11e5ea0b81ef02e15c84a8af4fa08eded12a4270", kill_on_drop: false }`
[INFO] [stdout] c5dec81d6c3fa947ff3c751a11e5ea0b81ef02e15c84a8af4fa08eded12a4270
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] ed5929481dd42480106d08c3ec30439d4d1ff5807a6c758a9476f5d80cdc1d4a
[INFO] running `Command { std: "docker" "start" "-a" "ed5929481dd42480106d08c3ec30439d4d1ff5807a6c758a9476f5d80cdc1d4a", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.105
[INFO] [stderr]    Compiling quote v1.0.43
[INFO] [stderr]    Compiling libm v0.2.15
[INFO] [stderr]     Checking bitflags v2.10.0
[INFO] [stderr]    Compiling zerocopy v0.8.33
[INFO] [stderr]     Checking simd-adler32 v0.3.8
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]     Checking itertools v0.14.0
[INFO] [stderr]     Checking memchr v2.7.6
[INFO] [stderr]     Checking foldhash v0.2.0
[INFO] [stderr]     Checking arrayvec v0.7.6
[INFO] [stderr]     Checking as-slice v0.2.1
[INFO] [stderr]    Compiling built v0.8.0
[INFO] [stderr]    Compiling av-scenechange v0.14.1
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]     Checking linux-raw-sys v0.11.0
[INFO] [stderr]     Checking aligned v0.4.3
[INFO] [stderr]     Checking quick-error v2.0.1
[INFO] [stderr]    Compiling pastey v0.1.1
[INFO] [stderr]     Checking hashbrown v0.16.1
[INFO] [stderr]     Checking y4m v0.8.0
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking castaway v0.2.4
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking maybe-rayon v0.1.1
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling noop_proc_macro v0.3.0
[INFO] [stderr]     Checking unicode-width v0.2.0
[INFO] [stderr]     Checking new_debug_unreachable v1.0.6
[INFO] [stderr]    Compiling instability v0.3.11
[INFO] [stderr]     Checking weezl v0.1.12
[INFO] [stderr]     Checking imgref v1.12.0
[INFO] [stderr]     Checking flate2 v1.1.8
[INFO] [stderr]    Compiling indoc v2.0.7
[INFO] [stderr]     Checking compact_str v0.9.0
[INFO] [stderr]    Compiling convert_case v0.10.0
[INFO] [stderr]     Checking zune-jpeg v0.4.21
[INFO] [stderr]     Checking loop9 v0.1.5
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking avif-serialize v0.8.6
[INFO] [stderr]     Checking fdeflate v0.3.7
[INFO] [stderr]     Checking zune-inflate v0.2.54
[INFO] [stderr]    Compiling rav1e v0.8.1
[INFO] [stderr]     Checking mio v1.1.1
[INFO] [stderr]     Checking lebe v0.5.3
[INFO] [stderr]    Compiling radium v0.7.0
[INFO] [stderr]     Checking rgb v0.8.52
[INFO] [stderr]     Checking core2 v0.4.0
[INFO] [stderr]     Checking nom v8.0.0
[INFO] [stderr]     Checking zune-core v0.5.1
[INFO] [stderr]     Checking bitstream-io v4.9.0
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]     Checking bit_field v0.10.3
[INFO] [stderr]     Checking png v0.18.0
[INFO] [stderr]    Compiling simd_helpers v0.1.0
[INFO] [stderr]     Checking deranged v0.5.5
[INFO] [stderr]     Checking image-webp v0.2.4
[INFO] [stderr]     Checking gif v0.14.1
[INFO] [stderr]     Checking lru v0.16.3
[INFO] [stderr]     Checking time-core v0.1.7
[INFO] [stderr]    Compiling palette v0.7.6
[INFO] [stderr]    Compiling by_address v1.2.1
[INFO] [stderr]     Checking rand_core v0.9.5
[INFO] [stderr]    Compiling litrs v1.0.0
[INFO] [stderr]     Checking tap v1.0.1
[INFO] [stderr]     Checking signal-hook-mio v0.2.5
[INFO] [stderr]     Checking zune-jpeg v0.5.9
[INFO] [stderr]     Checking wyz v0.5.1
[INFO] [stderr]    Compiling cc v1.2.53
[INFO] [stderr]     Checking line-clipping v0.3.5
[INFO] [stderr]     Checking funty v2.0.0
[INFO] [stderr]     Checking fast-srgb8 v1.0.0
[INFO] [stderr]     Checking rand v0.9.2
[INFO] [stderr]     Checking rand_xoshiro v0.7.0
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling zmij v1.0.14
[INFO] [stderr]     Checking vsimd v0.8.0
[INFO] [stderr]     Checking bitvec v1.0.1
[INFO] [stderr]     Checking unicode-truncate v2.0.1
[INFO] [stderr]     Checking x11rb-protocol v0.13.2
[INFO] [stderr]    Compiling document-features v0.2.12
[INFO] [stderr]     Checking outref v0.5.2
[INFO] [stderr]    Compiling ratatui-image v10.0.2
[INFO] [stderr]     Checking linux-raw-sys v0.4.15
[INFO] [stderr]     Checking dirs-sys v0.5.0
[INFO] [stderr]     Checking getrandom v0.3.4
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking pxfm v0.1.27
[INFO] [stderr]     Checking ordered-float v5.1.0
[INFO] [stderr]     Checking hashlink v0.11.0
[INFO] [stderr]     Checking socket2 v0.6.1
[INFO] [stderr]     Checking fallible-streaming-iterator v0.1.9
[INFO] [stderr]     Checking base64-simd v0.8.0
[INFO] [stderr]     Checking time v0.3.45
[INFO] [stderr]     Checking iana-time-zone v0.1.64
[INFO] [stderr]     Checking serde_json v1.0.149
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking uuid v1.19.0
[INFO] [stderr]     Checking directories v6.0.0
[INFO] [stderr]    Compiling libsqlite3-sys v0.36.0
[INFO] [stderr]     Checking num-rational v0.4.2
[INFO] [stderr]     Checking moxcms v0.7.11
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling equator-macro v0.4.2
[INFO] [stderr]    Compiling zerocopy-derive v0.8.33
[INFO] [stderr]    Compiling bytemuck_derive v1.10.2
[INFO] [stderr]    Compiling arg_enum_proc_macro v0.3.4
[INFO] [stderr]    Compiling profiling-procmacros v1.0.17
[INFO] [stderr]    Compiling fax_derive v0.2.0
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]    Compiling strum_macros v0.27.2
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]    Compiling ref-cast-impl v1.0.25
[INFO] [stderr]     Checking profiling v1.0.17
[INFO] [stderr]    Compiling palette_derive v0.7.6
[INFO] [stderr]     Checking ref-cast v1.0.25
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]     Checking derive_more v2.1.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]     Checking crossterm v0.29.0
[INFO] [stderr]     Checking equator v0.4.2
[INFO] [stderr]     Checking fax v0.2.6
[INFO] [stderr]     Checking gethostname v1.1.0
[INFO] [stderr]     Checking x11rb v0.13.2
[INFO] [stderr]     Checking aligned-vec v0.6.4
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]     Checking tokio v1.49.0
[INFO] [stderr]     Checking v_frame v0.3.9
[INFO] [stderr]     Checking av1-grain v0.2.5
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking bytemuck v1.24.0
[INFO] [stderr]     Checking kasuari v0.4.11
[INFO] [stderr]     Checking qoi v0.4.1
[INFO] [stderr]     Checking safe_arch v0.9.3
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]     Checking strum v0.27.2
[INFO] [stderr]     Checking ratatui-core v0.1.0
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]     Checking wide v0.8.3
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]     Checking ratatui-widgets v0.3.0
[INFO] [stderr]     Checking ratatui-crossterm v0.1.0
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking half v2.7.1
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking chrono v0.4.43
[INFO] [stderr]     Checking tiff v0.10.3
[INFO] [stderr]     Checking exr v1.74.0
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking ratatui-macros v0.7.0
[INFO] [stderr]     Checking ratatui v0.30.0
[INFO] [stderr]     Checking ravif v0.12.0
[INFO] [stderr]     Checking image v0.25.9
[INFO] [stderr]     Checking rusqlite v0.38.0
[INFO] [stderr]     Checking quantette v0.5.1
[INFO] [stderr]     Checking arboard v3.6.1
[INFO] [stderr]     Checking icy_sixel v0.5.0
[INFO] [stderr]     Checking signal-tty v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: field `jsonrpc` is never read
[INFO] [stdout]   --> src/infrastructure/jsonrpc/types.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub struct JsonRpcResponse {
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] 27 |     pub jsonrpc: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `JsonRpcResponse` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `jsonrpc` is never read
[INFO] [stdout]   --> src/infrastructure/jsonrpc/types.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct JsonRpcNotification {
[INFO] [stdout]    |            ------------------- field in this struct
[INFO] [stdout] 45 |     pub jsonrpc: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `JsonRpcNotification` 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 `is_notification` and `id` are never used
[INFO] [stdout]   --> src/infrastructure/jsonrpc/types.rs:59:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl JsonRpcMessage {
[INFO] [stdout]    | ------------------- methods in this implementation
[INFO] [stdout] 59 |     pub fn is_notification(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub fn id(&self) -> Option<&str> {
[INFO] [stdout]    |            ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PARSE_ERROR` is never used
[INFO] [stdout]    --> src/infrastructure/jsonrpc/types.rs:107:15
[INFO] [stdout]     |
[INFO] [stdout] 107 |     pub const PARSE_ERROR: i32 = -32700;
[INFO] [stdout]     |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INVALID_REQUEST` is never used
[INFO] [stdout]    --> src/infrastructure/jsonrpc/types.rs:108:15
[INFO] [stdout]     |
[INFO] [stdout] 108 |     pub const INVALID_REQUEST: i32 = -32600;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `METHOD_NOT_FOUND` is never used
[INFO] [stdout]    --> src/infrastructure/jsonrpc/types.rs:109:15
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub const METHOD_NOT_FOUND: i32 = -32601;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INVALID_PARAMS` is never used
[INFO] [stdout]    --> src/infrastructure/jsonrpc/types.rs:110:15
[INFO] [stdout]     |
[INFO] [stdout] 110 |     pub const INVALID_PARAMS: i32 = -32602;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INTERNAL_ERROR` is never used
[INFO] [stdout]    --> src/infrastructure/jsonrpc/types.rs:111:15
[INFO] [stdout]     |
[INFO] [stdout] 111 |     pub const INTERNAL_ERROR: i32 = -32603;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `account` is never read
[INFO] [stdout]   --> src/infrastructure/signal/client.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct SignalClient {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 15 |     rpc: Arc<JsonRpcClient<StdioTransport>>,
[INFO] [stdout] 16 |     account: Option<String>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `EmptyParams` is never constructed
[INFO] [stdout]   --> src/infrastructure/signal/client.rs:84:8
[INFO] [stdout]    |
[INFO] [stdout] 84 | struct EmptyParams {}
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/infrastructure/signal/error.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub enum SignalError {
[INFO] [stdout]    |          ----------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 10 |     NotConnected,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 13 |     NotRegistered,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     InvalidRecipient(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 19 |     GroupNotFound(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     ContactNotFound(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 25 |     SendFailed(String),
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     RateLimited { retry_after: u64 },
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     UntrustedIdentity { address: String },
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 34 |     CaptchaRequired,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     Unknown(String),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SignalError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]   --> src/infrastructure/signal/repository.rs:9:8
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub trait SignalRepository: Send + Sync {
[INFO] [stdout]    |           ---------------- methods in this trait
[INFO] [stdout]  8 |     async fn connect(&self) -> Result<(), SignalError>;
[INFO] [stdout]  9 |     fn is_connected(&self) -> bool;
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 12 |     async fn get_account_info(&self) -> Result<Account, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 13 |     async fn list_accounts(&self) -> Result<Vec<String>, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     async fn send_reaction(&self, recipient: &str, emoji: &str, target_author: &str, target_timestamp: i64) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 19 |     async fn remove_reaction(&self, recipient: &str, emoji: &str, target_author: &str, target_timestamp: i64) -> Result<(), SignalEr...
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 20 |
[INFO] [stdout] 21 |     async fn list_contacts(&self) -> Result<Vec<Contact>, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 22 |     async fn get_contact(&self, identifier: &str) -> Result<Contact, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 23 |     async fn update_contact_name(&self, identifier: &str, name: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     async fn block_contact(&self, identifier: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 25 |     async fn unblock_contact(&self, identifier: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 26 |
[INFO] [stdout] 27 |     async fn list_groups(&self) -> Result<Vec<Group>, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 28 |     async fn get_group(&self, group_id: &str) -> Result<Group, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^
[INFO] [stdout] 29 |     async fn leave_group(&self, group_id: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 30 |     async fn block_group(&self, group_id: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 31 |
[INFO] [stdout] 32 |     async fn list_identities(&self) -> Result<Vec<Identity>, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 33 |     async fn trust_identity(&self, identifier: &str, trust_all_keys: bool) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^
[INFO] [stdout] 34 |
[INFO] [stdout] 35 |     async fn send_typing_started(&self, recipient: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 36 |     async fn send_typing_stopped(&self, recipient: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Account` is never constructed
[INFO] [stdout]  --> src/infrastructure/signal/types.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Account {
[INFO] [stdout]   |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Contact` is never constructed
[INFO] [stdout]   --> src/infrastructure/signal/types.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Contact {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `display_name` and `identifier` are never used
[INFO] [stdout]   --> src/infrastructure/signal/types.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl Contact {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] 29 |     pub fn display_name(&self) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn identifier(&self) -> Option<String> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Group` is never constructed
[INFO] [stdout]   --> src/infrastructure/signal/types.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct Group {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `display_name` is never used
[INFO] [stdout]   --> src/infrastructure/signal/types.rs:59:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl Group {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] 59 |     pub fn display_name(&self) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `sender_display` is never used
[INFO] [stdout]   --> src/infrastructure/signal/types.rs:94:12
[INFO] [stdout]    |
[INFO] [stdout] 93 | impl Envelope {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] 94 |     pub fn sender_display(&self) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SendMessageParams` is never constructed
[INFO] [stdout]    --> src/infrastructure/signal/types.rs:218:12
[INFO] [stdout]     |
[INFO] [stdout] 218 | pub struct SendMessageParams {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Identity` is never constructed
[INFO] [stdout]    --> src/infrastructure/signal/types.rs:258:12
[INFO] [stdout]     |
[INFO] [stdout] 258 | pub struct Identity {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `SendFailed` and `ReceiveFailed` are never constructed
[INFO] [stdout]   --> src/infrastructure/transport/mod.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum TransportError {
[INFO] [stdout]    |          -------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 15 |     SendFailed(String),
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     ReceiveFailed(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TransportError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `subscribe`, `is_connected`, and `disconnect` are never used
[INFO] [stdout]   --> src/infrastructure/transport/mod.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub trait Transport: Send + Sync {
[INFO] [stdout]    |           --------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 32 |     fn subscribe(&self) -> broadcast::Receiver<Vec<u8>>;
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 33 |     fn is_connected(&self) -> bool;
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 34 |     async fn disconnect(&self) -> Result<(), TransportError>;
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `signal_id` is never used
[INFO] [stdout]    --> src/storage/models.rs:116:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | impl Message {
[INFO] [stdout]     | ------------ method in this implementation
[INFO] [stdout] 116 |     pub fn signal_id(&self) -> (String, i64) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Reaction` is never constructed
[INFO] [stdout]    --> src/storage/models.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 122 | pub struct Reaction {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DeliveryState` is never used
[INFO] [stdout]    --> src/storage/models.rs:131:10
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub enum DeliveryState {
[INFO] [stdout]     |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DeliveryStatus` is never constructed
[INFO] [stdout]    --> src/storage/models.rs:140:12
[INFO] [stdout]     |
[INFO] [stdout] 140 | pub struct DeliveryStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GroupMember` is never constructed
[INFO] [stdout]    --> src/storage/models.rs:148:12
[INFO] [stdout]     |
[INFO] [stdout] 148 | pub struct GroupMember {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `NotFound` and `Serialization` are never constructed
[INFO] [stdout]   --> src/storage/repository.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub enum StorageError {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 10 |     NotFound(String),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 13 |     Serialization(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `StorageError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]   --> src/storage/repository.rs:30:8
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub trait StorageRepository: Send + Sync {
[INFO] [stdout]    |           ----------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 30 |     fn get_conversation(&self, id: &str) -> Result<Option<Conversation>, StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     fn get_message(&self, id: &str) -> Result<Option<Message>, StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     fn mark_message_deleted(&self, sender_uuid: &str, timestamp: i64) -> Result<(), StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     fn save_reaction(&self, reaction: &Reaction) -> Result<(), StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 75 |
[INFO] [stdout] 76 |     fn remove_reaction(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 83 |     fn get_reactions(&self, message_id: &str) -> Result<Vec<Reaction>, StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 84 |
[INFO] [stdout] 85 |     fn save_delivery_status(&self, status: &DeliveryStatus) -> Result<(), StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 86 |
[INFO] [stdout] 87 |     fn get_delivery_statuses(&self, message_id: &str) -> Result<Vec<DeliveryStatus>, StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `jsonrpc` is never read
[INFO] [stdout]   --> src/infrastructure/jsonrpc/types.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub struct JsonRpcResponse {
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] 27 |     pub jsonrpc: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `JsonRpcResponse` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `jsonrpc` is never read
[INFO] [stdout]   --> src/infrastructure/jsonrpc/types.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct JsonRpcNotification {
[INFO] [stdout]    |            ------------------- field in this struct
[INFO] [stdout] 45 |     pub jsonrpc: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `JsonRpcNotification` 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 `is_notification` and `id` are never used
[INFO] [stdout]   --> src/infrastructure/jsonrpc/types.rs:59:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl JsonRpcMessage {
[INFO] [stdout]    | ------------------- methods in this implementation
[INFO] [stdout] 59 |     pub fn is_notification(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub fn id(&self) -> Option<&str> {
[INFO] [stdout]    |            ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PARSE_ERROR` is never used
[INFO] [stdout]    --> src/infrastructure/jsonrpc/types.rs:107:15
[INFO] [stdout]     |
[INFO] [stdout] 107 |     pub const PARSE_ERROR: i32 = -32700;
[INFO] [stdout]     |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INVALID_REQUEST` is never used
[INFO] [stdout]    --> src/infrastructure/jsonrpc/types.rs:108:15
[INFO] [stdout]     |
[INFO] [stdout] 108 |     pub const INVALID_REQUEST: i32 = -32600;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `METHOD_NOT_FOUND` is never used
[INFO] [stdout]    --> src/infrastructure/jsonrpc/types.rs:109:15
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub const METHOD_NOT_FOUND: i32 = -32601;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INVALID_PARAMS` is never used
[INFO] [stdout]    --> src/infrastructure/jsonrpc/types.rs:110:15
[INFO] [stdout]     |
[INFO] [stdout] 110 |     pub const INVALID_PARAMS: i32 = -32602;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INTERNAL_ERROR` is never used
[INFO] [stdout]    --> src/infrastructure/jsonrpc/types.rs:111:15
[INFO] [stdout]     |
[INFO] [stdout] 111 |     pub const INTERNAL_ERROR: i32 = -32603;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `account` is never read
[INFO] [stdout]   --> src/infrastructure/signal/client.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct SignalClient {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 15 |     rpc: Arc<JsonRpcClient<StdioTransport>>,
[INFO] [stdout] 16 |     account: Option<String>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `EmptyParams` is never constructed
[INFO] [stdout]   --> src/infrastructure/signal/client.rs:84:8
[INFO] [stdout]    |
[INFO] [stdout] 84 | struct EmptyParams {}
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/infrastructure/signal/error.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub enum SignalError {
[INFO] [stdout]    |          ----------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 10 |     NotConnected,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 13 |     NotRegistered,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     InvalidRecipient(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 19 |     GroupNotFound(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     ContactNotFound(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 25 |     SendFailed(String),
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     RateLimited { retry_after: u64 },
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     UntrustedIdentity { address: String },
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 34 |     CaptchaRequired,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     Unknown(String),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SignalError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]   --> src/infrastructure/signal/repository.rs:9:8
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub trait SignalRepository: Send + Sync {
[INFO] [stdout]    |           ---------------- methods in this trait
[INFO] [stdout]  8 |     async fn connect(&self) -> Result<(), SignalError>;
[INFO] [stdout]  9 |     fn is_connected(&self) -> bool;
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 12 |     async fn get_account_info(&self) -> Result<Account, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 13 |     async fn list_accounts(&self) -> Result<Vec<String>, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     async fn send_reaction(&self, recipient: &str, emoji: &str, target_author: &str, target_timestamp: i64) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 19 |     async fn remove_reaction(&self, recipient: &str, emoji: &str, target_author: &str, target_timestamp: i64) -> Result<(), SignalEr...
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 20 |
[INFO] [stdout] 21 |     async fn list_contacts(&self) -> Result<Vec<Contact>, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 22 |     async fn get_contact(&self, identifier: &str) -> Result<Contact, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 23 |     async fn update_contact_name(&self, identifier: &str, name: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     async fn block_contact(&self, identifier: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 25 |     async fn unblock_contact(&self, identifier: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 26 |
[INFO] [stdout] 27 |     async fn list_groups(&self) -> Result<Vec<Group>, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 28 |     async fn get_group(&self, group_id: &str) -> Result<Group, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^
[INFO] [stdout] 29 |     async fn leave_group(&self, group_id: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 30 |     async fn block_group(&self, group_id: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 31 |
[INFO] [stdout] 32 |     async fn list_identities(&self) -> Result<Vec<Identity>, SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 33 |     async fn trust_identity(&self, identifier: &str, trust_all_keys: bool) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^
[INFO] [stdout] 34 |
[INFO] [stdout] 35 |     async fn send_typing_started(&self, recipient: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 36 |     async fn send_typing_stopped(&self, recipient: &str) -> Result<(), SignalError>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Account` is never constructed
[INFO] [stdout]  --> src/infrastructure/signal/types.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Account {
[INFO] [stdout]   |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Contact` is never constructed
[INFO] [stdout]   --> src/infrastructure/signal/types.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Contact {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `display_name` and `identifier` are never used
[INFO] [stdout]   --> src/infrastructure/signal/types.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl Contact {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] 29 |     pub fn display_name(&self) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn identifier(&self) -> Option<String> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Group` is never constructed
[INFO] [stdout]   --> src/infrastructure/signal/types.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct Group {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `display_name` is never used
[INFO] [stdout]   --> src/infrastructure/signal/types.rs:59:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl Group {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] 59 |     pub fn display_name(&self) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `sender_display` is never used
[INFO] [stdout]   --> src/infrastructure/signal/types.rs:94:12
[INFO] [stdout]    |
[INFO] [stdout] 93 | impl Envelope {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] 94 |     pub fn sender_display(&self) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SendMessageParams` is never constructed
[INFO] [stdout]    --> src/infrastructure/signal/types.rs:218:12
[INFO] [stdout]     |
[INFO] [stdout] 218 | pub struct SendMessageParams {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Identity` is never constructed
[INFO] [stdout]    --> src/infrastructure/signal/types.rs:258:12
[INFO] [stdout]     |
[INFO] [stdout] 258 | pub struct Identity {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `SendFailed` and `ReceiveFailed` are never constructed
[INFO] [stdout]   --> src/infrastructure/transport/mod.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum TransportError {
[INFO] [stdout]    |          -------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 15 |     SendFailed(String),
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     ReceiveFailed(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TransportError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `subscribe`, `is_connected`, and `disconnect` are never used
[INFO] [stdout]   --> src/infrastructure/transport/mod.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub trait Transport: Send + Sync {
[INFO] [stdout]    |           --------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 32 |     fn subscribe(&self) -> broadcast::Receiver<Vec<u8>>;
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 33 |     fn is_connected(&self) -> bool;
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 34 |     async fn disconnect(&self) -> Result<(), TransportError>;
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `signal_id` is never used
[INFO] [stdout]    --> src/storage/models.rs:116:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | impl Message {
[INFO] [stdout]     | ------------ method in this implementation
[INFO] [stdout] 116 |     pub fn signal_id(&self) -> (String, i64) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Reaction` is never constructed
[INFO] [stdout]    --> src/storage/models.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 122 | pub struct Reaction {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DeliveryState` is never used
[INFO] [stdout]    --> src/storage/models.rs:131:10
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub enum DeliveryState {
[INFO] [stdout]     |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DeliveryStatus` is never constructed
[INFO] [stdout]    --> src/storage/models.rs:140:12
[INFO] [stdout]     |
[INFO] [stdout] 140 | pub struct DeliveryStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GroupMember` is never constructed
[INFO] [stdout]    --> src/storage/models.rs:148:12
[INFO] [stdout]     |
[INFO] [stdout] 148 | pub struct GroupMember {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `NotFound` and `Serialization` are never constructed
[INFO] [stdout]   --> src/storage/repository.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub enum StorageError {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 10 |     NotFound(String),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 13 |     Serialization(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `StorageError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]   --> src/storage/repository.rs:30:8
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub trait StorageRepository: Send + Sync {
[INFO] [stdout]    |           ----------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 30 |     fn get_conversation(&self, id: &str) -> Result<Option<Conversation>, StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     fn get_message(&self, id: &str) -> Result<Option<Message>, StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     fn mark_message_deleted(&self, sender_uuid: &str, timestamp: i64) -> Result<(), StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     fn save_reaction(&self, reaction: &Reaction) -> Result<(), StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 75 |
[INFO] [stdout] 76 |     fn remove_reaction(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 83 |     fn get_reactions(&self, message_id: &str) -> Result<Vec<Reaction>, StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 84 |
[INFO] [stdout] 85 |     fn save_delivery_status(&self, status: &DeliveryStatus) -> Result<(), StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 86 |
[INFO] [stdout] 87 |     fn get_delivery_statuses(&self, message_id: &str) -> Result<Vec<DeliveryStatus>, StorageError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 02s
[INFO] running `Command { std: "docker" "inspect" "ed5929481dd42480106d08c3ec30439d4d1ff5807a6c758a9476f5d80cdc1d4a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ed5929481dd42480106d08c3ec30439d4d1ff5807a6c758a9476f5d80cdc1d4a", kill_on_drop: false }`
[INFO] [stdout] ed5929481dd42480106d08c3ec30439d4d1ff5807a6c758a9476f5d80cdc1d4a
