[INFO] fetching crate garage_rpc 0.9.0...
[INFO] checking garage_rpc-0.9.0 against master#b0696a5160711c068cb1f01b7437db7990d15750 for pr-121848
[INFO] extracting crate garage_rpc 0.9.0 into /workspace/builds/worker-1-tc1/source
[INFO] validating manifest of crates.io crate garage_rpc 0.9.0 on toolchain b0696a5160711c068cb1f01b7437db7990d15750
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b0696a5160711c068cb1f01b7437db7990d15750" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate garage_rpc 0.9.0
[INFO] finished tweaking crates.io crate garage_rpc 0.9.0
[INFO] tweaked toml for crates.io crate garage_rpc 0.9.0 written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b0696a5160711c068cb1f01b7437db7990d15750" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[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" "+b0696a5160711c068cb1f01b7437db7990d15750" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded format_table v0.1.1
[INFO] [stderr]   Downloaded garage_util v0.9.3
[INFO] [stderr]   Downloaded treediff v3.0.2
[INFO] [stderr]   Downloaded pnet_sys v0.33.0
[INFO] [stderr]   Downloaded json-patch v0.2.7
[INFO] [stderr]   Downloaded xxhash-rust v0.8.10
[INFO] [stderr]   Downloaded kube-core v0.75.0
[INFO] [stderr]   Downloaded opentelemetry-contrib v0.9.0
[INFO] [stderr]   Downloaded kube-derive v0.75.0
[INFO] [stderr]   Downloaded pnet_base v0.33.0
[INFO] [stderr]   Downloaded kube v0.75.0
[INFO] [stderr]   Downloaded garage_db v0.9.3
[INFO] [stderr]   Downloaded garage_net v0.9.3
[INFO] [stderr]   Downloaded netapp v0.10.0
[INFO] [stderr]   Downloaded kube-client v0.75.0
[INFO] [stderr]   Downloaded kube-runtime v0.75.0
[INFO] [stderr]   Downloaded pnet_datalink v0.33.0
[INFO] [stderr]   Downloaded jsonpath_lib v0.3.0
[INFO] [stderr]   Downloaded err-derive v0.3.1
[INFO] [stderr]   Downloaded kuska-handshake v0.2.0
[INFO] [stderr]   Downloaded kuska-sodiumoxide v0.2.5-0
[INFO] [stderr]   Downloaded libsodium-sys v0.2.7
[INFO] [stderr]   Downloaded k8s-openapi v0.16.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+b0696a5160711c068cb1f01b7437db7990d15750" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] dd05770d835afa53521118db73d6fe8554ba9bfe304196e25be9e7aaf5405224
[INFO] running `Command { std: "docker" "start" "-a" "dd05770d835afa53521118db73d6fe8554ba9bfe304196e25be9e7aaf5405224", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "dd05770d835afa53521118db73d6fe8554ba9bfe304196e25be9e7aaf5405224", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "dd05770d835afa53521118db73d6fe8554ba9bfe304196e25be9e7aaf5405224", kill_on_drop: false }`
[INFO] [stdout] dd05770d835afa53521118db73d6fe8554ba9bfe304196e25be9e7aaf5405224
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+b0696a5160711c068cb1f01b7437db7990d15750" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] e21110c4561379a3c398542dc282f8160c7fba259c1789a3989de449bd765b78
[INFO] running `Command { std: "docker" "start" "-a" "e21110c4561379a3c398542dc282f8160c7fba259c1789a3989de449bd765b78", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde v1.0.197
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking tokio v1.36.0
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling libsodium-sys v0.2.7
[INFO] [stderr]    Compiling err-derive v0.3.1
[INFO] [stderr]     Checking crossbeam-channel v0.5.12
[INFO] [stderr]     Checking dashmap v4.0.2
[INFO] [stderr]     Checking subtle v2.5.0
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking http v1.1.0
[INFO] [stderr]     Checking arrayvec v0.5.2
[INFO] [stderr]     Checking arc-swap v1.7.0
[INFO] [stderr]     Checking winnow v0.6.5
[INFO] [stderr]     Checking itertools v0.4.19
[INFO] [stderr]     Checking hexdump v0.1.1
[INFO] [stderr]     Checking rmp v0.8.12
[INFO] [stderr]     Checking http-body v1.0.0
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]    Compiling garage_util v0.9.3
[INFO] [stderr]     Checking no-std-net v0.6.0
[INFO] [stderr]     Checking chrono v0.4.35
[INFO] [stderr]     Checking sha2 v0.10.8
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]    Compiling synstructure v0.12.6
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]     Checking pnet_base v0.33.0
[INFO] [stderr]     Checking blake2 v0.10.6
[INFO] [stderr]     Checking serde_spanned v0.6.5
[INFO] [stderr]     Checking rmp-serde v1.1.2
[INFO] [stderr]     Checking toml_datetime v0.6.5
[INFO] [stderr]     Checking serde_json v1.0.114
[INFO] [stderr]     Checking toml_edit v0.22.7
[INFO] [stderr]     Checking ipnetwork v0.20.0
[INFO] [stderr]     Checking pnet_sys v0.33.0
[INFO] [stderr]     Checking bitflags v2.4.2
[INFO] [stderr]     Checking xxhash-rust v0.8.10
[INFO] [stderr]     Checking bytesize v1.3.0
[INFO] [stderr]     Checking nix v0.27.1
[INFO] [stderr]     Checking pnet_datalink v0.33.0
[INFO] [stderr]     Checking serde_bytes v0.11.14
[INFO] [stderr]     Checking gethostname v0.4.3
[INFO] [stderr]     Checking format_table v0.1.1
[INFO] [stderr]     Checking tokio-stream v0.1.14
[INFO] [stderr]     Checking tokio-util v0.7.10
[INFO] [stderr]     Checking hyper v1.2.0
[INFO] [stderr]     Checking opentelemetry v0.17.0
[INFO] [stderr]     Checking toml v0.8.11
[INFO] [stderr]     Checking garage_db v0.9.3
[INFO] [stderr]     Checking opentelemetry-contrib v0.9.0
[INFO] [stderr]     Checking kuska-sodiumoxide v0.2.5-0
[INFO] [stderr]     Checking kuska-handshake v0.2.0
[INFO] [stderr]     Checking garage_net v0.9.3
[INFO] [stderr]     Checking netapp v0.10.0
[INFO] [stderr]     Checking garage_rpc v0.9.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the item `Error` is imported redundantly
[INFO] [stdout]     --> layout.rs:1135:14
[INFO] [stdout]      |
[INFO] [stdout] 1135 |     use super::{Error, *};
[INFO] [stdout]      |                 ^^^^^  - the item `Error` is already imported here
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Endpoint` is imported redundantly
[INFO] [stdout]   --> system.rs:19:24
[INFO] [stdout]    |
[INFO] [stdout] 19 | use netapp::endpoint::{Endpoint, EndpointHandler};
[INFO] [stdout]    |                        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `Endpoint` is already imported here
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Endpoint` is imported redundantly
[INFO] [stdout]   --> system.rs:19:24
[INFO] [stdout]    |
[INFO] [stdout] 19 | use netapp::endpoint::{Endpoint, EndpointHandler};
[INFO] [stdout]    |                        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `Endpoint` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `EndpointHandler` is imported redundantly
[INFO] [stdout]   --> system.rs:19:34
[INFO] [stdout]    |
[INFO] [stdout] 19 | use netapp::endpoint::{Endpoint, EndpointHandler};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `EndpointHandler` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `EndpointHandler` is imported redundantly
[INFO] [stdout]   --> system.rs:19:34
[INFO] [stdout]    |
[INFO] [stdout] 19 | use netapp::endpoint::{Endpoint, EndpointHandler};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `EndpointHandler` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `NetApp` is imported redundantly
[INFO] [stdout]   --> system.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 | use netapp::{NetApp, NetworkKey, NodeID, NodeKey};
[INFO] [stdout]    |              ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `NetApp` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `NetApp` is imported redundantly
[INFO] [stdout]   --> system.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 | use netapp::{NetApp, NetworkKey, NodeID, NodeKey};
[INFO] [stdout]    |              ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `NetApp` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `NodeID` is imported redundantly
[INFO] [stdout]   --> system.rs:23:34
[INFO] [stdout]    |
[INFO] [stdout] 23 | use netapp::{NetApp, NetworkKey, NodeID, NodeKey};
[INFO] [stdout]    |                                  ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `NodeID` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `NodeID` is imported redundantly
[INFO] [stdout]   --> system.rs:23:34
[INFO] [stdout]    |
[INFO] [stdout] 23 | use netapp::{NetApp, NetworkKey, NodeID, NodeKey};
[INFO] [stdout]    |                                  ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `NodeID` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:186:63
[INFO] [stdout]     |
[INFO] [stdout] 186 |         let msg = msg.into_req().map_err(netapp::error::Error::from)?;
[INFO] [stdout]     |                                                                     ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<Vec<(garage_util::data::FixedBytes32, Result<S, garage_util::error::Error>)>, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<Vec<(garage_util::data::FixedBytes32, Result<S, garage_util::error::Error>)>, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:186:63
[INFO] [stdout]     |
[INFO] [stdout] 186 |         let msg = msg.into_req().map_err(netapp::error::Error::from)?;
[INFO] [stdout]     |                                                                     ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<Vec<(FixedBytes32, Result<S, garage_util::error::Error>)>, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<Vec<(FixedBytes32, Result<S, garage_util::error::Error>)>, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:159:18
[INFO] [stdout]     |
[INFO] [stdout] 159 |                 let res = res?.into_msg();
[INFO] [stdout]     |                              ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<S, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<S, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:159:18
[INFO] [stdout]     |
[INFO] [stdout] 159 |                 let res = res?.into_msg();
[INFO] [stdout]     |                              ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<S, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<S, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:277:63
[INFO] [stdout]     |
[INFO] [stdout] 277 |         let msg = msg.into_req().map_err(netapp::error::Error::from)?;
[INFO] [stdout]     |                                                                     ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<Vec<S>, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<Vec<S>, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:277:63
[INFO] [stdout]     |
[INFO] [stdout] 277 |         let msg = msg.into_req().map_err(netapp::error::Error::from)?;
[INFO] [stdout]     |                                                                     ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<Vec<S>, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<Vec<S>, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors; 4 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0277`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `garage_rpc` (lib) due to 4 previous errors; 4 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error: aborting due to 3 previous errors; 5 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0277`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `garage_rpc` (lib test) due to 4 previous errors; 5 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "e21110c4561379a3c398542dc282f8160c7fba259c1789a3989de449bd765b78", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e21110c4561379a3c398542dc282f8160c7fba259c1789a3989de449bd765b78", kill_on_drop: false }`
[INFO] [stdout] e21110c4561379a3c398542dc282f8160c7fba259c1789a3989de449bd765b78
[INFO] checking garage_rpc-0.9.0 against try#bfe97fcae016881ad333f0ff8cea2cadb9cf136c for pr-121848
[INFO] extracting crate garage_rpc 0.9.0 into /workspace/builds/worker-1-tc2/source
[INFO] validating manifest of crates.io crate garage_rpc 0.9.0 on toolchain bfe97fcae016881ad333f0ff8cea2cadb9cf136c
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bfe97fcae016881ad333f0ff8cea2cadb9cf136c" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate garage_rpc 0.9.0
[INFO] finished tweaking crates.io crate garage_rpc 0.9.0
[INFO] tweaked toml for crates.io crate garage_rpc 0.9.0 written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bfe97fcae016881ad333f0ff8cea2cadb9cf136c" "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" "+bfe97fcae016881ad333f0ff8cea2cadb9cf136c" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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" "+bfe97fcae016881ad333f0ff8cea2cadb9cf136c" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 81509d986fe016566567ad8bb545971e0aa7e4e272b2c2a2bba327f7e91b6d3e
[INFO] running `Command { std: "docker" "start" "-a" "81509d986fe016566567ad8bb545971e0aa7e4e272b2c2a2bba327f7e91b6d3e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "81509d986fe016566567ad8bb545971e0aa7e4e272b2c2a2bba327f7e91b6d3e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "81509d986fe016566567ad8bb545971e0aa7e4e272b2c2a2bba327f7e91b6d3e", kill_on_drop: false }`
[INFO] [stdout] 81509d986fe016566567ad8bb545971e0aa7e4e272b2c2a2bba327f7e91b6d3e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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" "-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" "+bfe97fcae016881ad333f0ff8cea2cadb9cf136c" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 28d48720f6115a9e92328cfe6aad8773c9c6539da5711c8958cee96b305f809b
[INFO] running `Command { std: "docker" "start" "-a" "28d48720f6115a9e92328cfe6aad8773c9c6539da5711c8958cee96b305f809b", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde v1.0.197
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]     Checking tokio v1.36.0
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling libsodium-sys v0.2.7
[INFO] [stderr]    Compiling err-derive v0.3.1
[INFO] [stderr]     Checking crossbeam-channel v0.5.12
[INFO] [stderr]     Checking dashmap v4.0.2
[INFO] [stderr]     Checking subtle v2.5.0
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking http v1.1.0
[INFO] [stderr]     Checking arc-swap v1.7.0
[INFO] [stderr]     Checking itertools v0.4.19
[INFO] [stderr]     Checking arrayvec v0.5.2
[INFO] [stderr]     Checking winnow v0.6.5
[INFO] [stderr]     Checking hexdump v0.1.1
[INFO] [stderr]     Checking http-body v1.0.0
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]    Compiling garage_util v0.9.3
[INFO] [stderr]     Checking rmp v0.8.12
[INFO] [stderr]     Checking no-std-net v0.6.0
[INFO] [stderr]     Checking pnet_base v0.33.0
[INFO] [stderr]     Checking sha2 v0.10.8
[INFO] [stderr]     Checking chrono v0.4.35
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]    Compiling synstructure v0.12.6
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]     Checking blake2 v0.10.6
[INFO] [stderr]     Checking pnet_sys v0.33.0
[INFO] [stderr]     Checking toml_datetime v0.6.5
[INFO] [stderr]     Checking serde_spanned v0.6.5
[INFO] [stderr]     Checking rmp-serde v1.1.2
[INFO] [stderr]     Checking ipnetwork v0.20.0
[INFO] [stderr]     Checking toml_edit v0.22.7
[INFO] [stderr]     Checking serde_json v1.0.114
[INFO] [stderr]     Checking bitflags v2.4.2
[INFO] [stderr]     Checking xxhash-rust v0.8.10
[INFO] [stderr]     Checking bytesize v1.3.0
[INFO] [stderr]     Checking nix v0.27.1
[INFO] [stderr]     Checking pnet_datalink v0.33.0
[INFO] [stderr]     Checking serde_bytes v0.11.14
[INFO] [stderr]     Checking gethostname v0.4.3
[INFO] [stderr]     Checking format_table v0.1.1
[INFO] [stderr]     Checking tokio-stream v0.1.14
[INFO] [stderr]     Checking tokio-util v0.7.10
[INFO] [stderr]     Checking hyper v1.2.0
[INFO] [stderr]     Checking opentelemetry v0.17.0
[INFO] [stderr]     Checking toml v0.8.11
[INFO] [stderr]     Checking garage_db v0.9.3
[INFO] [stderr]     Checking opentelemetry-contrib v0.9.0
[INFO] [stderr]     Checking kuska-sodiumoxide v0.2.5-0
[INFO] [stderr]     Checking kuska-handshake v0.2.0
[INFO] [stderr]     Checking garage_net v0.9.3
[INFO] [stderr]     Checking netapp v0.10.0
[INFO] [stderr]     Checking garage_rpc v0.9.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the item `Endpoint` is imported redundantly
[INFO] [stdout]   --> system.rs:19:24
[INFO] [stdout]    |
[INFO] [stdout] 19 | use netapp::endpoint::{Endpoint, EndpointHandler};
[INFO] [stdout]    |                        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `Endpoint` is already imported here
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `EndpointHandler` is imported redundantly
[INFO] [stdout]   --> system.rs:19:34
[INFO] [stdout]    |
[INFO] [stdout] 19 | use netapp::endpoint::{Endpoint, EndpointHandler};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `EndpointHandler` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `NetApp` is imported redundantly
[INFO] [stdout]   --> system.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 | use netapp::{NetApp, NetworkKey, NodeID, NodeKey};
[INFO] [stdout]    |              ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `NetApp` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `NodeID` is imported redundantly
[INFO] [stdout]   --> system.rs:23:34
[INFO] [stdout]    |
[INFO] [stdout] 23 | use netapp::{NetApp, NetworkKey, NodeID, NodeKey};
[INFO] [stdout]    |                                  ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `NodeID` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Error` is imported redundantly
[INFO] [stdout]     --> layout.rs:1135:14
[INFO] [stdout]      |
[INFO] [stdout] 1135 |     use super::{Error, *};
[INFO] [stdout]      |                 ^^^^^  - the item `Error` is already imported here
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Endpoint` is imported redundantly
[INFO] [stdout]   --> system.rs:19:24
[INFO] [stdout]    |
[INFO] [stdout] 19 | use netapp::endpoint::{Endpoint, EndpointHandler};
[INFO] [stdout]    |                        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `Endpoint` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `EndpointHandler` is imported redundantly
[INFO] [stdout]   --> system.rs:19:34
[INFO] [stdout]    |
[INFO] [stdout] 19 | use netapp::endpoint::{Endpoint, EndpointHandler};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `EndpointHandler` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `NetApp` is imported redundantly
[INFO] [stdout]   --> system.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 | use netapp::{NetApp, NetworkKey, NodeID, NodeKey};
[INFO] [stdout]    |              ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `NetApp` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `NodeID` is imported redundantly
[INFO] [stdout]   --> system.rs:23:34
[INFO] [stdout]    |
[INFO] [stdout] 23 | use netapp::{NetApp, NetworkKey, NodeID, NodeKey};
[INFO] [stdout]    |                                  ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 | use crate::rpc_helper::*;
[INFO] [stdout]    |     -------------------- the item `NodeID` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:186:63
[INFO] [stdout]     |
[INFO] [stdout] 186 |         let msg = msg.into_req().map_err(netapp::error::Error::from)?;
[INFO] [stdout]     |                                                                     ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<Vec<(garage_util::data::FixedBytes32, Result<S, garage_util::error::Error>)>, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<Vec<(garage_util::data::FixedBytes32, Result<S, garage_util::error::Error>)>, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:186:63
[INFO] [stdout]     |
[INFO] [stdout] 186 |         let msg = msg.into_req().map_err(netapp::error::Error::from)?;
[INFO] [stdout]     |                                                                     ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<Vec<(FixedBytes32, Result<S, garage_util::error::Error>)>, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<Vec<(FixedBytes32, Result<S, garage_util::error::Error>)>, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:159:18
[INFO] [stdout]     |
[INFO] [stdout] 159 |                 let res = res?.into_msg();
[INFO] [stdout]     |                              ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<S, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<S, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:159:18
[INFO] [stdout]     |
[INFO] [stdout] 159 |                 let res = res?.into_msg();
[INFO] [stdout]     |                              ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<S, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<S, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:277:63
[INFO] [stdout]     |
[INFO] [stdout] 277 |         let msg = msg.into_req().map_err(netapp::error::Error::from)?;
[INFO] [stdout]     |                                                                     ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<Vec<S>, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<Vec<S>, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `?` couldn't convert the error to `garage_util::error::Error`
[INFO] [stdout]    --> rpc_helper.rs:277:63
[INFO] [stdout]     |
[INFO] [stdout] 277 |         let msg = msg.into_req().map_err(netapp::error::Error::from)?;
[INFO] [stdout]     |                                                                     ^ the trait `From<netapp::error::Error>` is not implemented for `garage_util::error::Error`, which is required by `Result<Vec<S>, garage_util::error::Error>: FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
[INFO] [stdout]     = help: the following other types implement trait `From<T>`:
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::TxError<garage_util::error::Error>>>
[INFO] [stdout]               <garage_util::error::Error as From<hyper::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_db::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<serde_json::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<garage_net::error::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<toml::de::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::decode::Error>>
[INFO] [stdout]               <garage_util::error::Error as From<rmp_serde::encode::Error>>
[INFO] [stdout]             and 10 others
[INFO] [stdout]     = note: required for `Result<Vec<S>, garage_util::error::Error>` to implement `FromResidual<Result<Infallible, netapp::error::Error>>`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors; 4 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0277`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `garage_rpc` (lib) due to 4 previous errors; 4 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error: aborting due to 3 previous errors; 5 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0277`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `garage_rpc` (lib test) due to 4 previous errors; 5 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "28d48720f6115a9e92328cfe6aad8773c9c6539da5711c8958cee96b305f809b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "28d48720f6115a9e92328cfe6aad8773c9c6539da5711c8958cee96b305f809b", kill_on_drop: false }`
[INFO] [stdout] 28d48720f6115a9e92328cfe6aad8773c9c6539da5711c8958cee96b305f809b
