[INFO] cloning repository https://github.com/YeShengDe/OneKey
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/YeShengDe/OneKey" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FYeShengDe%2FOneKey", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FYeShengDe%2FOneKey'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 03ef38fcb015f4b4c0c9d0d2e8a7df8c41f92cd2
[INFO] checking YeShengDe/OneKey against master#779e19d8baa3e3625bd4fc5c85cbb2ad47b43155 for pr-147589-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FYeShengDe%2FOneKey" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/YeShengDe/OneKey
[INFO] finished tweaking git repo https://github.com/YeShengDe/OneKey
[INFO] tweaked toml for git repo https://github.com/YeShengDe/OneKey written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/YeShengDe/OneKey on toolchain 779e19d8baa3e3625bd4fc5c85cbb2ad47b43155
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/YeShengDe/OneKey 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" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded sysinfo v0.31.4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 4cfd675673e2681f6e2b7a64eba7b129ea19441731d50175a0b99799bd72431c
[INFO] running `Command { std: "docker" "start" "-a" "4cfd675673e2681f6e2b7a64eba7b129ea19441731d50175a0b99799bd72431c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4cfd675673e2681f6e2b7a64eba7b129ea19441731d50175a0b99799bd72431c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4cfd675673e2681f6e2b7a64eba7b129ea19441731d50175a0b99799bd72431c", kill_on_drop: false }`
[INFO] [stdout] 4cfd675673e2681f6e2b7a64eba7b129ea19441731d50175a0b99799bd72431c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c4344e8d45ae905d6a5ea42a251b0d6220cf28f7f79dfbf0c1366a2ef2d430c7
[INFO] running `Command { std: "docker" "start" "-a" "c4344e8d45ae905d6a5ea42a251b0d6220cf28f7f79dfbf0c1366a2ef2d430c7", kill_on_drop: false }`
[INFO] [stderr]    Compiling cc v1.2.27
[INFO] [stderr]    Compiling syn v2.0.104
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking signal-hook v0.3.18
[INFO] [stderr]     Checking mio v0.8.11
[INFO] [stderr]     Checking castaway v0.2.3
[INFO] [stderr]     Checking itertools v0.13.0
[INFO] [stderr]     Checking rayon v1.10.0
[INFO] [stderr]     Checking itertools v0.12.1
[INFO] [stderr]     Checking lru v0.12.5
[INFO] [stderr]     Checking rustix v1.0.7
[INFO] [stderr]     Checking num_cpus v1.17.0
[INFO] [stderr]     Checking compact_str v0.7.1
[INFO] [stderr]     Checking signal-hook-mio v0.2.4
[INFO] [stderr]     Checking crossterm v0.27.0
[INFO] [stderr]     Checking unicode-truncate v1.1.0
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]     Checking tempfile v3.20.0
[INFO] [stderr]     Checking sysinfo v0.31.4
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling stability v0.2.1
[INFO] [stderr]     Checking tokio v1.45.1
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking yoke v0.8.0
[INFO] [stderr]     Checking zerovec v0.11.2
[INFO] [stderr]     Checking zerotrie v0.2.2
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]     Checking ratatui v0.26.3
[INFO] [stderr]     Checking tinystr v0.8.1
[INFO] [stderr]     Checking potential_utf v0.1.2
[INFO] [stderr]     Checking icu_collections v2.0.0
[INFO] [stderr]     Checking serde v1.0.219
[INFO] [stderr]     Checking icu_locale_core v2.0.0
[INFO] [stderr]     Checking icu_provider v2.0.0
[INFO] [stderr]     Checking icu_properties v2.0.1
[INFO] [stderr]     Checking icu_normalizer v2.0.0
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.0.3
[INFO] [stderr]     Checking url v2.5.4
[INFO] [stderr]     Checking tokio-util v0.7.15
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking serde_json v1.0.140
[INFO] [stderr]     Checking chrono v0.4.41
[INFO] [stderr]     Checking h2 v0.3.26
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking onekey v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `tokio::time::timeout`
[INFO] [stdout]  --> src/handlers/network_test.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tokio::time::timeout;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout] help: if this is a test module, consider adding a `#[cfg(test)]` to the containing module
[INFO] [stdout]  --> src/handlers/mod.rs:6:1
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub mod network_test;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::time::timeout`
[INFO] [stdout]  --> src/handlers/network_test.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tokio::time::timeout;
[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: `futures_util::StreamExt`
[INFO] [stdout]  --> src/handlers/network_test.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use futures_util::StreamExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures_util::StreamExt`
[INFO] [stdout]  --> src/handlers/network_test.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use futures_util::StreamExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `total_phases`
[INFO] [stdout]    --> src/handlers/disk_test.rs:162:9
[INFO] [stdout]     |
[INFO] [stdout] 162 |     let total_phases = block_sizes.len() * 2 + 1; // 每个块大小有读写两个阶段，加上准备阶段
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_total_phases`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `test_duration`
[INFO] [stdout]    --> src/handlers/disk_test.rs:914:13
[INFO] [stdout]     |
[INFO] [stdout] 914 |         let test_duration = Duration::from_secs(5); // 5秒测试
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_test_duration`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `latency`
[INFO] [stdout]    --> src/handlers/disk_test.rs:920:35
[INFO] [stdout]     |
[INFO] [stdout] 920 |         if let Some((speed, iops, latency)) = result {
[INFO] [stdout]     |                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_latency`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `test_duration`
[INFO] [stdout]    --> src/handlers/disk_test.rs:953:13
[INFO] [stdout]     |
[INFO] [stdout] 953 |         let test_duration = Duration::from_secs(5); // 5秒测试
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_test_duration`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `latency`
[INFO] [stdout]    --> src/handlers/disk_test.rs:959:35
[INFO] [stdout]     |
[INFO] [stdout] 959 |         if let Some((speed, iops, latency)) = result {
[INFO] [stdout]     |                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_latency`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `total_phases`
[INFO] [stdout]    --> src/handlers/disk_test.rs:162:9
[INFO] [stdout]     |
[INFO] [stdout] 162 |     let total_phases = block_sizes.len() * 2 + 1; // 每个块大小有读写两个阶段，加上准备阶段
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_total_phases`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `test_duration`
[INFO] [stdout]    --> src/handlers/disk_test.rs:914:13
[INFO] [stdout]     |
[INFO] [stdout] 914 |         let test_duration = Duration::from_secs(5); // 5秒测试
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_test_duration`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `latency`
[INFO] [stdout]    --> src/handlers/disk_test.rs:920:35
[INFO] [stdout]     |
[INFO] [stdout] 920 |         if let Some((speed, iops, latency)) = result {
[INFO] [stdout]     |                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_latency`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `test_duration`
[INFO] [stdout]    --> src/handlers/disk_test.rs:953:13
[INFO] [stdout]     |
[INFO] [stdout] 953 |         let test_duration = Duration::from_secs(5); // 5秒测试
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_test_duration`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `latency`
[INFO] [stdout]    --> src/handlers/disk_test.rs:959:35
[INFO] [stdout]     |
[INFO] [stdout] 959 |         if let Some((speed, iops, latency)) = result {
[INFO] [stdout]     |                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_latency`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `selection_mode` is never read
[INFO] [stdout]   --> src/app.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct App {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub selection_mode: bool,  // 新增：是否在文本选择模式
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `set_needs_refresh`, `check_needs_refresh`, `toggle_selection_mode`, `copy_content`, `enable_text_selection`, and `disable_text_selection` are never used
[INFO] [stdout]    --> src/app.rs:189:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl App {
[INFO] [stdout]     | -------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 189 |     pub fn set_needs_refresh(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn check_needs_refresh(&mut self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub fn toggle_selection_mode(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 209 |     pub fn copy_content(&self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 289 |     pub fn enable_text_selection() -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 298 |     pub fn disable_text_selection() -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `description` is never used
[INFO] [stdout]   --> src/menu.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl MenuItem {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn description(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `can_scroll_down` and `can_scroll_up` are never used
[INFO] [stdout]   --> src/types.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl ScrollPosition {
[INFO] [stdout]    | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn can_scroll_down(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn can_scroll_up(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_combined_test_interface` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:287:4
[INFO] [stdout]     |
[INFO] [stdout] 287 | fn draw_combined_test_interface(f: &mut Frame, area: Rect, test_info: &NetworkTestInfo, is_focused: bool) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_realtime_test_status` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:308:4
[INFO] [stdout]     |
[INFO] [stdout] 308 | fn draw_realtime_test_status(f: &mut Frame, area: Rect, test_info: &NetworkTestInfo, is_focused: bool) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_realtime_speeds` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:376:4
[INFO] [stdout]     |
[INFO] [stdout] 376 | fn draw_realtime_speeds(f: &mut Frame, area: Rect, test_info: &NetworkTestInfo) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_speed_style` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:436:4
[INFO] [stdout]     |
[INFO] [stdout] 436 | fn get_speed_style(speed: f64) -> Style {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_waiting_info` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:448:4
[INFO] [stdout]     |
[INFO] [stdout] 448 | fn draw_waiting_info(f: &mut Frame, area: Rect, is_focused: bool) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_test_results_table` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:485:4
[INFO] [stdout]     |
[INFO] [stdout] 485 | fn draw_test_results_table(f: &mut Frame, area: Rect, test_info: &NetworkTestInfo, is_focused: bool) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_duration` is never used
[INFO] [stdout]   --> src/ui/helpers.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub fn format_duration(duration: Duration) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_enhanced_progress_bar` is never used
[INFO] [stdout]   --> src/ui/helpers.rs:51:8
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub fn create_enhanced_progress_bar(progress: u8, width: usize) -> Span<'static> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_speed_bar` is never used
[INFO] [stdout]   --> src/ui/helpers.rs:72:8
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub fn create_speed_bar(speed: f64, max_speed: f64, is_read: bool) -> Span<'static> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_speed` is never used
[INFO] [stdout]    --> src/ui/helpers.rs:104:8
[INFO] [stdout]     |
[INFO] [stdout] 104 | pub fn format_speed(speed: f64) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_iops` is never used
[INFO] [stdout]    --> src/ui/helpers.rs:113:8
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub fn format_iops(iops: f64) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CommandRunner` is never constructed
[INFO] [stdout]  --> src/handlers/command.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct CommandRunner;
[INFO] [stdout]   |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `run`, `run_status`, `run_sudo`, and `command_exists` are never used
[INFO] [stdout]   --> src/handlers/command.rs:8:12
[INFO] [stdout]    |
[INFO] [stdout]  6 | impl CommandRunner {
[INFO] [stdout]    | ------------------ associated functions in this implementation
[INFO] [stdout]  7 |     /// 执行系统命令并返回输出
[INFO] [stdout]  8 |     pub fn run(cmd: &str, args: &[&str]) -> io::Result<String> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn run_status(cmd: &str, args: &[&str]) -> io::Result<bool> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33 |     pub fn run_sudo(cmd: &str, args: &[&str]) -> io::Result<String> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn command_exists(cmd: &str) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `details` is never read
[INFO] [stdout]   --> src/handlers/cpu_test.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct CpuTestResult {
[INFO] [stdout]    |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 15 |     pub details: HashMap<String, String>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CpuTestResult` 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: function `update_test_status_with_error` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:257:4
[INFO] [stdout]     |
[INFO] [stdout] 257 | fn update_test_status_with_error(error: String) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_final_scores` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:269:4
[INFO] [stdout]     |
[INFO] [stdout] 269 | fn calculate_final_scores(results: &[CpuTestResult]) -> CpuTestResult {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_integer_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:442:12
[INFO] [stdout]     |
[INFO] [stdout] 442 |     pub fn run_integer_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_floating_point_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:487:12
[INFO] [stdout]     |
[INFO] [stdout] 487 |     pub fn run_floating_point_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_vector_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:531:12
[INFO] [stdout]     |
[INFO] [stdout] 531 |     pub fn run_vector_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_encryption_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:581:12
[INFO] [stdout]     |
[INFO] [stdout] 581 |     pub fn run_encryption_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_compression_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:630:12
[INFO] [stdout]     |
[INFO] [stdout] 630 |     pub fn run_compression_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_memory_bandwidth_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:671:12
[INFO] [stdout]     |
[INFO] [stdout] 671 |     pub fn run_memory_bandwidth_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_comprehensive_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:718:12
[INFO] [stdout]     |
[INFO] [stdout] 718 |     pub fn run_comprehensive_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fibonacci_iterative` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:768:8
[INFO] [stdout]     |
[INFO] [stdout] 768 |     fn fibonacci_iterative(n: u64) -> u64 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `prime_check` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:780:8
[INFO] [stdout]     |
[INFO] [stdout] 780 |     fn prime_check(n: u64) -> u64 {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `simple_compress` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:788:8
[INFO] [stdout]     |
[INFO] [stdout] 788 |     fn simple_compress(data: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `timestamp`, `read_speed`, `write_speed`, `read_iops`, and `write_iops` are never read
[INFO] [stdout]   --> src/handlers/disk_test.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub struct PerformanceDataPoint {
[INFO] [stdout]    |            -------------------- fields in this struct
[INFO] [stdout] 27 |     pub timestamp: f64,  // 相对时间戳（秒）
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 28 |     pub read_speed: f64,  // MB/s
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 29 |     pub write_speed: f64, // MB/s
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 30 |     pub read_iops: f64,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 31 |     pub write_iops: f64,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PerformanceDataPoint` 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 `chart_data_points` is never read
[INFO] [stdout]   --> src/handlers/disk_test.rs:57:9
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct DiskTestInfo {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub chart_data_points: Vec<(f64, f64)>, // 折线图数据点 (时间, 值)
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DiskTestInfo` 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: function `get_realtime_ui_data` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:461:8
[INFO] [stdout]     |
[INFO] [stdout] 461 | pub fn get_realtime_ui_data() -> Option<(f64, f64, f64, f64, usize, String, u8)> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_fio_4k_mixed_async` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:489:4
[INFO] [stdout]     |
[INFO] [stdout] 489 | fn run_fio_4k_mixed_async(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_fio_64k_mixed_async` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:515:4
[INFO] [stdout]     |
[INFO] [stdout] 515 | fn run_fio_64k_mixed_async(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_fio_1m_seq_async` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:541:4
[INFO] [stdout]     |
[INFO] [stdout] 541 | fn run_fio_1m_seq_async(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dd_write_test_async` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:567:4
[INFO] [stdout]     |
[INFO] [stdout] 567 | fn run_dd_write_test_async() -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dd_read_test_async` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:592:4
[INFO] [stdout]     |
[INFO] [stdout] 592 | fn run_dd_read_test_async() -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_fio_output_to_result` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:616:4
[INFO] [stdout]     |
[INFO] [stdout] 616 | fn parse_fio_output_to_result(output: &str, test_name: &str) -> Option<DiskTestResult> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_totals` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:662:4
[INFO] [stdout]     |
[INFO] [stdout] 662 | fn calculate_totals(read_bw: &str, write_bw: &str, read_iops: &str, write_iops: &str) -> (String, String) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_fio_output` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:670:4
[INFO] [stdout]     |
[INFO] [stdout] 670 | fn parse_fio_output(output: &str, block_size: &str) -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dd_tests` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:710:4
[INFO] [stdout]     |
[INFO] [stdout] 710 | fn run_dd_tests() -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dd_write_test` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:739:4
[INFO] [stdout]     |
[INFO] [stdout] 739 | fn run_dd_write_test() -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dd_read_test` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:757:4
[INFO] [stdout]     |
[INFO] [stdout] 757 | fn run_dd_read_test() -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_dd_output` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:774:4
[INFO] [stdout]     |
[INFO] [stdout] 774 | fn parse_dd_output(output: &str) -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEST_DURATION_SECS` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:862:11
[INFO] [stdout]     |
[INFO] [stdout] 862 |     const TEST_DURATION_SECS: u64 = 3;  // 减少到3秒
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `WARMUP_DURATION_SECS` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:863:11
[INFO] [stdout]     |
[INFO] [stdout] 863 |     const WARMUP_DURATION_SECS: u64 = 1; // 减少预热时间
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_realtime_rw_test` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:866:12
[INFO] [stdout]     |
[INFO] [stdout] 866 |     pub fn run_realtime_rw_test(test_dir: &str) -> Vec<DiskTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_read_only_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1057:12
[INFO] [stdout]      |
[INFO] [stdout] 1057 |     pub fn run_read_only_test(test_dir: &str) -> Vec<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_write_only_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1082:12
[INFO] [stdout]      |
[INFO] [stdout] 1082 |     pub fn run_write_only_test(test_dir: &str) -> Vec<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_realtime_read_write_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1107:8
[INFO] [stdout]      |
[INFO] [stdout] 1107 |     fn run_realtime_read_write_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dedicated_read_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1161:8
[INFO] [stdout]      |
[INFO] [stdout] 1161 |     fn run_dedicated_read_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dedicated_write_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1193:8
[INFO] [stdout]      |
[INFO] [stdout] 1193 |     fn run_dedicated_write_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_continuous_read_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1219:8
[INFO] [stdout]      |
[INFO] [stdout] 1219 |     fn run_continuous_read_test(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_continuous_write_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1296:8
[INFO] [stdout]      |
[INFO] [stdout] 1296 |     fn run_continuous_write_test(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_professional_disk_tests` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1376:12
[INFO] [stdout]      |
[INFO] [stdout] 1376 |     pub fn run_professional_disk_tests(test_dir: &str) -> Vec<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_4k_random_mixed_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1417:8
[INFO] [stdout]      |
[INFO] [stdout] 1417 |     fn run_4k_random_mixed_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_4k_random_read_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1442:12
[INFO] [stdout]      |
[INFO] [stdout] 1442 |     pub fn run_4k_random_read_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_4k_random_write_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1470:12
[INFO] [stdout]      |
[INFO] [stdout] 1470 |     pub fn run_4k_random_write_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_64k_sequential_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1493:12
[INFO] [stdout]      |
[INFO] [stdout] 1493 |     pub fn run_64k_sequential_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_1m_sequential_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1524:12
[INFO] [stdout]      |
[INFO] [stdout] 1524 |     pub fn run_1m_sequential_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_multi_thread_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1550:12
[INFO] [stdout]      |
[INFO] [stdout] 1550 |     pub fn run_multi_thread_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_mixed_workload_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1612:8
[INFO] [stdout]      |
[INFO] [stdout] 1612 |     fn run_mixed_workload_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_io_benchmark` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1682:8
[INFO] [stdout]      |
[INFO] [stdout] 1682 |     fn run_io_benchmark(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_mixed_io_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1861:8
[INFO] [stdout]      |
[INFO] [stdout] 1861 |     fn run_mixed_io_test(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_rust_disk_tests` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:2035:12
[INFO] [stdout]      |
[INFO] [stdout] 2035 |     pub fn run_rust_disk_tests(test_dir: &str) -> Vec<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `test_urls` and `color` are never read
[INFO] [stdout]   --> src/handlers/network_test.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct NetworkProvider {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 11 |     pub name: String,
[INFO] [stdout] 12 |     pub test_urls: Vec<String>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 13 |     pub color: &'static str,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `NetworkProvider` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `provider` and `packet_loss` are never read
[INFO] [stdout]   --> src/handlers/network_test.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct SpeedTestResult {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 18 |     pub provider: String,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub packet_loss: f64,    // %
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SpeedTestResult` 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: function `get_info` is never used
[INFO] [stdout]  --> src/handlers/sing_box.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub fn get_info() -> String {
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `rx_packets`, `tx_packets`, and `interface_name` are never read
[INFO] [stdout]   --> src/handlers/system_info.rs:42:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct NetworkStats {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub rx_packets: u64,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 43 |     pub tx_packets: u64,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 44 |     pub interface_name: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `NetworkStats` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `name` and `file_system` are never read
[INFO] [stdout]   --> src/handlers/system_info.rs:62:9
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub struct DiskInfo {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 62 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub file_system: String,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DiskInfo` 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: function `format_bytes_gb` is never used
[INFO] [stdout]    --> src/handlers/system_info.rs:618:4
[INFO] [stdout]     |
[INFO] [stdout] 618 | fn format_bytes_gb(bytes: u64) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_info` is never used
[INFO] [stdout]  --> src/handlers/xray.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub fn get_info() -> String {
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `prompt_input` is never used
[INFO] [stdout]  --> src/utils.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub fn prompt_input(prompt: &str, default: &str) -> String {
[INFO] [stdout]   |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `save_output` is never used
[INFO] [stdout]   --> src/utils.rs:28:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub fn save_output(task_name: &str, content: &str) {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_current_time` is never used
[INFO] [stdout]   --> src/utils.rs:47:8
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub fn get_current_time() -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `wait_for_key` is never used
[INFO] [stdout]   --> src/utils.rs:52:8
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn wait_for_key() {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/theme.rs:11:15
[INFO] [stdout]     |
[INFO] [stdout]   6 | impl Theme {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  11 |     pub const BACKGROUND: Color = Color::Black;       // 背景色
[INFO] [stdout]     |               ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  20 |     pub const GAUGE_NORMAL: Color = Color::Green;     // 正常范围 (0-70%)
[INFO] [stdout]     |               ^^^^^^^^^^^^
[INFO] [stdout]  21 |     pub const GAUGE_WARNING: Color = Color::Rgb(255, 165, 0);  // 警告范围 (70-85%) 橙色
[INFO] [stdout]     |               ^^^^^^^^^^^^^
[INFO] [stdout]  22 |     pub const GAUGE_CRITICAL: Color = Color::Red;     // 危险范围 (85-100%)
[INFO] [stdout]     |               ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  25 |     pub const GAUGE_BAR_NORMAL: Color = Color::Cyan;       // 正常状态的进度条
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^
[INFO] [stdout]  26 |     pub const GAUGE_BAR_WARNING: Color = Color::Yellow;    // 警告状态的进度条
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^
[INFO] [stdout]  27 |     pub const GAUGE_BAR_CRITICAL: Color = Color::Red;      // 危险状态的进度条
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  30 |     pub fn default() -> Style {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn gauge_style(percentage: f64) -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn realtime_speed_high() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 160 |     pub fn realtime_speed_medium() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 164 |     pub fn realtime_speed_low() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub fn realtime_iops_high() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 172 |     pub fn realtime_iops_medium() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 176 |     pub fn realtime_iops_low() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 186 |     pub fn test_phase_active() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 190 |     pub fn test_phase_waiting() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn test_phase_completed() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn speed_style(speed_mbps: f64) -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 210 |     pub fn iops_style(iops: f64) -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 225 |     pub fn chart_write_color() -> Color {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/ui/helpers.rs:11:28
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn create_block(title: &str, is_focused: bool) -> Block {
[INFO] [stdout]    |                            ^^^^                       ^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn create_block(title: &str, is_focused: bool) -> Block<'_> {
[INFO] [stdout]    |                                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `selection_mode` is never read
[INFO] [stdout]   --> src/app.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct App {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub selection_mode: bool,  // 新增：是否在文本选择模式
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `set_needs_refresh`, `check_needs_refresh`, `toggle_selection_mode`, `copy_content`, `enable_text_selection`, and `disable_text_selection` are never used
[INFO] [stdout]    --> src/app.rs:189:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl App {
[INFO] [stdout]     | -------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 189 |     pub fn set_needs_refresh(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn check_needs_refresh(&mut self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub fn toggle_selection_mode(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 209 |     pub fn copy_content(&self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 289 |     pub fn enable_text_selection() -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 298 |     pub fn disable_text_selection() -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `description` is never used
[INFO] [stdout]   --> src/menu.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl MenuItem {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn description(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `can_scroll_down` and `can_scroll_up` are never used
[INFO] [stdout]   --> src/types.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl ScrollPosition {
[INFO] [stdout]    | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn can_scroll_down(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn can_scroll_up(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_combined_test_interface` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:287:4
[INFO] [stdout]     |
[INFO] [stdout] 287 | fn draw_combined_test_interface(f: &mut Frame, area: Rect, test_info: &NetworkTestInfo, is_focused: bool) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_realtime_test_status` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:308:4
[INFO] [stdout]     |
[INFO] [stdout] 308 | fn draw_realtime_test_status(f: &mut Frame, area: Rect, test_info: &NetworkTestInfo, is_focused: bool) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_realtime_speeds` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:376:4
[INFO] [stdout]     |
[INFO] [stdout] 376 | fn draw_realtime_speeds(f: &mut Frame, area: Rect, test_info: &NetworkTestInfo) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_speed_style` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:436:4
[INFO] [stdout]     |
[INFO] [stdout] 436 | fn get_speed_style(speed: f64) -> Style {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_waiting_info` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:448:4
[INFO] [stdout]     |
[INFO] [stdout] 448 | fn draw_waiting_info(f: &mut Frame, area: Rect, is_focused: bool) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_test_results_table` is never used
[INFO] [stdout]    --> src/ui/network_test.rs:485:4
[INFO] [stdout]     |
[INFO] [stdout] 485 | fn draw_test_results_table(f: &mut Frame, area: Rect, test_info: &NetworkTestInfo, is_focused: bool) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_duration` is never used
[INFO] [stdout]   --> src/ui/helpers.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub fn format_duration(duration: Duration) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_enhanced_progress_bar` is never used
[INFO] [stdout]   --> src/ui/helpers.rs:51:8
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub fn create_enhanced_progress_bar(progress: u8, width: usize) -> Span<'static> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_speed_bar` is never used
[INFO] [stdout]   --> src/ui/helpers.rs:72:8
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub fn create_speed_bar(speed: f64, max_speed: f64, is_read: bool) -> Span<'static> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_speed` is never used
[INFO] [stdout]    --> src/ui/helpers.rs:104:8
[INFO] [stdout]     |
[INFO] [stdout] 104 | pub fn format_speed(speed: f64) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_iops` is never used
[INFO] [stdout]    --> src/ui/helpers.rs:113:8
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub fn format_iops(iops: f64) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `run`, `run_status`, and `run_sudo` are never used
[INFO] [stdout]   --> src/handlers/command.rs:8:12
[INFO] [stdout]    |
[INFO] [stdout]  6 | impl CommandRunner {
[INFO] [stdout]    | ------------------ associated functions in this implementation
[INFO] [stdout]  7 |     /// 执行系统命令并返回输出
[INFO] [stdout]  8 |     pub fn run(cmd: &str, args: &[&str]) -> io::Result<String> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn run_status(cmd: &str, args: &[&str]) -> io::Result<bool> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33 |     pub fn run_sudo(cmd: &str, args: &[&str]) -> io::Result<String> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `details` is never read
[INFO] [stdout]   --> src/handlers/cpu_test.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct CpuTestResult {
[INFO] [stdout]    |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 15 |     pub details: HashMap<String, String>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CpuTestResult` 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: function `update_test_status_with_error` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:257:4
[INFO] [stdout]     |
[INFO] [stdout] 257 | fn update_test_status_with_error(error: String) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_final_scores` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:269:4
[INFO] [stdout]     |
[INFO] [stdout] 269 | fn calculate_final_scores(results: &[CpuTestResult]) -> CpuTestResult {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_integer_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:442:12
[INFO] [stdout]     |
[INFO] [stdout] 442 |     pub fn run_integer_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_floating_point_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:487:12
[INFO] [stdout]     |
[INFO] [stdout] 487 |     pub fn run_floating_point_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_vector_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:531:12
[INFO] [stdout]     |
[INFO] [stdout] 531 |     pub fn run_vector_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_encryption_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:581:12
[INFO] [stdout]     |
[INFO] [stdout] 581 |     pub fn run_encryption_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_compression_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:630:12
[INFO] [stdout]     |
[INFO] [stdout] 630 |     pub fn run_compression_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_memory_bandwidth_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:671:12
[INFO] [stdout]     |
[INFO] [stdout] 671 |     pub fn run_memory_bandwidth_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_comprehensive_test` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:718:12
[INFO] [stdout]     |
[INFO] [stdout] 718 |     pub fn run_comprehensive_test() -> Option<CpuTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fibonacci_iterative` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:768:8
[INFO] [stdout]     |
[INFO] [stdout] 768 |     fn fibonacci_iterative(n: u64) -> u64 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `prime_check` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:780:8
[INFO] [stdout]     |
[INFO] [stdout] 780 |     fn prime_check(n: u64) -> u64 {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `simple_compress` is never used
[INFO] [stdout]    --> src/handlers/cpu_test.rs:788:8
[INFO] [stdout]     |
[INFO] [stdout] 788 |     fn simple_compress(data: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `timestamp`, `read_speed`, `write_speed`, `read_iops`, and `write_iops` are never read
[INFO] [stdout]   --> src/handlers/disk_test.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub struct PerformanceDataPoint {
[INFO] [stdout]    |            -------------------- fields in this struct
[INFO] [stdout] 27 |     pub timestamp: f64,  // 相对时间戳（秒）
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 28 |     pub read_speed: f64,  // MB/s
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 29 |     pub write_speed: f64, // MB/s
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 30 |     pub read_iops: f64,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 31 |     pub write_iops: f64,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PerformanceDataPoint` 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 `chart_data_points` is never read
[INFO] [stdout]   --> src/handlers/disk_test.rs:57:9
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct DiskTestInfo {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub chart_data_points: Vec<(f64, f64)>, // 折线图数据点 (时间, 值)
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DiskTestInfo` 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: function `get_realtime_ui_data` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:461:8
[INFO] [stdout]     |
[INFO] [stdout] 461 | pub fn get_realtime_ui_data() -> Option<(f64, f64, f64, f64, usize, String, u8)> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_fio_4k_mixed_async` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:489:4
[INFO] [stdout]     |
[INFO] [stdout] 489 | fn run_fio_4k_mixed_async(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_fio_64k_mixed_async` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:515:4
[INFO] [stdout]     |
[INFO] [stdout] 515 | fn run_fio_64k_mixed_async(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_fio_1m_seq_async` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:541:4
[INFO] [stdout]     |
[INFO] [stdout] 541 | fn run_fio_1m_seq_async(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dd_write_test_async` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:567:4
[INFO] [stdout]     |
[INFO] [stdout] 567 | fn run_dd_write_test_async() -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dd_read_test_async` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:592:4
[INFO] [stdout]     |
[INFO] [stdout] 592 | fn run_dd_read_test_async() -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_fio_output_to_result` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:616:4
[INFO] [stdout]     |
[INFO] [stdout] 616 | fn parse_fio_output_to_result(output: &str, test_name: &str) -> Option<DiskTestResult> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_totals` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:662:4
[INFO] [stdout]     |
[INFO] [stdout] 662 | fn calculate_totals(read_bw: &str, write_bw: &str, read_iops: &str, write_iops: &str) -> (String, String) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_fio_output` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:670:4
[INFO] [stdout]     |
[INFO] [stdout] 670 | fn parse_fio_output(output: &str, block_size: &str) -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dd_tests` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:710:4
[INFO] [stdout]     |
[INFO] [stdout] 710 | fn run_dd_tests() -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dd_write_test` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:739:4
[INFO] [stdout]     |
[INFO] [stdout] 739 | fn run_dd_write_test() -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dd_read_test` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:757:4
[INFO] [stdout]     |
[INFO] [stdout] 757 | fn run_dd_read_test() -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_dd_output` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:774:4
[INFO] [stdout]     |
[INFO] [stdout] 774 | fn parse_dd_output(output: &str) -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEST_DURATION_SECS` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:862:11
[INFO] [stdout]     |
[INFO] [stdout] 862 |     const TEST_DURATION_SECS: u64 = 3;  // 减少到3秒
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `WARMUP_DURATION_SECS` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:863:11
[INFO] [stdout]     |
[INFO] [stdout] 863 |     const WARMUP_DURATION_SECS: u64 = 1; // 减少预热时间
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_realtime_rw_test` is never used
[INFO] [stdout]    --> src/handlers/disk_test.rs:866:12
[INFO] [stdout]     |
[INFO] [stdout] 866 |     pub fn run_realtime_rw_test(test_dir: &str) -> Vec<DiskTestResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_read_only_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1057:12
[INFO] [stdout]      |
[INFO] [stdout] 1057 |     pub fn run_read_only_test(test_dir: &str) -> Vec<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_write_only_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1082:12
[INFO] [stdout]      |
[INFO] [stdout] 1082 |     pub fn run_write_only_test(test_dir: &str) -> Vec<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_realtime_read_write_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1107:8
[INFO] [stdout]      |
[INFO] [stdout] 1107 |     fn run_realtime_read_write_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dedicated_read_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1161:8
[INFO] [stdout]      |
[INFO] [stdout] 1161 |     fn run_dedicated_read_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_dedicated_write_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1193:8
[INFO] [stdout]      |
[INFO] [stdout] 1193 |     fn run_dedicated_write_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_continuous_read_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1219:8
[INFO] [stdout]      |
[INFO] [stdout] 1219 |     fn run_continuous_read_test(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_continuous_write_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1296:8
[INFO] [stdout]      |
[INFO] [stdout] 1296 |     fn run_continuous_write_test(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_professional_disk_tests` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1376:12
[INFO] [stdout]      |
[INFO] [stdout] 1376 |     pub fn run_professional_disk_tests(test_dir: &str) -> Vec<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_4k_random_mixed_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1417:8
[INFO] [stdout]      |
[INFO] [stdout] 1417 |     fn run_4k_random_mixed_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_4k_random_read_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1442:12
[INFO] [stdout]      |
[INFO] [stdout] 1442 |     pub fn run_4k_random_read_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_4k_random_write_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1470:12
[INFO] [stdout]      |
[INFO] [stdout] 1470 |     pub fn run_4k_random_write_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_64k_sequential_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1493:12
[INFO] [stdout]      |
[INFO] [stdout] 1493 |     pub fn run_64k_sequential_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_1m_sequential_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1524:12
[INFO] [stdout]      |
[INFO] [stdout] 1524 |     pub fn run_1m_sequential_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_multi_thread_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1550:12
[INFO] [stdout]      |
[INFO] [stdout] 1550 |     pub fn run_multi_thread_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_mixed_workload_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1612:8
[INFO] [stdout]      |
[INFO] [stdout] 1612 |     fn run_mixed_workload_test(test_dir: &str) -> Option<DiskTestResult> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_io_benchmark` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1682:8
[INFO] [stdout]      |
[INFO] [stdout] 1682 |     fn run_io_benchmark(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_mixed_io_test` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:1861:8
[INFO] [stdout]      |
[INFO] [stdout] 1861 |     fn run_mixed_io_test(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_rust_disk_tests` is never used
[INFO] [stdout]     --> src/handlers/disk_test.rs:2035:12
[INFO] [stdout]      |
[INFO] [stdout] 2035 |     pub fn run_rust_disk_tests(test_dir: &str) -> Vec<DiskTestResult> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `test_urls` and `color` are never read
[INFO] [stdout]   --> src/handlers/network_test.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct NetworkProvider {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 11 |     pub name: String,
[INFO] [stdout] 12 |     pub test_urls: Vec<String>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 13 |     pub color: &'static str,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `NetworkProvider` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `provider` and `packet_loss` are never read
[INFO] [stdout]   --> src/handlers/network_test.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct SpeedTestResult {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 18 |     pub provider: String,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub packet_loss: f64,    // %
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SpeedTestResult` 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: function `get_info` is never used
[INFO] [stdout]  --> src/handlers/sing_box.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub fn get_info() -> String {
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `rx_packets`, `tx_packets`, and `interface_name` are never read
[INFO] [stdout]   --> src/handlers/system_info.rs:42:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct NetworkStats {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub rx_packets: u64,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 43 |     pub tx_packets: u64,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 44 |     pub interface_name: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `NetworkStats` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `name` and `file_system` are never read
[INFO] [stdout]   --> src/handlers/system_info.rs:62:9
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub struct DiskInfo {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 62 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub file_system: String,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DiskInfo` 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: function `format_bytes_gb` is never used
[INFO] [stdout]    --> src/handlers/system_info.rs:618:4
[INFO] [stdout]     |
[INFO] [stdout] 618 | fn format_bytes_gb(bytes: u64) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_info` is never used
[INFO] [stdout]  --> src/handlers/xray.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub fn get_info() -> String {
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `prompt_input` is never used
[INFO] [stdout]  --> src/utils.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub fn prompt_input(prompt: &str, default: &str) -> String {
[INFO] [stdout]   |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `save_output` is never used
[INFO] [stdout]   --> src/utils.rs:28:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub fn save_output(task_name: &str, content: &str) {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_current_time` is never used
[INFO] [stdout]   --> src/utils.rs:47:8
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub fn get_current_time() -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `wait_for_key` is never used
[INFO] [stdout]   --> src/utils.rs:52:8
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn wait_for_key() {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/theme.rs:11:15
[INFO] [stdout]     |
[INFO] [stdout]   6 | impl Theme {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  11 |     pub const BACKGROUND: Color = Color::Black;       // 背景色
[INFO] [stdout]     |               ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  20 |     pub const GAUGE_NORMAL: Color = Color::Green;     // 正常范围 (0-70%)
[INFO] [stdout]     |               ^^^^^^^^^^^^
[INFO] [stdout]  21 |     pub const GAUGE_WARNING: Color = Color::Rgb(255, 165, 0);  // 警告范围 (70-85%) 橙色
[INFO] [stdout]     |               ^^^^^^^^^^^^^
[INFO] [stdout]  22 |     pub const GAUGE_CRITICAL: Color = Color::Red;     // 危险范围 (85-100%)
[INFO] [stdout]     |               ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  25 |     pub const GAUGE_BAR_NORMAL: Color = Color::Cyan;       // 正常状态的进度条
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^
[INFO] [stdout]  26 |     pub const GAUGE_BAR_WARNING: Color = Color::Yellow;    // 警告状态的进度条
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^
[INFO] [stdout]  27 |     pub const GAUGE_BAR_CRITICAL: Color = Color::Red;      // 危险状态的进度条
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  30 |     pub fn default() -> Style {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn gauge_style(percentage: f64) -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn realtime_speed_high() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 160 |     pub fn realtime_speed_medium() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 164 |     pub fn realtime_speed_low() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub fn realtime_iops_high() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 172 |     pub fn realtime_iops_medium() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 176 |     pub fn realtime_iops_low() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 186 |     pub fn test_phase_active() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 190 |     pub fn test_phase_waiting() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn test_phase_completed() -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn speed_style(speed_mbps: f64) -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 210 |     pub fn iops_style(iops: f64) -> Style {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 225 |     pub fn chart_write_color() -> Color {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/ui/helpers.rs:11:28
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn create_block(title: &str, is_focused: bool) -> Block {
[INFO] [stdout]    |                            ^^^^                       ^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn create_block(title: &str, is_focused: bool) -> Block<'_> {
[INFO] [stdout]    |                                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 25.74s
[INFO] running `Command { std: "docker" "inspect" "c4344e8d45ae905d6a5ea42a251b0d6220cf28f7f79dfbf0c1366a2ef2d430c7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c4344e8d45ae905d6a5ea42a251b0d6220cf28f7f79dfbf0c1366a2ef2d430c7", kill_on_drop: false }`
[INFO] [stdout] c4344e8d45ae905d6a5ea42a251b0d6220cf28f7f79dfbf0c1366a2ef2d430c7
