[INFO] fetching crate ecu_diagnostics 0.99.0... [INFO] testing ecu_diagnostics-0.99.0 against 1.90.0 for beta-1.91-3 [INFO] extracting crate ecu_diagnostics 0.99.0 into /workspace/builds/worker-3-tc1/source [INFO] started tweaking crates.io crate ecu_diagnostics 0.99.0 [INFO] finished tweaking crates.io crate ecu_diagnostics 0.99.0 [INFO] tweaked toml for crates.io crate ecu_diagnostics 0.99.0 written to /workspace/builds/worker-3-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate ecu_diagnostics 0.99.0 on toolchain 1.90.0 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate ecu_diagnostics 0.99.0 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.90.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded thiserror-impl v1.0.44 [INFO] [stderr] Downloaded embedded-can v0.4.1 [INFO] [stderr] Downloaded strum v0.27.2 [INFO] [stderr] Downloaded neli v0.6.4 [INFO] [stderr] Downloaded j2534_rust v1.5.0 [INFO] [stderr] Downloaded neli-proc-macros v0.1.3 [INFO] [stderr] Downloaded displaydoc v0.2.3 [INFO] [stderr] Downloaded automotive_diag v0.1.21 [INFO] [stderr] Downloaded jiff-static v0.2.5 [INFO] [stderr] Downloaded socketcan v3.5.0 [INFO] [stderr] Downloaded serial-rs v0.2.1 [INFO] [stderr] Downloaded cc v1.2.17 [INFO] [stderr] Downloaded unicode-ident v1.0.8 [INFO] [stderr] Downloaded regex v1.7.3 [INFO] [stderr] Downloaded nix v0.23.2 [INFO] [stderr] Downloaded shellexpand v3.1.1 [INFO] [stderr] Downloaded strum_macros v0.27.2 [INFO] [stderr] Downloaded thiserror v1.0.44 [INFO] [stderr] Downloaded jiff v0.2.5 [INFO] [stderr] Downloaded socketcan-isotp v1.0.2 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 9b3fff686a53a7141ecb7a6fa930c662fa44346930cdfc8451f70ed1807c1a19 [INFO] running `Command { std: "docker" "start" "-a" "9b3fff686a53a7141ecb7a6fa930c662fa44346930cdfc8451f70ed1807c1a19", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "9b3fff686a53a7141ecb7a6fa930c662fa44346930cdfc8451f70ed1807c1a19", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "9b3fff686a53a7141ecb7a6fa930c662fa44346930cdfc8451f70ed1807c1a19", kill_on_drop: false }` [INFO] [stdout] 9b3fff686a53a7141ecb7a6fa930c662fa44346930cdfc8451f70ed1807c1a19 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 848215c4e981249b693c230c37af8a14d170786eef099c4d1f9448e3173a9163 [INFO] running `Command { std: "docker" "start" "-a" "848215c4e981249b693c230c37af8a14d170786eef099c4d1f9448e3173a9163", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.94 [INFO] [stderr] Compiling unicode-ident v1.0.8 [INFO] [stderr] Compiling autocfg v1.1.0 [INFO] [stderr] Compiling libc v0.2.175 [INFO] [stderr] Compiling cfg-if v1.0.0 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling memchr v2.5.0 [INFO] [stderr] Compiling bitflags v1.3.2 [INFO] [stderr] Compiling serde v1.0.219 [INFO] [stderr] Compiling cfg_aliases v0.2.1 [INFO] [stderr] Compiling nb v1.1.0 [INFO] [stderr] Compiling thiserror v2.0.14 [INFO] [stderr] Compiling bitflags v2.9.1 [INFO] [stderr] Compiling either v1.9.0 [INFO] [stderr] Compiling thiserror v1.0.44 [INFO] [stderr] Compiling heck v0.5.0 [INFO] [stderr] Compiling pin-utils v0.1.0 [INFO] [stderr] Compiling socketcan v3.5.0 [INFO] [stderr] Compiling nix v0.29.0 [INFO] [stderr] Compiling embedded-can v0.4.1 [INFO] [stderr] Compiling regex-syntax v0.6.29 [INFO] [stderr] Compiling log v0.4.27 [INFO] [stderr] Compiling byteorder v1.5.0 [INFO] [stderr] Compiling itoa v1.0.6 [INFO] [stderr] Compiling hex v0.4.3 [INFO] [stderr] Compiling ryu v1.0.13 [INFO] [stderr] Compiling memoffset v0.9.1 [INFO] [stderr] Compiling memoffset v0.7.1 [INFO] [stderr] Compiling memoffset v0.6.5 [INFO] [stderr] Compiling itertools v0.13.0 [INFO] [stderr] Compiling glob v0.3.2 [INFO] [stderr] Compiling libloading v0.8.8 [INFO] [stderr] Compiling j2534_rust v1.5.0 [INFO] [stderr] Compiling aho-corasick v0.7.20 [INFO] [stderr] Compiling quote v1.0.40 [INFO] [stderr] Compiling syn v2.0.100 [INFO] [stderr] Compiling regex v1.7.3 [INFO] [stderr] Compiling dirs-sys v0.3.7 [INFO] [stderr] Compiling socket2 v0.5.10 [INFO] [stderr] Compiling nix v0.26.4 [INFO] [stderr] Compiling nix v0.23.2 [INFO] [stderr] Compiling dirs v4.0.0 [INFO] [stderr] Compiling shellexpand v3.1.1 [INFO] [stderr] Compiling serde_json v1.0.142 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling strum_macros v0.27.2 [INFO] [stderr] Compiling thiserror-impl v1.0.44 [INFO] [stderr] Compiling thiserror-impl v2.0.14 [INFO] [stderr] Compiling displaydoc v0.2.3 [INFO] [stderr] Compiling strum v0.27.2 [INFO] [stderr] Compiling automotive_diag v0.1.21 [INFO] [stderr] Compiling serial-rs v0.2.1 [INFO] [stderr] Compiling socketcan-isotp v1.0.2 [INFO] [stderr] Compiling neli-proc-macros v0.1.3 [INFO] [stderr] Compiling neli v0.6.4 [INFO] [stderr] Compiling ecu_diagnostics v0.99.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `DiagServerResult` [INFO] [stdout] --> src/kwp2000/mod.rs:18:77 [INFO] [stdout] | [INFO] [stdout] 18 | use crate::{dynamic_diag::{self, DiagAction, DiagPayload, DiagSessionMode}, DiagServerResult}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ecu_reset::*` [INFO] [stdout] --> src/kwp2000/mod.rs:36:9 [INFO] [stdout] | [INFO] [stdout] 36 | pub use ecu_reset::*; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error::*` [INFO] [stdout] --> src/kwp2000/mod.rs:37:9 [INFO] [stdout] | [INFO] [stdout] 37 | pub use error::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `message_transmission::*` [INFO] [stdout] --> src/kwp2000/mod.rs:39:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub use message_transmission::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_data_by_identifier::*` [INFO] [stdout] --> src/kwp2000/mod.rs:40:9 [INFO] [stdout] | [INFO] [stdout] 40 | pub use read_data_by_identifier::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_memory_by_address::*` [INFO] [stdout] --> src/kwp2000/mod.rs:44:9 [INFO] [stdout] | [INFO] [stdout] 44 | pub use read_memory_by_address::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_status_of_dtc::*` [INFO] [stdout] --> src/kwp2000/mod.rs:45:9 [INFO] [stdout] | [INFO] [stdout] 45 | pub use read_status_of_dtc::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `security_access::*` [INFO] [stdout] --> src/kwp2000/mod.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | pub use security_access::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `start_diagnostic_session::*` [INFO] [stdout] --> src/kwp2000/mod.rs:48:9 [INFO] [stdout] | [INFO] [stdout] 48 | pub use start_diagnostic_session::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DiagServerResult` [INFO] [stdout] --> src/uds/mod.rs:6:93 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::{dynamic_diag::{DiagAction, DiagPayload, DiagProtocol, DiagSessionMode, EcuNRC}, DiagServerResult}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ScalingType` [INFO] [stdout] --> src/uds/scaling_data.rs:11:50 [INFO] [stdout] | [INFO] [stdout] 11 | pub use automotive_diag::uds::{ScalingExtension, ScalingType}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `access_timing_parameter::*` [INFO] [stdout] --> src/uds/mod.rs:18:9 [INFO] [stdout] | [INFO] [stdout] 18 | pub use access_timing_parameter::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `clear_diagnostic_information::*` [INFO] [stdout] --> src/uds/mod.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 21 | pub use clear_diagnostic_information::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `diagnostic_session_control::*` [INFO] [stdout] --> src/uds/mod.rs:23:9 [INFO] [stdout] | [INFO] [stdout] 23 | pub use diagnostic_session_control::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ecu_reset::*` [INFO] [stdout] --> src/uds/mod.rs:24:9 [INFO] [stdout] | [INFO] [stdout] 24 | pub use ecu_reset::*; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_dtc_information::*` [INFO] [stdout] --> src/uds/mod.rs:25:9 [INFO] [stdout] | [INFO] [stdout] 25 | pub use read_dtc_information::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `security_access::*` [INFO] [stdout] --> src/uds/mod.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | pub use security_access::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/dynamic_diag.rs:325:37 [INFO] [stdout] | [INFO] [stdout] 325 | ... let mut needs_response = true; [INFO] [stdout] | ----^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/dynamic_diag.rs:326:37 [INFO] [stdout] | [INFO] [stdout] 326 | ... let mut ext_id = None; [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `stop_filter_fn` is never read [INFO] [stdout] --> src/hardware/passthru/lib_funcs.rs:100:5 [INFO] [stdout] | [INFO] [stdout] 76 | pub struct PassthruDrv { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 100 | stop_filter_fn: PassThruStopMsgFilterFn, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `PassthruDrv` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `stop_msg_filter` is never used [INFO] [stdout] --> src/hardware/passthru/lib_funcs.rs:430:12 [INFO] [stdout] | [INFO] [stdout] 132 | impl PassthruDrv { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 430 | pub fn stop_msg_filter(&self, channel_id: u32, filter_id: u32) -> PassthruResult<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `ext_id` is never read [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:20:16 [INFO] [stdout] | [INFO] [stdout] 20 | SendData { ext_id: Option, d: T }, [INFO] [stdout] | -------- ^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this variant [INFO] [stdout] | [INFO] [stdout] = note: `ChannelMessage` 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 `ClearRx` is never constructed [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 17 | enum ChannelMessage { [INFO] [stdout] | -------------- variant in this enum [INFO] [stdout] 18 | ClearRx, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ChannelMessage` 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 `ext_addr` is never read [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:63:9 [INFO] [stdout] | [INFO] [stdout] 56 | struct IsoTpPayload { [INFO] [stdout] | ------------ field in this struct [INFO] [stdout] ... [INFO] [stdout] 63 | pub ext_addr: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_packet` is never used [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:71:4 [INFO] [stdout] | [INFO] [stdout] 71 | fn parse_packet(cf: &CanFrame, iso_tp_ext: bool) -> (u32, &[u8]) { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `ext_id` is never read [INFO] [stdout] --> src/hardware/slcan/mod.rs:68:16 [INFO] [stdout] | [INFO] [stdout] 68 | SendData { ext_id: Option, d: T }, [INFO] [stdout] | -------- ^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this variant [INFO] [stdout] | [INFO] [stdout] = note: `ChannelMessage` 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 `ext_addr` is never read [INFO] [stdout] --> src/hardware/slcan/mod.rs:101:9 [INFO] [stdout] | [INFO] [stdout] 94 | struct IsoTpPayload { [INFO] [stdout] | ------------ field in this struct [INFO] [stdout] ... [INFO] [stdout] 101 | pub ext_addr: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/uds/scaling_data.rs:30:19 [INFO] [stdout] | [INFO] [stdout] 28 | impl ScalingData { [INFO] [stdout] | ---------------- associated function in this implementation [INFO] [stdout] 29 | /// Creates a new scaling data structure [INFO] [stdout] 30 | pub(crate) fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/obd2/service01.rs:21:32 [INFO] [stdout] | [INFO] [stdout] 21 | pub fn obd_init_service_01(&self) -> DiagServerResult { [INFO] [stdout] | ^^^^^ --------- the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 21 | pub fn obd_init_service_01(&self) -> DiagServerResult> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/obd2/service09.rs:19:32 [INFO] [stdout] | [INFO] [stdout] 19 | pub fn obd_init_service_09(&self) -> DiagServerResult { [INFO] [stdout] | ^^^^^ --------- the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 19 | pub fn obd_init_service_09(&self) -> DiagServerResult> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 28.14s [INFO] running `Command { std: "docker" "inspect" "848215c4e981249b693c230c37af8a14d170786eef099c4d1f9448e3173a9163", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "848215c4e981249b693c230c37af8a14d170786eef099c4d1f9448e3173a9163", kill_on_drop: false }` [INFO] [stdout] 848215c4e981249b693c230c37af8a14d170786eef099c4d1f9448e3173a9163 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 7098af5b63a357d96726edbeb06b6de4ac3ac4873486eb12871b4fa52917c7eb [INFO] running `Command { std: "docker" "start" "-a" "7098af5b63a357d96726edbeb06b6de4ac3ac4873486eb12871b4fa52917c7eb", kill_on_drop: false }` [INFO] [stderr] Compiling log v0.4.27 [INFO] [stderr] Compiling utf8parse v0.2.2 [INFO] [stderr] Compiling is_terminal_polyfill v1.70.0 [INFO] [stderr] Compiling anstyle-query v1.1.0 [INFO] [stderr] Compiling colorchoice v1.0.1 [INFO] [stderr] Compiling anstyle v1.0.7 [INFO] [stderr] Compiling jiff v0.2.5 [INFO] [stderr] Compiling anstyle-parse v0.2.4 [INFO] [stderr] Compiling neli v0.6.4 [INFO] [stderr] Compiling env_filter v0.1.0 [INFO] [stderr] Compiling anstream v0.6.14 [INFO] [stderr] Compiling socketcan v3.5.0 [INFO] [stderr] Compiling ecu_diagnostics v0.99.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `DiagServerResult` [INFO] [stdout] --> src/kwp2000/mod.rs:18:77 [INFO] [stdout] | [INFO] [stdout] 18 | use crate::{dynamic_diag::{self, DiagAction, DiagPayload, DiagSessionMode}, DiagServerResult}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ecu_reset::*` [INFO] [stdout] --> src/kwp2000/mod.rs:36:9 [INFO] [stdout] | [INFO] [stdout] 36 | pub use ecu_reset::*; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error::*` [INFO] [stdout] --> src/kwp2000/mod.rs:37:9 [INFO] [stdout] | [INFO] [stdout] 37 | pub use error::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `message_transmission::*` [INFO] [stdout] --> src/kwp2000/mod.rs:39:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub use message_transmission::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_data_by_identifier::*` [INFO] [stdout] --> src/kwp2000/mod.rs:40:9 [INFO] [stdout] | [INFO] [stdout] 40 | pub use read_data_by_identifier::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_memory_by_address::*` [INFO] [stdout] --> src/kwp2000/mod.rs:44:9 [INFO] [stdout] | [INFO] [stdout] 44 | pub use read_memory_by_address::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_status_of_dtc::*` [INFO] [stdout] --> src/kwp2000/mod.rs:45:9 [INFO] [stdout] | [INFO] [stdout] 45 | pub use read_status_of_dtc::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `security_access::*` [INFO] [stdout] --> src/kwp2000/mod.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | pub use security_access::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `start_diagnostic_session::*` [INFO] [stdout] --> src/kwp2000/mod.rs:48:9 [INFO] [stdout] | [INFO] [stdout] 48 | pub use start_diagnostic_session::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DiagServerResult` [INFO] [stdout] --> src/uds/mod.rs:6:93 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::{dynamic_diag::{DiagAction, DiagPayload, DiagProtocol, DiagSessionMode, EcuNRC}, DiagServerResult}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ScalingType` [INFO] [stdout] --> src/uds/scaling_data.rs:11:50 [INFO] [stdout] | [INFO] [stdout] 11 | pub use automotive_diag::uds::{ScalingExtension, ScalingType}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `access_timing_parameter::*` [INFO] [stdout] --> src/uds/mod.rs:18:9 [INFO] [stdout] | [INFO] [stdout] 18 | pub use access_timing_parameter::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `clear_diagnostic_information::*` [INFO] [stdout] --> src/uds/mod.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 21 | pub use clear_diagnostic_information::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `diagnostic_session_control::*` [INFO] [stdout] --> src/uds/mod.rs:23:9 [INFO] [stdout] | [INFO] [stdout] 23 | pub use diagnostic_session_control::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ecu_reset::*` [INFO] [stdout] --> src/uds/mod.rs:24:9 [INFO] [stdout] | [INFO] [stdout] 24 | pub use ecu_reset::*; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_dtc_information::*` [INFO] [stdout] --> src/uds/mod.rs:25:9 [INFO] [stdout] | [INFO] [stdout] 25 | pub use read_dtc_information::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `security_access::*` [INFO] [stdout] --> src/uds/mod.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | pub use security_access::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/dynamic_diag.rs:325:37 [INFO] [stdout] | [INFO] [stdout] 325 | ... let mut needs_response = true; [INFO] [stdout] | ----^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/dynamic_diag.rs:326:37 [INFO] [stdout] | [INFO] [stdout] 326 | ... let mut ext_id = None; [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling env_logger v0.11.8 [INFO] [stdout] warning: field `stop_filter_fn` is never read [INFO] [stdout] --> src/hardware/passthru/lib_funcs.rs:100:5 [INFO] [stdout] | [INFO] [stdout] 76 | pub struct PassthruDrv { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 100 | stop_filter_fn: PassThruStopMsgFilterFn, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `PassthruDrv` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `stop_msg_filter` is never used [INFO] [stdout] --> src/hardware/passthru/lib_funcs.rs:430:12 [INFO] [stdout] | [INFO] [stdout] 132 | impl PassthruDrv { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 430 | pub fn stop_msg_filter(&self, channel_id: u32, filter_id: u32) -> PassthruResult<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `ext_id` is never read [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:20:16 [INFO] [stdout] | [INFO] [stdout] 20 | SendData { ext_id: Option, d: T }, [INFO] [stdout] | -------- ^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this variant [INFO] [stdout] | [INFO] [stdout] = note: `ChannelMessage` 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 `ClearRx` is never constructed [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 17 | enum ChannelMessage { [INFO] [stdout] | -------------- variant in this enum [INFO] [stdout] 18 | ClearRx, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ChannelMessage` 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 `ext_addr` is never read [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:63:9 [INFO] [stdout] | [INFO] [stdout] 56 | struct IsoTpPayload { [INFO] [stdout] | ------------ field in this struct [INFO] [stdout] ... [INFO] [stdout] 63 | pub ext_addr: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_packet` is never used [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:71:4 [INFO] [stdout] | [INFO] [stdout] 71 | fn parse_packet(cf: &CanFrame, iso_tp_ext: bool) -> (u32, &[u8]) { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `ext_id` is never read [INFO] [stdout] --> src/hardware/slcan/mod.rs:68:16 [INFO] [stdout] | [INFO] [stdout] 68 | SendData { ext_id: Option, d: T }, [INFO] [stdout] | -------- ^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this variant [INFO] [stdout] | [INFO] [stdout] = note: `ChannelMessage` 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 `ext_addr` is never read [INFO] [stdout] --> src/hardware/slcan/mod.rs:101:9 [INFO] [stdout] | [INFO] [stdout] 94 | struct IsoTpPayload { [INFO] [stdout] | ------------ field in this struct [INFO] [stdout] ... [INFO] [stdout] 101 | pub ext_addr: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/uds/scaling_data.rs:30:19 [INFO] [stdout] | [INFO] [stdout] 28 | impl ScalingData { [INFO] [stdout] | ---------------- associated function in this implementation [INFO] [stdout] 29 | /// Creates a new scaling data structure [INFO] [stdout] 30 | pub(crate) fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/obd2/service01.rs:21:32 [INFO] [stdout] | [INFO] [stdout] 21 | pub fn obd_init_service_01(&self) -> DiagServerResult { [INFO] [stdout] | ^^^^^ --------- the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 21 | pub fn obd_init_service_01(&self) -> DiagServerResult> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/obd2/service09.rs:19:32 [INFO] [stdout] | [INFO] [stdout] 19 | pub fn obd_init_service_09(&self) -> DiagServerResult { [INFO] [stdout] | ^^^^^ --------- the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 19 | pub fn obd_init_service_09(&self) -> DiagServerResult> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DiagServerResult` [INFO] [stdout] --> src/kwp2000/mod.rs:18:77 [INFO] [stdout] | [INFO] [stdout] 18 | use crate::{dynamic_diag::{self, DiagAction, DiagPayload, DiagSessionMode}, DiagServerResult}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ecu_reset::*` [INFO] [stdout] --> src/kwp2000/mod.rs:36:9 [INFO] [stdout] | [INFO] [stdout] 36 | pub use ecu_reset::*; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error::*` [INFO] [stdout] --> src/kwp2000/mod.rs:37:9 [INFO] [stdout] | [INFO] [stdout] 37 | pub use error::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `message_transmission::*` [INFO] [stdout] --> src/kwp2000/mod.rs:39:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub use message_transmission::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_data_by_identifier::*` [INFO] [stdout] --> src/kwp2000/mod.rs:40:9 [INFO] [stdout] | [INFO] [stdout] 40 | pub use read_data_by_identifier::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_memory_by_address::*` [INFO] [stdout] --> src/kwp2000/mod.rs:44:9 [INFO] [stdout] | [INFO] [stdout] 44 | pub use read_memory_by_address::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_status_of_dtc::*` [INFO] [stdout] --> src/kwp2000/mod.rs:45:9 [INFO] [stdout] | [INFO] [stdout] 45 | pub use read_status_of_dtc::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `security_access::*` [INFO] [stdout] --> src/kwp2000/mod.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | pub use security_access::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `start_diagnostic_session::*` [INFO] [stdout] --> src/kwp2000/mod.rs:48:9 [INFO] [stdout] | [INFO] [stdout] 48 | pub use start_diagnostic_session::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DiagServerResult` [INFO] [stdout] --> src/uds/mod.rs:6:93 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::{dynamic_diag::{DiagAction, DiagPayload, DiagProtocol, DiagSessionMode, EcuNRC}, DiagServerResult}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ScalingType` [INFO] [stdout] --> src/uds/scaling_data.rs:11:50 [INFO] [stdout] | [INFO] [stdout] 11 | pub use automotive_diag::uds::{ScalingExtension, ScalingType}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `access_timing_parameter::*` [INFO] [stdout] --> src/uds/mod.rs:18:9 [INFO] [stdout] | [INFO] [stdout] 18 | pub use access_timing_parameter::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `clear_diagnostic_information::*` [INFO] [stdout] --> src/uds/mod.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 21 | pub use clear_diagnostic_information::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `diagnostic_session_control::*` [INFO] [stdout] --> src/uds/mod.rs:23:9 [INFO] [stdout] | [INFO] [stdout] 23 | pub use diagnostic_session_control::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ecu_reset::*` [INFO] [stdout] --> src/uds/mod.rs:24:9 [INFO] [stdout] | [INFO] [stdout] 24 | pub use ecu_reset::*; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `read_dtc_information::*` [INFO] [stdout] --> src/uds/mod.rs:25:9 [INFO] [stdout] | [INFO] [stdout] 25 | pub use read_dtc_information::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `security_access::*` [INFO] [stdout] --> src/uds/mod.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | pub use security_access::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/dynamic_diag.rs:325:37 [INFO] [stdout] | [INFO] [stdout] 325 | ... let mut needs_response = true; [INFO] [stdout] | ----^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/dynamic_diag.rs:326:37 [INFO] [stdout] | [INFO] [stdout] 326 | ... let mut ext_id = None; [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `stop_filter_fn` is never read [INFO] [stdout] --> src/hardware/passthru/lib_funcs.rs:100:5 [INFO] [stdout] | [INFO] [stdout] 76 | pub struct PassthruDrv { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 100 | stop_filter_fn: PassThruStopMsgFilterFn, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `PassthruDrv` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `stop_msg_filter` is never used [INFO] [stdout] --> src/hardware/passthru/lib_funcs.rs:430:12 [INFO] [stdout] | [INFO] [stdout] 132 | impl PassthruDrv { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 430 | pub fn stop_msg_filter(&self, channel_id: u32, filter_id: u32) -> PassthruResult<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `ext_id` is never read [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:20:16 [INFO] [stdout] | [INFO] [stdout] 20 | SendData { ext_id: Option, d: T }, [INFO] [stdout] | -------- ^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this variant [INFO] [stdout] | [INFO] [stdout] = note: `ChannelMessage` 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 `ClearRx` is never constructed [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 17 | enum ChannelMessage { [INFO] [stdout] | -------------- variant in this enum [INFO] [stdout] 18 | ClearRx, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ChannelMessage` 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 `ext_addr` is never read [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:63:9 [INFO] [stdout] | [INFO] [stdout] 56 | struct IsoTpPayload { [INFO] [stdout] | ------------ field in this struct [INFO] [stdout] ... [INFO] [stdout] 63 | pub ext_addr: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_packet` is never used [INFO] [stdout] --> src/hardware/passthru/sw_isotp.rs:71:4 [INFO] [stdout] | [INFO] [stdout] 71 | fn parse_packet(cf: &CanFrame, iso_tp_ext: bool) -> (u32, &[u8]) { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `ext_id` is never read [INFO] [stdout] --> src/hardware/slcan/mod.rs:68:16 [INFO] [stdout] | [INFO] [stdout] 68 | SendData { ext_id: Option, d: T }, [INFO] [stdout] | -------- ^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this variant [INFO] [stdout] | [INFO] [stdout] = note: `ChannelMessage` 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 `ext_addr` is never read [INFO] [stdout] --> src/hardware/slcan/mod.rs:101:9 [INFO] [stdout] | [INFO] [stdout] 94 | struct IsoTpPayload { [INFO] [stdout] | ------------ field in this struct [INFO] [stdout] ... [INFO] [stdout] 101 | pub ext_addr: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `print_pid` is never used [INFO] [stdout] --> src/obd2/service01.rs:75:8 [INFO] [stdout] | [INFO] [stdout] 75 | fn print_pid(v: DiagServerResult) { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/uds/scaling_data.rs:30:19 [INFO] [stdout] | [INFO] [stdout] 28 | impl ScalingData { [INFO] [stdout] | ---------------- associated function in this implementation [INFO] [stdout] 29 | /// Creates a new scaling data structure [INFO] [stdout] 30 | pub(crate) fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: missing documentation for a module [INFO] [stdout] --> src/dtc.rs:113:1 [INFO] [stdout] | [INFO] [stdout] 113 | pub mod test { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | missing_docs, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: missing documentation for a function [INFO] [stdout] --> src/dtc.rs:117:5 [INFO] [stdout] | [INFO] [stdout] 117 | pub fn test_dtc_parse_raw() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/obd2/service01.rs:21:32 [INFO] [stdout] | [INFO] [stdout] 21 | pub fn obd_init_service_01(&self) -> DiagServerResult { [INFO] [stdout] | ^^^^^ --------- the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 21 | pub fn obd_init_service_01(&self) -> DiagServerResult> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: missing documentation for a module [INFO] [stdout] --> src/obd2/service01.rs:71:1 [INFO] [stdout] | [INFO] [stdout] 71 | pub mod service_09_test { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/obd2/service09.rs:19:32 [INFO] [stdout] | [INFO] [stdout] 19 | pub fn obd_init_service_09(&self) -> DiagServerResult { [INFO] [stdout] | ^^^^^ --------- the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 19 | pub fn obd_init_service_09(&self) -> DiagServerResult> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 10.62s [INFO] running `Command { std: "docker" "inspect" "7098af5b63a357d96726edbeb06b6de4ac3ac4873486eb12871b4fa52917c7eb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7098af5b63a357d96726edbeb06b6de4ac3ac4873486eb12871b4fa52917c7eb", kill_on_drop: false }` [INFO] [stdout] 7098af5b63a357d96726edbeb06b6de4ac3ac4873486eb12871b4fa52917c7eb [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 5b91f2ba611f5e0a25f92c63ebd044d574b388f42ce7b3a26e8bac63add7254d [INFO] running `Command { std: "docker" "start" "-a" "5b91f2ba611f5e0a25f92c63ebd044d574b388f42ce7b3a26e8bac63add7254d", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `DiagServerResult` [INFO] [stderr] --> src/kwp2000/mod.rs:18:77 [INFO] [stderr] | [INFO] [stderr] 18 | use crate::{dynamic_diag::{self, DiagAction, DiagPayload, DiagSessionMode}, DiagServerResult}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `ecu_reset::*` [INFO] [stderr] --> src/kwp2000/mod.rs:36:9 [INFO] [stderr] | [INFO] [stderr] 36 | pub use ecu_reset::*; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `error::*` [INFO] [stderr] --> src/kwp2000/mod.rs:37:9 [INFO] [stderr] | [INFO] [stderr] 37 | pub use error::*; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `message_transmission::*` [INFO] [stderr] --> src/kwp2000/mod.rs:39:9 [INFO] [stderr] | [INFO] [stderr] 39 | pub use message_transmission::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `read_data_by_identifier::*` [INFO] [stderr] --> src/kwp2000/mod.rs:40:9 [INFO] [stderr] | [INFO] [stderr] 40 | pub use read_data_by_identifier::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `read_memory_by_address::*` [INFO] [stderr] --> src/kwp2000/mod.rs:44:9 [INFO] [stderr] | [INFO] [stderr] 44 | pub use read_memory_by_address::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `read_status_of_dtc::*` [INFO] [stderr] --> src/kwp2000/mod.rs:45:9 [INFO] [stderr] | [INFO] [stderr] 45 | pub use read_status_of_dtc::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `security_access::*` [INFO] [stderr] --> src/kwp2000/mod.rs:47:9 [INFO] [stderr] | [INFO] [stderr] 47 | pub use security_access::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `start_diagnostic_session::*` [INFO] [stderr] --> src/kwp2000/mod.rs:48:9 [INFO] [stderr] | [INFO] [stderr] 48 | pub use start_diagnostic_session::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `DiagServerResult` [INFO] [stderr] --> src/uds/mod.rs:6:93 [INFO] [stderr] | [INFO] [stderr] 6 | use crate::{dynamic_diag::{DiagAction, DiagPayload, DiagProtocol, DiagSessionMode, EcuNRC}, DiagServerResult}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `ScalingType` [INFO] [stderr] --> src/uds/scaling_data.rs:11:50 [INFO] [stderr] | [INFO] [stderr] 11 | pub use automotive_diag::uds::{ScalingExtension, ScalingType}; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `access_timing_parameter::*` [INFO] [stderr] --> src/uds/mod.rs:18:9 [INFO] [stderr] | [INFO] [stderr] 18 | pub use access_timing_parameter::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `clear_diagnostic_information::*` [INFO] [stderr] --> src/uds/mod.rs:21:9 [INFO] [stderr] | [INFO] [stderr] 21 | pub use clear_diagnostic_information::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `diagnostic_session_control::*` [INFO] [stderr] --> src/uds/mod.rs:23:9 [INFO] [stderr] | [INFO] [stderr] 23 | pub use diagnostic_session_control::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `ecu_reset::*` [INFO] [stderr] --> src/uds/mod.rs:24:9 [INFO] [stderr] | [INFO] [stderr] 24 | pub use ecu_reset::*; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `read_dtc_information::*` [INFO] [stderr] --> src/uds/mod.rs:25:9 [INFO] [stderr] | [INFO] [stderr] 25 | pub use read_dtc_information::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `security_access::*` [INFO] [stderr] --> src/uds/mod.rs:27:9 [INFO] [stderr] | [INFO] [stderr] 27 | pub use security_access::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/dynamic_diag.rs:325:37 [INFO] [stderr] | [INFO] [stderr] 325 | ... let mut needs_response = true; [INFO] [stderr] | ----^^^^^^^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/dynamic_diag.rs:326:37 [INFO] [stderr] | [INFO] [stderr] 326 | ... let mut ext_id = None; [INFO] [stderr] | ----^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: field `stop_filter_fn` is never read [INFO] [stderr] --> src/hardware/passthru/lib_funcs.rs:100:5 [INFO] [stderr] | [INFO] [stderr] 76 | pub struct PassthruDrv { [INFO] [stderr] | ----------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 100 | stop_filter_fn: PassThruStopMsgFilterFn, [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `PassthruDrv` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: method `stop_msg_filter` is never used [INFO] [stderr] --> src/hardware/passthru/lib_funcs.rs:430:12 [INFO] [stderr] | [INFO] [stderr] 132 | impl PassthruDrv { [INFO] [stderr] | ---------------- method in this implementation [INFO] [stderr] ... [INFO] [stderr] 430 | pub fn stop_msg_filter(&self, channel_id: u32, filter_id: u32) -> PassthruResult<()> { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `ext_id` is never read [INFO] [stderr] --> src/hardware/passthru/sw_isotp.rs:20:16 [INFO] [stderr] | [INFO] [stderr] 20 | SendData { ext_id: Option, d: T }, [INFO] [stderr] | -------- ^^^^^^ [INFO] [stdout] [INFO] [stderr] | | [INFO] [stdout] running 1 test [INFO] [stderr] | field in this variant [INFO] [stderr] | [INFO] [stderr] = note: `ChannelMessage` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: variant `ClearRx` is never constructed [INFO] [stdout] test dtc::test::test_dtc_parse_raw ... ok [INFO] [stderr] --> src/hardware/passthru/sw_isotp.rs:18:5 [INFO] [stdout] [INFO] [stderr] | [INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stderr] 17 | enum ChannelMessage { [INFO] [stdout] [INFO] [stderr] | -------------- variant in this enum [INFO] [stderr] 18 | ClearRx, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `ChannelMessage` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: field `ext_addr` is never read [INFO] [stderr] --> src/hardware/passthru/sw_isotp.rs:63:9 [INFO] [stderr] | [INFO] [stderr] 56 | struct IsoTpPayload { [INFO] [stderr] | ------------ field in this struct [INFO] [stderr] ... [INFO] [stderr] 63 | pub ext_addr: bool, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `parse_packet` is never used [INFO] [stderr] --> src/hardware/passthru/sw_isotp.rs:71:4 [INFO] [stderr] | [INFO] [stderr] 71 | fn parse_packet(cf: &CanFrame, iso_tp_ext: bool) -> (u32, &[u8]) { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `ext_id` is never read [INFO] [stderr] --> src/hardware/slcan/mod.rs:68:16 [INFO] [stderr] | [INFO] [stderr] 68 | SendData { ext_id: Option, d: T }, [INFO] [stderr] | -------- ^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | field in this variant [INFO] [stderr] | [INFO] [stderr] = note: `ChannelMessage` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: field `ext_addr` is never read [INFO] [stderr] --> src/hardware/slcan/mod.rs:101:9 [INFO] [stderr] | [INFO] [stderr] 94 | struct IsoTpPayload { [INFO] [stderr] | ------------ field in this struct [INFO] [stderr] ... [INFO] [stderr] 101 | pub ext_addr: bool, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `new` is never used [INFO] [stderr] --> src/uds/scaling_data.rs:30:19 [INFO] [stderr] | [INFO] [stderr] 28 | impl ScalingData { [INFO] [stderr] | ---------------- associated function in this implementation [INFO] [stderr] 29 | /// Creates a new scaling data structure [INFO] [stderr] 30 | pub(crate) fn new( [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stderr] --> src/obd2/service01.rs:21:32 [INFO] [stderr] | [INFO] [stderr] 21 | pub fn obd_init_service_01(&self) -> DiagServerResult { [INFO] [stderr] | ^^^^^ --------- the same lifetime is hidden here [INFO] [stderr] | | [INFO] [stderr] | the lifetime is elided here [INFO] [stderr] | [INFO] [stderr] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stderr] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stderr] help: use `'_` for type paths [INFO] [stderr] | [INFO] [stderr] 21 | pub fn obd_init_service_01(&self) -> DiagServerResult> { [INFO] [stderr] | ++++ [INFO] [stderr] [INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stderr] --> src/obd2/service09.rs:19:32 [INFO] [stderr] | [INFO] [stderr] 19 | pub fn obd_init_service_09(&self) -> DiagServerResult { [INFO] [stderr] | ^^^^^ --------- the same lifetime is hidden here [INFO] [stderr] | | [INFO] [stderr] | the lifetime is elided here [INFO] [stderr] | [INFO] [stderr] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stderr] help: use `'_` for type paths [INFO] [stderr] | [INFO] [stderr] 19 | pub fn obd_init_service_09(&self) -> DiagServerResult> { [INFO] [stderr] | ++++ [INFO] [stderr] [INFO] [stderr] warning: function `print_pid` is never used [INFO] [stderr] --> src/obd2/service01.rs:75:8 [INFO] [stderr] | [INFO] [stderr] 75 | fn print_pid(v: DiagServerResult) { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: missing documentation for a module [INFO] [stderr] --> src/dtc.rs:113:1 [INFO] [stderr] | [INFO] [stderr] 113 | pub mod test { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] note: the lint level is defined here [INFO] [stderr] --> src/lib.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | missing_docs, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: missing documentation for a function [INFO] [stderr] --> src/dtc.rs:117:5 [INFO] [stderr] | [INFO] [stderr] 117 | pub fn test_dtc_parse_raw() { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: missing documentation for a module [INFO] [stderr] --> src/obd2/service01.rs:71:1 [INFO] [stderr] | [INFO] [stderr] 71 | pub mod service_09_test { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `ecu_diagnostics` (lib) generated 30 warnings (run `cargo fix --lib -p ecu_diagnostics` to apply 19 suggestions) [INFO] [stderr] warning: `ecu_diagnostics` (lib test) generated 34 warnings (30 duplicates) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.15s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/ecu_diagnostics-52c036a1bcdea073) [INFO] [stderr] Doc-tests ecu_diagnostics [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "5b91f2ba611f5e0a25f92c63ebd044d574b388f42ce7b3a26e8bac63add7254d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5b91f2ba611f5e0a25f92c63ebd044d574b388f42ce7b3a26e8bac63add7254d", kill_on_drop: false }` [INFO] [stdout] 5b91f2ba611f5e0a25f92c63ebd044d574b388f42ce7b3a26e8bac63add7254d