[INFO] cloning repository https://github.com/crashbit666/pvpccheap4
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/crashbit666/pvpccheap4" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcrashbit666%2Fpvpccheap4", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcrashbit666%2Fpvpccheap4'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 96e5448ffc03ef95837a260c4026a686d0eec53a
[INFO] testing crashbit666/pvpccheap4 against 1.94.0 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcrashbit666%2Fpvpccheap4" "/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/crashbit666/pvpccheap4
[INFO] finished tweaking git repo https://github.com/crashbit666/pvpccheap4
[INFO] tweaked toml for git repo https://github.com/crashbit666/pvpccheap4 written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/crashbit666/pvpccheap4 on toolchain 1.94.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.94.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/crashbit666/pvpccheap4 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" "+1.94.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded async-tungstenite v0.29.1
[INFO] [stderr]   Downloaded actix-cors v0.7.1
[INFO] [stderr]   Downloaded bytestring v1.5.0
[INFO] [stderr]   Downloaded time-macros v0.2.25
[INFO] [stderr]   Downloaded toml v0.9.11+spec-1.1.0
[INFO] [stderr]   Downloaded time-core v0.1.7
[INFO] [stderr]   Downloaded pq-sys v0.7.5
[INFO] [stderr]   Downloaded actix-http v3.11.2
[INFO] [stderr]   Downloaded diesel v2.3.6
[INFO] [stderr]   Downloaded diesel_migrations v2.3.1
[INFO] [stderr]   Downloaded jsonwebtoken v10.2.0
[INFO] [stderr]   Downloaded actix-web v4.12.1
[INFO] [stderr]   Downloaded ws_stream_tungstenite v0.15.0
[INFO] [stderr]   Downloaded rumqttc v0.25.1
[INFO] [stderr]   Downloaded tokio-cron-scheduler v0.15.1
[INFO] [stderr]   Downloaded time v0.3.45
[INFO] [stderr]   Downloaded md5 v0.8.0
[INFO] [stderr]   Downloaded diesel_derives v2.3.6
[INFO] [stderr]   Downloaded actix-rt v2.11.0
[INFO] [stderr]   Downloaded croner v3.0.1
[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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2735468a38f62089f413726b3367ca9237475b235d9ca02ecee25fe7baab4664
[INFO] running `Command { std: "docker" "start" "-a" "2735468a38f62089f413726b3367ca9237475b235d9ca02ecee25fe7baab4664", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2735468a38f62089f413726b3367ca9237475b235d9ca02ecee25fe7baab4664", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2735468a38f62089f413726b3367ca9237475b235d9ca02ecee25fe7baab4664", kill_on_drop: false }`
[INFO] [stdout] 2735468a38f62089f413726b3367ca9237475b235d9ca02ecee25fe7baab4664
[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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 99214b2ee5615714c4c66a8d46712f48bc5eecdd2876197cdf3307b91dc9b153
[INFO] running `Command { std: "docker" "start" "-a" "99214b2ee5615714c4c66a8d46712f48bc5eecdd2876197cdf3307b91dc9b153", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.105
[INFO] [stderr]    Compiling quote v1.0.43
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling subtle v2.6.1
[INFO] [stderr]    Compiling const-oid v0.9.6
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling socket2 v0.6.1
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling zerocopy v0.8.33
[INFO] [stderr]    Compiling base64ct v1.8.3
[INFO] [stderr]    Compiling fs_extra v1.3.0
[INFO] [stderr]    Compiling dunce v1.0.5
[INFO] [stderr]    Compiling aws-lc-rs v1.15.3
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling pem-rfc7468 v0.7.0
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling icu_properties_data v2.1.2
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling rustls v0.23.36
[INFO] [stderr]    Compiling cc v1.2.53
[INFO] [stderr]    Compiling der v0.7.10
[INFO] [stderr]    Compiling rustls-pki-types v1.14.0
[INFO] [stderr]    Compiling rand_core v0.9.5
[INFO] [stderr]    Compiling zmij v1.0.14
[INFO] [stderr]    Compiling ff v0.13.1
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling base16ct v0.2.0
[INFO] [stderr]    Compiling time-core v0.1.7
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling alloc-no-stdlib v2.0.4
[INFO] [stderr]    Compiling zstd-safe v7.2.4
[INFO] [stderr]    Compiling local-waker v0.1.4
[INFO] [stderr]    Compiling openssl-probe v0.2.0
[INFO] [stderr]    Compiling group v0.13.0
[INFO] [stderr]    Compiling alloc-stdlib v0.2.2
[INFO] [stderr]    Compiling convert_case v0.10.0
[INFO] [stderr]    Compiling time-macros v0.2.25
[INFO] [stderr]    Compiling pharos v0.5.3
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.7
[INFO] [stderr]    Compiling crypto-bigint v0.5.5
[INFO] [stderr]    Compiling rustls-native-certs v0.8.3
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling regex-lite v0.1.8
[INFO] [stderr]    Compiling spki v0.7.3
[INFO] [stderr]    Compiling cmake v0.1.57
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling pkcs8 v0.10.2
[INFO] [stderr]    Compiling signature v2.2.0
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling sec1 v0.7.3
[INFO] [stderr]    Compiling hkdf v0.12.4
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling log v0.4.29
[INFO] [stderr]    Compiling bytes v1.11.0
[INFO] [stderr]    Compiling rfc6979 v0.4.0
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling brotli-decompressor v5.0.0
[INFO] [stderr]    Compiling actix-utils v3.0.1
[INFO] [stderr]    Compiling pq-sys v0.7.5
[INFO] [stderr]    Compiling bytestring v1.5.0
[INFO] [stderr]    Compiling curve25519-dalek v4.1.3
[INFO] [stderr]    Compiling async_io_stream v0.3.3
[INFO] [stderr]    Compiling time v0.3.45
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling toml_datetime v0.7.5+spec-1.1.0
[INFO] [stderr]    Compiling serde_spanned v1.0.4
[INFO] [stderr]    Compiling actix-service v2.0.3
[INFO] [stderr]    Compiling cookie v0.16.2
[INFO] [stderr]    Compiling aws-lc-sys v0.36.0
[INFO] [stderr]    Compiling zstd-sys v2.0.16+zstd.1.5.7
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling num-bigint-dig v0.8.6
[INFO] [stderr]    Compiling diesel_derives v2.3.6
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling phf_shared v0.12.1
[INFO] [stderr]    Compiling elliptic-curve v0.13.8
[INFO] [stderr]    Compiling toml_parser v1.0.6+spec-1.1.0
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling ecdsa v0.16.9
[INFO] [stderr]    Compiling brotli v8.0.2
[INFO] [stderr]    Compiling primeorder v0.13.6
[INFO] [stderr]    Compiling flate2 v1.1.8
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling num-iter v0.1.45
[INFO] [stderr]    Compiling toml v0.9.11+spec-1.1.0
[INFO] [stderr]    Compiling local-channel v0.1.5
[INFO] [stderr]    Compiling lazy_static v1.5.0
[INFO] [stderr]    Compiling scheduled-thread-pool v0.2.7
[INFO] [stderr]    Compiling ws_stream_tungstenite v0.15.0
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling ryu v1.0.22
[INFO] [stderr]    Compiling chrono-tz v0.10.4
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling r2d2 v0.8.10
[INFO] [stderr]    Compiling phf v0.12.1
[INFO] [stderr]    Compiling ed25519 v2.2.3
[INFO] [stderr]    Compiling pkcs1 v0.7.5
[INFO] [stderr]    Compiling num-bigint v0.4.6
[INFO] [stderr]    Compiling iri-string v0.7.10
[INFO] [stderr]    Compiling impl-more v0.1.9
[INFO] [stderr]    Compiling downcast-rs v2.0.2
[INFO] [stderr]    Compiling tokio-cron-scheduler v0.15.1
[INFO] [stderr]    Compiling anstream v0.6.21
[INFO] [stderr]    Compiling env_filter v0.1.4
[INFO] [stderr]    Compiling p256 v0.13.2
[INFO] [stderr]    Compiling p384 v0.13.1
[INFO] [stderr]    Compiling blake2 v0.10.6
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling rustls-pemfile v2.2.0
[INFO] [stderr]    Compiling flume v0.11.1
[INFO] [stderr]    Compiling pem v3.0.6
[INFO] [stderr]    Compiling password-hash v0.5.0
[INFO] [stderr]    Compiling uuid v1.20.0
[INFO] [stderr]    Compiling jiff v0.2.18
[INFO] [stderr]    Compiling urlencoding v2.1.3
[INFO] [stderr]    Compiling md5 v0.8.0
[INFO] [stderr]    Compiling rsa v0.9.10
[INFO] [stderr]    Compiling argon2 v0.5.3
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]    Compiling diesel_table_macro_syntax v0.3.0
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling curve25519-dalek-derive v0.1.1
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling strum_macros v0.27.2
[INFO] [stderr]    Compiling actix-macros v0.2.4
[INFO] [stderr]    Compiling simple_asn1 v0.6.3
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling rustls-webpki v0.102.8
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling zstd v0.13.3
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling derive_builder_core v0.20.2
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling dsl_auto_type v0.2.0
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling ed25519-dalek v2.2.0
[INFO] [stderr]    Compiling derive_more v2.1.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling strum v0.27.2
[INFO] [stderr]    Compiling derive_builder_macro v0.20.2
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling derive_builder v0.20.2
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling chrono v0.4.43
[INFO] [stderr]    Compiling actix-router v0.5.3
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling migrations_internals v2.3.0
[INFO] [stderr]    Compiling jsonwebtoken v10.2.0
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling migrations_macros v2.3.0
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling actix-web-codegen v4.3.0
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling actix-rt v2.11.0
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]    Compiling croner v3.0.1
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling actix-codec v0.5.2
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling actix-server v2.6.0
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling diesel v2.3.6
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling actix-http v3.11.2
[INFO] [stderr]    Compiling hyper-util v0.1.19
[INFO] [stderr]    Compiling actix-web v4.12.1
[INFO] [stderr]    Compiling rustls-webpki v0.103.9
[INFO] [stderr]    Compiling actix-cors v0.7.1
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling tungstenite v0.26.2
[INFO] [stderr]    Compiling rustls-platform-verifier v0.6.2
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling reqwest v0.13.1
[INFO] [stderr]    Compiling async-tungstenite v0.29.1
[INFO] [stderr]    Compiling rumqttc v0.25.1
[INFO] [stderr]    Compiling diesel_migrations v2.3.1
[INFO] [stderr]    Compiling backend v0.1.0 (/opt/rustwide/workdir/backend)
[INFO] [stdout] warning: unused import: `MqttError`
[INFO] [stdout]  --> backend/src/integrations/meross_mqtt.rs:6:47
[INFO] [stdout]   |
[INFO] [stdout] 6 | use super::mqtt::{MqttConfig, MqttConnection, MqttError};
[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: `warn`
[INFO] [stdout]  --> backend/src/integrations/meross_mqtt.rs:8:31
[INFO] [stdout]   |
[INFO] [stdout] 8 | use log::{debug, error, info, warn};
[INFO] [stdout]   |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Datelike`
[INFO] [stdout]  --> backend/src/services/price_fetcher.rs:4:24
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::{DateTime, Datelike, Local, NaiveDate, NaiveDateTime, Timelike};
[INFO] [stdout]   |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reqwest::Error as ReqwestError`
[INFO] [stdout]  --> backend/src/services/price_fetcher.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use reqwest::Error as ReqwestError;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `sys_status` and `timestamp` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | struct MerossResponse<T> {
[INFO] [stdout]    |        -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 32 |     sys_status: Option<i32>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 |     timestamp: Option<i64>,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `email` is never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 39 | struct MerossLoginData {
[INFO] [stdout]    |        --------------- field in this struct
[INFO] [stdout] 40 |     userid: String,
[INFO] [stdout] 41 |     email: String,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossLoginData` 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 `online_status`, `channels`, `domain`, and `region` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:59:5
[INFO] [stdout]    |
[INFO] [stdout] 51 | struct MerossDeviceData {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 59 |     online_status: serde_json::Value,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 60 |     #[serde(default)]
[INFO] [stdout] 61 |     channels: Option<Vec<MerossChannel>>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 62 |     #[serde(default)]
[INFO] [stdout] 63 |     domain: Option<String>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 64 |     #[serde(default)]
[INFO] [stdout] 65 |     region: Option<String>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossDeviceData` 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 `channel`, `dev_name`, and `channel_type` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:74:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | struct MerossChannel {
[INFO] [stdout]    |        ------------- fields in this struct
[INFO] [stdout] 73 |     #[serde(default)]
[INFO] [stdout] 74 |     channel: Option<i32>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 75 |     #[serde(rename = "devName", default)]
[INFO] [stdout] 76 |     dev_name: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 77 |     #[serde(rename = "type", default)]
[INFO] [stdout] 78 |     channel_type: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossChannel` 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 `run_automation` is never used
[INFO] [stdout]    --> backend/src/bin/cron_runner.rs:271:10
[INFO] [stdout]     |
[INFO] [stdout] 271 | async fn run_automation(pool: Arc<DbPool>) {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MqttError`
[INFO] [stdout]  --> backend/src/integrations/meross_mqtt.rs:6:47
[INFO] [stdout]   |
[INFO] [stdout] 6 | use super::mqtt::{MqttConfig, MqttConnection, MqttError};
[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: `warn`
[INFO] [stdout]  --> backend/src/integrations/meross_mqtt.rs:8:31
[INFO] [stdout]   |
[INFO] [stdout] 8 | use log::{debug, error, info, warn};
[INFO] [stdout]   |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Datelike`
[INFO] [stdout]  --> backend/src/services/price_fetcher.rs:4:24
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::{DateTime, Datelike, Local, NaiveDate, NaiveDateTime, Timelike};
[INFO] [stdout]   |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reqwest::Error as ReqwestError`
[INFO] [stdout]  --> backend/src/services/price_fetcher.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use reqwest::Error as ReqwestError;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `has_provider` is never used
[INFO] [stdout]    --> backend/src/integrations/mod.rs:174:12
[INFO] [stdout]     |
[INFO] [stdout] 142 | impl ProviderRegistry {
[INFO] [stdout]     | --------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 174 |     pub fn has_provider(&self, name: &str) -> 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: fields `sys_status` and `timestamp` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | struct MerossResponse<T> {
[INFO] [stdout]    |        -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 32 |     sys_status: Option<i32>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 |     timestamp: Option<i64>,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `email` is never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 39 | struct MerossLoginData {
[INFO] [stdout]    |        --------------- field in this struct
[INFO] [stdout] 40 |     userid: String,
[INFO] [stdout] 41 |     email: String,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossLoginData` 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 `online_status`, `channels`, `domain`, and `region` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:59:5
[INFO] [stdout]    |
[INFO] [stdout] 51 | struct MerossDeviceData {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 59 |     online_status: serde_json::Value,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 60 |     #[serde(default)]
[INFO] [stdout] 61 |     channels: Option<Vec<MerossChannel>>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 62 |     #[serde(default)]
[INFO] [stdout] 63 |     domain: Option<String>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 64 |     #[serde(default)]
[INFO] [stdout] 65 |     region: Option<String>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossDeviceData` 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 `channel`, `dev_name`, and `channel_type` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:74:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | struct MerossChannel {
[INFO] [stdout]    |        ------------- fields in this struct
[INFO] [stdout] 73 |     #[serde(default)]
[INFO] [stdout] 74 |     channel: Option<i32>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 75 |     #[serde(rename = "devName", default)]
[INFO] [stdout] 76 |     dev_name: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 77 |     #[serde(rename = "type", default)]
[INFO] [stdout] 78 |     channel_type: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossChannel` 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: struct `TogglePayload` is never constructed
[INFO] [stdout]   --> backend/src/integrations/meross_mqtt.rs:39:12
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct TogglePayload {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ToggleX` is never constructed
[INFO] [stdout]   --> backend/src/integrations/meross_mqtt.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub struct ToggleX {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Toggle` is never constructed
[INFO] [stdout]   --> backend/src/integrations/meross_mqtt.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub struct Toggle {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `channel` is never read
[INFO] [stdout]   --> backend/src/integrations/meross_mqtt.rs:74:9
[INFO] [stdout]    |
[INFO] [stdout] 73 | pub struct ToggleXState {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 74 |     pub channel: i32,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ToggleXState` 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: variant `InvalidResponse` is never constructed
[INFO] [stdout]   --> backend/src/integrations/mqtt.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub enum MqttError {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 51 |     InvalidResponse(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MqttError` 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 `topic` is never read
[INFO] [stdout]   --> backend/src/integrations/mqtt.rs:72:9
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub struct MqttMessage {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] 72 |     pub topic: String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MqttMessage` 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: method `payload_str` is never used
[INFO] [stdout]   --> backend/src/integrations/mqtt.rs:83:12
[INFO] [stdout]    |
[INFO] [stdout] 76 | impl MqttMessage {
[INFO] [stdout]    | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 83 |     pub fn payload_str(&self) -> Option<String> {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `publish_json` and `request_json` are never used
[INFO] [stdout]    --> backend/src/integrations/mqtt.rs:341:18
[INFO] [stdout]     |
[INFO] [stdout] 102 | impl MqttConnection {
[INFO] [stdout]     | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 341 |     pub async fn publish_json<T: Serialize>(&self, topic: &str, payload: &T) -> Result<(), MqttError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 394 |     pub async fn request_json<Req: Serialize, Resp: for<'de> Deserialize<'de>>(
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `RuleType` is never used
[INFO] [stdout]   --> backend/src/models.rs:86:10
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub enum RuleType {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `as_str` and `from_str` are never used
[INFO] [stdout]    --> backend/src/models.rs:98:12
[INFO] [stdout]     |
[INFO] [stdout]  97 | impl RuleType {
[INFO] [stdout]     | ------------- associated items in this implementation
[INFO] [stdout]  98 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub fn from_str(s: &str) -> Option<Self> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_rule_type` and `get_action` are never used
[INFO] [stdout]    --> backend/src/models.rs:164:12
[INFO] [stdout]     |
[INFO] [stdout] 163 | impl AutomationRule {
[INFO] [stdout]     | ------------------- methods in this implementation
[INFO] [stdout] 164 |     pub fn get_rule_type(&self) -> Option<RuleType> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub fn get_action(&self) -> Option<RuleAction> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_str` is never used
[INFO] [stdout]    --> backend/src/models.rs:258:12
[INFO] [stdout]     |
[INFO] [stdout] 247 | impl ExecutionStatus {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 258 |     pub fn from_str(s: &str) -> Option<Self> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_status` is never used
[INFO] [stdout]    --> backend/src/models.rs:287:12
[INFO] [stdout]     |
[INFO] [stdout] 286 | impl ScheduledExecution {
[INFO] [stdout]     | ----------------------- method in this implementation
[INFO] [stdout] 287 |     pub fn get_status(&self) -> Option<ExecutionStatus> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `rule_id` is never read
[INFO] [stdout]   --> backend/src/services/automation_engine.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct RuleEvaluation {
[INFO] [stdout]    |            -------------- field in this struct
[INFO] [stdout] 20 |     pub rule_id: i32,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RuleEvaluation` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `execute_current_hour`, `execute_scheduled_execution`, `update_scheduled_status`, and `retry_failed_executions` are never used
[INFO] [stdout]    --> backend/src/services/automation_engine.rs:674:18
[INFO] [stdout]     |
[INFO] [stdout]  43 | impl AutomationEngine {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 674 |     pub async fn execute_current_hour(&self) -> Vec<ExecutionResult> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 758 |     async fn execute_scheduled_execution(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 786 |     async fn update_scheduled_status(&self, scheduled_id: i32, result: &ExecutionResult) {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 860 |     pub async fn retry_failed_executions(&self) -> Vec<ExecutionResult> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HomeAssistantClient` is never constructed
[INFO] [stdout]  --> backend/src/services/ha_client.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct HomeAssistantClient {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `turn_on`, `turn_off`, and `call_service` are never used
[INFO] [stdout]   --> backend/src/services/ha_client.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl HomeAssistantClient {
[INFO] [stdout]    | ------------------------ associated items in this implementation
[INFO] [stdout] 10 |     pub fn new(base_url: String, token: String) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 14 |     pub async fn turn_on(&self, entity_id: &str) -> Result<(), Error> {
[INFO] [stdout]    |                  ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub async fn turn_off(&self, entity_id: &str) -> Result<(), Error> {
[INFO] [stdout]    |                  ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     async fn call_service(
[INFO] [stdout]    |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `with_token` and `has_prices_for_date` are never used
[INFO] [stdout]    --> backend/src/services/price_fetcher.rs:66:12
[INFO] [stdout]     |
[INFO] [stdout]  60 | impl PriceService {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  66 |     pub fn with_token(pool: DbPool, token: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 201 |     pub fn has_prices_for_date(&self, date: NaiveDate) -> Result<bool, PriceFetchError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_esios_value` is never used
[INFO] [stdout]    --> backend/src/services/price_fetcher.rs:271:8
[INFO] [stdout]     |
[INFO] [stdout] 271 | pub fn parse_esios_value(value: f64, datetime: &str) -> Result<PriceData, String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `rule_has_overnight_window`, `recompute_overnight_rules`, `delete_pending_overnight_for_rule`, `get_schedule_for_date`, and `recompute_schedule_for_rule` are never used
[INFO] [stdout]    --> backend/src/services/schedule_computation.rs:261:12
[INFO] [stdout]     |
[INFO] [stdout]  14 | impl ScheduleComputationService {
[INFO] [stdout]     | ------------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 261 |     pub fn rule_has_overnight_window(&self, rule: &AutomationRule) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 288 |     pub fn recompute_overnight_rules(&self) -> Result<usize, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 338 |     fn delete_pending_overnight_for_rule(&self, rule: &AutomationRule, date: NaiveDate) -> Result<usize, String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 404 |     pub fn get_schedule_for_date(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 453 |     pub fn recompute_schedule_for_rule(&self, rule_id: i32) -> Result<usize, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_cheapest_hours` is never used
[INFO] [stdout]  --> backend/src/services/scheduler.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn find_cheapest_hours(prices: &[Price], duration_minutes: i32) -> Vec<NaiveDateTime> {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 54s
[INFO] running `Command { std: "docker" "inspect" "99214b2ee5615714c4c66a8d46712f48bc5eecdd2876197cdf3307b91dc9b153", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "99214b2ee5615714c4c66a8d46712f48bc5eecdd2876197cdf3307b91dc9b153", kill_on_drop: false }`
[INFO] [stdout] 99214b2ee5615714c4c66a8d46712f48bc5eecdd2876197cdf3307b91dc9b153
[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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2a75e3eb00b59c84e1f7aca1124313b34590d403635db10f462ff86a184b7b5a
[INFO] running `Command { std: "docker" "start" "-a" "2a75e3eb00b59c84e1f7aca1124313b34590d403635db10f462ff86a184b7b5a", kill_on_drop: false }`
[INFO] [stderr]    Compiling actix-rt v2.11.0
[INFO] [stderr]    Compiling actix-server v2.6.0
[INFO] [stderr]    Compiling actix-http v3.11.2
[INFO] [stderr]    Compiling actix-web v4.12.1
[INFO] [stderr]    Compiling actix-cors v0.7.1
[INFO] [stderr]    Compiling backend v0.1.0 (/opt/rustwide/workdir/backend)
[INFO] [stdout] warning: unused import: `MqttError`
[INFO] [stdout]  --> backend/src/integrations/meross_mqtt.rs:6:47
[INFO] [stdout]   |
[INFO] [stdout] 6 | use super::mqtt::{MqttConfig, MqttConnection, MqttError};
[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: `warn`
[INFO] [stdout]  --> backend/src/integrations/meross_mqtt.rs:8:31
[INFO] [stdout]   |
[INFO] [stdout] 8 | use log::{debug, error, info, warn};
[INFO] [stdout]   |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Datelike`
[INFO] [stdout]  --> backend/src/services/price_fetcher.rs:4:24
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::{DateTime, Datelike, Local, NaiveDate, NaiveDateTime, Timelike};
[INFO] [stdout]   |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reqwest::Error as ReqwestError`
[INFO] [stdout]  --> backend/src/services/price_fetcher.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use reqwest::Error as ReqwestError;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MqttError`
[INFO] [stdout]  --> backend/src/integrations/meross_mqtt.rs:6:47
[INFO] [stdout]   |
[INFO] [stdout] 6 | use super::mqtt::{MqttConfig, MqttConnection, MqttError};
[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: `warn`
[INFO] [stdout]  --> backend/src/integrations/meross_mqtt.rs:8:31
[INFO] [stdout]   |
[INFO] [stdout] 8 | use log::{debug, error, info, warn};
[INFO] [stdout]   |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reqwest::Error as ReqwestError`
[INFO] [stdout]  --> backend/src/services/price_fetcher.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use reqwest::Error as ReqwestError;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `sys_status` and `timestamp` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | struct MerossResponse<T> {
[INFO] [stdout]    |        -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 32 |     sys_status: Option<i32>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 |     timestamp: Option<i64>,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `email` is never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 39 | struct MerossLoginData {
[INFO] [stdout]    |        --------------- field in this struct
[INFO] [stdout] 40 |     userid: String,
[INFO] [stdout] 41 |     email: String,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossLoginData` 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 `online_status`, `channels`, `domain`, and `region` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:59:5
[INFO] [stdout]    |
[INFO] [stdout] 51 | struct MerossDeviceData {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 59 |     online_status: serde_json::Value,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 60 |     #[serde(default)]
[INFO] [stdout] 61 |     channels: Option<Vec<MerossChannel>>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 62 |     #[serde(default)]
[INFO] [stdout] 63 |     domain: Option<String>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 64 |     #[serde(default)]
[INFO] [stdout] 65 |     region: Option<String>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossDeviceData` 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 `channel`, `dev_name`, and `channel_type` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:74:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | struct MerossChannel {
[INFO] [stdout]    |        ------------- fields in this struct
[INFO] [stdout] 73 |     #[serde(default)]
[INFO] [stdout] 74 |     channel: Option<i32>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 75 |     #[serde(rename = "devName", default)]
[INFO] [stdout] 76 |     dev_name: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 77 |     #[serde(rename = "type", default)]
[INFO] [stdout] 78 |     channel_type: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossChannel` 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 `sys_status` and `timestamp` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | struct MerossResponse<T> {
[INFO] [stdout]    |        -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 32 |     sys_status: Option<i32>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 |     timestamp: Option<i64>,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `email` is never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 39 | struct MerossLoginData {
[INFO] [stdout]    |        --------------- field in this struct
[INFO] [stdout] 40 |     userid: String,
[INFO] [stdout] 41 |     email: String,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossLoginData` 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 `online_status`, `channels`, `domain`, and `region` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:59:5
[INFO] [stdout]    |
[INFO] [stdout] 51 | struct MerossDeviceData {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 59 |     online_status: serde_json::Value,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 60 |     #[serde(default)]
[INFO] [stdout] 61 |     channels: Option<Vec<MerossChannel>>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 62 |     #[serde(default)]
[INFO] [stdout] 63 |     domain: Option<String>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 64 |     #[serde(default)]
[INFO] [stdout] 65 |     region: Option<String>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossDeviceData` 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 `channel`, `dev_name`, and `channel_type` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:74:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | struct MerossChannel {
[INFO] [stdout]    |        ------------- fields in this struct
[INFO] [stdout] 73 |     #[serde(default)]
[INFO] [stdout] 74 |     channel: Option<i32>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 75 |     #[serde(rename = "devName", default)]
[INFO] [stdout] 76 |     dev_name: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 77 |     #[serde(rename = "type", default)]
[INFO] [stdout] 78 |     channel_type: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossChannel` 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 `value` is never read
[INFO] [stdout]    --> backend/src/integrations/mqtt.rs:470:13
[INFO] [stdout]     |
[INFO] [stdout] 469 |         struct TestPayload {
[INFO] [stdout]     |                ----------- field in this struct
[INFO] [stdout] 470 |             value: i32,
[INFO] [stdout]     |             ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_automation` is never used
[INFO] [stdout]    --> backend/src/bin/cron_runner.rs:271:10
[INFO] [stdout]     |
[INFO] [stdout] 271 | async fn run_automation(pool: Arc<DbPool>) {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MqttError`
[INFO] [stdout]  --> backend/src/integrations/meross_mqtt.rs:6:47
[INFO] [stdout]   |
[INFO] [stdout] 6 | use super::mqtt::{MqttConfig, MqttConnection, MqttError};
[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: `warn`
[INFO] [stdout]  --> backend/src/integrations/meross_mqtt.rs:8:31
[INFO] [stdout]   |
[INFO] [stdout] 8 | use log::{debug, error, info, warn};
[INFO] [stdout]   |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reqwest::Error as ReqwestError`
[INFO] [stdout]  --> backend/src/services/price_fetcher.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use reqwest::Error as ReqwestError;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `sys_status` and `timestamp` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | struct MerossResponse<T> {
[INFO] [stdout]    |        -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 32 |     sys_status: Option<i32>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 |     timestamp: Option<i64>,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `email` is never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 39 | struct MerossLoginData {
[INFO] [stdout]    |        --------------- field in this struct
[INFO] [stdout] 40 |     userid: String,
[INFO] [stdout] 41 |     email: String,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossLoginData` 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 `online_status`, `channels`, `domain`, and `region` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:59:5
[INFO] [stdout]    |
[INFO] [stdout] 51 | struct MerossDeviceData {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 59 |     online_status: serde_json::Value,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 60 |     #[serde(default)]
[INFO] [stdout] 61 |     channels: Option<Vec<MerossChannel>>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 62 |     #[serde(default)]
[INFO] [stdout] 63 |     domain: Option<String>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 64 |     #[serde(default)]
[INFO] [stdout] 65 |     region: Option<String>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossDeviceData` 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 `channel`, `dev_name`, and `channel_type` are never read
[INFO] [stdout]   --> backend/src/integrations/meross.rs:74:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | struct MerossChannel {
[INFO] [stdout]    |        ------------- fields in this struct
[INFO] [stdout] 73 |     #[serde(default)]
[INFO] [stdout] 74 |     channel: Option<i32>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 75 |     #[serde(rename = "devName", default)]
[INFO] [stdout] 76 |     dev_name: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 77 |     #[serde(rename = "type", default)]
[INFO] [stdout] 78 |     channel_type: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MerossChannel` 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: struct `TogglePayload` is never constructed
[INFO] [stdout]   --> backend/src/integrations/meross_mqtt.rs:39:12
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct TogglePayload {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ToggleX` is never constructed
[INFO] [stdout]   --> backend/src/integrations/meross_mqtt.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub struct ToggleX {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Toggle` is never constructed
[INFO] [stdout]   --> backend/src/integrations/meross_mqtt.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub struct Toggle {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `channel` is never read
[INFO] [stdout]   --> backend/src/integrations/meross_mqtt.rs:74:9
[INFO] [stdout]    |
[INFO] [stdout] 73 | pub struct ToggleXState {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 74 |     pub channel: i32,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ToggleXState` 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: variant `InvalidResponse` is never constructed
[INFO] [stdout]   --> backend/src/integrations/mqtt.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub enum MqttError {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 51 |     InvalidResponse(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MqttError` 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 `topic` is never read
[INFO] [stdout]   --> backend/src/integrations/mqtt.rs:72:9
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub struct MqttMessage {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] 72 |     pub topic: String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MqttMessage` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `publish_json` and `request_json` are never used
[INFO] [stdout]    --> backend/src/integrations/mqtt.rs:341:18
[INFO] [stdout]     |
[INFO] [stdout] 102 | impl MqttConnection {
[INFO] [stdout]     | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 341 |     pub async fn publish_json<T: Serialize>(&self, topic: &str, payload: &T) -> Result<(), MqttError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 394 |     pub async fn request_json<Req: Serialize, Resp: for<'de> Deserialize<'de>>(
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> backend/src/integrations/mqtt.rs:470:13
[INFO] [stdout]     |
[INFO] [stdout] 469 |         struct TestPayload {
[INFO] [stdout]     |                ----------- field in this struct
[INFO] [stdout] 470 |             value: i32,
[INFO] [stdout]     |             ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_rule_type` and `get_action` are never used
[INFO] [stdout]    --> backend/src/models.rs:164:12
[INFO] [stdout]     |
[INFO] [stdout] 163 | impl AutomationRule {
[INFO] [stdout]     | ------------------- methods in this implementation
[INFO] [stdout] 164 |     pub fn get_rule_type(&self) -> Option<RuleType> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub fn get_action(&self) -> Option<RuleAction> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_str` is never used
[INFO] [stdout]    --> backend/src/models.rs:258:12
[INFO] [stdout]     |
[INFO] [stdout] 247 | impl ExecutionStatus {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 258 |     pub fn from_str(s: &str) -> Option<Self> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_status` is never used
[INFO] [stdout]    --> backend/src/models.rs:287:12
[INFO] [stdout]     |
[INFO] [stdout] 286 | impl ScheduledExecution {
[INFO] [stdout]     | ----------------------- method in this implementation
[INFO] [stdout] 287 |     pub fn get_status(&self) -> Option<ExecutionStatus> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `rule_id` is never read
[INFO] [stdout]   --> backend/src/services/automation_engine.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct RuleEvaluation {
[INFO] [stdout]    |            -------------- field in this struct
[INFO] [stdout] 20 |     pub rule_id: i32,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RuleEvaluation` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `execute_current_hour`, `execute_scheduled_execution`, `update_scheduled_status`, and `retry_failed_executions` are never used
[INFO] [stdout]    --> backend/src/services/automation_engine.rs:674:18
[INFO] [stdout]     |
[INFO] [stdout]  43 | impl AutomationEngine {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 674 |     pub async fn execute_current_hour(&self) -> Vec<ExecutionResult> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 758 |     async fn execute_scheduled_execution(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 786 |     async fn update_scheduled_status(&self, scheduled_id: i32, result: &ExecutionResult) {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 860 |     pub async fn retry_failed_executions(&self) -> Vec<ExecutionResult> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `turn_on`, `turn_off`, and `call_service` are never used
[INFO] [stdout]   --> backend/src/services/ha_client.rs:14:18
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl HomeAssistantClient {
[INFO] [stdout]    | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 14 |     pub async fn turn_on(&self, entity_id: &str) -> Result<(), Error> {
[INFO] [stdout]    |                  ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub async fn turn_off(&self, entity_id: &str) -> Result<(), Error> {
[INFO] [stdout]    |                  ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     async fn call_service(
[INFO] [stdout]    |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `with_token` and `has_prices_for_date` are never used
[INFO] [stdout]    --> backend/src/services/price_fetcher.rs:66:12
[INFO] [stdout]     |
[INFO] [stdout]  60 | impl PriceService {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  66 |     pub fn with_token(pool: DbPool, token: String) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 201 |     pub fn has_prices_for_date(&self, date: NaiveDate) -> Result<bool, PriceFetchError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `rule_has_overnight_window`, `recompute_overnight_rules`, `delete_pending_overnight_for_rule`, `get_schedule_for_date`, and `recompute_schedule_for_rule` are never used
[INFO] [stdout]    --> backend/src/services/schedule_computation.rs:261:12
[INFO] [stdout]     |
[INFO] [stdout]  14 | impl ScheduleComputationService {
[INFO] [stdout]     | ------------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 261 |     pub fn rule_has_overnight_window(&self, rule: &AutomationRule) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 288 |     pub fn recompute_overnight_rules(&self) -> Result<usize, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 338 |     fn delete_pending_overnight_for_rule(&self, rule: &AutomationRule, date: NaiveDate) -> Result<usize, String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 404 |     pub fn get_schedule_for_date(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 453 |     pub fn recompute_schedule_for_rule(&self, rule_id: i32) -> Result<usize, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 45.36s
[INFO] running `Command { std: "docker" "inspect" "2a75e3eb00b59c84e1f7aca1124313b34590d403635db10f462ff86a184b7b5a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2a75e3eb00b59c84e1f7aca1124313b34590d403635db10f462ff86a184b7b5a", kill_on_drop: false }`
[INFO] [stdout] 2a75e3eb00b59c84e1f7aca1124313b34590d403635db10f462ff86a184b7b5a
[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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 2ae8374ce1059a743e77c8a35581e4fd712363af35d7fae7a5152cc43ed5c1e3
[INFO] running `Command { std: "docker" "start" "-a" "2ae8374ce1059a743e77c8a35581e4fd712363af35d7fae7a5152cc43ed5c1e3", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `MqttError`
[INFO] [stderr]  --> backend/src/integrations/meross_mqtt.rs:6:47
[INFO] [stderr]   |
[INFO] [stderr] 6 | use super::mqtt::{MqttConfig, MqttConnection, MqttError};
[INFO] [stderr]   |                                               ^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `warn`
[INFO] [stderr]  --> backend/src/integrations/meross_mqtt.rs:8:31
[INFO] [stderr]   |
[INFO] [stderr] 8 | use log::{debug, error, info, warn};
[INFO] [stderr]   |                               ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Datelike`
[INFO] [stderr]  --> backend/src/services/price_fetcher.rs:4:24
[INFO] [stderr]   |
[INFO] [stderr] 4 | use chrono::{DateTime, Datelike, Local, NaiveDate, NaiveDateTime, Timelike};
[INFO] [stderr]   |                        ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `reqwest::Error as ReqwestError`
[INFO] [stderr]  --> backend/src/services/price_fetcher.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use reqwest::Error as ReqwestError;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `sys_status` and `timestamp` are never read
[INFO] [stderr]   --> backend/src/integrations/meross.rs:32:5
[INFO] [stderr]    |
[INFO] [stderr] 28 | struct MerossResponse<T> {
[INFO] [stderr]    |        -------------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 32 |     sys_status: Option<i32>,
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 35 |     timestamp: Option<i64>,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MerossResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `email` is never read
[INFO] [stderr]   --> backend/src/integrations/meross.rs:41:5
[INFO] [stderr]    |
[INFO] [stderr] 39 | struct MerossLoginData {
[INFO] [stderr]    |        --------------- field in this struct
[INFO] [stderr] 40 |     userid: String,
[INFO] [stderr] 41 |     email: String,
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MerossLoginData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `online_status`, `channels`, `domain`, and `region` are never read
[INFO] [stderr]   --> backend/src/integrations/meross.rs:59:5
[INFO] [stderr]    |
[INFO] [stderr] 51 | struct MerossDeviceData {
[INFO] [stderr]    |        ---------------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 59 |     online_status: serde_json::Value,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 60 |     #[serde(default)]
[INFO] [stderr] 61 |     channels: Option<Vec<MerossChannel>>,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 62 |     #[serde(default)]
[INFO] [stderr] 63 |     domain: Option<String>,
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] 64 |     #[serde(default)]
[INFO] [stderr] 65 |     region: Option<String>,
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MerossDeviceData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `channel`, `dev_name`, and `channel_type` are never read
[INFO] [stderr]   --> backend/src/integrations/meross.rs:74:5
[INFO] [stderr]    |
[INFO] [stderr] 72 | struct MerossChannel {
[INFO] [stderr]    |        ------------- fields in this struct
[INFO] [stderr] 73 |     #[serde(default)]
[INFO] [stderr] 74 |     channel: Option<i32>,
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] 75 |     #[serde(rename = "devName", default)]
[INFO] [stderr] 76 |     dev_name: Option<String>,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 77 |     #[serde(rename = "type", default)]
[INFO] [stderr] 78 |     channel_type: Option<String>,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MerossChannel` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `value` is never read
[INFO] [stderr]    --> backend/src/integrations/mqtt.rs:470:13
[INFO] [stderr]     |
[INFO] [stderr] 469 |         struct TestPayload {
[INFO] [stderr]     |                ----------- field in this struct
[INFO] [stderr] 470 |             value: i32,
[INFO] [stderr]     |             ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `backend` (lib) generated 8 warnings (run `cargo fix --lib -p backend` to apply 4 suggestions)
[INFO] [stderr] warning: `backend` (lib test) generated 8 warnings (7 duplicates)
[INFO] [stderr] warning: function `run_automation` is never used
[INFO] [stderr]    --> backend/src/bin/cron_runner.rs:271:10
[INFO] [stderr]     |
[INFO] [stderr] 271 | async fn run_automation(pool: Arc<DbPool>) {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: struct `TogglePayload` is never constructed
[INFO] [stderr]   --> backend/src/integrations/meross_mqtt.rs:39:12
[INFO] [stderr]    |
[INFO] [stderr] 39 | pub struct TogglePayload {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ToggleX` is never constructed
[INFO] [stderr]   --> backend/src/integrations/meross_mqtt.rs:45:12
[INFO] [stderr]    |
[INFO] [stderr] 45 | pub struct ToggleX {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Toggle` is never constructed
[INFO] [stderr]   --> backend/src/integrations/meross_mqtt.rs:51:12
[INFO] [stderr]    |
[INFO] [stderr] 51 | pub struct Toggle {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `channel` is never read
[INFO] [stderr]   --> backend/src/integrations/meross_mqtt.rs:74:9
[INFO] [stderr]    |
[INFO] [stderr] 73 | pub struct ToggleXState {
[INFO] [stderr]    |            ------------ field in this struct
[INFO] [stderr] 74 |     pub channel: i32,
[INFO] [stderr]    |         ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ToggleXState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variant `InvalidResponse` is never constructed
[INFO] [stderr]   --> backend/src/integrations/mqtt.rs:51:5
[INFO] [stderr]    |
[INFO] [stderr] 45 | pub enum MqttError {
[INFO] [stderr]    |          --------- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 51 |     InvalidResponse(String),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MqttError` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `topic` is never read
[INFO] [stderr]   --> backend/src/integrations/mqtt.rs:72:9
[INFO] [stderr]    |
[INFO] [stderr] 71 | pub struct MqttMessage {
[INFO] [stderr]    |            ----------- field in this struct
[INFO] [stderr] 72 |     pub topic: String,
[INFO] [stderr]    |         ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MqttMessage` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `publish_json` and `request_json` are never used
[INFO] [stderr]    --> backend/src/integrations/mqtt.rs:341:18
[INFO] [stderr]     |
[INFO] [stderr] 102 | impl MqttConnection {
[INFO] [stderr]     | ------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 341 |     pub async fn publish_json<T: Serialize>(&self, topic: &str, payload: &T) -> Result<(), MqttError> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 394 |     pub async fn request_json<Req: Serialize, Resp: for<'de> Deserialize<'de>>(
[INFO] [stderr]     |                  ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `get_rule_type` and `get_action` are never used
[INFO] [stderr]    --> backend/src/models.rs:164:12
[INFO] [stderr]     |
[INFO] [stderr] 163 | impl AutomationRule {
[INFO] [stderr]     | ------------------- methods in this implementation
[INFO] [stderr] 164 |     pub fn get_rule_type(&self) -> Option<RuleType> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 168 |     pub fn get_action(&self) -> Option<RuleAction> {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_str` is never used
[INFO] [stderr]    --> backend/src/models.rs:258:12
[INFO] [stderr]     |
[INFO] [stderr] 247 | impl ExecutionStatus {
[INFO] [stderr]     | -------------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 258 |     pub fn from_str(s: &str) -> Option<Self> {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `get_status` is never used
[INFO] [stderr]    --> backend/src/models.rs:287:12
[INFO] [stderr]     |
[INFO] [stderr] 286 | impl ScheduledExecution {
[INFO] [stderr]     | ----------------------- method in this implementation
[INFO] [stderr] 287 |     pub fn get_status(&self) -> Option<ExecutionStatus> {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `rule_id` is never read
[INFO] [stderr]   --> backend/src/services/automation_engine.rs:20:9
[INFO] [stderr]    |
[INFO] [stderr] 19 | pub struct RuleEvaluation {
[INFO] [stderr]    |            -------------- field in this struct
[INFO] [stderr] 20 |     pub rule_id: i32,
[INFO] [stderr]    |         ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `RuleEvaluation` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `execute_current_hour`, `execute_scheduled_execution`, `update_scheduled_status`, and `retry_failed_executions` are never used
[INFO] [stderr]    --> backend/src/services/automation_engine.rs:674:18
[INFO] [stderr]     |
[INFO] [stderr]  43 | impl AutomationEngine {
[INFO] [stderr]     | --------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 674 |     pub async fn execute_current_hour(&self) -> Vec<ExecutionResult> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 758 |     async fn execute_scheduled_execution(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 786 |     async fn update_scheduled_status(&self, scheduled_id: i32, result: &ExecutionResult) {
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 860 |     pub async fn retry_failed_executions(&self) -> Vec<ExecutionResult> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `turn_on`, `turn_off`, and `call_service` are never used
[INFO] [stderr]   --> backend/src/services/ha_client.rs:14:18
[INFO] [stderr]    |
[INFO] [stderr]  9 | impl HomeAssistantClient {
[INFO] [stderr]    | ------------------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 14 |     pub async fn turn_on(&self, entity_id: &str) -> Result<(), Error> {
[INFO] [stderr]    |                  ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 18 |     pub async fn turn_off(&self, entity_id: &str) -> Result<(), Error> {
[INFO] [stderr]    |                  ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 22 |     async fn call_service(
[INFO] [stderr]    |              ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `with_token` and `has_prices_for_date` are never used
[INFO] [stderr]    --> backend/src/services/price_fetcher.rs:66:12
[INFO] [stderr]     |
[INFO] [stderr]  60 | impl PriceService {
[INFO] [stderr]     | ----------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  66 |     pub fn with_token(pool: DbPool, token: String) -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 201 |     pub fn has_prices_for_date(&self, date: NaiveDate) -> Result<bool, PriceFetchError> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `rule_has_overnight_window`, `recompute_overnight_rules`, `delete_pending_overnight_for_rule`, `get_schedule_for_date`, and `recompute_schedule_for_rule` are never used
[INFO] [stderr]    --> backend/src/services/schedule_computation.rs:261:12
[INFO] [stderr]     |
[INFO] [stderr]  14 | impl ScheduleComputationService {
[INFO] [stderr]     | ------------------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 261 |     pub fn rule_has_overnight_window(&self, rule: &AutomationRule) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 288 |     pub fn recompute_overnight_rules(&self) -> Result<usize, String> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 338 |     fn delete_pending_overnight_for_rule(&self, rule: &AutomationRule, date: NaiveDate) -> Result<usize, String> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 404 |     pub fn get_schedule_for_date(
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 453 |     pub fn recompute_schedule_for_rule(&self, rule_id: i32) -> Result<usize, String> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `backend` (bin "cron_runner" test) generated 1 warning
[INFO] [stderr] warning: `backend` (bin "backend" test) generated 23 warnings (8 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.58s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/backend-19297481cf8e69e7)
[INFO] [stdout] 
[INFO] [stdout] running 101 tests
[INFO] [stdout] test api::auth::tests::test_auth_request_deserialization ... ok
[INFO] [stdout] test api::auth::tests::test_auth_request_long_values ... ok
[INFO] [stdout] test api::auth::tests::test_auth_request_empty_strings ... ok
[INFO] [stdout] test api::auth::tests::test_auth_request_missing_field_fails ... ok
[INFO] [stdout] test api::auth::tests::test_auth_request_with_unicode ... ok
[INFO] [stdout] test api::automation::tests::test_automation_endpoint_exists ... ok
[INFO] [stdout] test api::devices::tests::test_device_action_request_deserialization ... ok
[INFO] [stdout] test api::devices::tests::test_sync_devices_request_deserialization ... ok
[INFO] [stdout] test api::auth::tests::test_auth_request_with_special_characters ... ok
[INFO] [stdout] test api::devices::tests::test_update_device_request_partial ... ok
[INFO] [stdout] test api::integrations::tests::test_add_integration_request_deserialization ... ok
[INFO] [stdout] test api::devices::tests::test_update_device_request_deserialization ... ok
[INFO] [stdout] test api::integrations::tests::test_add_integration_request_missing_credentials_fails ... ok
[INFO] [stdout] test api::integrations::tests::test_add_integration_request_missing_provider_fails ... ok
[INFO] [stdout] test api::integrations::tests::test_add_integration_request_with_empty_credentials ... ok
[INFO] [stdout] test api::integrations::tests::test_add_integration_request_with_complex_credentials ... ok
[INFO] [stdout] test api::integrations::tests::test_add_integration_request_with_null_credentials ... ok
[INFO] [stdout] test api::integrations::tests::test_supported_provider_names ... ok
[INFO] [stdout] test api::prices::tests::test_cheapest_hours_query_parsing ... ok
[INFO] [stdout] test api::prices::tests::test_date_query_parsing ... ok
[INFO] [stdout] test api::prices::tests::test_price_response_serialization ... ok
[INFO] [stdout] test api::prices::tests::test_sync_response_serialization ... ok
[INFO] [stdout] test api::rules::tests::test_pagination_query_defaults ... ok
[INFO] [stdout] test api::rules::tests::test_update_rule_request_partial ... ok
[INFO] [stdout] test integrations::meross::tests::test_base64_encode ... ok
[INFO] [stdout] test integrations::meross::tests::test_calculate_sign ... ok
[INFO] [stdout] test integrations::meross::tests::test_build_request ... ok
[INFO] [stdout] test integrations::meross::tests::test_generate_nonce ... ok
[INFO] [stdout] test integrations::meross::tests::test_get_api_url_custom ... ok
[INFO] [stdout] test integrations::meross::tests::test_get_api_url_default ... ok
[INFO] [stdout] test api::rules::tests::test_create_rule_request_deserialization ... ok
[INFO] [stdout] test integrations::meross_mqtt::tests::test_build_device_topic ... ok
[INFO] [stdout] test integrations::meross_mqtt::tests::test_calculate_sign ... ok
[INFO] [stdout] test integrations::meross_mqtt::tests::test_from_credentials_missing_key ... ok
[INFO] [stdout] test integrations::meross_mqtt::tests::test_from_credentials_missing_user_id ... ok
[INFO] [stdout] test integrations::meross_mqtt::tests::test_from_credentials_valid ... ok
[INFO] [stdout] test integrations::meross_mqtt::tests::test_generate_message_id ... ok
[INFO] [stdout] test integrations::meross_mqtt::tests::test_meross_message_serialization ... ok
[INFO] [stdout] test integrations::mqtt::tests::test_mqtt_config_default ... ok
[INFO] [stdout] test integrations::mqtt::tests::test_mqtt_error_display ... ok
[INFO] [stdout] test integrations::mqtt::tests::test_mqtt_message_parse_json ... ok
[INFO] [stdout] test integrations::mqtt::tests::test_mqtt_message_parse_json_invalid ... ok
[INFO] [stdout] test integrations::mqtt::tests::test_mqtt_message_payload_str ... ok
[INFO] [stdout] test integrations::tests::test_device_capabilities_default ... ok
[INFO] [stdout] test integrations::tests::test_provider_error_display ... ok
[INFO] [stdout] test integrations::tests::test_available_providers ... ok
[INFO] [stdout] test integrations::meross::tests::test_list_devices_missing_token ... ok
[INFO] [stdout] test integrations::meross::tests::test_turn_off_missing_token ... ok
[INFO] [stdout] test models::tests::test_cheapest_hours_config_serialization ... ok
[INFO] [stdout] test models::tests::test_price_threshold_config_serialization ... ok
[INFO] [stdout] test integrations::meross::tests::test_turn_off_requires_mqtt_credentials ... ok
[INFO] [stdout] test integrations::tests::test_provider_registry_creation ... ok
[INFO] [stdout] test models::tests::test_rule_action_conversion ... ok
[INFO] [stdout] test services::auth::tests::test_create_jwt_contains_correct_user_id ... ok
[INFO] [stdout] test models::tests::test_time_schedule_config_serialization ... ok
[INFO] [stdout] test integrations::meross::tests::test_turn_on_requires_mqtt_credentials ... ok
[INFO] [stdout] test integrations::meross::tests::test_login_missing_email ... ok
[INFO] [stdout] test services::auth::tests::test_create_jwt_returns_valid_token ... ok
[INFO] [stdout] test services::auth::tests::test_jwt_expiration_is_in_future ... ok
[INFO] [stdout] test models::tests::test_rule_type_conversion ... ok
[INFO] [stdout] test services::auth::tests::test_verify_password_invalid_hash ... ok
[INFO] [stdout] test services::automation_engine::tests::test_cheapest_hours_config_parsing ... ok
[INFO] [stdout] test services::automation_engine::tests::test_execution_result_struct ... ok
[INFO] [stdout] test services::automation_engine::tests::test_price_threshold_config_parsing ... ok
[INFO] [stdout] test integrations::meross::tests::test_provider_name ... ok
[INFO] [stdout] test services::automation_engine::tests::test_time_schedule_config_parsing ... ok
[INFO] [stdout] test services::ha_client::tests::test_authorization_header_format ... ok
[INFO] [stdout] test services::ha_client::tests::test_client_creation ... ok
[INFO] [stdout] test services::automation_engine::tests::test_rule_evaluation_struct ... ok
[INFO] [stdout] test services::ha_client::tests::test_client_with_different_urls ... ok
[INFO] [stdout] test services::ha_client::tests::test_service_url_format ... ok
[INFO] [stdout] test services::price_fetcher::tests::test_parse_esios_value_midnight ... ok
[INFO] [stdout] test services::price_fetcher::tests::test_parse_esios_value_negative_price ... ok
[INFO] [stdout] test services::price_fetcher::tests::test_parse_esios_value_price_conversion ... ok
[INFO] [stdout] test services::price_fetcher::tests::test_parse_esios_value_utc_timezone ... ok
[INFO] [stdout] test services::price_fetcher::tests::test_parse_esios_value_invalid_datetime ... ok
[INFO] [stdout] test services::price_fetcher::tests::test_parse_esios_value_valid ... ok
[INFO] [stdout] test services::price_fetcher::tests::test_parse_esios_value_zero_price ... ok
[INFO] [stdout] test services::price_fetcher::tests::test_price_data_struct ... ok
[INFO] [stdout] test services::scheduler::tests::test_find_cheapest_hours_empty_prices ... ok
[INFO] [stdout] test services::scheduler::tests::test_find_cheapest_hours_full_day ... ok
[INFO] [stdout] test integrations::meross::tests::test_default_trait ... ok
[INFO] [stdout] test integrations::meross::tests::test_capabilities ... ok
[INFO] [stdout] test services::scheduler::tests::test_find_cheapest_hours_multiple_hours ... ok
[INFO] [stdout] test services::scheduler::tests::test_find_cheapest_hours_rounds_up_duration ... ok
[INFO] [stdout] test services::scheduler::tests::test_find_cheapest_hours_single_hour ... ok
[INFO] [stdout] test services::scheduler::tests::test_find_cheapest_hours_zero_duration ... ok
[INFO] [stdout] test services::scheduler::tests::test_find_cheapest_hours_more_hours_than_available ... ok
[INFO] [stdout] test services::scheduler::tests::test_find_cheapest_hours_equal_prices ... ok
[INFO] [stdout] test integrations::meross::tests::test_turn_on_missing_token ... ok
[INFO] [stdout] test integrations::meross::tests::test_get_device_state_missing_token ... ok
[INFO] [stdout] test integrations::meross::tests::test_login_missing_password ... ok
[INFO] [stdout] test integrations::meross::tests::test_display_name ... ok
[INFO] [stdout] test integrations::meross_mqtt::tests::test_from_credentials_default_mqtt_domain ... FAILED
[INFO] [stdout] test integrations::tests::test_provider_registry_get ... ok
[INFO] [stdout] test integrations::meross::tests::test_get_device_state_fallback_on_connection_failure ... ok
[INFO] [stdout] test integrations::tests::test_provider_registry_unknown ... ok
[INFO] [stdout] test services::auth::tests::test_hash_password_returns_valid_hash ... ok
[INFO] [stdout] test services::auth::tests::test_verify_password_correct ... ok
[INFO] [stdout] test services::auth::tests::test_hash_password_produces_different_hashes_for_same_password ... ok
[INFO] [stdout] test services::auth::tests::test_verify_password_incorrect ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- integrations::meross_mqtt::tests::test_from_credentials_default_mqtt_domain stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'integrations::meross_mqtt::tests::test_from_credentials_default_mqtt_domain' (71) panicked at backend/src/integrations/meross_mqtt.rs:492:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: "mqtt-eu-5.meross.com"
[INFO] [stdout]  right: "eu-iotx.meross.com"
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5ebabfc6ecd2 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5ebabfc6ecd2 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5ebabfc6ecd2 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5ebabfc6ecd2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5ebabfc8257a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5ebabfc8257a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x5ebabfc3b7e6 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5ebabfc3b7e6 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5ebabfc4d5e9 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5ebabfc4d5e9 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5ebabfc4d481 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5ebabf02475e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x5ebabf02475e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5ebabfc4d912 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5ebabfc4d912 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5ebabfc4d6a8 - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x5ebabfc485a9 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5ebabfc3050d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5ebabfc8b64c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5ebabfc8b4d3 - core::panicking::assert_failed_inner::h3c3301979dc81b81
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:439:17
[INFO] [stdout]   20:     0x5ebabefa8c28 - core::panicking::assert_failed::had4be8b272261383
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x5ebabefee633 - backend::integrations::meross_mqtt::tests::test_from_credentials_default_mqtt_domain::h0d9821618286d310
[INFO] [stdout]                                at /opt/rustwide/workdir/backend/src/integrations/meross_mqtt.rs:492:9
[INFO] [stdout]   22:     0x5ebabefee6b7 - backend::integrations::meross_mqtt::tests::test_from_credentials_default_mqtt_domain::{{closure}}::h5c9e6e9c810039e6
[INFO] [stdout]                                at /opt/rustwide/workdir/backend/src/integrations/meross_mqtt.rs:485:51
[INFO] [stdout]   23:     0x5ebabef24f66 - core::ops::function::FnOnce::call_once::h602275e9b4f9b3dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5ebabf02451b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x5ebabf02451b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x5ebabf037f2a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x5ebabf037f2a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x5ebabf037f2a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   29:     0x5ebabf037f2a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   30:     0x5ebabf037f2a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x5ebabf037f2a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x5ebabf037f2a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x5ebabf012384 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x5ebabf012384 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   35:     0x5ebabf015d22 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   36:     0x5ebabf015d22 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x5ebabf015d22 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   38:     0x5ebabf015d22 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   39:     0x5ebabf015d22 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x5ebabf015d22 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   41:     0x5ebabf015d22 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x5ebabfc436ff - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   43:     0x5ebabfc436ff - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   44:     0x70b54545baa4 - <unknown>
[INFO] [stdout]   45:     0x70b5454e8a64 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     integrations::meross_mqtt::tests::test_from_credentials_default_mqtt_domain
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 100 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 3.96s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "2ae8374ce1059a743e77c8a35581e4fd712363af35d7fae7a5152cc43ed5c1e3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2ae8374ce1059a743e77c8a35581e4fd712363af35d7fae7a5152cc43ed5c1e3", kill_on_drop: false }`
[INFO] [stdout] 2ae8374ce1059a743e77c8a35581e4fd712363af35d7fae7a5152cc43ed5c1e3
