[INFO] fetching crate garage_rpc 0.9.0...
[INFO] checking garage_rpc-0.9.0 against master#80399064afa4a2cd153f30d02c25f7ea0383ed65 for opaque-soundness-fix
[INFO] extracting crate garage_rpc 0.9.0 into /workspace/builds/worker-0-tc1/source
[INFO] validating manifest of crates.io crate garage_rpc 0.9.0 on toolchain 80399064afa4a2cd153f30d02c25f7ea0383ed65
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+80399064afa4a2cd153f30d02c25f7ea0383ed65" "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-0-tc1/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+80399064afa4a2cd153f30d02c25f7ea0383ed65" "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" "+80399064afa4a2cd153f30d02c25f7ea0383ed65" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded pnet_datalink v0.33.0
[INFO] [stderr]   Downloaded ipnetwork v0.20.0
[INFO] [stderr]   Downloaded kube-runtime v0.75.0
[INFO] [stderr]   Downloaded pnet_base v0.33.0
[INFO] [stderr]   Downloaded kube v0.75.0
[INFO] [stderr]   Downloaded opentelemetry-contrib v0.9.0
[INFO] [stderr]   Downloaded http-range-header v0.3.1
[INFO] [stderr]   Downloaded format_table v0.1.1
[INFO] [stderr]   Downloaded gethostname v0.4.3
[INFO] [stderr]   Downloaded kube-derive v0.75.0
[INFO] [stderr]   Downloaded hexdump v0.1.1
[INFO] [stderr]   Downloaded garage_net v0.9.3
[INFO] [stderr]   Downloaded itertools v0.4.19
[INFO] [stderr]   Downloaded jsonpath_lib v0.3.0
[INFO] [stderr]   Downloaded garage_util v0.9.3
[INFO] [stderr]   Downloaded backoff v0.4.0
[INFO] [stderr]   Downloaded kube-core v0.75.0
[INFO] [stderr]   Downloaded kube-client v0.75.0
[INFO] [stderr]   Downloaded json-patch v0.2.7
[INFO] [stderr]   Downloaded treediff v3.0.2
[INFO] [stderr]   Downloaded tower-http v0.3.5
[INFO] [stderr]   Downloaded pnet_sys v0.33.0
[INFO] [stderr]   Downloaded k8s-openapi v0.16.0
[INFO] [stderr]   Downloaded garage_db v0.9.3
[INFO] [stderr]   Downloaded netapp v0.10.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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" "+80399064afa4a2cd153f30d02c25f7ea0383ed65" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] e23e6646d8d3561b4d0a123557e73ae4a723aa1922a7f15b0f109afb8ef8e42f
[INFO] running `Command { std: "docker" "start" "-a" "e23e6646d8d3561b4d0a123557e73ae4a723aa1922a7f15b0f109afb8ef8e42f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "e23e6646d8d3561b4d0a123557e73ae4a723aa1922a7f15b0f109afb8ef8e42f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e23e6646d8d3561b4d0a123557e73ae4a723aa1922a7f15b0f109afb8ef8e42f", kill_on_drop: false }`
[INFO] [stdout] e23e6646d8d3561b4d0a123557e73ae4a723aa1922a7f15b0f109afb8ef8e42f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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" "+80399064afa4a2cd153f30d02c25f7ea0383ed65" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 43f2da715f185e56adfddf5bbd42b725aea277aa42bf953e8b81e2b9d789b73a
[INFO] running `Command { std: "docker" "start" "-a" "43f2da715f185e56adfddf5bbd42b725aea277aa42bf953e8b81e2b9d789b73a", kill_on_drop: false }`
[INFO] [stderr]     Checking futures-io v0.3.30
[INFO] [stderr]     Checking memchr v2.7.1
[INFO] [stderr]     Checking futures-task v0.3.30
[INFO] [stderr]    Compiling rustversion v1.0.14
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]     Checking futures-channel v0.3.30
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking signal-hook-registry v1.4.1
[INFO] [stderr]     Checking getrandom v0.2.12
[INFO] [stderr]    Compiling tokio-macros v2.2.0
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]     Checking serde v1.0.197
[INFO] [stderr]    Compiling paste v1.0.14
[INFO] [stderr]    Compiling crossbeam-utils v0.8.19
[INFO] [stderr]    Compiling async-trait v0.1.78
[INFO] [stderr]    Compiling walkdir v2.5.0
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]    Compiling pin-project-internal v1.1.5
[INFO] [stderr]     Checking dashmap v4.0.2
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking hex v0.4.3
[INFO] [stderr]     Checking http v1.1.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]     Checking arrayvec v0.5.2
[INFO] [stderr]     Checking arc-swap v1.7.0
[INFO] [stderr]    Compiling libsodium-sys v0.2.7
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking itertools v0.4.19
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]     Checking winnow v0.6.5
[INFO] [stderr]     Checking crossbeam-channel v0.5.12
[INFO] [stderr]     Checking http-body v1.0.0
[INFO] [stderr]    Compiling garage_util v0.9.3
[INFO] [stderr]     Checking hexdump v0.1.1
[INFO] [stderr]     Checking no-std-net v0.6.0
[INFO] [stderr]     Checking iana-time-zone v0.1.60
[INFO] [stderr]     Checking pnet_base v0.33.0
[INFO] [stderr]     Checking blake2 v0.10.6
[INFO] [stderr]     Checking pnet_sys v0.33.0
[INFO] [stderr]     Checking xxhash-rust v0.8.10
[INFO] [stderr]    Compiling err-derive v0.3.1
[INFO] [stderr]     Checking bitflags v2.5.0
[INFO] [stderr]     Checking tokio v1.36.0
[INFO] [stderr]     Checking bytesize v1.3.0
[INFO] [stderr]     Checking either v1.10.0
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]     Checking nix v0.27.1
[INFO] [stderr]     Checking gethostname v0.4.3
[INFO] [stderr]     Checking format_table v0.1.1
[INFO] [stderr]     Checking itertools v0.10.5
[INFO] [stderr]     Checking rmp v0.8.12
[INFO] [stderr]     Checking chrono v0.4.35
[INFO] [stderr]     Checking pin-project v1.1.5
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking garage_db v0.9.3
[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.114
[INFO] [stderr]     Checking serde_bytes v0.11.14
[INFO] [stderr]     Checking pnet_datalink v0.33.0
[INFO] [stderr]     Checking toml_edit v0.22.9
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]     Checking toml v0.8.12
[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 opentelemetry v0.17.0
[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<(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: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: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; 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" "43f2da715f185e56adfddf5bbd42b725aea277aa42bf953e8b81e2b9d789b73a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "43f2da715f185e56adfddf5bbd42b725aea277aa42bf953e8b81e2b9d789b73a", kill_on_drop: false }`
[INFO] [stdout] 43f2da715f185e56adfddf5bbd42b725aea277aa42bf953e8b81e2b9d789b73a
