[INFO] cloning repository https://github.com/karthik558/Rust-Ping [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/karthik558/Rust-Ping" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkarthik558%2FRust-Ping", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkarthik558%2FRust-Ping'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] c2ba639303e3eac9a39838080d21d00696bb22ed [INFO] checking karthik558/Rust-Ping against master#779e19d8baa3e3625bd4fc5c85cbb2ad47b43155 for pr-147589-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkarthik558%2FRust-Ping" "/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/karthik558/Rust-Ping [INFO] finished tweaking git repo https://github.com/karthik558/Rust-Ping [INFO] tweaked toml for git repo https://github.com/karthik558/Rust-Ping written to /workspace/builds/worker-1-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/karthik558/Rust-Ping 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/karthik558/Rust-Ping 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] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded postgres-types v0.2.9 [INFO] [stderr] Downloaded ping v0.5.2 [INFO] [stderr] Downloaded quoted_printable v0.4.8 [INFO] [stderr] Downloaded email-encoding v0.2.1 [INFO] [stderr] Downloaded postgres-protocol v0.6.8 [INFO] [stderr] Downloaded tokio-postgres v0.7.13 [INFO] [stderr] Downloaded lettre v0.10.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] dfe5f6df3e797482eeeb316234c9db930442dfd63f2ed87bc99c3ef37bfb597c [INFO] running `Command { std: "docker" "start" "-a" "dfe5f6df3e797482eeeb316234c9db930442dfd63f2ed87bc99c3ef37bfb597c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "dfe5f6df3e797482eeeb316234c9db930442dfd63f2ed87bc99c3ef37bfb597c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "dfe5f6df3e797482eeeb316234c9db930442dfd63f2ed87bc99c3ef37bfb597c", kill_on_drop: false }` [INFO] [stdout] dfe5f6df3e797482eeeb316234c9db930442dfd63f2ed87bc99c3ef37bfb597c [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] 1fa579e5d0264f4182c0720fa85fb1db7b30b45eb904ed83257c2cb69903bfa4 [INFO] running `Command { std: "docker" "start" "-a" "1fa579e5d0264f4182c0720fa85fb1db7b30b45eb904ed83257c2cb69903bfa4", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2-diagnostics v0.10.1 [INFO] [stderr] Checking getrandom v0.3.1 [INFO] [stderr] Checking serde v1.0.219 [INFO] [stderr] Checking tokio v1.44.1 [INFO] [stderr] Checking futures-util v0.3.31 [INFO] [stderr] Compiling libc v0.2.171 [INFO] [stderr] Compiling ref-cast v1.0.24 [INFO] [stderr] Checking digest v0.10.7 [INFO] [stderr] Checking unicode-normalization v0.1.24 [INFO] [stderr] Checking tracing v0.1.41 [INFO] [stderr] Compiling ref-cast-impl v1.0.24 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Checking is-terminal v0.4.16 [INFO] [stderr] Compiling once_cell v1.21.1 [INFO] [stderr] Compiling http v0.2.12 [INFO] [stderr] Checking rand_core v0.9.3 [INFO] [stderr] Compiling tracing-core v0.1.33 [INFO] [stderr] Compiling devise_core v0.4.2 [INFO] [stderr] Compiling time v0.3.39 [INFO] [stderr] Checking yansi v1.0.1 [INFO] [stderr] Compiling pear_codegen v0.2.9 [INFO] [stderr] Checking openssl v0.10.71 [INFO] [stderr] Checking rand_chacha v0.9.0 [INFO] [stderr] Compiling httparse v1.10.1 [INFO] [stderr] Checking stringprep v0.1.5 [INFO] [stderr] Checking sha2 v0.10.8 [INFO] [stderr] Checking rand v0.9.0 [INFO] [stderr] Compiling http-body v0.4.6 [INFO] [stderr] Compiling indexmap v2.8.0 [INFO] [stderr] Checking rand_chacha v0.3.1 [INFO] [stderr] Checking md-5 v0.10.6 [INFO] [stderr] Compiling socket2 v0.5.8 [INFO] [stderr] Compiling mio v1.0.3 [INFO] [stderr] Checking hmac v0.12.1 [INFO] [stderr] Compiling async-trait v0.1.88 [INFO] [stderr] Compiling smallvec v1.14.0 [INFO] [stderr] Checking linux-raw-sys v0.9.3 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Checking postgres-protocol v0.6.8 [INFO] [stderr] Compiling devise_codegen v0.4.2 [INFO] [stderr] Checking regex-automata v0.4.9 [INFO] [stderr] Checking pear v0.2.9 [INFO] [stderr] Checking rand v0.8.5 [INFO] [stderr] Checking rustix v1.0.2 [INFO] [stderr] Checking phf_shared v0.11.3 [INFO] [stderr] Checking idna v1.0.3 [INFO] [stderr] Compiling futures v0.3.31 [INFO] [stderr] Compiling cookie v0.18.1 [INFO] [stderr] Compiling devise v0.4.2 [INFO] [stderr] Compiling async-stream-impl v0.3.6 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Checking socket2 v0.4.10 [INFO] [stderr] Compiling rocket v0.5.1 [INFO] [stderr] Checking serde_json v1.0.140 [INFO] [stderr] Checking toml_datetime v0.6.8 [INFO] [stderr] Checking serde_spanned v0.6.8 [INFO] [stderr] Checking uncased v0.9.10 [INFO] [stderr] Checking uuid v1.16.0 [INFO] [stderr] Compiling glob v0.3.2 [INFO] [stderr] Checking serde_urlencoded v0.7.1 [INFO] [stderr] Checking async-stream v0.3.6 [INFO] [stderr] Checking ubyte v0.10.4 [INFO] [stderr] Checking hostname v0.3.1 [INFO] [stderr] Checking url v2.5.4 [INFO] [stderr] Checking phf v0.11.3 [INFO] [stderr] Checking idna v0.3.0 [INFO] [stderr] Checking email-encoding v0.2.1 [INFO] [stderr] Checking num_cpus v1.16.0 [INFO] [stderr] Checking email_address v0.2.9 [INFO] [stderr] Checking whoami v1.5.2 [INFO] [stderr] Checking fastrand v1.9.0 [INFO] [stderr] Checking quoted_printable v0.4.8 [INFO] [stderr] Checking chrono v0.4.40 [INFO] [stderr] Checking futures-executor v0.3.31 [INFO] [stderr] Checking tracing-subscriber v0.3.19 [INFO] [stderr] Checking toml_edit v0.22.24 [INFO] [stderr] Checking postgres-types v0.2.9 [INFO] [stderr] Checking thiserror v1.0.69 [INFO] [stderr] Checking native-tls v0.2.14 [INFO] [stderr] Checking ping v0.5.2 [INFO] [stderr] Checking tempfile v3.19.0 [INFO] [stderr] Checking regex v1.11.1 [INFO] [stderr] Checking tokio-util v0.7.14 [INFO] [stderr] Checking tokio-native-tls v0.3.1 [INFO] [stderr] Checking tokio-stream v0.1.17 [INFO] [stderr] Checking env_logger v0.10.2 [INFO] [stderr] Checking lettre v0.10.4 [INFO] [stderr] Checking toml v0.8.20 [INFO] [stderr] Checking h2 v0.3.26 [INFO] [stderr] Checking multer v3.1.0 [INFO] [stderr] Checking tokio-postgres v0.7.13 [INFO] [stderr] Checking figment v0.10.19 [INFO] [stderr] Compiling hyper v0.14.32 [INFO] [stderr] Compiling rocket_http v0.5.1 [INFO] [stderr] Compiling rocket_codegen v0.5.1 [INFO] [stderr] Checking hyper-tls v0.5.0 [INFO] [stderr] Checking reqwest v0.11.27 [INFO] [stderr] Checking RustPing v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `transport::smtp::client::SmtpConnection` [INFO] [stdout] --> src/email.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | transport::smtp::client::SmtpConnection, [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: `rocket::http::ContentType` [INFO] [stdout] --> src/main.rs:34:5 [INFO] [stdout] | [INFO] [stdout] 34 | use rocket::http::ContentType; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `transport::smtp::client::SmtpConnection` [INFO] [stdout] --> src/email.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | transport::smtp::client::SmtpConnection, [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: `rocket::http::ContentType` [INFO] [stdout] --> src/main.rs:34:5 [INFO] [stdout] | [INFO] [stdout] 34 | use rocket::http::ContentType; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: irrefutable `if let` pattern [INFO] [stdout] --> src/main.rs:775:20 [INFO] [stdout] | [INFO] [stdout] 775 | if let Ok(config_content) = content.parse::() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this pattern will always match, so the `if let` is useless [INFO] [stdout] = help: consider replacing the `if let` with a `let` [INFO] [stdout] = note: `#[warn(irrefutable_let_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: irrefutable `if let` pattern [INFO] [stdout] --> src/main.rs:775:20 [INFO] [stdout] | [INFO] [stdout] 775 | if let Ok(config_content) = content.parse::() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this pattern will always match, so the `if let` is useless [INFO] [stdout] = help: consider replacing the `if let` with a `let` [INFO] [stdout] = note: `#[warn(irrefutable_let_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `process_logs` is never used [INFO] [stdout] --> src/main.rs:54:10 [INFO] [stdout] | [INFO] [stdout] 54 | async fn process_logs(start_date_parsed: Option, end_date_parsed: Option) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `http_status` and `bandwidth_usage` are never read [INFO] [stdout] --> src/main.rs:87:5 [INFO] [stdout] | [INFO] [stdout] 85 | struct DeviceStatus { [INFO] [stdout] | ------------ fields in this struct [INFO] [stdout] 86 | ping_status: Option, [INFO] [stdout] 87 | http_status: Option, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 88 | bandwidth_usage: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DeviceStatus` 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: type alias `DeviceStatusMap` is never used [INFO] [stdout] --> src/main.rs:117:6 [INFO] [stdout] | [INFO] [stdout] 117 | type DeviceStatusMap = Arc>>; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `DeviceList` is never used [INFO] [stdout] --> src/main.rs:119:6 [INFO] [stdout] | [INFO] [stdout] 119 | type DeviceList = Arc>>; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variants `Missing` and `Invalid` are never constructed [INFO] [stdout] --> src/main.rs:362:5 [INFO] [stdout] | [INFO] [stdout] 361 | enum AuthError { [INFO] [stdout] | --------- variants in this enum [INFO] [stdout] 362 | Missing, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] 363 | Invalid, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AuthError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `NOTIFICATION_INTERVAL` is never used [INFO] [stdout] --> src/email.rs:21:7 [INFO] [stdout] | [INFO] [stdout] 21 | const NOTIFICATION_INTERVAL: Duration = Duration::from_secs(1800); // 30 minutes [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `LOG_COLLECTION_PERIOD` is never used [INFO] [stdout] --> src/email.rs:22:7 [INFO] [stdout] | [INFO] [stdout] 22 | const LOG_COLLECTION_PERIOD: Duration = Duration::from_secs(1800); // 30 minutes [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/email.rs:51:9 [INFO] [stdout] | [INFO] [stdout] 50 | pub struct DeviceStatus { [INFO] [stdout] | ------------ fields in this struct [INFO] [stdout] 51 | pub name: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] 52 | pub status: String, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 53 | pub timestamp: String, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 54 | pub ping_status: String, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 55 | pub http_status: String, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 56 | pub bandwidth: String, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 57 | pub failure_count: u32, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 58 | pub last_failure: Option, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DeviceStatus` 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 `pending_notifications`, `last_notification`, and `device_status_history` are never read [INFO] [stdout] --> src/email.rs:64:5 [INFO] [stdout] | [INFO] [stdout] 61 | pub struct EmailService { [INFO] [stdout] | ------------ fields in this struct [INFO] [stdout] ... [INFO] [stdout] 64 | pending_notifications: Arc>>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 65 | last_notification: Arc>>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 66 | device_status_history: Arc>>>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `add_notification` and `send_batch_notification` are never used [INFO] [stdout] --> src/email.rs:192:18 [INFO] [stdout] | [INFO] [stdout] 69 | impl EmailService { [INFO] [stdout] | ----------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 192 | pub async fn add_notification(&self, device_name: &str, status: &str, log_data: &LogData) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 237 | async fn send_batch_notification(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `process_logs` is never used [INFO] [stdout] --> src/main.rs:54:10 [INFO] [stdout] | [INFO] [stdout] 54 | async fn process_logs(start_date_parsed: Option, end_date_parsed: Option) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `http_status` and `bandwidth_usage` are never read [INFO] [stdout] --> src/main.rs:87:5 [INFO] [stdout] | [INFO] [stdout] 85 | struct DeviceStatus { [INFO] [stdout] | ------------ fields in this struct [INFO] [stdout] 86 | ping_status: Option, [INFO] [stdout] 87 | http_status: Option, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 88 | bandwidth_usage: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DeviceStatus` 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: type alias `DeviceStatusMap` is never used [INFO] [stdout] --> src/main.rs:117:6 [INFO] [stdout] | [INFO] [stdout] 117 | type DeviceStatusMap = Arc>>; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `DeviceList` is never used [INFO] [stdout] --> src/main.rs:119:6 [INFO] [stdout] | [INFO] [stdout] 119 | type DeviceList = Arc>>; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variants `Missing` and `Invalid` are never constructed [INFO] [stdout] --> src/main.rs:362:5 [INFO] [stdout] | [INFO] [stdout] 361 | enum AuthError { [INFO] [stdout] | --------- variants in this enum [INFO] [stdout] 362 | Missing, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] 363 | Invalid, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AuthError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `NOTIFICATION_INTERVAL` is never used [INFO] [stdout] --> src/email.rs:21:7 [INFO] [stdout] | [INFO] [stdout] 21 | const NOTIFICATION_INTERVAL: Duration = Duration::from_secs(1800); // 30 minutes [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `LOG_COLLECTION_PERIOD` is never used [INFO] [stdout] --> src/email.rs:22:7 [INFO] [stdout] | [INFO] [stdout] 22 | const LOG_COLLECTION_PERIOD: Duration = Duration::from_secs(1800); // 30 minutes [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/email.rs:51:9 [INFO] [stdout] | [INFO] [stdout] 50 | pub struct DeviceStatus { [INFO] [stdout] | ------------ fields in this struct [INFO] [stdout] 51 | pub name: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] 52 | pub status: String, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 53 | pub timestamp: String, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 54 | pub ping_status: String, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 55 | pub http_status: String, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 56 | pub bandwidth: String, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 57 | pub failure_count: u32, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 58 | pub last_failure: Option, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DeviceStatus` 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 `pending_notifications`, `last_notification`, and `device_status_history` are never read [INFO] [stdout] --> src/email.rs:64:5 [INFO] [stdout] | [INFO] [stdout] 61 | pub struct EmailService { [INFO] [stdout] | ------------ fields in this struct [INFO] [stdout] ... [INFO] [stdout] 64 | pending_notifications: Arc>>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 65 | last_notification: Arc>>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 66 | device_status_history: Arc>>>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `add_notification` and `send_batch_notification` are never used [INFO] [stdout] --> src/email.rs:192:18 [INFO] [stdout] | [INFO] [stdout] 69 | impl EmailService { [INFO] [stdout] | ----------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 192 | pub async fn add_notification(&self, device_name: &str, status: &str, log_data: &LogData) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 237 | async fn send_batch_notification(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 41.86s [INFO] running `Command { std: "docker" "inspect" "1fa579e5d0264f4182c0720fa85fb1db7b30b45eb904ed83257c2cb69903bfa4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1fa579e5d0264f4182c0720fa85fb1db7b30b45eb904ed83257c2cb69903bfa4", kill_on_drop: false }` [INFO] [stdout] 1fa579e5d0264f4182c0720fa85fb1db7b30b45eb904ed83257c2cb69903bfa4