[INFO] fetching crate garage_rpc 0.9.0...
[INFO] checking garage_rpc-0.9.0 against master#30f74ff0dc4d66debc8b50724c446f817e5f75f4 for pr-121848-1
[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 30f74ff0dc4d66debc8b50724c446f817e5f75f4
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "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" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "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" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded netapp v0.10.0
[INFO] [stderr]   Downloaded rmp-serde v1.1.2
[INFO] [stderr]   Downloaded format_table v0.1.1
[INFO] [stderr]   Downloaded http-body v1.0.0
[INFO] [stderr]   Downloaded hexdump v0.1.1
[INFO] [stderr]   Downloaded pnet_base v0.33.0
[INFO] [stderr]   Downloaded dashmap v4.0.2
[INFO] [stderr]   Downloaded kube-derive v0.75.0
[INFO] [stderr]   Downloaded err-derive v0.3.1
[INFO] [stderr]   Downloaded opentelemetry-contrib v0.9.0
[INFO] [stderr]   Downloaded garage_util v0.9.3
[INFO] [stderr]   Downloaded garage_db v0.9.3
[INFO] [stderr]   Downloaded garage_net v0.9.3
[INFO] [stderr]   Downloaded itertools v0.4.19
[INFO] [stderr]   Downloaded kube-core v0.75.0
[INFO] [stderr]   Downloaded hyper v1.2.0
[INFO] [stderr]   Downloaded kube-client v0.75.0
[INFO] [stderr]   Downloaded kube-runtime v0.75.0
[INFO] [stderr]   Downloaded opentelemetry v0.17.0
[INFO] [stderr]   Downloaded pnet_datalink v0.33.0
[INFO] [stderr]   Downloaded kube v0.75.0
[INFO] [stderr]   Downloaded kuska-handshake v0.2.0
[INFO] [stderr]   Downloaded no-std-net v0.6.0
[INFO] [stderr]   Downloaded pnet_sys v0.33.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" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 15c0bd71f25ebd997f2d2e5d70312699c3e5c685134badd5ebaf89e670ed5222
[INFO] running `Command { std: "docker" "start" "-a" "15c0bd71f25ebd997f2d2e5d70312699c3e5c685134badd5ebaf89e670ed5222", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "15c0bd71f25ebd997f2d2e5d70312699c3e5c685134badd5ebaf89e670ed5222", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "15c0bd71f25ebd997f2d2e5d70312699c3e5c685134badd5ebaf89e670ed5222", kill_on_drop: false }`
[INFO] [stdout] 15c0bd71f25ebd997f2d2e5d70312699c3e5c685134badd5ebaf89e670ed5222
[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" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1913bd1ea9473b2f6090a3c5ea0d9f42cfdb664b32e87341d33be4853a267830
[INFO] running `Command { std: "docker" "start" "-a" "1913bd1ea9473b2f6090a3c5ea0d9f42cfdb664b32e87341d33be4853a267830", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde v1.0.197
[INFO] [stderr]     Checking futures-io v0.3.30
[INFO] [stderr]     Checking futures-channel v0.3.30
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking socket2 v0.5.6
[INFO] [stderr]     Checking mio v0.8.11
[INFO] [stderr]    Compiling serde_derive v1.0.197
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]    Compiling tokio-macros v2.2.0
[INFO] [stderr]     Checking signal-hook-registry v1.4.1
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling walkdir v2.5.0
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling thiserror-impl v1.0.58
[INFO] [stderr]    Compiling crossbeam-utils v0.8.19
[INFO] [stderr]    Compiling libsodium-sys v0.2.7
[INFO] [stderr]    Compiling err-derive v0.3.1
[INFO] [stderr]    Compiling pin-project-internal v1.1.5
[INFO] [stderr]     Checking tokio v1.37.0
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]    Compiling semver v1.0.22
[INFO] [stderr]    Compiling async-trait v0.1.79
[INFO] [stderr]     Checking thiserror v1.0.58
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking pin-project v1.1.5
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling synstructure v0.12.6
[INFO] [stderr]     Checking rmp v0.8.12
[INFO] [stderr]     Checking crossbeam-channel v0.5.12
[INFO] [stderr]     Checking dashmap v4.0.2
[INFO] [stderr]     Checking hex v0.4.3
[INFO] [stderr]    Compiling rustc_version v0.4.0
[INFO] [stderr]     Checking http v1.1.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]     Checking itertools v0.4.19
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]     Checking arc-swap v1.7.1
[INFO] [stderr]    Compiling garage_util v0.9.3
[INFO] [stderr]     Checking http-body v1.0.0
[INFO] [stderr]     Checking hexdump v0.1.1
[INFO] [stderr]     Checking no-std-net v0.6.0
[INFO] [stderr]     Checking pnet_base v0.33.0
[INFO] [stderr]     Checking chrono v0.4.37
[INFO] [stderr]     Checking blake2 v0.10.6
[INFO] [stderr]     Checking pnet_sys v0.33.0
[INFO] [stderr]     Checking bytesize v1.3.0
[INFO] [stderr]     Checking xxhash-rust v0.8.10
[INFO] [stderr]     Checking bitflags v2.5.0
[INFO] [stderr]     Checking gethostname v0.4.3
[INFO] [stderr]     Checking tokio-stream v0.1.15
[INFO] [stderr]     Checking tokio-util v0.7.10
[INFO] [stderr]     Checking hyper v1.2.0
[INFO] [stderr]     Checking nix v0.27.1
[INFO] [stderr]     Checking format_table v0.1.1
[INFO] [stderr]     Checking opentelemetry v0.17.0
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking garage_db v0.9.3
[INFO] [stderr]     Checking opentelemetry-contrib v0.9.0
[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.115
[INFO] [stderr]     Checking ipnetwork v0.20.0
[INFO] [stderr]     Checking serde_bytes v0.11.14
[INFO] [stderr]     Checking toml_edit v0.22.9
[INFO] [stderr]     Checking pnet_datalink v0.33.0
[INFO] [stderr]     Checking toml v0.8.12
[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] 
[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 `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 `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 `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; 5 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0277`.
[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 test) due to 4 previous errors; 5 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error: could not compile `garage_rpc` (lib) due to 4 previous errors; 4 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "1913bd1ea9473b2f6090a3c5ea0d9f42cfdb664b32e87341d33be4853a267830", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1913bd1ea9473b2f6090a3c5ea0d9f42cfdb664b32e87341d33be4853a267830", kill_on_drop: false }`
[INFO] [stdout] 1913bd1ea9473b2f6090a3c5ea0d9f42cfdb664b32e87341d33be4853a267830
[INFO] checking garage_rpc-0.9.0 against try#72eda894eb3548c7ba774079ce0afab42958d4ee for pr-121848-1
[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 72eda894eb3548c7ba774079ce0afab42958d4ee
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "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" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "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" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[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" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 09da54a76bbfe2f51ba760ff8f6299f3300ace6f770bb67b818eff31112a4d92
[INFO] running `Command { std: "docker" "start" "-a" "09da54a76bbfe2f51ba760ff8f6299f3300ace6f770bb67b818eff31112a4d92", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "09da54a76bbfe2f51ba760ff8f6299f3300ace6f770bb67b818eff31112a4d92", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "09da54a76bbfe2f51ba760ff8f6299f3300ace6f770bb67b818eff31112a4d92", kill_on_drop: false }`
[INFO] [stdout] 09da54a76bbfe2f51ba760ff8f6299f3300ace6f770bb67b818eff31112a4d92
[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" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 35087f2ca78f5764611893b30de1346bfa4c4c4fda20b136226956363c602273
[INFO] running `Command { std: "docker" "start" "-a" "35087f2ca78f5764611893b30de1346bfa4c4c4fda20b136226956363c602273", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde v1.0.197
[INFO] [stderr]     Checking futures-io v0.3.30
[INFO] [stderr]     Checking futures-channel v0.3.30
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking signal-hook-registry v1.4.1
[INFO] [stderr]     Checking mio v0.8.11
[INFO] [stderr]    Compiling serde_derive v1.0.197
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]    Compiling tokio-macros v2.2.0
[INFO] [stderr]     Checking socket2 v0.5.6
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling walkdir v2.5.0
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling thiserror-impl v1.0.58
[INFO] [stderr]    Compiling crossbeam-utils v0.8.19
[INFO] [stderr]    Compiling libsodium-sys v0.2.7
[INFO] [stderr]    Compiling err-derive v0.3.1
[INFO] [stderr]    Compiling pin-project-internal v1.1.5
[INFO] [stderr]     Checking tokio v1.37.0
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]    Compiling semver v1.0.22
[INFO] [stderr]     Checking thiserror v1.0.58
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]     Checking pin-project v1.1.5
[INFO] [stderr]    Compiling synstructure v0.12.6
[INFO] [stderr]    Compiling async-trait v0.1.79
[INFO] [stderr]     Checking rmp v0.8.12
[INFO] [stderr]     Checking crossbeam-channel v0.5.12
[INFO] [stderr]     Checking dashmap v4.0.2
[INFO] [stderr]     Checking hex v0.4.3
[INFO] [stderr]    Compiling rustc_version v0.4.0
[INFO] [stderr]     Checking http v1.1.0
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]     Checking itertools v0.4.19
[INFO] [stderr]     Checking arc-swap v1.7.1
[INFO] [stderr]    Compiling garage_util v0.9.3
[INFO] [stderr]     Checking no-std-net v0.6.0
[INFO] [stderr]     Checking pnet_base v0.33.0
[INFO] [stderr]     Checking chrono v0.4.37
[INFO] [stderr]     Checking hexdump v0.1.1
[INFO] [stderr]     Checking http-body v1.0.0
[INFO] [stderr]     Checking tokio-stream v0.1.15
[INFO] [stderr]     Checking tokio-util v0.7.10
[INFO] [stderr]     Checking blake2 v0.10.6
[INFO] [stderr]     Checking hyper v1.2.0
[INFO] [stderr]     Checking pnet_sys v0.33.0
[INFO] [stderr]     Checking bitflags v2.5.0
[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 gethostname v0.4.3
[INFO] [stderr]     Checking opentelemetry v0.17.0
[INFO] [stderr]     Checking format_table v0.1.1
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking garage_db v0.9.3
[INFO] [stderr]     Checking opentelemetry-contrib v0.9.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 serde_json v1.0.115
[INFO] [stderr]     Checking serde_bytes v0.11.14
[INFO] [stderr]     Checking toml_edit v0.22.9
[INFO] [stderr]     Checking pnet_datalink v0.33.0
[INFO] [stderr]     Checking toml v0.8.12
[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: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: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: 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] [stderr] warning: build failed, waiting for other jobs to finish...
[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] running `Command { std: "docker" "inspect" "35087f2ca78f5764611893b30de1346bfa4c4c4fda20b136226956363c602273", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "35087f2ca78f5764611893b30de1346bfa4c4c4fda20b136226956363c602273", kill_on_drop: false }`
[INFO] [stdout] 35087f2ca78f5764611893b30de1346bfa4c4c4fda20b136226956363c602273
