[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> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 289 | pub fn enable_text_selection() -> Result<(), Box> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 298 | pub fn disable_text_selection() -> Result<(), Box> { [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 { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 24 | pub fn run_status(cmd: &str, args: &[&str]) -> io::Result { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 33 | pub fn run_sudo(cmd: &str, args: &[&str]) -> io::Result { [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, [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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, [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> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 289 | pub fn enable_text_selection() -> Result<(), Box> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 298 | pub fn disable_text_selection() -> Result<(), Box> { [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 { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 24 | pub fn run_status(cmd: &str, args: &[&str]) -> io::Result { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 33 | pub fn run_sudo(cmd: &str, args: &[&str]) -> io::Result { [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, [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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 { [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, [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