[INFO] fetching crate juju 1.0.0...
[INFO] checking juju-1.0.0 against master#5518eaa946291f00471af8b254b2a1715f234882 for pr-120393
[INFO] extracting crate juju 1.0.0 into /workspace/builds/worker-2-tc1/source
[INFO] validating manifest of crates.io crate juju 1.0.0 on toolchain 5518eaa946291f00471af8b254b2a1715f234882
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+5518eaa946291f00471af8b254b2a1715f234882" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate juju 1.0.0
[INFO] finished tweaking crates.io crate juju 1.0.0
[INFO] tweaked toml for crates.io crate juju 1.0.0 written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+5518eaa946291f00471af8b254b2a1715f234882" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+5518eaa946291f00471af8b254b2a1715f234882" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded itoa v0.3.4
[INFO] [stderr]   Downloaded charmhelpers v0.1.3
[INFO] [stderr]   Downloaded serde_codegen_internals v0.14.2
[INFO] [stderr]   Downloaded serde_json v0.9.10
[INFO] [stderr]   Downloaded serde_derive v0.9.15
[INFO] [stderr]   Downloaded rusqlite v0.14.0
[INFO] [stderr]   Downloaded libsqlite3-sys v0.9.4
[INFO] [stderr]   Downloaded juju v0.3.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+5518eaa946291f00471af8b254b2a1715f234882" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] fe902ba3414d37338cb7fc5d00700a33d807bf6d0135ff6b3f76508bd993e3bc
[INFO] running `Command { std: "docker" "start" "-a" "fe902ba3414d37338cb7fc5d00700a33d807bf6d0135ff6b3f76508bd993e3bc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "fe902ba3414d37338cb7fc5d00700a33d807bf6d0135ff6b3f76508bd993e3bc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fe902ba3414d37338cb7fc5d00700a33d807bf6d0135ff6b3f76508bd993e3bc", kill_on_drop: false }`
[INFO] [stdout] fe902ba3414d37338cb7fc5d00700a33d807bf6d0135ff6b3f76508bd993e3bc
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+5518eaa946291f00471af8b254b2a1715f234882" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 285975f32bacabd80b1090c88b818bb6bd4bf77aaed6b08ca3a40b16e0deca64
[INFO] running `Command { std: "docker" "start" "-a" "285975f32bacabd80b1090c88b818bb6bd4bf77aaed6b08ca3a40b16e0deca64", kill_on_drop: false }`
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]    Compiling libc v0.2.152
[INFO] [stderr]    Compiling unicode-xid v0.0.4
[INFO] [stderr]    Compiling quote v0.3.15
[INFO] [stderr]     Checking iana-time-zone v0.1.59
[INFO] [stderr]     Checking linked-hash-map v0.5.6
[INFO] [stderr]     Checking log v0.4.20
[INFO] [stderr]    Compiling libsqlite3-sys v0.9.4
[INFO] [stderr]    Compiling synom v0.11.3
[INFO] [stderr]     Checking bitflags v1.3.2
[INFO] [stderr]     Checking itoa v0.3.4
[INFO] [stderr]     Checking log v0.3.9
[INFO] [stderr]     Checking lru-cache v0.1.2
[INFO] [stderr]    Compiling syn v0.11.11
[INFO] [stderr]     Checking serde v0.9.15
[INFO] [stderr]     Checking juju v0.3.1
[INFO] [stderr]     Checking charmhelpers v0.1.3
[INFO] [stderr]    Compiling serde_codegen_internals v0.14.2
[INFO] [stderr]     Checking time v0.1.45
[INFO] [stderr]     Checking memchr v1.0.2
[INFO] [stderr]    Compiling serde_derive v0.9.15
[INFO] [stderr]     Checking num-traits v0.1.43
[INFO] [stderr]     Checking chrono v0.4.33
[INFO] [stderr]     Checking serde_json v0.9.10
[INFO] [stderr]     Checking rusqlite v0.14.0
[INFO] [stderr]     Checking juju v1.0.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/lib.rs:123:32
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn cause(&self) -> Option<&Error> {
[INFO] [stdout]     |                                ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn cause(&self) -> Option<&dyn Error> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/lib.rs:123:32
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn cause(&self) -> Option<&Error> {
[INFO] [stdout]     |                                ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn cause(&self) -> Option<&dyn Error> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `core::str::<impl str>::trim_left_matches`: superseded by `trim_start_matches`
[INFO] [stdout]    --> src/unitdata.rs:113:34
[INFO] [stdout]     |
[INFO] [stdout] 113 |                 results.insert(k.trim_left_matches(&key_prefix).to_string(), value);
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] help: replace the use of the deprecated method
[INFO] [stdout]     |
[INFO] [stdout] 113 |                 results.insert(k.trim_start_matches(&key_prefix).to_string(), value);
[INFO] [stdout]     |                                  ~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `core::str::<impl str>::trim_left_matches`: superseded by `trim_start_matches`
[INFO] [stdout]    --> src/unitdata.rs:113:34
[INFO] [stdout]     |
[INFO] [stdout] 113 |                 results.insert(k.trim_left_matches(&key_prefix).to_string(), value);
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] help: replace the use of the deprecated method
[INFO] [stdout]     |
[INFO] [stdout] 113 |                 results.insert(k.trim_start_matches(&key_prefix).to_string(), value);
[INFO] [stdout]     |                                  ~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/unitdata.rs:165:38
[INFO] [stdout]     |
[INFO] [stdout] 165 |                 let mut values: Vec<&rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 165 |                 let mut values: Vec<&dyn rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/unitdata.rs:180:42
[INFO] [stdout]     |
[INFO] [stdout] 180 |                     let mut values: Vec<&rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 180 |                     let mut values: Vec<&dyn rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/unitdata.rs:165:38
[INFO] [stdout]     |
[INFO] [stdout] 165 |                 let mut values: Vec<&rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 165 |                 let mut values: Vec<&dyn rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/unitdata.rs:180:42
[INFO] [stdout]     |
[INFO] [stdout] 180 |                     let mut values: Vec<&rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 180 |                     let mut values: Vec<&dyn rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:95:55
[INFO] [stdout]    |
[INFO] [stdout] 95 |             JujuError::AddrParseError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:96:54
[INFO] [stdout]    |
[INFO] [stdout] 96 |             JujuError::FromUtf8Error(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:97:48
[INFO] [stdout]    |
[INFO] [stdout] 97 |             JujuError::IoError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:98:54
[INFO] [stdout]    |
[INFO] [stdout] 98 |             JujuError::ParseIntError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:99:54
[INFO] [stdout]    |
[INFO] [stdout] 99 |             JujuError::RusqliteError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:100:51
[INFO] [stdout]     |
[INFO] [stdout] 100 |             JujuError::SerdeError(ref err) => err.description().to_string(),
[INFO] [stdout]     |                                                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:101:49
[INFO] [stdout]     |
[INFO] [stdout] 101 |             JujuError::VarError(ref err) => err.description().to_string(),
[INFO] [stdout]     |                                                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:107:26
[INFO] [stdout]     |
[INFO] [stdout] 107 |         f.write_str(self.description())
[INFO] [stdout]     |                          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:95:55
[INFO] [stdout]    |
[INFO] [stdout] 95 |             JujuError::AddrParseError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:114:55
[INFO] [stdout]     |
[INFO] [stdout] 114 |             JujuError::AddrParseError(ref err) => err.description(),
[INFO] [stdout]     |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:115:54
[INFO] [stdout]     |
[INFO] [stdout] 115 |             JujuError::FromUtf8Error(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:116:48
[INFO] [stdout]     |
[INFO] [stdout] 116 |             JujuError::IoError(ref err) => err.description(),
[INFO] [stdout]     |                                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:96:54
[INFO] [stdout]    |
[INFO] [stdout] 96 |             JujuError::FromUtf8Error(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:97:48
[INFO] [stdout]    |
[INFO] [stdout] 97 |             JujuError::IoError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:117:54
[INFO] [stdout]     |
[INFO] [stdout] 117 |             JujuError::ParseIntError(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:118:54
[INFO] [stdout]     |
[INFO] [stdout] 118 |             JujuError::RusqliteError(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:98:54
[INFO] [stdout]    |
[INFO] [stdout] 98 |             JujuError::ParseIntError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:119:51
[INFO] [stdout]     |
[INFO] [stdout] 119 |             JujuError::SerdeError(ref err) => err.description(),
[INFO] [stdout]     |                                                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:120:49
[INFO] [stdout]     |
[INFO] [stdout] 120 |             JujuError::VarError(ref err) => err.description(),
[INFO] [stdout]     |                                                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:125:55
[INFO] [stdout]     |
[INFO] [stdout] 125 |             JujuError::AddrParseError(ref err) => err.cause(),
[INFO] [stdout]     |                                                       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:99:54
[INFO] [stdout]    |
[INFO] [stdout] 99 |             JujuError::RusqliteError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:126:54
[INFO] [stdout]     |
[INFO] [stdout] 126 |             JujuError::FromUtf8Error(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:100:51
[INFO] [stdout]     |
[INFO] [stdout] 100 |             JujuError::SerdeError(ref err) => err.description().to_string(),
[INFO] [stdout]     |                                                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:101:49
[INFO] [stdout]     |
[INFO] [stdout] 101 |             JujuError::VarError(ref err) => err.description().to_string(),
[INFO] [stdout]     |                                                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:107:26
[INFO] [stdout]     |
[INFO] [stdout] 107 |         f.write_str(self.description())
[INFO] [stdout]     |                          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:127:48
[INFO] [stdout]     |
[INFO] [stdout] 127 |             JujuError::IoError(ref err) => err.cause(),
[INFO] [stdout]     |                                                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:128:54
[INFO] [stdout]     |
[INFO] [stdout] 128 |             JujuError::ParseIntError(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:114:55
[INFO] [stdout]     |
[INFO] [stdout] 114 |             JujuError::AddrParseError(ref err) => err.description(),
[INFO] [stdout]     |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:129:51
[INFO] [stdout]     |
[INFO] [stdout] 129 |             JujuError::SerdeError(ref err) => err.cause(),
[INFO] [stdout]     |                                                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:130:54
[INFO] [stdout]     |
[INFO] [stdout] 130 |             JujuError::RusqliteError(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:115:54
[INFO] [stdout]     |
[INFO] [stdout] 115 |             JujuError::FromUtf8Error(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:131:49
[INFO] [stdout]     |
[INFO] [stdout] 131 |             JujuError::VarError(ref err) => err.cause(),
[INFO] [stdout]     |                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:116:48
[INFO] [stdout]     |
[INFO] [stdout] 116 |             JujuError::IoError(ref err) => err.description(),
[INFO] [stdout]     |                                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:117:54
[INFO] [stdout]     |
[INFO] [stdout] 117 |             JujuError::ParseIntError(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:118:54
[INFO] [stdout]     |
[INFO] [stdout] 118 |             JujuError::RusqliteError(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:119:51
[INFO] [stdout]     |
[INFO] [stdout] 119 |             JujuError::SerdeError(ref err) => err.description(),
[INFO] [stdout]     |                                                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:120:49
[INFO] [stdout]     |
[INFO] [stdout] 120 |             JujuError::VarError(ref err) => err.description(),
[INFO] [stdout]     |                                                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:125:55
[INFO] [stdout]     |
[INFO] [stdout] 125 |             JujuError::AddrParseError(ref err) => err.cause(),
[INFO] [stdout]     |                                                       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:126:54
[INFO] [stdout]     |
[INFO] [stdout] 126 |             JujuError::FromUtf8Error(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:127:48
[INFO] [stdout]     |
[INFO] [stdout] 127 |             JujuError::IoError(ref err) => err.cause(),
[INFO] [stdout]     |                                                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:128:54
[INFO] [stdout]     |
[INFO] [stdout] 128 |             JujuError::ParseIntError(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:129:51
[INFO] [stdout]     |
[INFO] [stdout] 129 |             JujuError::SerdeError(ref err) => err.cause(),
[INFO] [stdout]     |                                                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:130:54
[INFO] [stdout]     |
[INFO] [stdout] 130 |             JujuError::RusqliteError(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:131:49
[INFO] [stdout]     |
[INFO] [stdout] 131 |             JujuError::VarError(ref err) => err.cause(),
[INFO] [stdout]     |                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `slots` is never read
[INFO] [stdout]   --> src/unitdata.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct Record {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] 29 |     slots: HashMap<String, String>,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Record` has a derived impl for the trait `Debug`, 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: fields `data`, `date`, `hook`, `key`, and `revision` are never read
[INFO] [stdout]   --> src/unitdata.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct History {
[INFO] [stdout]    |            ------- fields in this struct
[INFO] [stdout] 34 |     data: Value,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 35 |     date: DateTime<Utc>,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 36 |     hook: String,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 37 |     key: String,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 38 |     revision: u32,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `History` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/lib.rs:650:35
[INFO] [stdout]     |
[INFO] [stdout] 650 |     let arg = format!("{}={}", key.clone(), value);
[INFO] [stdout]     |                                   ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `slots` is never read
[INFO] [stdout]   --> src/unitdata.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct Record {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] 29 |     slots: HashMap<String, String>,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Record` has a derived impl for the trait `Debug`, 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: fields `data`, `date`, `hook`, `key`, and `revision` are never read
[INFO] [stdout]   --> src/unitdata.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct History {
[INFO] [stdout]    |            ------- fields in this struct
[INFO] [stdout] 34 |     data: Value,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 35 |     date: DateTime<Utc>,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 36 |     hook: String,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 37 |     key: String,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 38 |     revision: u32,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `History` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 29 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/lib.rs:650:35
[INFO] [stdout]     |
[INFO] [stdout] 650 |     let arg = format!("{}={}", key.clone(), value);
[INFO] [stdout]     |                                   ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 29 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]   --> tests/test_unitdata.rs:36:53
[INFO] [stdout]    |
[INFO] [stdout] 36 |     assert_eq!(results.get("foo3").unwrap(), "bar");;
[INFO] [stdout]    |                                                     ^ help: remove this semicolon
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(redundant_semicolons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]   --> tests/test_unitdata.rs:42:52
[INFO] [stdout]    |
[INFO] [stdout] 42 |     assert_eq!(results_2.get("3").unwrap(), "bar");;
[INFO] [stdout]    |                                                    ^ help: remove this semicolon
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 2 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished dev [unoptimized + debuginfo] target(s) in 1.86s
[INFO] running `Command { std: "docker" "inspect" "285975f32bacabd80b1090c88b818bb6bd4bf77aaed6b08ca3a40b16e0deca64", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "285975f32bacabd80b1090c88b818bb6bd4bf77aaed6b08ca3a40b16e0deca64", kill_on_drop: false }`
[INFO] [stdout] 285975f32bacabd80b1090c88b818bb6bd4bf77aaed6b08ca3a40b16e0deca64
[INFO] checking juju-1.0.0 against try#7622c0f807a4e13c4db886a1681bf343795692df+rustflags=-Dnon_local_definitions for pr-120393
[INFO] extracting crate juju 1.0.0 into /workspace/builds/worker-2-tc2/source
[INFO] validating manifest of crates.io crate juju 1.0.0 on toolchain 7622c0f807a4e13c4db886a1681bf343795692df
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+7622c0f807a4e13c4db886a1681bf343795692df" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate juju 1.0.0
[INFO] finished tweaking crates.io crate juju 1.0.0
[INFO] tweaked toml for crates.io crate juju 1.0.0 written to /workspace/builds/worker-2-tc2/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+7622c0f807a4e13c4db886a1681bf343795692df" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+7622c0f807a4e13c4db886a1681bf343795692df" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+7622c0f807a4e13c4db886a1681bf343795692df" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] f3e1491df73cfd2d82d05230f8c08ed90402fad241acb4ed259438803afd470f
[INFO] running `Command { std: "docker" "start" "-a" "f3e1491df73cfd2d82d05230f8c08ed90402fad241acb4ed259438803afd470f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "f3e1491df73cfd2d82d05230f8c08ed90402fad241acb4ed259438803afd470f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f3e1491df73cfd2d82d05230f8c08ed90402fad241acb4ed259438803afd470f", kill_on_drop: false }`
[INFO] [stdout] f3e1491df73cfd2d82d05230f8c08ed90402fad241acb4ed259438803afd470f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Dnon_local_definitions" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+7622c0f807a4e13c4db886a1681bf343795692df" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c711add7af753d94f72cea1bcb32773f5fb292f87857af72ffbc0f3b08f72610
[INFO] running `Command { std: "docker" "start" "-a" "c711add7af753d94f72cea1bcb32773f5fb292f87857af72ffbc0f3b08f72610", kill_on_drop: false }`
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]    Compiling libc v0.2.152
[INFO] [stderr]    Compiling unicode-xid v0.0.4
[INFO] [stderr]    Compiling quote v0.3.15
[INFO] [stderr]     Checking iana-time-zone v0.1.59
[INFO] [stderr]     Checking log v0.4.20
[INFO] [stderr]     Checking linked-hash-map v0.5.6
[INFO] [stderr]    Compiling libsqlite3-sys v0.9.4
[INFO] [stderr]    Compiling synom v0.11.3
[INFO] [stderr]     Checking juju v0.3.1
[INFO] [stderr]     Checking log v0.3.9
[INFO] [stderr]    Compiling syn v0.11.11
[INFO] [stderr]     Checking lru-cache v0.1.2
[INFO] [stderr]     Checking itoa v0.3.4
[INFO] [stderr]     Checking serde v0.9.15
[INFO] [stderr]     Checking bitflags v1.3.2
[INFO] [stderr]     Checking charmhelpers v0.1.3
[INFO] [stderr]    Compiling serde_codegen_internals v0.14.2
[INFO] [stderr]     Checking time v0.1.45
[INFO] [stderr]     Checking memchr v1.0.2
[INFO] [stderr]    Compiling serde_derive v0.9.15
[INFO] [stderr]     Checking chrono v0.4.33
[INFO] [stderr]     Checking num-traits v0.1.43
[INFO] [stderr]     Checking serde_json v0.9.10
[INFO] [stderr]     Checking rusqlite v0.14.0
[INFO] [stderr]     Checking juju v1.0.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/lib.rs:123:32
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn cause(&self) -> Option<&Error> {
[INFO] [stdout]     |                                ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn cause(&self) -> Option<&dyn Error> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/lib.rs:123:32
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn cause(&self) -> Option<&Error> {
[INFO] [stdout]     |                                ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn cause(&self) -> Option<&dyn Error> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `core::str::<impl str>::trim_left_matches`: superseded by `trim_start_matches`
[INFO] [stdout]    --> src/unitdata.rs:113:34
[INFO] [stdout]     |
[INFO] [stdout] 113 |                 results.insert(k.trim_left_matches(&key_prefix).to_string(), value);
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] help: replace the use of the deprecated method
[INFO] [stdout]     |
[INFO] [stdout] 113 |                 results.insert(k.trim_start_matches(&key_prefix).to_string(), value);
[INFO] [stdout]     |                                  ~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `core::str::<impl str>::trim_left_matches`: superseded by `trim_start_matches`
[INFO] [stdout]    --> src/unitdata.rs:113:34
[INFO] [stdout]     |
[INFO] [stdout] 113 |                 results.insert(k.trim_left_matches(&key_prefix).to_string(), value);
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] help: replace the use of the deprecated method
[INFO] [stdout]     |
[INFO] [stdout] 113 |                 results.insert(k.trim_start_matches(&key_prefix).to_string(), value);
[INFO] [stdout]     |                                  ~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/unitdata.rs:165:38
[INFO] [stdout]     |
[INFO] [stdout] 165 |                 let mut values: Vec<&rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 165 |                 let mut values: Vec<&dyn rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/unitdata.rs:180:42
[INFO] [stdout]     |
[INFO] [stdout] 180 |                     let mut values: Vec<&rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 180 |                     let mut values: Vec<&dyn rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/unitdata.rs:165:38
[INFO] [stdout]     |
[INFO] [stdout] 165 |                 let mut values: Vec<&rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 165 |                 let mut values: Vec<&dyn rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/unitdata.rs:180:42
[INFO] [stdout]     |
[INFO] [stdout] 180 |                     let mut values: Vec<&rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 180 |                     let mut values: Vec<&dyn rusqlite::types::ToSql> = Vec::new();
[INFO] [stdout]     |                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:95:55
[INFO] [stdout]    |
[INFO] [stdout] 95 |             JujuError::AddrParseError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:96:54
[INFO] [stdout]    |
[INFO] [stdout] 96 |             JujuError::FromUtf8Error(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:97:48
[INFO] [stdout]    |
[INFO] [stdout] 97 |             JujuError::IoError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:98:54
[INFO] [stdout]    |
[INFO] [stdout] 98 |             JujuError::ParseIntError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:99:54
[INFO] [stdout]    |
[INFO] [stdout] 99 |             JujuError::RusqliteError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:100:51
[INFO] [stdout]     |
[INFO] [stdout] 100 |             JujuError::SerdeError(ref err) => err.description().to_string(),
[INFO] [stdout]     |                                                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:101:49
[INFO] [stdout]     |
[INFO] [stdout] 101 |             JujuError::VarError(ref err) => err.description().to_string(),
[INFO] [stdout]     |                                                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:107:26
[INFO] [stdout]     |
[INFO] [stdout] 107 |         f.write_str(self.description())
[INFO] [stdout]     |                          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:114:55
[INFO] [stdout]     |
[INFO] [stdout] 114 |             JujuError::AddrParseError(ref err) => err.description(),
[INFO] [stdout]     |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:95:55
[INFO] [stdout]    |
[INFO] [stdout] 95 |             JujuError::AddrParseError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:115:54
[INFO] [stdout]     |
[INFO] [stdout] 115 |             JujuError::FromUtf8Error(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:116:48
[INFO] [stdout]     |
[INFO] [stdout] 116 |             JujuError::IoError(ref err) => err.description(),
[INFO] [stdout]     |                                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:117:54
[INFO] [stdout]     |
[INFO] [stdout] 117 |             JujuError::ParseIntError(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:96:54
[INFO] [stdout]    |
[INFO] [stdout] 96 |             JujuError::FromUtf8Error(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:97:48
[INFO] [stdout]    |
[INFO] [stdout] 97 |             JujuError::IoError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:98:54
[INFO] [stdout]    |
[INFO] [stdout] 98 |             JujuError::ParseIntError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:118:54
[INFO] [stdout]     |
[INFO] [stdout] 118 |             JujuError::RusqliteError(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]   --> src/lib.rs:99:54
[INFO] [stdout]    |
[INFO] [stdout] 99 |             JujuError::RusqliteError(ref err) => err.description().to_string(),
[INFO] [stdout]    |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:100:51
[INFO] [stdout]     |
[INFO] [stdout] 100 |             JujuError::SerdeError(ref err) => err.description().to_string(),
[INFO] [stdout]     |                                                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:101:49
[INFO] [stdout]     |
[INFO] [stdout] 101 |             JujuError::VarError(ref err) => err.description().to_string(),
[INFO] [stdout]     |                                                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:107:26
[INFO] [stdout]     |
[INFO] [stdout] 107 |         f.write_str(self.description())
[INFO] [stdout]     |                          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:114:55
[INFO] [stdout]     |
[INFO] [stdout] 114 |             JujuError::AddrParseError(ref err) => err.description(),
[INFO] [stdout]     |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:119:51
[INFO] [stdout]     |
[INFO] [stdout] 119 |             JujuError::SerdeError(ref err) => err.description(),
[INFO] [stdout]     |                                                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:115:54
[INFO] [stdout]     |
[INFO] [stdout] 115 |             JujuError::FromUtf8Error(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:120:49
[INFO] [stdout]     |
[INFO] [stdout] 120 |             JujuError::VarError(ref err) => err.description(),
[INFO] [stdout]     |                                                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:116:48
[INFO] [stdout]     |
[INFO] [stdout] 116 |             JujuError::IoError(ref err) => err.description(),
[INFO] [stdout]     |                                                ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:125:55
[INFO] [stdout]     |
[INFO] [stdout] 125 |             JujuError::AddrParseError(ref err) => err.cause(),
[INFO] [stdout]     |                                                       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:117:54
[INFO] [stdout]     |
[INFO] [stdout] 117 |             JujuError::ParseIntError(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:126:54
[INFO] [stdout]     |
[INFO] [stdout] 126 |             JujuError::FromUtf8Error(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:118:54
[INFO] [stdout]     |
[INFO] [stdout] 118 |             JujuError::RusqliteError(ref err) => err.description(),
[INFO] [stdout]     |                                                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:127:48
[INFO] [stdout]     |
[INFO] [stdout] 127 |             JujuError::IoError(ref err) => err.cause(),
[INFO] [stdout]     |                                                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:119:51
[INFO] [stdout]     |
[INFO] [stdout] 119 |             JujuError::SerdeError(ref err) => err.description(),
[INFO] [stdout]     |                                                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:128:54
[INFO] [stdout]     |
[INFO] [stdout] 128 |             JujuError::ParseIntError(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/lib.rs:120:49
[INFO] [stdout]     |
[INFO] [stdout] 120 |             JujuError::VarError(ref err) => err.description(),
[INFO] [stdout]     |                                                 ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:125:55
[INFO] [stdout]     |
[INFO] [stdout] 125 |             JujuError::AddrParseError(ref err) => err.cause(),
[INFO] [stdout]     |                                                       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:126:54
[INFO] [stdout]     |
[INFO] [stdout] 126 |             JujuError::FromUtf8Error(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:127:48
[INFO] [stdout]     |
[INFO] [stdout] 127 |             JujuError::IoError(ref err) => err.cause(),
[INFO] [stdout]     |                                                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:128:54
[INFO] [stdout]     |
[INFO] [stdout] 128 |             JujuError::ParseIntError(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:129:51
[INFO] [stdout]     |
[INFO] [stdout] 129 |             JujuError::SerdeError(ref err) => err.cause(),
[INFO] [stdout]     |                                                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:130:54
[INFO] [stdout]     |
[INFO] [stdout] 130 |             JujuError::RusqliteError(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:131:49
[INFO] [stdout]     |
[INFO] [stdout] 131 |             JujuError::VarError(ref err) => err.cause(),
[INFO] [stdout]     |                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:129:51
[INFO] [stdout]     |
[INFO] [stdout] 129 |             JujuError::SerdeError(ref err) => err.cause(),
[INFO] [stdout]     |                                                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:130:54
[INFO] [stdout]     |
[INFO] [stdout] 130 |             JujuError::RusqliteError(ref err) => err.cause(),
[INFO] [stdout]     |                                                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::cause`: replaced by Error::source, which can support downcasting
[INFO] [stdout]    --> src/lib.rs:131:49
[INFO] [stdout]     |
[INFO] [stdout] 131 |             JujuError::VarError(ref err) => err.cause(),
[INFO] [stdout]     |                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `slots` is never read
[INFO] [stdout]   --> src/unitdata.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct Record {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] 29 |     slots: HashMap<String, String>,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Record` has a derived impl for the trait `Debug`, 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: fields `data`, `date`, `hook`, `key`, and `revision` are never read
[INFO] [stdout]   --> src/unitdata.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct History {
[INFO] [stdout]    |            ------- fields in this struct
[INFO] [stdout] 34 |     data: Value,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 35 |     date: DateTime<Utc>,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 36 |     hook: String,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 37 |     key: String,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 38 |     revision: u32,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `History` 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 `slots` is never read
[INFO] [stdout]   --> src/unitdata.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct Record {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] 29 |     slots: HashMap<String, String>,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Record` has a derived impl for the trait `Debug`, 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: fields `data`, `date`, `hook`, `key`, and `revision` are never read
[INFO] [stdout]   --> src/unitdata.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct History {
[INFO] [stdout]    |            ------- fields in this struct
[INFO] [stdout] 34 |     data: Value,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 35 |     date: DateTime<Utc>,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 36 |     hook: String,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 37 |     key: String,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 38 |     revision: u32,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `History` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/lib.rs:650:35
[INFO] [stdout]     |
[INFO] [stdout] 650 |     let arg = format!("{}={}", key.clone(), value);
[INFO] [stdout]     |                                   ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/lib.rs:650:35
[INFO] [stdout]     |
[INFO] [stdout] 650 |     let arg = format!("{}={}", key.clone(), value);
[INFO] [stdout]     |                                   ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: non-local `impl` definition, they should be avoided as they go against expectation
[INFO] [stdout]   --> src/unitdata.rs:27:17
[INFO] [stdout]    |
[INFO] [stdout] 27 | #[derive(Debug, Deserialize)]
[INFO] [stdout]    |                 ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: move this `impl` block outside the of the current constant `_IMPL_DESERIALIZE_FOR_Record`
[INFO] [stdout]    = note: an `impl` definition is non-local if it is nested inside an item and neither the type nor the trait are at the same nesting level as the `impl` block
[INFO] [stdout]    = note: this lint may become deny-by-default in the edition 2024 and higher, see the tracking issue <https://github.com/rust-lang/rust/issues/120363>
[INFO] [stdout]    = note: requested on the command line with `-D non-local-definitions`
[INFO] [stdout]    = note: this error originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: non-local `impl` definition, they should be avoided as they go against expectation
[INFO] [stdout]   --> src/unitdata.rs:27:17
[INFO] [stdout]    |
[INFO] [stdout] 27 | #[derive(Debug, Deserialize)]
[INFO] [stdout]    |                 ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: move this `impl` block outside the of the current constant `_IMPL_DESERIALIZE_FOR_Record`
[INFO] [stdout]    = note: an `impl` definition is non-local if it is nested inside an item and neither the type nor the trait are at the same nesting level as the `impl` block
[INFO] [stdout]    = note: this lint may become deny-by-default in the edition 2024 and higher, see the tracking issue <https://github.com/rust-lang/rust/issues/120363>
[INFO] [stdout]    = note: requested on the command line with `-D non-local-definitions`
[INFO] [stdout]    = note: this error originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 1 previous error; 29 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 1 previous error; 29 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `juju` (lib) due to 2 previous errors; 29 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error: could not compile `juju` (lib test) due to 2 previous errors; 29 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "c711add7af753d94f72cea1bcb32773f5fb292f87857af72ffbc0f3b08f72610", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c711add7af753d94f72cea1bcb32773f5fb292f87857af72ffbc0f3b08f72610", kill_on_drop: false }`
[INFO] [stdout] c711add7af753d94f72cea1bcb32773f5fb292f87857af72ffbc0f3b08f72610
