[INFO] cloning repository https://github.com/xyber-nova/LGS-Paintboard-Helper
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/xyber-nova/LGS-Paintboard-Helper" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fxyber-nova%2FLGS-Paintboard-Helper", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fxyber-nova%2FLGS-Paintboard-Helper'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] ea32c8edfc9a8553a04d4959602af7c90529735f
[INFO] testing xyber-nova/LGS-Paintboard-Helper/ea32c8edfc9a8553a04d4959602af7c90529735f against master#1ef7943ee607160a564655b6596f83670ef95df5 for pr-146098-6
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fxyber-nova%2FLGS-Paintboard-Helper" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/xyber-nova/LGS-Paintboard-Helper
[INFO] finished tweaking git repo https://github.com/xyber-nova/LGS-Paintboard-Helper
[INFO] tweaked toml for git repo https://github.com/xyber-nova/LGS-Paintboard-Helper written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/xyber-nova/LGS-Paintboard-Helper on toolchain 1ef7943ee607160a564655b6596f83670ef95df5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/xyber-nova/LGS-Paintboard-Helper 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" "+1ef7943ee607160a564655b6596f83670ef95df5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: /workspace/builds/worker-3-tc1/source/Cargo.toml: only one of `license` or `license-file` is necessary
[INFO] [stderr] `license` should be used if the package license can be expressed with a standard SPDX expression.
[INFO] [stderr] `license-file` should be used if the package uses a non-standard license.
[INFO] [stderr] See https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields for more information.
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded tokio-test v0.4.4
[INFO] [stderr]   Downloaded deadpool-runtime v0.1.4
[INFO] [stderr]   Downloaded wasi v0.14.7+wasi-0.2.4
[INFO] [stderr]   Downloaded wasm-bindgen-futures v0.4.54
[INFO] [stderr]   Downloaded generic-array v0.14.8
[INFO] [stderr]   Downloaded deadpool v0.12.3
[INFO] [stderr]   Downloaded quanta v0.12.6
[INFO] [stderr]   Downloaded custom_derive v0.1.7
[INFO] [stderr]   Downloaded bit_field v0.10.3
[INFO] [stderr]   Downloaded hyper-timeout v0.5.2
[INFO] [stderr]   Downloaded conv v0.3.3
[INFO] [stderr]   Downloaded console-api v0.8.1
[INFO] [stderr]   Downloaded prost v0.13.5
[INFO] [stderr]   Downloaded clap v4.5.48
[INFO] [stderr]   Downloaded tonic v0.12.3
[INFO] [stderr]   Downloaded wide v0.7.33
[INFO] [stderr]   Downloaded console-subscriber v0.4.1
[INFO] [stderr]   Downloaded owned_ttf_parser v0.15.2
[INFO] [stderr]   Downloaded h2 v0.3.27
[INFO] [stderr]   Downloaded clap_builder v4.5.48
[INFO] [stderr]   Downloaded h2 v0.4.12
[INFO] [stderr]   Downloaded regex v1.12.1
[INFO] [stderr]   Downloaded rayon v1.11.0
[INFO] [stderr]   Downloaded half v2.7.0
[INFO] [stderr]   Downloaded rayon-core v1.13.0
[INFO] [stderr]   Downloaded raw-cpuid v11.6.0
[INFO] [stderr]   Downloaded prost-types v0.13.5
[INFO] [stderr]   Downloaded matrixmultiply v0.3.10
[INFO] [stderr]   Downloaded nalgebra v0.30.1
[INFO] [stderr]   Downloaded simba v0.7.3
[INFO] [stderr]   Downloaded owo-colors v4.2.3
[INFO] [stderr]   Downloaded regex-syntax v0.8.7
[INFO] [stderr]   Downloaded rand_distr v0.2.2
[INFO] [stderr]   Downloaded rusttype v0.9.3
[INFO] [stderr]   Downloaded indenter v0.3.4
[INFO] [stderr]   Downloaded gif v0.13.3
[INFO] [stderr]   Downloaded prost-derive v0.13.5
[INFO] [stderr]   Downloaded lebe v0.5.3
[INFO] [stderr]   Downloaded color-spantrace v0.3.0
[INFO] [stderr]   Downloaded regex-automata v0.4.12
[INFO] [stderr]   Downloaded color-eyre v0.6.5
[INFO] [stderr]   Downloaded imageproc v0.23.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] b792664eb79a4f0e2f29935281b1fcb56166e50e1801c7073bb0293c5dcad915
[INFO] running `Command { std: "docker" "start" "-a" "b792664eb79a4f0e2f29935281b1fcb56166e50e1801c7073bb0293c5dcad915", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "b792664eb79a4f0e2f29935281b1fcb56166e50e1801c7073bb0293c5dcad915", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b792664eb79a4f0e2f29935281b1fcb56166e50e1801c7073bb0293c5dcad915", kill_on_drop: false }`
[INFO] [stdout] b792664eb79a4f0e2f29935281b1fcb56166e50e1801c7073bb0293c5dcad915
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 78ac785dfd957b72ecdc7d7fcba29f4a7784b8e4a590380af5b7993d2c762b81
[INFO] running `Command { std: "docker" "start" "-a" "78ac785dfd957b72ecdc7d7fcba29f4a7784b8e4a590380af5b7993d2c762b81", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: only one of `license` or `license-file` is necessary
[INFO] [stderr] `license` should be used if the package license can be expressed with a standard SPDX expression.
[INFO] [stderr] `license-file` should be used if the package uses a non-standard license.
[INFO] [stderr] See https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields for more information.
[INFO] [stderr]    Compiling cfg-if v1.0.3
[INFO] [stderr]    Compiling libc v0.2.177
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling lock_api v0.4.14
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling log v0.4.28
[INFO] [stderr]    Compiling find-msvc-tools v0.1.4
[INFO] [stderr]    Compiling hashbrown v0.16.0
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling cc v1.2.41
[INFO] [stderr]    Compiling tower-service v0.3.3
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling adler2 v2.0.1
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling http v1.3.1
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling socket2 v0.6.0
[INFO] [stderr]    Compiling indexmap v2.11.4
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling bitflags v2.9.4
[INFO] [stderr]    Compiling litemap v0.8.0
[INFO] [stderr]    Compiling try-lock v0.2.5
[INFO] [stderr]    Compiling percent-encoding v2.3.2
[INFO] [stderr]    Compiling writeable v0.6.1
[INFO] [stderr]    Compiling want v0.3.1
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling regex-syntax v0.8.7
[INFO] [stderr]    Compiling httpdate v1.0.3
[INFO] [stderr]    Compiling icu_properties_data v2.0.1
[INFO] [stderr]    Compiling generic-array v0.14.8
[INFO] [stderr]    Compiling icu_normalizer_data v2.0.0
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling lazy_static v1.5.0
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling bytemuck v1.24.0
[INFO] [stderr]    Compiling tower-layer v0.3.3
[INFO] [stderr]    Compiling openssl-probe v0.1.6
[INFO] [stderr]    Compiling getrandom v0.1.16
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]    Compiling atomic-waker v1.1.2
[INFO] [stderr]    Compiling flate2 v1.1.4
[INFO] [stderr]    Compiling sharded-slab v0.1.7
[INFO] [stderr]    Compiling form_urlencoded v1.2.2
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling regex-automata v0.4.12
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling nu-ansi-term v0.50.3
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling base64 v0.21.7
[INFO] [stderr]    Compiling object v0.37.3
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling owo-colors v4.2.3
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling rand_core v0.5.1
[INFO] [stderr]    Compiling rayon v1.11.0
[INFO] [stderr]    Compiling num-bigint v0.4.6
[INFO] [stderr]    Compiling http-body v0.4.6
[INFO] [stderr]    Compiling safe_arch v0.7.4
[INFO] [stderr]    Compiling num-complex v0.4.6
[INFO] [stderr]    Compiling matrixmultiply v0.3.10
[INFO] [stderr]    Compiling eyre v0.6.12
[INFO] [stderr]    Compiling matchit v0.7.3
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]    Compiling gimli v0.32.3
[INFO] [stderr]    Compiling weezl v0.1.10
[INFO] [stderr]    Compiling color-spantrace v0.3.0
[INFO] [stderr]    Compiling wide v0.7.33
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling zerocopy-derive v0.8.27
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling yoke v0.8.0
[INFO] [stderr]    Compiling zerovec v0.11.4
[INFO] [stderr]    Compiling zerotrie v0.2.2
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling tracing-subscriber v0.3.20
[INFO] [stderr]    Compiling prost-derive v0.13.5
[INFO] [stderr]    Compiling tinystr v0.8.1
[INFO] [stderr]    Compiling potential_utf v0.1.3
[INFO] [stderr]    Compiling icu_collections v2.0.0
[INFO] [stderr]    Compiling icu_locale_core v2.0.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.5
[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 pin-project-internal v1.1.10
[INFO] [stderr]    Compiling prost v0.13.5
[INFO] [stderr]    Compiling tokio-util v0.7.16
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling axum-core v0.4.5
[INFO] [stderr]    Compiling pin-project v1.1.10
[INFO] [stderr]    Compiling h2 v0.4.12
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling url v2.5.7
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling axum v0.7.9
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling tracing-error v0.2.1
[INFO] [stderr]    Compiling rand_chacha v0.2.2
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling half v2.7.0
[INFO] [stderr]    Compiling addr2line v0.25.1
[INFO] [stderr]    Compiling jpeg-decoder v0.3.2
[INFO] [stderr]    Compiling num-rational v0.4.2
[INFO] [stderr]    Compiling raw-cpuid v11.6.0
[INFO] [stderr]    Compiling approx v0.5.1
[INFO] [stderr]    Compiling fdeflate v0.3.7
[INFO] [stderr]    Compiling zune-inflate v0.2.54
[INFO] [stderr]    Compiling hyper v1.7.0
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling anstyle-query v1.1.4
[INFO] [stderr]    Compiling color_quant v1.1.0
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling lebe v0.5.3
[INFO] [stderr]    Compiling bit_field v0.10.3
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling anstyle v1.0.13
[INFO] [stderr]    Compiling indenter v0.3.4
[INFO] [stderr]    Compiling utf-8 v0.7.6
[INFO] [stderr]    Compiling ttf-parser v0.15.2
[INFO] [stderr]    Compiling rawpointer v0.2.1
[INFO] [stderr]    Compiling data-encoding v2.9.0
[INFO] [stderr]    Compiling rustc-demangle v0.1.26
[INFO] [stderr]    Compiling base64 v0.22.1
[INFO] [stderr]    Compiling hyper-util v0.1.17
[INFO] [stderr]    Compiling backtrace v0.3.76
[INFO] [stderr]    Compiling tungstenite v0.20.1
[INFO] [stderr]    Compiling dashmap v5.5.3
[INFO] [stderr]    Compiling hyper-tls v0.5.0
[INFO] [stderr]    Compiling anstream v0.6.21
[INFO] [stderr]    Compiling quanta v0.12.6
[INFO] [stderr]    Compiling exr v1.73.0
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling hyper-timeout v0.5.2
[INFO] [stderr]    Compiling tonic v0.12.3
[INFO] [stderr]    Compiling owned_ttf_parser v0.15.2
[INFO] [stderr]    Compiling png v0.17.16
[INFO] [stderr]    Compiling gif v0.13.3
[INFO] [stderr]    Compiling tiff v0.9.1
[INFO] [stderr]    Compiling simba v0.7.3
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling rand v0.7.3
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling prost-types v0.13.5
[INFO] [stderr]    Compiling deadpool-runtime v0.1.4
[INFO] [stderr]    Compiling rustls-pemfile v1.0.4
[INFO] [stderr]    Compiling num-iter v0.1.45
[INFO] [stderr]    Compiling qoi v0.4.1
[INFO] [stderr]    Compiling num_cpus v1.17.0
[INFO] [stderr]    Compiling spinning_top v0.3.0
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling custom_derive v0.1.7
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling nonzero_ext v0.3.0
[INFO] [stderr]    Compiling ab_glyph_rasterizer v0.1.10
[INFO] [stderr]    Compiling humantime v2.3.0
[INFO] [stderr]    Compiling no-std-compat v0.4.1
[INFO] [stderr]    Compiling futures-timer v3.0.3
[INFO] [stderr]    Compiling clap_builder v4.5.48
[INFO] [stderr]    Compiling console-api v0.8.1
[INFO] [stderr]    Compiling image v0.24.9
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling governor v0.6.3
[INFO] [stderr]    Compiling rusttype v0.9.3
[INFO] [stderr]    Compiling clap_derive v4.5.47
[INFO] [stderr]    Compiling conv v0.3.3
[INFO] [stderr]    Compiling deadpool v0.12.3
[INFO] [stderr]    Compiling num v0.4.3
[INFO] [stderr]    Compiling uuid v1.18.1
[INFO] [stderr]    Compiling rand_distr v0.2.2
[INFO] [stderr]    Compiling hdrhistogram v7.5.4
[INFO] [stderr]    Compiling color-eyre v0.6.5
[INFO] [stderr]    Compiling tokio-tungstenite v0.20.1
[INFO] [stderr]    Compiling nalgebra v0.30.1
[INFO] [stderr]    Compiling regex v1.12.1
[INFO] [stderr]    Compiling is-terminal v0.4.16
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling termcolor v1.4.1
[INFO] [stderr]    Compiling clap v4.5.48
[INFO] [stderr]    Compiling console-subscriber v0.4.1
[INFO] [stderr]    Compiling winter-paintboard-sdk v0.1.0 (/opt/rustwide/workdir/crates/winter-paintboard-sdk)
[INFO] [stderr]    Compiling env_logger v0.10.2
[INFO] [stdout] warning: unused imports: `Board`, `Pos`, `Rgb`, `config::Config`, and `error::PaintboardError`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     config::Config,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 26 |     error::PaintboardError,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 27 |     models::{Board, Pos, Rgb},
[INFO] [stdout]    |              ^^^^^  ^^^  ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AtomicBool` and `Ordering`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:29:25
[INFO] [stdout]    |
[INFO] [stdout] 29 | use std::sync::atomic::{AtomicBool, Ordering};
[INFO] [stdout]    |                         ^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_trait::async_trait`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | use async_trait::async_trait;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unexpected `cfg` condition value: `reqwest`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/error/mod.rs:216:7
[INFO] [stdout]     |
[INFO] [stdout] 216 | #[cfg(feature = "reqwest")]
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stdout]     |
[INFO] [stdout]     = note: no expected values for `feature`
[INFO] [stdout]     = help: consider adding `reqwest` as a feature in `Cargo.toml`
[INFO] [stdout]     = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]     = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stdout] warning: unused variable: `operations`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:104:9
[INFO] [stdout]     |
[INFO] [stdout] 104 |         operations: Vec<(Pos, Rgb)>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_operations`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uid`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:105:9
[INFO] [stdout]     |
[INFO] [stdout] 105 |         uid: u32,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_uid`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:106:9
[INFO] [stdout]     |
[INFO] [stdout] 106 |         token: &str,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event_bus`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:316:21
[INFO] [stdout]     |
[INFO] [stdout] 316 |                 let event_bus = EventBus::global();
[INFO] [stdout]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_bus`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `other`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:149:13
[INFO] [stdout]     |
[INFO] [stdout] 149 |             other => {
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_other`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config_clone`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:167:13
[INFO] [stdout]     |
[INFO] [stdout] 167 |         let config_clone = config.clone();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_config_clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `rate_limiter` is never read
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 61 | struct WsActor {
[INFO] [stdout]    |        ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 65 |     rate_limiter: Arc<WsRateLimiter>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `actor_task_handle` is never read
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:826:5
[INFO] [stdout]     |
[INFO] [stdout] 816 | pub struct AsyncWsProvider {
[INFO] [stdout]     |            --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 826 |     actor_task_handle: Arc<TokioMutex<Option<JoinHandle<()>>>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AsyncWsProvider` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WsConnection` is never constructed
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct WsConnection {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `stream`, `connect`, `is_connected`, `send_binary`, and `close` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:22:12
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl WsConnection {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout]  21 |     /// 创建一个新的 WsConnection（初始处于未连接状态）
[INFO] [stdout]  22 |     pub fn new(config: Arc<Config>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  30 |     pub fn stream(&self) -> Arc<TokioMutex<Option<WebSocketStream<MaybeTlsStream<TcpStream>>>>> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     pub async fn connect(&self) -> Result<(), PaintboardError> {
[INFO] [stdout]     |                  ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub async fn is_connected(&self) -> bool {
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  88 |     pub async fn send_binary(&self, data: Vec<u8>) -> Result<(), Report> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub async fn close(&self) -> Result<(), PaintboardError> {
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WsMessageHandler` is never constructed
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct WsMessageHandler {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `handle_message_stream`, `handle_single_message`, and `start_message_processing_task` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:27:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl WsMessageHandler {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout]  27 |     pub fn new(response_tracker: Arc<WsResponseTracker>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  32 |     pub async fn handle_message_stream(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     async fn handle_single_message(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub async fn start_message_processing_task(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `current_delay`, `max_delay`, and `initial_delay` are never read
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct WsReconnectStrategy {
[INFO] [stdout]    |            ------------------- fields in this struct
[INFO] [stdout] 12 |     should_reconnect: Arc<AtomicBool>,
[INFO] [stdout] 13 |     current_delay: Duration,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 14 |     max_delay: Duration,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 15 |     initial_delay: Duration,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `WsReconnectStrategy` 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 `should_reconnect`, `next_delay`, `reset`, and `current_delay` are never used
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl WsReconnectStrategy {
[INFO] [stdout]    | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn should_reconnect(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn next_delay(&mut self) -> Duration {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn reset(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn current_delay(&self) -> Duration {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `should_reconnect`, `next_delay`, `reset`, `current_delay`, and `reconnect` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:69:12
[INFO] [stdout]     |
[INFO] [stdout]  68 | impl WsReconnectManager {
[INFO] [stdout]     | ----------------------- associated items in this implementation
[INFO] [stdout]  69 |     pub fn new(initial_delay: Duration, max_delay: Duration) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  81 |     pub fn should_reconnect(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  89 |     pub async fn next_delay(&mut self) -> Duration {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub async fn reset(&mut self) {
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn current_delay(&self) -> Duration {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub async fn reconnect(&mut self, connection: Arc<WsConnection>) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `pending_count` is never used
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_response_tracker.rs:63:18
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl WsResponseTracker {
[INFO] [stdout]    | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub async fn pending_count(&self) -> usize {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling imageproc v0.23.0
[INFO] [stderr]    Compiling lgs-paintboard v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `time::Duration`
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{sync::Arc, time::Duration};
[INFO] [stdout]   |                      ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::app::multi_token::cli::get_penalty_scale`
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::app::multi_token::cli::get_penalty_scale;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/app/image_processing.rs:3:24
[INFO] [stdout]   |
[INFO] [stdout] 3 | use imageproc::edges::{self, canny};
[INFO] [stdout]   |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `clap::error`
[INFO] [stdout]  --> src/app/multi_token/paint_executor.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use clap::error;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `color_eyre::Report`
[INFO] [stdout]  --> src/app/multi_token/paint_executor.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use color_eyre::Report;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::Rgb`
[INFO] [stdout]  --> src/app/utils.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use winter_paintboard_sdk::Rgb;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `app::board_sync::local_board::LocalBoard::verify_integrity`: 不必要的完整性检查，造成性能损耗，改为返回 `true`
[INFO] [stdout]    --> src/app/board_sync/sync_manager.rs:166:35
[INFO] [stdout]     |
[INFO] [stdout] 166 |                         if !board.verify_integrity() {
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stdout]  --> src/app/board_sync/sync_manager.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PaintboardClientTrait`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:21:72
[INFO] [stdout]    |
[INFO] [stdout] 21 | use winter_paintboard_sdk::{basic_client::AsyncClient, config::Config, PaintboardClientTrait};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stdout]  --> src/app/multi_token/token_worker.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `original_version`
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:172:13
[INFO] [stdout]     |
[INFO] [stdout] 172 |         let original_version = self.version;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_version`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canny_low_thresh`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |         canny_low_thresh: f32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_low_thresh`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canny_high_thresh`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:77:9
[INFO] [stdout]    |
[INFO] [stdout] 77 |         canny_high_thresh: f32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_high_thresh`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/app/multi_token/token_manager.rs:120:29
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `access_keys`
[INFO] [stdout]   --> src/app/mod.rs:42:13
[INFO] [stdout]    |
[INFO] [stdout] 42 |             access_keys,
[INFO] [stdout]    |             ^^^^^^^^^^^ help: try ignoring the field: `access_keys: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uids`
[INFO] [stdout]   --> src/app/mod.rs:43:13
[INFO] [stdout]    |
[INFO] [stdout] 43 |             uids,
[INFO] [stdout]    |             ^^^^ help: try ignoring the field: `uids: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> src/app/mod.rs:214:9
[INFO] [stdout]     |
[INFO] [stdout] 214 |     let token = match validate_auth_args(&token, &access_key) {
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/app/mod.rs:110:73
[INFO] [stdout]     |
[INFO] [stdout] 110 |     let _ = multi_token::cli::PENALTY_SCALE.set(penalty_scale).map_err(|e| {
[INFO] [stdout]     |                                                                         ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cd_time`
[INFO] [stdout]   --> src/app/mod.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 |     cd_time: u64,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cd_time`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> src/app/mod.rs:137:13
[INFO] [stdout]     |
[INFO] [stdout] 137 |         let token = match (&first_token.token, &first_token.access_key) {
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HEATMAP_EXPIRE_DURATION_MILLS` is never used
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | const HEATMAP_EXPIRE_DURATION_MILLS: u64 = 10 * 60 * 1000; // 10min
[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 `source` and `timestamp` are never read
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct PixelStatus {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 21 |     pub color: Rgb,
[INFO] [stdout] 22 |     pub source: PixelSource,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 23 |     pub timestamp: std::time::SystemTime,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PixelStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:45:11
[INFO] [stdout]    |
[INFO] [stdout] 45 |     Error(String),
[INFO] [stdout]    |     ----- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SyncStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 45 -     Error(String),
[INFO] [stdout] 45 +     Error(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Syncing` is never constructed
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub enum SyncStatus {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] 43 |     Idle,
[INFO] [stdout] 44 |     Syncing,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SyncStatus` 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 `sync_status`, `last_sync_time`, and `version` are never used
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:218:12
[INFO] [stdout]     |
[INFO] [stdout]  48 | impl LocalBoard {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 218 |     pub fn sync_status(&self) -> &SyncStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn last_sync_time(&self) -> Option<&std::time::SystemTime> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 238 |     pub fn version(&self) -> u64 {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `start_sync_loop` and `stop` are never used
[INFO] [stdout]    --> src/app/board_sync/sync_manager.rs:38:18
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl BoardSyncManager {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  38 |     pub async fn start_sync_loop(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 297 |     pub async fn stop(&self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_client_type` is never used
[INFO] [stdout]    --> src/app/cli.rs:127:4
[INFO] [stdout]     |
[INFO] [stdout] 127 | fn parse_client_type(s: &str) -> Result<winter_paintboard_sdk::ClientType, String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `scale_level_operations` is never read
[INFO] [stdout]   --> src/app/image_processing.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct ProcessedImageData {
[INFO] [stdout]    |            ------------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 14 |     pub scale_level_operations: Vec<Vec<(winter_paintboard_sdk::Pos, winter_paintboard_sdk::Rgb)>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProcessedImageData` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_cli_args` is never used
[INFO] [stdout]   --> src/app/multi_token/config.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 26 | impl TokenConfig {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn from_cli_args(
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `metrics_handle` is never read
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct MultiTokenService {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 28 |     metrics_handle: Option<tokio::task::JoinHandle<()>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:44:18
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl MultiTokenService {
[INFO] [stdout]    | ---------------------- associated function in this implementation
[INFO] [stdout] 43 |     /// 创建新的多 Token 服务
[INFO] [stdout] 44 |     pub async fn new(
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `retry_count` and `max_retries` are never read
[INFO] [stdout]   --> src/app/multi_token/paint_request.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct PaintRequest {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout]  9 |     pub retry_count: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 10 |     pub max_retries: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PaintRequest` 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 `can_retry` and `increment_retry` are never used
[INFO] [stdout]   --> src/app/multi_token/paint_request.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl PaintRequest {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn can_retry(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn increment_retry(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `reset_and_push`, `len`, `is_empty`, and `get_all_pixels` are never used
[INFO] [stdout]   --> src/app/multi_token/pixel_queue.rs:22:18
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl PixelQueue {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub async fn reset_and_push(&self, pixels: Vec<PriorityPixel>) {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub async fn len(&self) -> usize {
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 43 |     pub async fn is_empty(&self) -> bool {
[INFO] [stdout]    |                  ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub async fn get_all_pixels(&self) -> Vec<PriorityPixel> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `last_paint_time` and `is_available` are never read
[INFO] [stdout]   --> src/app/multi_token/token_manager.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct TokenInfo {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 11 |     pub last_paint_time: Option<Instant>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 12 |     pub is_available: bool,
[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: associated function `new` is never used
[INFO] [stdout]   --> src/app/multi_token/token_manager.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl TokenInfo {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 16 |     /// 创建新的 TokenInfo
[INFO] [stdout] 17 |     pub fn new(uid: u32, token: String) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `cd_duration`, `next_available_time`, and `get_token` are never used
[INFO] [stdout]    --> src/app/multi_token/token_manager.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout]  34 | impl TokenManager {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub fn cd_duration(&self) -> Duration {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn next_available_time(&self) -> Option<Duration> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 120 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_auth_token` is never used
[INFO] [stdout]   --> src/app/utils.rs:46:14
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub async fn resolve_auth_token(
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `uid` is never read
[INFO] [stdout]   --> src/app/metrics/mod.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct TokenMetricsData {
[INFO] [stdout]    |            ---------------- field in this struct
[INFO] [stdout] 25 |     /// 关联的 UID
[INFO] [stdout] 26 |     pub uid: u32,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 4m 27s
[INFO] running `Command { std: "docker" "inspect" "78ac785dfd957b72ecdc7d7fcba29f4a7784b8e4a590380af5b7993d2c762b81", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "78ac785dfd957b72ecdc7d7fcba29f4a7784b8e4a590380af5b7993d2c762b81", kill_on_drop: false }`
[INFO] [stdout] 78ac785dfd957b72ecdc7d7fcba29f4a7784b8e4a590380af5b7993d2c762b81
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 64b068152cbd8948b5892ffb44398076133a3b1da968b208330f078db3cf7bda
[INFO] running `Command { std: "docker" "start" "-a" "64b068152cbd8948b5892ffb44398076133a3b1da968b208330f078db3cf7bda", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: only one of `license` or `license-file` is necessary
[INFO] [stderr] `license` should be used if the package license can be expressed with a standard SPDX expression.
[INFO] [stderr] `license-file` should be used if the package uses a non-standard license.
[INFO] [stderr] See https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields for more information.
[INFO] [stdout] warning: unused imports: `Board`, `Pos`, `Rgb`, `config::Config`, and `error::PaintboardError`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     config::Config,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 26 |     error::PaintboardError,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 27 |     models::{Board, Pos, Rgb},
[INFO] [stdout]    |              ^^^^^  ^^^  ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AtomicBool` and `Ordering`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:29:25
[INFO] [stdout]    |
[INFO] [stdout] 29 | use std::sync::atomic::{AtomicBool, Ordering};
[INFO] [stdout]    |                         ^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_trait::async_trait`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | use async_trait::async_trait;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unexpected `cfg` condition value: `reqwest`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/error/mod.rs:216:7
[INFO] [stdout]     |
[INFO] [stdout] 216 | #[cfg(feature = "reqwest")]
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stdout]     |
[INFO] [stdout]     = note: no expected values for `feature`
[INFO] [stdout]     = help: consider adding `reqwest` as a feature in `Cargo.toml`
[INFO] [stdout]     = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]     = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `operations`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:104:9
[INFO] [stdout]     |
[INFO] [stdout] 104 |         operations: Vec<(Pos, Rgb)>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_operations`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uid`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:105:9
[INFO] [stdout]     |
[INFO] [stdout] 105 |         uid: u32,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_uid`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:106:9
[INFO] [stdout]     |
[INFO] [stdout] 106 |         token: &str,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event_bus`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:316:21
[INFO] [stdout]     |
[INFO] [stdout] 316 |                 let event_bus = EventBus::global();
[INFO] [stdout]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_bus`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `other`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:149:13
[INFO] [stdout]     |
[INFO] [stdout] 149 |             other => {
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_other`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config_clone`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:167:13
[INFO] [stdout]     |
[INFO] [stdout] 167 |         let config_clone = config.clone();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_config_clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `rate_limiter` is never read
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 61 | struct WsActor {
[INFO] [stdout]    |        ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 65 |     rate_limiter: Arc<WsRateLimiter>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `actor_task_handle` is never read
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:826:5
[INFO] [stdout]     |
[INFO] [stdout] 816 | pub struct AsyncWsProvider {
[INFO] [stdout]     |            --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 826 |     actor_task_handle: Arc<TokioMutex<Option<JoinHandle<()>>>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AsyncWsProvider` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WsConnection` is never constructed
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct WsConnection {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `stream`, `connect`, `is_connected`, `send_binary`, and `close` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:22:12
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl WsConnection {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout]  21 |     /// 创建一个新的 WsConnection（初始处于未连接状态）
[INFO] [stdout]  22 |     pub fn new(config: Arc<Config>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  30 |     pub fn stream(&self) -> Arc<TokioMutex<Option<WebSocketStream<MaybeTlsStream<TcpStream>>>>> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     pub async fn connect(&self) -> Result<(), PaintboardError> {
[INFO] [stdout]     |                  ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub async fn is_connected(&self) -> bool {
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  88 |     pub async fn send_binary(&self, data: Vec<u8>) -> Result<(), Report> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub async fn close(&self) -> Result<(), PaintboardError> {
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WsMessageHandler` is never constructed
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct WsMessageHandler {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `handle_message_stream`, `handle_single_message`, and `start_message_processing_task` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:27:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl WsMessageHandler {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout]  27 |     pub fn new(response_tracker: Arc<WsResponseTracker>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  32 |     pub async fn handle_message_stream(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     async fn handle_single_message(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub async fn start_message_processing_task(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `current_delay`, `max_delay`, and `initial_delay` are never read
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct WsReconnectStrategy {
[INFO] [stdout]    |            ------------------- fields in this struct
[INFO] [stdout] 12 |     should_reconnect: Arc<AtomicBool>,
[INFO] [stdout] 13 |     current_delay: Duration,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 14 |     max_delay: Duration,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 15 |     initial_delay: Duration,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `WsReconnectStrategy` 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 `should_reconnect`, `next_delay`, `reset`, and `current_delay` are never used
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl WsReconnectStrategy {
[INFO] [stdout]    | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn should_reconnect(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn next_delay(&mut self) -> Duration {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn reset(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn current_delay(&self) -> Duration {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `should_reconnect`, `next_delay`, `reset`, `current_delay`, and `reconnect` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:69:12
[INFO] [stdout]     |
[INFO] [stdout]  68 | impl WsReconnectManager {
[INFO] [stdout]     | ----------------------- associated items in this implementation
[INFO] [stdout]  69 |     pub fn new(initial_delay: Duration, max_delay: Duration) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  81 |     pub fn should_reconnect(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  89 |     pub async fn next_delay(&mut self) -> Duration {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub async fn reset(&mut self) {
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn current_delay(&self) -> Duration {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub async fn reconnect(&mut self, connection: Arc<WsConnection>) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `pending_count` is never used
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_response_tracker.rs:63:18
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl WsResponseTracker {
[INFO] [stdout]    | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub async fn pending_count(&self) -> usize {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling lgs-paintboard v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `time::Duration`
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{sync::Arc, time::Duration};
[INFO] [stdout]   |                      ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::app::multi_token::cli::get_penalty_scale`
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::app::multi_token::cli::get_penalty_scale;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/app/image_processing.rs:3:24
[INFO] [stdout]   |
[INFO] [stdout] 3 | use imageproc::edges::{self, canny};
[INFO] [stdout]   |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `clap::error`
[INFO] [stdout]  --> src/app/multi_token/paint_executor.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use clap::error;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `color_eyre::Report`
[INFO] [stdout]  --> src/app/multi_token/paint_executor.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use color_eyre::Report;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::Rgb`
[INFO] [stdout]  --> src/app/utils.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use winter_paintboard_sdk::Rgb;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `app::board_sync::local_board::LocalBoard::verify_integrity`: 不必要的完整性检查，造成性能损耗，改为返回 `true`
[INFO] [stdout]    --> src/app/board_sync/sync_manager.rs:166:35
[INFO] [stdout]     |
[INFO] [stdout] 166 |                         if !board.verify_integrity() {
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stdout]  --> src/app/board_sync/sync_manager.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PaintboardClientTrait`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:21:72
[INFO] [stdout]    |
[INFO] [stdout] 21 | use winter_paintboard_sdk::{basic_client::AsyncClient, config::Config, PaintboardClientTrait};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stdout]  --> src/app/multi_token/token_worker.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `original_version`
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:172:13
[INFO] [stdout]     |
[INFO] [stdout] 172 |         let original_version = self.version;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_version`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canny_low_thresh`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |         canny_low_thresh: f32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_low_thresh`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canny_high_thresh`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:77:9
[INFO] [stdout]    |
[INFO] [stdout] 77 |         canny_high_thresh: f32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_high_thresh`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/app/multi_token/token_manager.rs:120:29
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `access_keys`
[INFO] [stdout]   --> src/app/mod.rs:42:13
[INFO] [stdout]    |
[INFO] [stdout] 42 |             access_keys,
[INFO] [stdout]    |             ^^^^^^^^^^^ help: try ignoring the field: `access_keys: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uids`
[INFO] [stdout]   --> src/app/mod.rs:43:13
[INFO] [stdout]    |
[INFO] [stdout] 43 |             uids,
[INFO] [stdout]    |             ^^^^ help: try ignoring the field: `uids: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> src/app/mod.rs:214:9
[INFO] [stdout]     |
[INFO] [stdout] 214 |     let token = match validate_auth_args(&token, &access_key) {
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/app/mod.rs:110:73
[INFO] [stdout]     |
[INFO] [stdout] 110 |     let _ = multi_token::cli::PENALTY_SCALE.set(penalty_scale).map_err(|e| {
[INFO] [stdout]     |                                                                         ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cd_time`
[INFO] [stdout]   --> src/app/mod.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 |     cd_time: u64,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cd_time`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> src/app/mod.rs:137:13
[INFO] [stdout]     |
[INFO] [stdout] 137 |         let token = match (&first_token.token, &first_token.access_key) {
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HEATMAP_EXPIRE_DURATION_MILLS` is never used
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | const HEATMAP_EXPIRE_DURATION_MILLS: u64 = 10 * 60 * 1000; // 10min
[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 `source` and `timestamp` are never read
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct PixelStatus {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 21 |     pub color: Rgb,
[INFO] [stdout] 22 |     pub source: PixelSource,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 23 |     pub timestamp: std::time::SystemTime,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PixelStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:45:11
[INFO] [stdout]    |
[INFO] [stdout] 45 |     Error(String),
[INFO] [stdout]    |     ----- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SyncStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 45 -     Error(String),
[INFO] [stdout] 45 +     Error(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Syncing` is never constructed
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub enum SyncStatus {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] 43 |     Idle,
[INFO] [stdout] 44 |     Syncing,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SyncStatus` 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 `sync_status`, `last_sync_time`, and `version` are never used
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:218:12
[INFO] [stdout]     |
[INFO] [stdout]  48 | impl LocalBoard {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 218 |     pub fn sync_status(&self) -> &SyncStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn last_sync_time(&self) -> Option<&std::time::SystemTime> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 238 |     pub fn version(&self) -> u64 {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `start_sync_loop` and `stop` are never used
[INFO] [stdout]    --> src/app/board_sync/sync_manager.rs:38:18
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl BoardSyncManager {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  38 |     pub async fn start_sync_loop(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 297 |     pub async fn stop(&self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_client_type` is never used
[INFO] [stdout]    --> src/app/cli.rs:127:4
[INFO] [stdout]     |
[INFO] [stdout] 127 | fn parse_client_type(s: &str) -> Result<winter_paintboard_sdk::ClientType, String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `scale_level_operations` is never read
[INFO] [stdout]   --> src/app/image_processing.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct ProcessedImageData {
[INFO] [stdout]    |            ------------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 14 |     pub scale_level_operations: Vec<Vec<(winter_paintboard_sdk::Pos, winter_paintboard_sdk::Rgb)>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProcessedImageData` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_cli_args` is never used
[INFO] [stdout]   --> src/app/multi_token/config.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 26 | impl TokenConfig {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn from_cli_args(
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `metrics_handle` is never read
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct MultiTokenService {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 28 |     metrics_handle: Option<tokio::task::JoinHandle<()>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:44:18
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl MultiTokenService {
[INFO] [stdout]    | ---------------------- associated function in this implementation
[INFO] [stdout] 43 |     /// 创建新的多 Token 服务
[INFO] [stdout] 44 |     pub async fn new(
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `retry_count` and `max_retries` are never read
[INFO] [stdout]   --> src/app/multi_token/paint_request.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct PaintRequest {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout]  9 |     pub retry_count: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 10 |     pub max_retries: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PaintRequest` 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 `can_retry` and `increment_retry` are never used
[INFO] [stdout]   --> src/app/multi_token/paint_request.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl PaintRequest {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn can_retry(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn increment_retry(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `reset_and_push`, `len`, `is_empty`, and `get_all_pixels` are never used
[INFO] [stdout]   --> src/app/multi_token/pixel_queue.rs:22:18
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl PixelQueue {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub async fn reset_and_push(&self, pixels: Vec<PriorityPixel>) {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub async fn len(&self) -> usize {
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 43 |     pub async fn is_empty(&self) -> bool {
[INFO] [stdout]    |                  ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub async fn get_all_pixels(&self) -> Vec<PriorityPixel> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `last_paint_time` and `is_available` are never read
[INFO] [stdout]   --> src/app/multi_token/token_manager.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct TokenInfo {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 11 |     pub last_paint_time: Option<Instant>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 12 |     pub is_available: bool,
[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: associated function `new` is never used
[INFO] [stdout]   --> src/app/multi_token/token_manager.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl TokenInfo {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 16 |     /// 创建新的 TokenInfo
[INFO] [stdout] 17 |     pub fn new(uid: u32, token: String) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `cd_duration`, `next_available_time`, and `get_token` are never used
[INFO] [stdout]    --> src/app/multi_token/token_manager.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout]  34 | impl TokenManager {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub fn cd_duration(&self) -> Duration {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn next_available_time(&self) -> Option<Duration> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 120 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_auth_token` is never used
[INFO] [stdout]   --> src/app/utils.rs:46:14
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub async fn resolve_auth_token(
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `uid` is never read
[INFO] [stdout]   --> src/app/metrics/mod.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct TokenMetricsData {
[INFO] [stdout]    |            ---------------- field in this struct
[INFO] [stdout] 25 |     /// 关联的 UID
[INFO] [stdout] 26 |     pub uid: u32,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused implementer of `Future` that must be used
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:260:9
[INFO] [stdout]     |
[INFO] [stdout] 260 |         board.update_pixel(10, 20, test_color, PixelSource::Own);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused implementer of `Future` that must be used
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:277:9
[INFO] [stdout]     |
[INFO] [stdout] 277 |         local.update_pixel(0, 0, Rgb::new(0, 0, 0), PixelSource::Own);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused implementer of `Future` that must be used
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:279:9
[INFO] [stdout]     |
[INFO] [stdout] 279 |         local.update_from_board(&server_board);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 6.26s
[INFO] running `Command { std: "docker" "inspect" "64b068152cbd8948b5892ffb44398076133a3b1da968b208330f078db3cf7bda", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "64b068152cbd8948b5892ffb44398076133a3b1da968b208330f078db3cf7bda", kill_on_drop: false }`
[INFO] [stdout] 64b068152cbd8948b5892ffb44398076133a3b1da968b208330f078db3cf7bda
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 5e7b8544b420c03ac67ffbeb07346ea00990f87fd8362b73a139386b19a2ee5a
[INFO] running `Command { std: "docker" "start" "-a" "5e7b8544b420c03ac67ffbeb07346ea00990f87fd8362b73a139386b19a2ee5a", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: only one of `license` or `license-file` is necessary
[INFO] [stderr] `license` should be used if the package license can be expressed with a standard SPDX expression.
[INFO] [stderr] `license-file` should be used if the package uses a non-standard license.
[INFO] [stderr] See https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields for more information.
[INFO] [stderr] warning: unused imports: `Board`, `Pos`, `Rgb`, `config::Config`, and `error::PaintboardError`
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 |     config::Config,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 26 |     error::PaintboardError,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 27 |     models::{Board, Pos, Rgb},
[INFO] [stderr]    |              ^^^^^  ^^^  ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `AtomicBool` and `Ordering`
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:29:25
[INFO] [stderr]    |
[INFO] [stderr] 29 | use std::sync::atomic::{AtomicBool, Ordering};
[INFO] [stderr]    |                         ^^^^^^^^^^  ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::sync::Arc`
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:30:5
[INFO] [stderr]    |
[INFO] [stderr] 30 | use std::sync::Arc;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `async_trait::async_trait`
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:32:5
[INFO] [stderr]    |
[INFO] [stderr] 32 | use async_trait::async_trait;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unexpected `cfg` condition value: `reqwest`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/error/mod.rs:216:7
[INFO] [stderr]     |
[INFO] [stderr] 216 | #[cfg(feature = "reqwest")]
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stderr]     |
[INFO] [stderr]     = note: no expected values for `feature`
[INFO] [stderr]     = help: consider adding `reqwest` as a feature in `Cargo.toml`
[INFO] [stderr]     = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stderr]     = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `operations`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:104:9
[INFO] [stderr]     |
[INFO] [stderr] 104 |         operations: Vec<(Pos, Rgb)>,
[INFO] [stderr]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_operations`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `uid`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:105:9
[INFO] [stderr]     |
[INFO] [stderr] 105 |         uid: u32,
[INFO] [stderr]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_uid`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `token`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:106:9
[INFO] [stderr]     |
[INFO] [stderr] 106 |         token: &str,
[INFO] [stderr]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `event_bus`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:316:21
[INFO] [stderr]     |
[INFO] [stderr] 316 |                 let event_bus = EventBus::global();
[INFO] [stderr]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_bus`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `other`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:149:13
[INFO] [stderr]     |
[INFO] [stderr] 149 |             other => {
[INFO] [stderr]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_other`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `config_clone`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:167:13
[INFO] [stderr]     |
[INFO] [stderr] 167 |         let config_clone = config.clone();
[INFO] [stderr]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_config_clone`
[INFO] [stderr] 
[INFO] [stderr] warning: field `rate_limiter` is never read
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:65:5
[INFO] [stderr]    |
[INFO] [stderr] 61 | struct WsActor {
[INFO] [stderr]    |        ------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 65 |     rate_limiter: Arc<WsRateLimiter>,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `actor_task_handle` is never read
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:826:5
[INFO] [stderr]     |
[INFO] [stderr] 816 | pub struct AsyncWsProvider {
[INFO] [stderr]     |            --------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 826 |     actor_task_handle: Arc<TokioMutex<Option<JoinHandle<()>>>>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `AsyncWsProvider` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `WsConnection` is never constructed
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:15:12
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub struct WsConnection {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `stream`, `connect`, `is_connected`, `send_binary`, and `close` are never used
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:22:12
[INFO] [stderr]     |
[INFO] [stderr]  20 | impl WsConnection {
[INFO] [stderr]     | ----------------- associated items in this implementation
[INFO] [stderr]  21 |     /// 创建一个新的 WsConnection（初始处于未连接状态）
[INFO] [stderr]  22 |     pub fn new(config: Arc<Config>) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr]  30 |     pub fn stream(&self) -> Arc<TokioMutex<Option<WebSocketStream<MaybeTlsStream<TcpStream>>>>> {
[INFO] [stderr]     |            ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  35 |     pub async fn connect(&self) -> Result<(), PaintboardError> {
[INFO] [stderr]     |                  ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  76 |     pub async fn is_connected(&self) -> bool {
[INFO] [stderr]     |                  ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  88 |     pub async fn send_binary(&self, data: Vec<u8>) -> Result<(), Report> {
[INFO] [stderr]     |                  ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 117 |     pub async fn close(&self) -> Result<(), PaintboardError> {
[INFO] [stderr]     |                  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `WsMessageHandler` is never constructed
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:22:12
[INFO] [stderr]    |
[INFO] [stderr] 22 | pub struct WsMessageHandler {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `handle_message_stream`, `handle_single_message`, and `start_message_processing_task` are never used
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:27:12
[INFO] [stderr]     |
[INFO] [stderr]  26 | impl WsMessageHandler {
[INFO] [stderr]     | --------------------- associated items in this implementation
[INFO] [stderr]  27 |     pub fn new(response_tracker: Arc<WsResponseTracker>) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr]  32 |     pub async fn handle_message_stream(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  85 |     async fn handle_single_message(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 156 |     pub async fn start_message_processing_task(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `current_delay`, `max_delay`, and `initial_delay` are never read
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub struct WsReconnectStrategy {
[INFO] [stderr]    |            ------------------- fields in this struct
[INFO] [stderr] 12 |     should_reconnect: Arc<AtomicBool>,
[INFO] [stderr] 13 |     current_delay: Duration,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 14 |     max_delay: Duration,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 15 |     initial_delay: Duration,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `WsReconnectStrategy` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `should_reconnect`, `next_delay`, `reset`, and `current_delay` are never used
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:35:12
[INFO] [stderr]    |
[INFO] [stderr] 18 | impl WsReconnectStrategy {
[INFO] [stderr]    | ------------------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 35 |     pub fn should_reconnect(&self) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 45 |     pub fn next_delay(&mut self) -> Duration {
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 53 |     pub fn reset(&mut self) {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 58 |     pub fn current_delay(&self) -> Duration {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `should_reconnect`, `next_delay`, `reset`, `current_delay`, and `reconnect` are never used
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:69:12
[INFO] [stderr]     |
[INFO] [stderr]  68 | impl WsReconnectManager {
[INFO] [stderr]     | ----------------------- associated items in this implementation
[INFO] [stderr]  69 |     pub fn new(initial_delay: Duration, max_delay: Duration) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr]  81 |     pub fn should_reconnect(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  89 |     pub async fn next_delay(&mut self) -> Duration {
[INFO] [stderr]     |                  ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  93 |     pub async fn reset(&mut self) {
[INFO] [stderr]     |                  ^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  97 |     pub fn current_delay(&self) -> Duration {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 101 |     pub async fn reconnect(&mut self, connection: Arc<WsConnection>) -> Result<()> {
[INFO] [stderr]     |                  ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `pending_count` is never used
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_response_tracker.rs:63:18
[INFO] [stderr]    |
[INFO] [stderr] 20 | impl WsResponseTracker {
[INFO] [stderr]    | ---------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 63 |     pub async fn pending_count(&self) -> usize {
[INFO] [stderr]    |                  ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `winter-paintboard-sdk` (lib) generated 21 warnings (run `cargo fix --lib -p winter-paintboard-sdk` to apply 10 suggestions)
[INFO] [stderr] warning: unused import: `time::Duration`
[INFO] [stderr]  --> src/app/board_sync/local_board.rs:1:22
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::{sync::Arc, time::Duration};
[INFO] [stderr]   |                      ^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::app::multi_token::cli::get_penalty_scale`
[INFO] [stderr]  --> src/app/board_sync/local_board.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::app::multi_token::cli::get_penalty_scale;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `self`
[INFO] [stderr]  --> src/app/image_processing.rs:3:24
[INFO] [stderr]   |
[INFO] [stderr] 3 | use imageproc::edges::{self, canny};
[INFO] [stderr]   |                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `clap::error`
[INFO] [stderr]  --> src/app/multi_token/paint_executor.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use clap::error;
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `color_eyre::Report`
[INFO] [stderr]  --> src/app/multi_token/paint_executor.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use color_eyre::Report;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `winter_paintboard_sdk::Rgb`
[INFO] [stderr]  --> src/app/utils.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use winter_paintboard_sdk::Rgb;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `app::board_sync::local_board::LocalBoard::verify_integrity`: 不必要的完整性检查，造成性能损耗，改为返回 `true`
[INFO] [stderr]    --> src/app/board_sync/sync_manager.rs:166:35
[INFO] [stderr]     |
[INFO] [stderr] 166 |                         if !board.verify_integrity() {
[INFO] [stderr]     |                                   ^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stderr]  --> src/app/board_sync/sync_manager.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `PaintboardClientTrait`
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:21:72
[INFO] [stderr]    |
[INFO] [stderr] 21 | use winter_paintboard_sdk::{basic_client::AsyncClient, config::Config, PaintboardClientTrait};
[INFO] [stderr]    |                                                                        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stderr]  --> src/app/multi_token/token_worker.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `original_version`
[INFO] [stderr]    --> src/app/board_sync/local_board.rs:172:13
[INFO] [stderr]     |
[INFO] [stderr] 172 |         let original_version = self.version;
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_version`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `canny_low_thresh`
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:76:9
[INFO] [stderr]    |
[INFO] [stderr] 76 |         canny_low_thresh: f32,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_low_thresh`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `canny_high_thresh`
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:77:9
[INFO] [stderr]    |
[INFO] [stderr] 77 |         canny_high_thresh: f32,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_high_thresh`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `index`
[INFO] [stderr]    --> src/app/multi_token/token_manager.rs:120:29
[INFO] [stderr]     |
[INFO] [stderr] 120 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stderr]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `access_keys`
[INFO] [stderr]   --> src/app/mod.rs:42:13
[INFO] [stderr]    |
[INFO] [stderr] 42 |             access_keys,
[INFO] [stderr]    |             ^^^^^^^^^^^ help: try ignoring the field: `access_keys: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `uids`
[INFO] [stderr]   --> src/app/mod.rs:43:13
[INFO] [stderr]    |
[INFO] [stderr] 43 |             uids,
[INFO] [stderr]    |             ^^^^ help: try ignoring the field: `uids: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `token`
[INFO] [stderr]    --> src/app/mod.rs:214:9
[INFO] [stderr]     |
[INFO] [stderr] 214 |     let token = match validate_auth_args(&token, &access_key) {
[INFO] [stderr]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/app/mod.rs:110:73
[INFO] [stderr]     |
[INFO] [stderr] 110 |     let _ = multi_token::cli::PENALTY_SCALE.set(penalty_scale).map_err(|e| {
[INFO] [stderr]     |                                                                         ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `cd_time`
[INFO] [stderr]   --> src/app/mod.rs:93:5
[INFO] [stderr]    |
[INFO] [stderr] 93 |     cd_time: u64,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cd_time`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `token`
[INFO] [stderr]    --> src/app/mod.rs:137:13
[INFO] [stderr]     |
[INFO] [stderr] 137 |         let token = match (&first_token.token, &first_token.access_key) {
[INFO] [stderr]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stderr] 
[INFO] [stderr] warning: constant `HEATMAP_EXPIRE_DURATION_MILLS` is never used
[INFO] [stderr]  --> src/app/board_sync/local_board.rs:9:7
[INFO] [stderr]   |
[INFO] [stderr] 9 | const HEATMAP_EXPIRE_DURATION_MILLS: u64 = 10 * 60 * 1000; // 10min
[INFO] [stderr]   |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: fields `source` and `timestamp` are never read
[INFO] [stderr]   --> src/app/board_sync/local_board.rs:22:9
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub struct PixelStatus {
[INFO] [stderr]    |            ----------- fields in this struct
[INFO] [stderr] 21 |     pub color: Rgb,
[INFO] [stderr] 22 |     pub source: PixelSource,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 23 |     pub timestamp: std::time::SystemTime,
[INFO] [stderr]    |         ^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `PixelStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/app/board_sync/local_board.rs:45:11
[INFO] [stderr]    |
[INFO] [stderr] 45 |     Error(String),
[INFO] [stderr]    |     ----- ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `SyncStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 45 -     Error(String),
[INFO] [stderr] 45 +     Error(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Syncing` is never constructed
[INFO] [stderr]   --> src/app/board_sync/local_board.rs:44:5
[INFO] [stderr]    |
[INFO] [stderr] 42 | pub enum SyncStatus {
[INFO] [stderr]    |          ---------- variant in this enum
[INFO] [stderr] 43 |     Idle,
[INFO] [stderr] 44 |     Syncing,
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `SyncStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `sync_status`, `last_sync_time`, and `version` are never used
[INFO] [stderr]    --> src/app/board_sync/local_board.rs:218:12
[INFO] [stderr]     |
[INFO] [stderr]  48 | impl LocalBoard {
[INFO] [stderr]     | --------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 218 |     pub fn sync_status(&self) -> &SyncStatus {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 228 |     pub fn last_sync_time(&self) -> Option<&std::time::SystemTime> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 238 |     pub fn version(&self) -> u64 {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `start_sync_loop` and `stop` are never used
[INFO] [stderr]    --> src/app/board_sync/sync_manager.rs:38:18
[INFO] [stderr]     |
[INFO] [stderr]  20 | impl BoardSyncManager {
[INFO] [stderr]     | --------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  38 |     pub async fn start_sync_loop(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 297 |     pub async fn stop(&self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]     |                  ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_client_type` is never used
[INFO] [stderr]    --> src/app/cli.rs:127:4
[INFO] [stderr]     |
[INFO] [stderr] 127 | fn parse_client_type(s: &str) -> Result<winter_paintboard_sdk::ClientType, String> {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `scale_level_operations` is never read
[INFO] [stderr]   --> src/app/image_processing.rs:14:9
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub struct ProcessedImageData {
[INFO] [stderr]    |            ------------------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 14 |     pub scale_level_operations: Vec<Vec<(winter_paintboard_sdk::Pos, winter_paintboard_sdk::Rgb)>>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProcessedImageData` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_cli_args` is never used
[INFO] [stderr]   --> src/app/multi_token/config.rs:35:12
[INFO] [stderr]    |
[INFO] [stderr] 26 | impl TokenConfig {
[INFO] [stderr]    | ---------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 35 |     pub fn from_cli_args(
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `metrics_handle` is never read
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:28:5
[INFO] [stderr]    |
[INFO] [stderr] 24 | pub struct MultiTokenService {
[INFO] [stderr]    |            ----------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 28 |     metrics_handle: Option<tokio::task::JoinHandle<()>>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:44:18
[INFO] [stderr]    |
[INFO] [stderr] 42 | impl MultiTokenService {
[INFO] [stderr]    | ---------------------- associated function in this implementation
[INFO] [stderr] 43 |     /// 创建新的多 Token 服务
[INFO] [stderr] 44 |     pub async fn new(
[INFO] [stderr]    |                  ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `retry_count` and `max_retries` are never read
[INFO] [stderr]   --> src/app/multi_token/paint_request.rs:9:9
[INFO] [stderr]    |
[INFO] [stderr]  6 | pub struct PaintRequest {
[INFO] [stderr]    |            ------------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr]  9 |     pub retry_count: u32,
[INFO] [stderr]    |         ^^^^^^^^^^^
[INFO] [stderr] 10 |     pub max_retries: u32,
[INFO] [stderr]    |         ^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `PaintRequest` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `can_retry` and `increment_retry` are never used
[INFO] [stderr]   --> src/app/multi_token/paint_request.rs:23:12
[INFO] [stderr]    |
[INFO] [stderr] 13 | impl PaintRequest {
[INFO] [stderr]    | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 23 |     pub fn can_retry(&self) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 27 |     pub fn increment_retry(&mut self) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `reset_and_push`, `len`, `is_empty`, and `get_all_pixels` are never used
[INFO] [stderr]   --> src/app/multi_token/pixel_queue.rs:22:18
[INFO] [stderr]    |
[INFO] [stderr] 13 | impl PixelQueue {
[INFO] [stderr]    | --------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 22 |     pub async fn reset_and_push(&self, pixels: Vec<PriorityPixel>) {
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 37 |     pub async fn len(&self) -> usize {
[INFO] [stderr]    |                  ^^^
[INFO] [stderr] ...
[INFO] [stderr] 43 |     pub async fn is_empty(&self) -> bool {
[INFO] [stderr]    |                  ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 49 |     pub async fn get_all_pixels(&self) -> Vec<PriorityPixel> {
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `last_paint_time` and `is_available` are never read
[INFO] [stderr]   --> src/app/multi_token/token_manager.rs:11:9
[INFO] [stderr]    |
[INFO] [stderr]  8 | pub struct TokenInfo {
[INFO] [stderr]    |            --------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 11 |     pub last_paint_time: Option<Instant>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^
[INFO] [stderr] 12 |     pub is_available: bool,
[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: associated function `new` is never used
[INFO] [stderr]   --> src/app/multi_token/token_manager.rs:17:12
[INFO] [stderr]    |
[INFO] [stderr] 15 | impl TokenInfo {
[INFO] [stderr]    | -------------- associated function in this implementation
[INFO] [stderr] 16 |     /// 创建新的 TokenInfo
[INFO] [stderr] 17 |     pub fn new(uid: u32, token: String) -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `cd_duration`, `next_available_time`, and `get_token` are never used
[INFO] [stderr]    --> src/app/multi_token/token_manager.rs:110:12
[INFO] [stderr]     |
[INFO] [stderr]  34 | impl TokenManager {
[INFO] [stderr]     | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 110 |     pub fn cd_duration(&self) -> Duration {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 115 |     pub fn next_available_time(&self) -> Option<Duration> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 120 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `resolve_auth_token` is never used
[INFO] [stderr]   --> src/app/utils.rs:46:14
[INFO] [stderr]    |
[INFO] [stderr] 46 | pub async fn resolve_auth_token(
[INFO] [stderr]    |              ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `uid` is never read
[INFO] [stderr]   --> src/app/metrics/mod.rs:26:9
[INFO] [stderr]    |
[INFO] [stderr] 24 | pub struct TokenMetricsData {
[INFO] [stderr]    |            ---------------- field in this struct
[INFO] [stderr] 25 |     /// 关联的 UID
[INFO] [stderr] 26 |     pub uid: u32,
[INFO] [stderr]    |         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused implementer of `Future` that must be used
[INFO] [stderr]    --> src/app/board_sync/local_board.rs:260:9
[INFO] [stderr]     |
[INFO] [stderr] 260 |         board.update_pixel(10, 20, test_color, PixelSource::Own);
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused implementer of `Future` that must be used
[INFO] [stderr]    --> src/app/board_sync/local_board.rs:277:9
[INFO] [stderr]     |
[INFO] [stderr] 277 |         local.update_pixel(0, 0, Rgb::new(0, 0, 0), PixelSource::Own);
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stderr] 
[INFO] [stderr] warning: unused implementer of `Future` that must be used
[INFO] [stderr]    --> src/app/board_sync/local_board.rs:279:9
[INFO] [stderr]     |
[INFO] [stderr] 279 |         local.update_from_board(&server_board);
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stderr] 
[INFO] [stderr] warning: `lgs-paintboard` (bin "lgs-paintboard" test) generated 42 warnings (run `cargo fix --bin "lgs-paintboard" -p lgs-paintboard --tests` to apply 16 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.48s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/lgs_paintboard-4979f75ad1c08a0a)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test app::board_sync::local_board::tests::test_local_board_creation ... ok
[INFO] [stdout] test app::board_sync::local_board::tests::test_update_from_board_applies_server_data ... FAILED
[INFO] [stdout] test app::board_sync::local_board::tests::test_local_board_pixel_operations ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- app::board_sync::local_board::tests::test_update_from_board_applies_server_data stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'app::board_sync::local_board::tests::test_update_from_board_applies_server_data' (19) panicked at src/app/board_sync/local_board.rs:282:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: None
[INFO] [stdout]  right: Some(Rgb { r: 255, g: 255, b: 255 })
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5cbfce7c4762 - std::backtrace_rs::backtrace::libunwind::trace::h786de35fecf3582f
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5cbfce7c4762 - std::backtrace_rs::backtrace::trace_unsynchronized::h4a7da1a2a64387f1
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5cbfce7c4762 - std::sys::backtrace::_print_fmt::h6bd7d500070c788c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5cbfce7c4762 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h6d82c1afff976903
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5cbfce7d4bcf - core::fmt::rt::Argument::fmt::hc4ce6d643d397690
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5cbfce7d4bcf - core::fmt::write::hb1e7ca88b6a3936e
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/fmt/mod.rs:1469:25
[INFO] [stdout]    6:     0x5cbfce791ba3 - std::io::default_write_fmt::haffd49d96f1984a8
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5cbfce791ba3 - std::io::Write::write_fmt::h027871c57cf57c01
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5cbfce79dc22 - std::sys::backtrace::BacktraceLock::print::ha2430613ee79d059
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5cbfce7a286f - std::panicking::default_hook::{{closure}}::hdbd2db9e5c303cf6
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x5cbfce7a2701 - std::panicking::default_hook::hed93c70cba5fdcf0
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x5cbfce6d1a3e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hd0ee8b569efc6a07
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   12:     0x5cbfce6d1a3e - test::test_main_with_exit_callback::{{closure}}::hf10864b576ecd15d
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5cbfce7a2f2f - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h3a55ca34534c0d00
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   14:     0x5cbfce7a2f2f - std::panicking::panic_with_hook::h3862d766c2cec19b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x5cbfce7a2cda - std::panicking::panic_handler::{{closure}}::hb95eb402b5e28ee1
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:707:13
[INFO] [stdout]   16:     0x5cbfce79dd59 - std::sys::backtrace::__rust_end_short_backtrace::hf73a26dc1835d85a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x5cbfce78643d - __rustc[6ed5915ee467787]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x5cbfce7dc880 - core::panicking::panic_fmt::h3454303eb8e6f7cd
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5cbfce7dc683 - core::panicking::assert_failed_inner::hdcc703ae7c807131
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:444:17
[INFO] [stdout]   20:     0x5cbfce6a73ba - core::panicking::assert_failed::he20c9bfc220f7f8e
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:399:5
[INFO] [stdout]   21:     0x5cbfce6af8b5 - lgs_paintboard::app::board_sync::local_board::tests::test_update_from_board_applies_server_data::{{closure}}::h9d7720643619d691
[INFO] [stdout]                                at /opt/rustwide/workdir/src/app/board_sync/local_board.rs:282:9
[INFO] [stdout]   22:     0x5cbfce6ac962 - <core::pin::Pin<P> as core::future::future::Future>::poll::h0f0f357db8264605
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x5cbfce6ac9dd - <core::pin::Pin<P> as core::future::future::Future>::poll::hf96245f1cf7e589e
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x5cbfce6ac4ad - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::{{closure}}::hc519c7801d76e1f2
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:70
[INFO] [stdout]   25:     0x5cbfce6ac20b - tokio::task::coop::with_budget::h225224ce99f2e9d0
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:167:5
[INFO] [stdout]   26:     0x5cbfce6ac20b - tokio::task::coop::budget::h914b3c383c880efc
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:133:5
[INFO] [stdout]   27:     0x5cbfce6ac20b - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::h348bf788eb2ad7f4
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:25
[INFO] [stdout]   28:     0x5cbfce6a9560 - tokio::runtime::scheduler::current_thread::Context::enter::h621de83e5b94a171
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:432:19
[INFO] [stdout]   29:     0x5cbfce6aae4d - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::h7bdcb1f1387b9eb1
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:741:44
[INFO] [stdout]   30:     0x5cbfce6aaaf4 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::{{closure}}::heb79c2bc80404160
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:68
[INFO] [stdout]   31:     0x5cbfce6ae11b - tokio::runtime::context::scoped::Scoped<T>::set::hf03b80eb1f1d727a
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x5cbfce6b1039 - tokio::runtime::context::set_scheduler::{{closure}}::h672559bdde15fb5f
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:38
[INFO] [stdout]   33:     0x5cbfce6a62a2 - std::thread::local::LocalKey<T>::try_with::h976d7c8f32e77b4c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/local.rs:508:12
[INFO] [stdout]   34:     0x5cbfce6a574e - std::thread::local::LocalKey<T>::with::h8162d8eda6da6e35
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/local.rs:472:20
[INFO] [stdout]   35:     0x5cbfce6b0fad - tokio::runtime::context::set_scheduler::h3b2363859a8cadbd
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:17
[INFO] [stdout]   36:     0x5cbfce6aa480 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::h10e1d67cee86256e
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:27
[INFO] [stdout]   37:     0x5cbfce6aab33 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::h6986b4e6d2abf601
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:729:24
[INFO] [stdout]   38:     0x5cbfce6a8e20 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::{{closure}}::hc2cf87aac67ce406
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   39:     0x5cbfce6ad080 - tokio::runtime::context::runtime::enter_runtime::h9552eadebffdbeff
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x5cbfce6a87e1 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::h25b54c222e8e8379
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   41:     0x5cbfce6b00e4 - tokio::runtime::runtime::Runtime::block_on_inner::hfe76fc758c59da23
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:356:52
[INFO] [stdout]   42:     0x5cbfce6b02ac - tokio::runtime::runtime::Runtime::block_on::he4fb73a281ce39e4
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:330:18
[INFO] [stdout]   43:     0x5cbfce6af267 - lgs_paintboard::app::board_sync::local_board::tests::test_update_from_board_applies_server_data::h63f3dd41f26b72ac
[INFO] [stdout]                                at /opt/rustwide/workdir/src/app/board_sync/local_board.rs:284:40
[INFO] [stdout]   44:     0x5cbfce6afa87 - lgs_paintboard::app::board_sync::local_board::tests::test_update_from_board_applies_server_data::{{closure}}::hf3b7a7287c3d89df
[INFO] [stdout]                                at /opt/rustwide/workdir/src/app/board_sync/local_board.rs:266:58
[INFO] [stdout]   45:     0x5cbfce6a45d6 - core::ops::function::FnOnce::call_once::h5431fec4de134baa
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x5cbfce6d181b - core::ops::function::FnOnce::call_once::ha729ee35d2fab541
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x5cbfce6d181b - test::__rust_begin_short_backtrace::ha40f4db8207e1111
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:663:18
[INFO] [stdout]   48:     0x5cbfce6e589d - test::run_test_in_process::{{closure}}::hc1b77cda5d44f0f3
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:686:74
[INFO] [stdout]   49:     0x5cbfce6e589d - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h1dbea1de64785521
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   50:     0x5cbfce6e589d - std::panicking::catch_unwind::do_call::hd5febe9affd5a1b3
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:590:40
[INFO] [stdout]   51:     0x5cbfce6e589d - std::panicking::catch_unwind::h51ea89627559b6f4
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:553:19
[INFO] [stdout]   52:     0x5cbfce6e589d - std::panic::catch_unwind::hb8b8c2367cae3d66
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panic.rs:359:14
[INFO] [stdout]   53:     0x5cbfce6e589d - test::run_test_in_process::ha5b55801407ea100
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:686:27
[INFO] [stdout]   54:     0x5cbfce6e589d - test::run_test::{{closure}}::h0b9d4072b527abf5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:607:43
[INFO] [stdout]   55:     0x5cbfce6bedb4 - test::run_test::{{closure}}::hb1056b5731205822
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:637:41
[INFO] [stdout]   56:     0x5cbfce6bedb4 - std::sys::backtrace::__rust_begin_short_backtrace::hb61ff5a34023c7ef
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   57:     0x5cbfce6c26ea - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hb0a83c0e8b353cff
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/mod.rs:562:17
[INFO] [stdout]   58:     0x5cbfce6c26ea - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hb4f32cb008535298
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   59:     0x5cbfce6c26ea - std::panicking::catch_unwind::do_call::h16d110e4fc35789a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:590:40
[INFO] [stdout]   60:     0x5cbfce6c26ea - std::panicking::catch_unwind::hea9118f355699c4b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:553:19
[INFO] [stdout]   61:     0x5cbfce6c26ea - std::panic::catch_unwind::hf4b3c2a06d3f42f5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panic.rs:359:14
[INFO] [stdout]   62:     0x5cbfce6c26ea - std::thread::Builder::spawn_unchecked_::{{closure}}::h3f4cb733a52d53d5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/mod.rs:560:30
[INFO] [stdout]   63:     0x5cbfce6c26ea - core::ops::function::FnOnce::call_once{{vtable.shim}}::h4052f0967b37caeb
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   64:     0x5cbfce79915f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h7ec433abd3f148b4
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2085:9
[INFO] [stdout]   65:     0x5cbfce79915f - std::sys::thread::unix::Thread::new::thread_start::he514622d3d7ba65c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/thread/unix.rs:124:17
[INFO] [stdout]   66:     0x71bf4d35baa4 - <unknown>
[INFO] [stdout]   67:     0x71bf4d3e8a64 - clone
[INFO] [stdout]   68:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- app::board_sync::local_board::tests::test_local_board_pixel_operations stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'app::board_sync::local_board::tests::test_local_board_pixel_operations' (18) panicked at src/app/board_sync/local_board.rs:261:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: None
[INFO] [stdout]  right: Some(Rgb { r: 255, g: 0, b: 0 })
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5cbfce7c4762 - std::backtrace_rs::backtrace::libunwind::trace::h786de35fecf3582f
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5cbfce7c4762 - std::backtrace_rs::backtrace::trace_unsynchronized::h4a7da1a2a64387f1
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5cbfce7c4762 - std::sys::backtrace::_print_fmt::h6bd7d500070c788c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5cbfce7c4762 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h6d82c1afff976903
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5cbfce7d4bcf - core::fmt::rt::Argument::fmt::hc4ce6d643d397690
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5cbfce7d4bcf - core::fmt::write::hb1e7ca88b6a3936e
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/fmt/mod.rs:1469:25
[INFO] [stdout]    6:     0x5cbfce791ba3 - std::io::default_write_fmt::haffd49d96f1984a8
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5cbfce791ba3 - std::io::Write::write_fmt::h027871c57cf57c01
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5cbfce79dc22 - std::sys::backtrace::BacktraceLock::print::ha2430613ee79d059
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5cbfce7a286f - std::panicking::default_hook::{{closure}}::hdbd2db9e5c303cf6
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x5cbfce7a2701 - std::panicking::default_hook::hed93c70cba5fdcf0
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x5cbfce6d1a3e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hd0ee8b569efc6a07
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   12:     0x5cbfce6d1a3e - test::test_main_with_exit_callback::{{closure}}::hf10864b576ecd15d
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5cbfce7a2f2f - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h3a55ca34534c0d00
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   14:     0x5cbfce7a2f2f - std::panicking::panic_with_hook::h3862d766c2cec19b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x5cbfce7a2cda - std::panicking::panic_handler::{{closure}}::hb95eb402b5e28ee1
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:707:13
[INFO] [stdout]   16:     0x5cbfce79dd59 - std::sys::backtrace::__rust_end_short_backtrace::hf73a26dc1835d85a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x5cbfce78643d - __rustc[6ed5915ee467787]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x5cbfce7dc880 - core::panicking::panic_fmt::h3454303eb8e6f7cd
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5cbfce7dc683 - core::panicking::assert_failed_inner::hdcc703ae7c807131
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:444:17
[INFO] [stdout]   20:     0x5cbfce6a73ba - core::panicking::assert_failed::he20c9bfc220f7f8e
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:399:5
[INFO] [stdout]   21:     0x5cbfce6af058 - lgs_paintboard::app::board_sync::local_board::tests::test_local_board_pixel_operations::{{closure}}::hc0361430387eec30
[INFO] [stdout]                                at /opt/rustwide/workdir/src/app/board_sync/local_board.rs:261:9
[INFO] [stdout]   22:     0x5cbfce6ac962 - <core::pin::Pin<P> as core::future::future::Future>::poll::h0f0f357db8264605
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x5cbfce6ac9dd - <core::pin::Pin<P> as core::future::future::Future>::poll::hf96245f1cf7e589e
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x5cbfce6ac4ad - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::{{closure}}::hc519c7801d76e1f2
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:70
[INFO] [stdout]   25:     0x5cbfce6ac20b - tokio::task::coop::with_budget::h225224ce99f2e9d0
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:167:5
[INFO] [stdout]   26:     0x5cbfce6ac20b - tokio::task::coop::budget::h914b3c383c880efc
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:133:5
[INFO] [stdout]   27:     0x5cbfce6ac20b - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::h348bf788eb2ad7f4
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:25
[INFO] [stdout]   28:     0x5cbfce6a9560 - tokio::runtime::scheduler::current_thread::Context::enter::h621de83e5b94a171
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:432:19
[INFO] [stdout]   29:     0x5cbfce6aae4d - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::h7bdcb1f1387b9eb1
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:741:44
[INFO] [stdout]   30:     0x5cbfce6aaaf4 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::{{closure}}::heb79c2bc80404160
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:68
[INFO] [stdout]   31:     0x5cbfce6ae11b - tokio::runtime::context::scoped::Scoped<T>::set::hf03b80eb1f1d727a
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x5cbfce6b1039 - tokio::runtime::context::set_scheduler::{{closure}}::h672559bdde15fb5f
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:38
[INFO] [stdout]   33:     0x5cbfce6a62a2 - std::thread::local::LocalKey<T>::try_with::h976d7c8f32e77b4c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/local.rs:508:12
[INFO] [stdout]   34:     0x5cbfce6a574e - std::thread::local::LocalKey<T>::with::h8162d8eda6da6e35
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/local.rs:472:20
[INFO] [stdout]   35:     0x5cbfce6b0fad - tokio::runtime::context::set_scheduler::h3b2363859a8cadbd
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:17
[INFO] [stdout]   36:     0x5cbfce6aa480 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::h10e1d67cee86256e
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:27
[INFO] [stdout]   37:     0x5cbfce6aab33 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::h6986b4e6d2abf601
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:729:24
[INFO] [stdout]   38:     0x5cbfce6a8e20 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::{{closure}}::hc2cf87aac67ce406
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   39:     0x5cbfce6ad080 - tokio::runtime::context::runtime::enter_runtime::h9552eadebffdbeff
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x5cbfce6a87e1 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::h25b54c222e8e8379
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   41:     0x5cbfce6b00e4 - tokio::runtime::runtime::Runtime::block_on_inner::hfe76fc758c59da23
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:356:52
[INFO] [stdout]   42:     0x5cbfce6b02ac - tokio::runtime::runtime::Runtime::block_on::he4fb73a281ce39e4
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:330:18
[INFO] [stdout]   43:     0x5cbfce6aed67 - lgs_paintboard::app::board_sync::local_board::tests::test_local_board_pixel_operations::hd782ed858cb08eff
[INFO] [stdout]                                at /opt/rustwide/workdir/src/app/board_sync/local_board.rs:262:50
[INFO] [stdout]   44:     0x5cbfce6aedf7 - lgs_paintboard::app::board_sync::local_board::tests::test_local_board_pixel_operations::{{closure}}::h726af12dea1b9dd5
[INFO] [stdout]                                at /opt/rustwide/workdir/src/app/board_sync/local_board.rs:256:49
[INFO] [stdout]   45:     0x5cbfce6a4666 - core::ops::function::FnOnce::call_once::h82a84d367000ac7a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x5cbfce6d181b - core::ops::function::FnOnce::call_once::ha729ee35d2fab541
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x5cbfce6d181b - test::__rust_begin_short_backtrace::ha40f4db8207e1111
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:663:18
[INFO] [stdout]   48:     0x5cbfce6e589d - test::run_test_in_process::{{closure}}::hc1b77cda5d44f0f3
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:686:74
[INFO] [stdout]   49:     0x5cbfce6e589d - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h1dbea1de64785521
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   50:     0x5cbfce6e589d - std::panicking::catch_unwind::do_call::hd5febe9affd5a1b3
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:590:40
[INFO] [stdout]   51:     0x5cbfce6e589d - std::panicking::catch_unwind::h51ea89627559b6f4
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:553:19
[INFO] [stdout]   52:     0x5cbfce6e589d - std::panic::catch_unwind::hb8b8c2367cae3d66
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panic.rs:359:14
[INFO] [stdout]   53:     0x5cbfce6e589d - test::run_test_in_process::ha5b55801407ea100
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:686:27
[INFO] [stdout]   54:     0x5cbfce6e589d - test::run_test::{{closure}}::h0b9d4072b527abf5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:607:43
[INFO] [stdout]   55:     0x5cbfce6bedb4 - test::run_test::{{closure}}::hb1056b5731205822
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:637:41
[INFO] [stdout]   56:     0x5cbfce6bedb4 - std::sys::backtrace::__rust_begin_short_backtrace::hb61ff5a34023c7ef
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   57:     0x5cbfce6c26ea - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hb0a83c0e8b353cff
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/mod.rs:562:17
[INFO] [stdout]   58:     0x5cbfce6c26ea - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hb4f32cb008535298
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   59:     0x5cbfce6c26ea - std::panicking::catch_unwind::do_call::h16d110e4fc35789a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:590:40
[INFO] [stdout]   60:     0x5cbfce6c26ea - std::panicking::catch_unwind::hea9118f355699c4b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:553:19
[INFO] [stdout]   61:     0x5cbfce6c26ea - std::panic::catch_unwind::hf4b3c2a06d3f42f5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panic.rs:359:14
[INFO] [stdout]   62:     0x5cbfce6c26ea - std::thread::Builder::spawn_unchecked_::{{closure}}::h3f4cb733a52d53d5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/mod.rs:560:30
[INFO] [stdout]   63:     0x5cbfce6c26ea - core::ops::function::FnOnce::call_once{{vtable.shim}}::h4052f0967b37caeb
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   64:     0x5cbfce79915f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h7ec433abd3f148b4
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2085:9
[INFO] [stdout]   65:     0x5cbfce79915f - std::sys::thread::unix::Thread::new::thread_start::he514622d3d7ba65c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/thread/unix.rs:124:17
[INFO] [stdout]   66:     0x71bf4d35baa4 - <unknown>
[INFO] [stdout]   67:     0x71bf4d3e8a64 - clone
[INFO] [stdout]   68:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     app::board_sync::local_board::tests::test_local_board_pixel_operations
[INFO] [stdout]     app::board_sync::local_board::tests::test_update_from_board_applies_server_data
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 1 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.34s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin lgs-paintboard`
[INFO] running `Command { std: "docker" "inspect" "5e7b8544b420c03ac67ffbeb07346ea00990f87fd8362b73a139386b19a2ee5a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5e7b8544b420c03ac67ffbeb07346ea00990f87fd8362b73a139386b19a2ee5a", kill_on_drop: false }`
[INFO] [stdout] 5e7b8544b420c03ac67ffbeb07346ea00990f87fd8362b73a139386b19a2ee5a
