[INFO] cloning repository https://github.com/Lovepreet67/whispering-woods
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Lovepreet67/whispering-woods" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FLovepreet67%2Fwhispering-woods", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FLovepreet67%2Fwhispering-woods'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] e203d236ddb977473b873a7425e30ce37dc14e57
[INFO] testing Lovepreet67/whispering-woods against master#1ef7943ee607160a564655b6596f83670ef95df5 for pr-146098-6
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FLovepreet67%2Fwhispering-woods" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Lovepreet67/whispering-woods
[INFO] finished tweaking git repo https://github.com/Lovepreet67/whispering-woods
[INFO] tweaked toml for git repo https://github.com/Lovepreet67/whispering-woods written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Lovepreet67/whispering-woods on toolchain 1ef7943ee607160a564655b6596f83670ef95df5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Lovepreet67/whispering-woods already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: virtual workspace defaulting to `resolver = "1"` despite one or more workspace members being on edition 2024 which implies `resolver = "3"`
[INFO] [stderr]   |
[INFO] [stderr]   = note: to keep the current resolver, specify `workspace.resolver = "1"` in the workspace root's manifest
[INFO] [stderr]   = note: to use the edition 2024 resolver, specify `workspace.resolver = "3"` in the workspace root's manifest
[INFO] [stderr]   = note: for more details see https://doc.rust-lang.org/cargo/reference/resolver.html#resolver-versions
[INFO] [stderr] warning: /workspace/builds/worker-1-tc1/source/Cargo.toml: unused manifest key: resolver
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded asn1-rs-derive v0.6.0
[INFO] [stderr]   Downloaded unicase_serde v0.1.0
[INFO] [stderr]   Downloaded oid-registry v0.8.1
[INFO] [stderr]   Downloaded devise v0.4.2
[INFO] [stderr]   Downloaded devise_codegen v0.4.2
[INFO] [stderr]   Downloaded opentelemetry-http v0.9.0
[INFO] [stderr]   Downloaded cc v1.2.38
[INFO] [stderr]   Downloaded atomic v0.6.1
[INFO] [stderr]   Downloaded devise_core v0.4.2
[INFO] [stderr]   Downloaded tonic-build v0.13.1
[INFO] [stderr]   Downloaded opentelemetry v0.20.0
[INFO] [stderr]   Downloaded opentelemetry-semantic-conventions v0.12.0
[INFO] [stderr]   Downloaded axum-core v0.5.2
[INFO] [stderr]   Downloaded der-parser v10.0.0
[INFO] [stderr]   Downloaded multer v3.1.0
[INFO] [stderr]   Downloaded tempfile v3.19.1
[INFO] [stderr]   Downloaded opentelemetry-otlp v0.13.0
[INFO] [stderr]   Downloaded opentelemetry_api v0.20.0
[INFO] [stderr]   Downloaded rcgen v0.14.4
[INFO] [stderr]   Downloaded asn1-rs v0.7.1
[INFO] [stderr]   Downloaded figment v0.10.19
[INFO] [stderr]   Downloaded opentelemetry_sdk v0.20.0
[INFO] [stderr]   Downloaded prettyplease v0.2.32
[INFO] [stderr]   Downloaded hyper-util v0.1.11
[INFO] [stderr]   Downloaded rocket_http v0.5.1
[INFO] [stderr]   Downloaded rocket_codegen v0.5.1
[INFO] [stderr]   Downloaded tonic v0.13.1
[INFO] [stderr]   Downloaded tracing-opentelemetry v0.21.0
[INFO] [stderr]   Downloaded opentelemetry-proto v0.3.0
[INFO] [stderr]   Downloaded axum v0.8.4
[INFO] [stderr]   Downloaded x509-parser v0.18.0
[INFO] [stderr]   Downloaded rocket_cors v0.6.0
[INFO] [stderr]   Downloaded rocket v0.5.1
[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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 05a3b42e4e5044552fa1f346ffe6ea979673c89ab1ee04ddbe6ed8284de0118e
[INFO] running `Command { std: "docker" "start" "-a" "05a3b42e4e5044552fa1f346ffe6ea979673c89ab1ee04ddbe6ed8284de0118e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "05a3b42e4e5044552fa1f346ffe6ea979673c89ab1ee04ddbe6ed8284de0118e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "05a3b42e4e5044552fa1f346ffe6ea979673c89ab1ee04ddbe6ed8284de0118e", kill_on_drop: false }`
[INFO] [stdout] 05a3b42e4e5044552fa1f346ffe6ea979673c89ab1ee04ddbe6ed8284de0118e
[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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 874212b30f10e83d27d5bad4bcbb71b0d3074d9e6f45913132f1e4c46625b0a8
[INFO] running `Command { std: "docker" "start" "-a" "874212b30f10e83d27d5bad4bcbb71b0d3074d9e6f45913132f1e4c46625b0a8", kill_on_drop: false }`
[INFO] [stderr] warning: virtual workspace defaulting to `resolver = "1"` despite one or more workspace members being on edition 2024 which implies `resolver = "3"`
[INFO] [stderr]   |
[INFO] [stderr]   = note: to keep the current resolver, specify `workspace.resolver = "1"` in the workspace root's manifest
[INFO] [stderr]   = note: to use the edition 2024 resolver, specify `workspace.resolver = "3"` in the workspace root's manifest
[INFO] [stderr]   = note: for more details see https://doc.rust-lang.org/cargo/reference/resolver.html#resolver-versions
[INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: unused manifest key: resolver
[INFO] [stderr]    Compiling libc v0.2.174
[INFO] [stderr]    Compiling smallvec v1.15.0
[INFO] [stderr]    Compiling hashbrown v0.15.3
[INFO] [stderr]    Compiling tracing-core v0.1.33
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling log v0.4.27
[INFO] [stderr]    Compiling powerfmt v0.2.0
[INFO] [stderr]    Compiling anyhow v1.0.98
[INFO] [stderr]    Compiling tracing-attributes v0.1.28
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling regex-syntax v0.8.5
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling num-conv v0.1.0
[INFO] [stderr]    Compiling time-core v0.1.4
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling deranged v0.4.0
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling time-macros v0.2.22
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]    Compiling serde_json v1.0.143
[INFO] [stderr]    Compiling proc-macro2-diagnostics v0.10.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling getrandom v0.3.2
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling indexmap v2.9.0
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]    Compiling rustix v1.0.7
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling time v0.3.41
[INFO] [stderr]    Compiling urlencoding v2.1.3
[INFO] [stderr]    Compiling thiserror v2.0.16
[INFO] [stderr]    Compiling thiserror-impl v2.0.16
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling signal-hook-registry v1.4.5
[INFO] [stderr]    Compiling mio v1.0.3
[INFO] [stderr]    Compiling socket2 v0.5.9
[INFO] [stderr]    Compiling parking_lot v0.12.3
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling is-terminal v0.4.16
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling yansi v1.0.1
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling yoke v0.8.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling tokio v1.45.0
[INFO] [stderr]    Compiling zerovec v0.11.2
[INFO] [stderr]    Compiling zerotrie v0.2.2
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling prost-derive v0.13.5
[INFO] [stderr]    Compiling pin-project v1.1.10
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling find-msvc-tools v0.1.2
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling cc v1.2.38
[INFO] [stderr]    Compiling axum-core v0.3.4
[INFO] [stderr]    Compiling tempfile v3.19.1
[INFO] [stderr]    Compiling ordered-float v3.9.2
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling opentelemetry_api v0.20.0
[INFO] [stderr]    Compiling uncased v0.9.10
[INFO] [stderr]    Compiling prettyplease v0.2.32
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling tinystr v0.8.1
[INFO] [stderr]    Compiling potential_utf v0.1.2
[INFO] [stderr]    Compiling pear_codegen v0.2.9
[INFO] [stderr]    Compiling icu_collections v2.0.0
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling axum v0.6.20
[INFO] [stderr]    Compiling regex-syntax v0.6.29
[INFO] [stderr]    Compiling icu_locale_core v2.0.0
[INFO] [stderr]    Compiling inlinable_string v0.1.15
[INFO] [stderr]    Compiling fixedbitset v0.5.7
[INFO] [stderr]    Compiling petgraph v0.7.1
[INFO] [stderr]    Compiling pear v0.2.9
[INFO] [stderr]    Compiling inout v0.1.4
[INFO] [stderr]    Compiling asn1-rs-derive v0.6.0
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling prost v0.13.5
[INFO] [stderr]    Compiling icu_provider v2.0.0
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling prost-types v0.13.5
[INFO] [stderr]    Compiling icu_normalizer v2.0.0
[INFO] [stderr]    Compiling icu_properties v2.0.1
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling asn1-rs-impl v0.2.0
[INFO] [stderr]    Compiling cpufeatures v0.2.17
[INFO] [stderr]    Compiling matchit v0.7.3
[INFO] [stderr]    Compiling toml_write v0.1.2
[INFO] [stderr]    Compiling multimap v0.10.0
[INFO] [stderr]    Compiling winnow v0.7.13
[INFO] [stderr]    Compiling universal-hash v0.5.1
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling regex-automata v0.1.10
[INFO] [stderr]    Compiling rusticata-macros v4.1.0
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling cipher v0.4.4
[INFO] [stderr]    Compiling axum-core v0.5.2
[INFO] [stderr]    Compiling tracing-serde v0.2.0
[INFO] [stderr]    Compiling asn1-rs v0.7.1
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling thread_local v1.1.8
[INFO] [stderr]    Compiling cookie v0.18.1
[INFO] [stderr]    Compiling figment v0.10.19
[INFO] [stderr]    Compiling prost-build v0.13.5
[INFO] [stderr]    Compiling oid-registry v0.8.1
[INFO] [stderr]    Compiling matchers v0.1.0
[INFO] [stderr]    Compiling unsafe-libyaml v0.2.11
[INFO] [stderr]    Compiling prost-derive v0.11.9
[INFO] [stderr]    Compiling ref-cast v1.0.24
[INFO] [stderr]    Compiling polyval v0.6.2
[INFO] [stderr]    Compiling tracing-subscriber v0.3.19
[INFO] [stderr]    Compiling pem v3.0.5
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling devise_core v0.4.2
[INFO] [stderr]    Compiling tonic-build v0.13.1
[INFO] [stderr]    Compiling serde_yaml v0.9.34+deprecated
[INFO] [stderr]    Compiling ref-cast-impl v1.0.24
[INFO] [stderr]    Compiling der-parser v10.0.0
[INFO] [stderr]    Compiling ghash v0.5.1
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling tokio-util v0.7.15
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling tokio-io-timeout v1.2.0
[INFO] [stderr]    Compiling ctr v0.9.2
[INFO] [stderr]    Compiling aes v0.8.4
[INFO] [stderr]    Compiling simple_asn1 v0.6.3
[INFO] [stderr]    Compiling aead v0.5.2
[INFO] [stderr]    Compiling tracing-log v0.1.4
[INFO] [stderr]    Compiling stable-pattern v0.1.0
[INFO] [stderr]    Compiling multer v3.1.0
[INFO] [stderr]    Compiling state v0.6.0
[INFO] [stderr]    Compiling h2 v0.3.26
[INFO] [stderr]    Compiling h2 v0.4.10
[INFO] [stderr]    Compiling opentelemetry_sdk v0.20.0
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling prost v0.11.9
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling devise_codegen v0.4.2
[INFO] [stderr]    Compiling data-encoding v2.9.0
[INFO] [stderr]    Compiling proto v0.1.0 (/opt/rustwide/workdir/proto)
[INFO] [stderr]    Compiling tracing-appender v0.2.3
[INFO] [stderr]    Compiling x509-parser v0.18.0
[INFO] [stderr]    Compiling devise v0.4.2
[INFO] [stderr]    Compiling aes-gcm v0.10.3
[INFO] [stderr]    Compiling nix v0.30.1
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling jsonwebtoken v9.3.1
[INFO] [stderr]    Compiling webpki v0.22.4
[INFO] [stderr]    Compiling axum v0.8.4
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling rocket v0.5.1
[INFO] [stderr]    Compiling glob v0.3.3
[INFO] [stderr]    Compiling unicode-xid v0.2.6
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling num_cpus v1.17.0
[INFO] [stderr]    Compiling ubyte v0.10.4
[INFO] [stderr]    Compiling binascii v0.1.4
[INFO] [stderr]    Compiling unicase v2.8.1
[INFO] [stderr]    Compiling atomic v0.5.3
[INFO] [stderr]    Compiling rustls-pki-types v1.12.0
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling unicase_serde v0.1.0
[INFO] [stderr]    Compiling yasna v0.5.2
[INFO] [stderr]    Compiling uuid v1.17.0
[INFO] [stderr]    Compiling opentelemetry v0.20.0
[INFO] [stderr]    Compiling opentelemetry-semantic-conventions v0.12.0
[INFO] [stderr]    Compiling tracing-opentelemetry v0.21.0
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling rcgen v0.14.4
[INFO] [stderr]    Compiling hyper v1.6.0
[INFO] [stderr]    Compiling storage v0.1.0 (/opt/rustwide/workdir/storage)
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]  --> storage/src/storage.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 |     async fn write(
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout]   = note: `#[warn(async_fn_in_trait)]` on by default
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]   |
[INFO] [stdout] 7 ~     fn write(
[INFO] [stdout] 8 |         &self,
[INFO] [stdout] 9 |         chunk_id: String,
[INFO] [stdout] 10|         chunk_stream: &mut (impl io::AsyncRead + Unpin),
[INFO] [stdout] 11~     ) -> impl std::future::Future<Output = Result<u64>> + Send;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     async fn commit(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 12 -     async fn commit(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout] 12 +     fn commit(&self, chunk_id: String) -> impl std::future::Future<Output = Result<bool>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 |     async fn read(&self, chunk_id: String) -> Result<Box<dyn io::AsyncRead + Unpin + Send>>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 13 -     async fn read(&self, chunk_id: String) -> Result<Box<dyn io::AsyncRead + Unpin + Send>>;
[INFO] [stdout] 13 +     fn read(&self, chunk_id: String) -> impl std::future::Future<Output = Result<Box<dyn io::AsyncRead + Unpin + Send>>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     async fn delete(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 14 -     async fn delete(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout] 14 +     fn delete(&self, chunk_id: String) -> impl std::future::Future<Output = Result<bool>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     async fn available_chunks(&self) -> Result<Vec<String>>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 15 -     async fn available_chunks(&self) -> Result<Vec<String>>;
[INFO] [stdout] 15 +     fn available_chunks(&self) -> impl std::future::Future<Output = Result<Vec<String>>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     async fn get_chunk_size(&self, chunk_id: &str) -> Result<u64>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 16 -     async fn get_chunk_size(&self, chunk_id: &str) -> Result<u64>;
[INFO] [stdout] 16 +     fn get_chunk_size(&self, chunk_id: &str) -> impl std::future::Future<Output = Result<u64>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling hyper-util v0.1.11
[INFO] [stderr]    Compiling hyper-timeout v0.5.2
[INFO] [stderr]    Compiling tonic v0.13.1
[INFO] [stderr]    Compiling hyper-timeout v0.4.1
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling rocket_http v0.5.1
[INFO] [stderr]    Compiling opentelemetry-http v0.9.0
[INFO] [stderr]    Compiling rocket_codegen v0.5.1
[INFO] [stderr]    Compiling tonic v0.9.2
[INFO] [stderr]    Compiling opentelemetry-proto v0.3.0
[INFO] [stderr]    Compiling opentelemetry-otlp v0.13.0
[INFO] [stderr]    Compiling utilities v0.1.0 (/opt/rustwide/workdir/utilities)
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> utilities/src/state_logger.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tracing::{info, trace};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> utilities/src/ticket/ticket_generator.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use tracing::{debug, info};
[INFO] [stdout]   |                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling client v0.1.0 (/opt/rustwide/workdir/client)
[INFO] [stderr]    Compiling datanode v0.1.0 (/opt/rustwide/workdir/datanode)
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> client/src/main.rs:12:32
[INFO] [stdout]    |
[INFO] [stdout] 12 |     ticket::ticket_decrypter::{self, DefaultTicketDecrypter, TicketDecrypter},
[INFO] [stdout]    |                                ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> client/src/datanode_service.rs:36:26
[INFO] [stdout]    |
[INFO] [stdout] 36 |         mut read_stream: (impl AsyncRead + Unpin),
[INFO] [stdout]    |                          ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 36 -         mut read_stream: (impl AsyncRead + Unpin),
[INFO] [stdout] 36 +         mut read_stream: impl AsyncRead + Unpin ,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Status`
[INFO] [stdout]  --> datanode/src/grpc/ticket.rs:2:13
[INFO] [stdout]   |
[INFO] [stdout] 2 | use tonic::{Status, service::Interceptor};
[INFO] [stdout]   |             ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> client/src/chunk_joiner.rs:54:9
[INFO] [stdout]    |
[INFO] [stdout] 54 |         tokio::fs::remove_file(&self.file_path).await;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 54 |         let _ = tokio::fs::remove_file(&self.file_path).await;
[INFO] [stdout]    |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> datanode/src/tcp/service.rs:139:25
[INFO] [stdout]     |
[INFO] [stdout] 139 |                         stream1.write_u64(bytes_received).await;
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 139 |                         let _ = stream1.write_u64(bytes_received).await;
[INFO] [stdout]     |                         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> datanode/src/tcp/stream_tee.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |             tx1.shutdown().await;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 31 |             let _ = tx1.shutdown().await;
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> datanode/src/tcp/stream_tee.rs:32:13
[INFO] [stdout]    |
[INFO] [stdout] 32 |             tx2.shutdown().await;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 32 |             let _ = tx2.shutdown().await;
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling rocket_cors v0.6.0
[INFO] [stderr]    Compiling namenode v0.1.0 (/opt/rustwide/workdir/namenode)
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> namenode/src/namenode_state/chunk_details.rs:22:20
[INFO] [stdout]    |
[INFO] [stdout] 22 |     Undereplicated(u8),
[INFO] [stdout]    |     -------------- ^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ChunkReplicationStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 22 -     Undereplicated(u8),
[INFO] [stdout] 22 +     Undereplicated(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 21s
[INFO] running `Command { std: "docker" "inspect" "874212b30f10e83d27d5bad4bcbb71b0d3074d9e6f45913132f1e4c46625b0a8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "874212b30f10e83d27d5bad4bcbb71b0d3074d9e6f45913132f1e4c46625b0a8", kill_on_drop: false }`
[INFO] [stdout] 874212b30f10e83d27d5bad4bcbb71b0d3074d9e6f45913132f1e4c46625b0a8
[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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2a4ff0ea4580fcd61ad8dd7eb8a4fe68bc4ccd99af96aa8774bd1164e97ad425
[INFO] running `Command { std: "docker" "start" "-a" "2a4ff0ea4580fcd61ad8dd7eb8a4fe68bc4ccd99af96aa8774bd1164e97ad425", kill_on_drop: false }`
[INFO] [stderr] warning: virtual workspace defaulting to `resolver = "1"` despite one or more workspace members being on edition 2024 which implies `resolver = "3"`
[INFO] [stderr]   |
[INFO] [stderr]   = note: to keep the current resolver, specify `workspace.resolver = "1"` in the workspace root's manifest
[INFO] [stderr]   = note: to use the edition 2024 resolver, specify `workspace.resolver = "3"` in the workspace root's manifest
[INFO] [stderr]   = note: for more details see https://doc.rust-lang.org/cargo/reference/resolver.html#resolver-versions
[INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: unused manifest key: resolver
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> utilities/src/state_logger.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tracing::{info, trace};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> utilities/src/ticket/ticket_generator.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use tracing::{debug, info};
[INFO] [stdout]   |                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling client v0.1.0 (/opt/rustwide/workdir/client)
[INFO] [stderr]    Compiling utilities v0.1.0 (/opt/rustwide/workdir/utilities)
[INFO] [stderr]    Compiling proto v0.1.0 (/opt/rustwide/workdir/proto)
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]  --> storage/src/storage.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 |     async fn write(
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout]   = note: `#[warn(async_fn_in_trait)]` on by default
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]   |
[INFO] [stdout] 7 ~     fn write(
[INFO] [stdout] 8 |         &self,
[INFO] [stdout] 9 |         chunk_id: String,
[INFO] [stdout] 10|         chunk_stream: &mut (impl io::AsyncRead + Unpin),
[INFO] [stdout] 11~     ) -> impl std::future::Future<Output = Result<u64>> + Send;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     async fn commit(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 12 -     async fn commit(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout] 12 +     fn commit(&self, chunk_id: String) -> impl std::future::Future<Output = Result<bool>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 |     async fn read(&self, chunk_id: String) -> Result<Box<dyn io::AsyncRead + Unpin + Send>>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 13 -     async fn read(&self, chunk_id: String) -> Result<Box<dyn io::AsyncRead + Unpin + Send>>;
[INFO] [stdout] 13 +     fn read(&self, chunk_id: String) -> impl std::future::Future<Output = Result<Box<dyn io::AsyncRead + Unpin + Send>>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     async fn delete(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 14 -     async fn delete(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout] 14 +     fn delete(&self, chunk_id: String) -> impl std::future::Future<Output = Result<bool>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     async fn available_chunks(&self) -> Result<Vec<String>>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 15 -     async fn available_chunks(&self) -> Result<Vec<String>>;
[INFO] [stdout] 15 +     fn available_chunks(&self) -> impl std::future::Future<Output = Result<Vec<String>>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     async fn get_chunk_size(&self, chunk_id: &str) -> Result<u64>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 16 -     async fn get_chunk_size(&self, chunk_id: &str) -> Result<u64>;
[INFO] [stdout] 16 +     fn get_chunk_size(&self, chunk_id: &str) -> impl std::future::Future<Output = Result<u64>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling storage v0.1.0 (/opt/rustwide/workdir/storage)
[INFO] [stderr]    Compiling datanode v0.1.0 (/opt/rustwide/workdir/datanode)
[INFO] [stderr]    Compiling namenode v0.1.0 (/opt/rustwide/workdir/namenode)
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> utilities/src/state_logger.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tracing::{info, trace};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> utilities/src/ticket/ticket_generator.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use tracing::{debug, info};
[INFO] [stdout]   |                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]  --> storage/src/storage.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 |     async fn write(
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout]   = note: `#[warn(async_fn_in_trait)]` on by default
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]   |
[INFO] [stdout] 7 ~     fn write(
[INFO] [stdout] 8 |         &self,
[INFO] [stdout] 9 |         chunk_id: String,
[INFO] [stdout] 10|         chunk_stream: &mut (impl io::AsyncRead + Unpin),
[INFO] [stdout] 11~     ) -> impl std::future::Future<Output = Result<u64>> + Send;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     async fn commit(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 12 -     async fn commit(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout] 12 +     fn commit(&self, chunk_id: String) -> impl std::future::Future<Output = Result<bool>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 |     async fn read(&self, chunk_id: String) -> Result<Box<dyn io::AsyncRead + Unpin + Send>>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 13 -     async fn read(&self, chunk_id: String) -> Result<Box<dyn io::AsyncRead + Unpin + Send>>;
[INFO] [stdout] 13 +     fn read(&self, chunk_id: String) -> impl std::future::Future<Output = Result<Box<dyn io::AsyncRead + Unpin + Send>>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     async fn delete(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 14 -     async fn delete(&self, chunk_id: String) -> Result<bool>;
[INFO] [stdout] 14 +     fn delete(&self, chunk_id: String) -> impl std::future::Future<Output = Result<bool>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     async fn available_chunks(&self) -> Result<Vec<String>>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 15 -     async fn available_chunks(&self) -> Result<Vec<String>>;
[INFO] [stdout] 15 +     fn available_chunks(&self) -> impl std::future::Future<Output = Result<Vec<String>>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stdout]   --> storage/src/storage.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     async fn get_chunk_size(&self, chunk_id: &str) -> Result<u64>;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stdout]    |
[INFO] [stdout] 16 -     async fn get_chunk_size(&self, chunk_id: &str) -> Result<u64>;
[INFO] [stdout] 16 +     fn get_chunk_size(&self, chunk_id: &str) -> impl std::future::Future<Output = Result<u64>> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> client/src/main.rs:12:32
[INFO] [stdout]    |
[INFO] [stdout] 12 |     ticket::ticket_decrypter::{self, DefaultTicketDecrypter, TicketDecrypter},
[INFO] [stdout]    |                                ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> client/src/datanode_service.rs:36:26
[INFO] [stdout]    |
[INFO] [stdout] 36 |         mut read_stream: (impl AsyncRead + Unpin),
[INFO] [stdout]    |                          ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 36 -         mut read_stream: (impl AsyncRead + Unpin),
[INFO] [stdout] 36 +         mut read_stream: impl AsyncRead + Unpin ,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Status`
[INFO] [stdout]  --> datanode/src/grpc/ticket.rs:2:13
[INFO] [stdout]   |
[INFO] [stdout] 2 | use tonic::{Status, service::Interceptor};
[INFO] [stdout]   |             ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> client/src/chunk_joiner.rs:54:9
[INFO] [stdout]    |
[INFO] [stdout] 54 |         tokio::fs::remove_file(&self.file_path).await;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 54 |         let _ = tokio::fs::remove_file(&self.file_path).await;
[INFO] [stdout]    |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> namenode/src/namenode_state/chunk_details.rs:22:20
[INFO] [stdout]    |
[INFO] [stdout] 22 |     Undereplicated(u8),
[INFO] [stdout]    |     -------------- ^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ChunkReplicationStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 22 -     Undereplicated(u8),
[INFO] [stdout] 22 +     Undereplicated(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> datanode/src/tcp/service.rs:139:25
[INFO] [stdout]     |
[INFO] [stdout] 139 |                         stream1.write_u64(bytes_received).await;
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 139 |                         let _ = stream1.write_u64(bytes_received).await;
[INFO] [stdout]     |                         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> datanode/src/tcp/stream_tee.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |             tx1.shutdown().await;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 31 |             let _ = tx1.shutdown().await;
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> datanode/src/tcp/stream_tee.rs:32:13
[INFO] [stdout]    |
[INFO] [stdout] 32 |             tx2.shutdown().await;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 32 |             let _ = tx2.shutdown().await;
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 5.60s
[INFO] running `Command { std: "docker" "inspect" "2a4ff0ea4580fcd61ad8dd7eb8a4fe68bc4ccd99af96aa8774bd1164e97ad425", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2a4ff0ea4580fcd61ad8dd7eb8a4fe68bc4ccd99af96aa8774bd1164e97ad425", kill_on_drop: false }`
[INFO] [stdout] 2a4ff0ea4580fcd61ad8dd7eb8a4fe68bc4ccd99af96aa8774bd1164e97ad425
[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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 2e058a0d5b276e9013ea19204b3dcfa399efdf064f6ac906536dbef9c80a58de
[INFO] running `Command { std: "docker" "start" "-a" "2e058a0d5b276e9013ea19204b3dcfa399efdf064f6ac906536dbef9c80a58de", kill_on_drop: false }`
[INFO] [stderr] warning: virtual workspace defaulting to `resolver = "1"` despite one or more workspace members being on edition 2024 which implies `resolver = "3"`
[INFO] [stderr]   |
[INFO] [stderr]   = note: to keep the current resolver, specify `workspace.resolver = "1"` in the workspace root's manifest
[INFO] [stderr]   = note: to use the edition 2024 resolver, specify `workspace.resolver = "3"` in the workspace root's manifest
[INFO] [stderr]   = note: for more details see https://doc.rust-lang.org/cargo/reference/resolver.html#resolver-versions
[INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: unused manifest key: resolver
[INFO] [stderr] warning: unused import: `info`
[INFO] [stderr]  --> utilities/src/state_logger.rs:6:15
[INFO] [stderr]   |
[INFO] [stderr] 6 | use tracing::{info, trace};
[INFO] [stderr]   |               ^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `info`
[INFO] [stderr]  --> utilities/src/ticket/ticket_generator.rs:8:22
[INFO] [stderr]   |
[INFO] [stderr] 8 | use tracing::{debug, info};
[INFO] [stderr]   |                      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `utilities` (lib) generated 2 warnings (run `cargo fix --lib -p utilities` to apply 2 suggestions)
[INFO] [stderr] warning: unused import: `self`
[INFO] [stderr]   --> client/src/main.rs:12:32
[INFO] [stderr]    |
[INFO] [stderr] 12 |     ticket::ticket_decrypter::{self, DefaultTicketDecrypter, TicketDecrypter},
[INFO] [stderr]    |                                ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around type
[INFO] [stderr]   --> client/src/datanode_service.rs:36:26
[INFO] [stderr]    |
[INFO] [stderr] 36 |         mut read_stream: (impl AsyncRead + Unpin),
[INFO] [stderr]    |                          ^                      ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 36 -         mut read_stream: (impl AsyncRead + Unpin),
[INFO] [stderr] 36 +         mut read_stream: impl AsyncRead + Unpin ,
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]   --> client/src/chunk_joiner.rs:54:9
[INFO] [stderr]    |
[INFO] [stderr] 54 |         tokio::fs::remove_file(&self.file_path).await;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]    |
[INFO] [stderr] 54 |         let _ = tokio::fs::remove_file(&self.file_path).await;
[INFO] [stderr]    |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `client` (bin "client" test) generated 3 warnings (run `cargo fix --bin "client" -p client --tests` to apply 2 suggestions)
[INFO] [stderr] warning: `utilities` (lib test) generated 2 warnings (2 duplicates)
[INFO] [stderr] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stderr]  --> storage/src/storage.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 |     async fn write(
[INFO] [stderr]   |     ^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stderr]   = note: `#[warn(async_fn_in_trait)]` on by default
[INFO] [stderr] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stderr]   |
[INFO] [stderr] 7 ~     fn write(
[INFO] [stderr] 8 |         &self,
[INFO] [stderr] 9 |         chunk_id: String,
[INFO] [stderr] 10|         chunk_stream: &mut (impl io::AsyncRead + Unpin),
[INFO] [stderr] 11~     ) -> impl std::future::Future<Output = Result<u64>> + Send;
[INFO] [stderr]   |
[INFO] [stderr] 
[INFO] [stderr] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stderr]   --> storage/src/storage.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 12 |     async fn commit(&self, chunk_id: String) -> Result<bool>;
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stderr] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stderr]    |
[INFO] [stderr] 12 -     async fn commit(&self, chunk_id: String) -> Result<bool>;
[INFO] [stderr] 12 +     fn commit(&self, chunk_id: String) -> impl std::future::Future<Output = Result<bool>> + Send;
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stderr]   --> storage/src/storage.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 |     async fn read(&self, chunk_id: String) -> Result<Box<dyn io::AsyncRead + Unpin + Send>>;
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stderr] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stderr]    |
[INFO] [stderr] 13 -     async fn read(&self, chunk_id: String) -> Result<Box<dyn io::AsyncRead + Unpin + Send>>;
[INFO] [stderr] 13 +     fn read(&self, chunk_id: String) -> impl std::future::Future<Output = Result<Box<dyn io::AsyncRead + Unpin + Send>>> + Send;
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stderr]   --> storage/src/storage.rs:14:5
[INFO] [stderr]    |
[INFO] [stderr] 14 |     async fn delete(&self, chunk_id: String) -> Result<bool>;
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stderr] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stderr]    |
[INFO] [stderr] 14 -     async fn delete(&self, chunk_id: String) -> Result<bool>;
[INFO] [stderr] 14 +     fn delete(&self, chunk_id: String) -> impl std::future::Future<Output = Result<bool>> + Send;
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stderr]   --> storage/src/storage.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 |     async fn available_chunks(&self) -> Result<Vec<String>>;
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stderr] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stderr]    |
[INFO] [stderr] 15 -     async fn available_chunks(&self) -> Result<Vec<String>>;
[INFO] [stderr] 15 +     fn available_chunks(&self) -> impl std::future::Future<Output = Result<Vec<String>>> + Send;
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified
[INFO] [stderr]   --> storage/src/storage.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 16 |     async fn get_chunk_size(&self, chunk_id: &str) -> Result<u64>;
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future`
[INFO] [stderr] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change
[INFO] [stderr]    |
[INFO] [stderr] 16 -     async fn get_chunk_size(&self, chunk_id: &str) -> Result<u64>;
[INFO] [stderr] 16 +     fn get_chunk_size(&self, chunk_id: &str) -> impl std::future::Future<Output = Result<u64>> + Send;
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: `storage` (lib) generated 6 warnings
[INFO] [stderr] warning: `storage` (lib test) generated 6 warnings (6 duplicates)
[INFO] [stderr] warning: unused import: `Status`
[INFO] [stderr]  --> datanode/src/grpc/ticket.rs:2:13
[INFO] [stderr]   |
[INFO] [stderr] 2 | use tonic::{Status, service::Interceptor};
[INFO] [stderr]   |             ^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> datanode/src/tcp/service.rs:139:25
[INFO] [stderr]     |
[INFO] [stderr] 139 |                         stream1.write_u64(bytes_received).await;
[INFO] [stderr]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 139 |                         let _ = stream1.write_u64(bytes_received).await;
[INFO] [stderr]     |                         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]   --> datanode/src/tcp/stream_tee.rs:31:13
[INFO] [stderr]    |
[INFO] [stderr] 31 |             tx1.shutdown().await;
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]    |
[INFO] [stderr] 31 |             let _ = tx1.shutdown().await;
[INFO] [stderr]    |             +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]   --> datanode/src/tcp/stream_tee.rs:32:13
[INFO] [stderr]    |
[INFO] [stderr] 32 |             tx2.shutdown().await;
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]    |
[INFO] [stderr] 32 |             let _ = tx2.shutdown().await;
[INFO] [stderr]    |             +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `datanode` (bin "datanode" test) generated 4 warnings (run `cargo fix --bin "datanode" -p datanode --tests` to apply 1 suggestion)
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> namenode/src/namenode_state/chunk_details.rs:22:20
[INFO] [stderr]    |
[INFO] [stderr] 22 |     Undereplicated(u8),
[INFO] [stderr]    |     -------------- ^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ChunkReplicationStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 22 -     Undereplicated(u8),
[INFO] [stderr] 22 +     Undereplicated(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: `namenode` (bin "namenode" test) generated 1 warning
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.31s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/client-b5a04a3c7a42c991)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/datanode-40f315633b66ae8b)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/namenode-09d699924930fc16)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/proto-b61b0ea8d220d12d)
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/storage-ef20e0b010337350)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test file_storage::tests::file_storage_test ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- file_storage::tests::file_storage_test stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'file_storage::tests::file_storage_test' (29) panicked at storage/src/file_storage/mod.rs:37:17:
[INFO] [stdout] Error during creating directory
[INFO] [stdout] stack backtrace:
[INFO] [stderr] error: test failed, to rerun pass `-p storage --lib`
[INFO] [stdout]    0:     0x58583dae8652 - std::backtrace_rs::backtrace::libunwind::trace::h786de35fecf3582f
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x58583dae8652 - std::backtrace_rs::backtrace::trace_unsynchronized::h4a7da1a2a64387f1
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x58583dae8652 - std::sys::backtrace::_print_fmt::h6bd7d500070c788c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x58583dae8652 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h6d82c1afff976903
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x58583daf8a8f - core::fmt::rt::Argument::fmt::hc4ce6d643d397690
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x58583daf8a8f - core::fmt::write::hb1e7ca88b6a3936e
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/fmt/mod.rs:1469:25
[INFO] [stdout]    6:     0x58583dab4253 - std::io::default_write_fmt::haffd49d96f1984a8
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x58583dab4253 - std::io::Write::write_fmt::h027871c57cf57c01
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x58583dac11a2 - std::sys::backtrace::BacktraceLock::print::ha2430613ee79d059
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x58583dac61ef - std::panicking::default_hook::{{closure}}::hdbd2db9e5c303cf6
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x58583dac6081 - std::panicking::default_hook::hed93c70cba5fdcf0
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x58583d9cf0be - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hd0ee8b569efc6a07
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   12:     0x58583d9cf0be - test::test_main_with_exit_callback::{{closure}}::hf10864b576ecd15d
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x58583dac68af - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h3a55ca34534c0d00
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   14:     0x58583dac68af - std::panicking::panic_with_hook::h3862d766c2cec19b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x58583dac6626 - std::panicking::panic_handler::{{closure}}::hb95eb402b5e28ee1
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:700:13
[INFO] [stdout]   16:     0x58583dac12d9 - std::sys::backtrace::__rust_end_short_backtrace::hf73a26dc1835d85a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x58583daa84bd - __rustc[6ed5915ee467787]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x58583db006a0 - core::panicking::panic_fmt::h3454303eb8e6f7cd
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x58583d9a3b17 - storage::file_storage::FileStorage::new::{{closure}}::he6b3477a32f49bc8
[INFO] [stdout]                                at /opt/rustwide/workdir/storage/src/file_storage/mod.rs:37:17
[INFO] [stdout]   20:     0x58583d98c0ce - storage::file_storage::tests::file_storage_test::{{closure}}::h25911fa1de57cab3
[INFO] [stdout]                                at /opt/rustwide/workdir/storage/src/file_storage/mod.rs:172:48
[INFO] [stdout]   21:     0x58583d995a1f - <core::pin::Pin<P> as core::future::future::Future>::poll::h18433908720c452b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/future/future.rs:133:9
[INFO] [stdout]   22:     0x58583d995adb - <core::pin::Pin<P> as core::future::future::Future>::poll::hf593ce3c324debd6
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x58583d9a0b3b - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::{{closure}}::h5a128ff8584d4ed8
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/scheduler/current_thread/mod.rs:733:70
[INFO] [stdout]   24:     0x58583d9a08ab - tokio::task::coop::with_budget::h32b416abeecb9fa1
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/task/coop/mod.rs:167:5
[INFO] [stdout]   25:     0x58583d9a08ab - tokio::task::coop::budget::h9e306b9f78f59369
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/task/coop/mod.rs:133:5
[INFO] [stdout]   26:     0x58583d9a08ab - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::hb2ac209d3fef3c24
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/scheduler/current_thread/mod.rs:733:25
[INFO] [stdout]   27:     0x58583d99df0d - tokio::runtime::scheduler::current_thread::Context::enter::hda1939daf1c8054b
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/scheduler/current_thread/mod.rs:432:19
[INFO] [stdout]   28:     0x58583d99fe9d - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::h311f3675a6f36c15
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/scheduler/current_thread/mod.rs:732:44
[INFO] [stdout]   29:     0x58583d99efcb - tokio::runtime::scheduler::current_thread::CoreGuard::enter::{{closure}}::h1f84880b42c0a00d
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/scheduler/current_thread/mod.rs:820:68
[INFO] [stdout]   30:     0x58583d98ff5a - tokio::runtime::context::scoped::Scoped<T>::set::h4b03d21119857835
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   31:     0x58583d9955fa - tokio::runtime::context::set_scheduler::{{closure}}::hc82e93c5ab0a5a7f
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/context.rs:176:38
[INFO] [stdout]   32:     0x58583d989715 - std::thread::local::LocalKey<T>::try_with::hc6e481dcca3352bb
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/local.rs:508:12
[INFO] [stdout]   33:     0x58583d9889cd - std::thread::local::LocalKey<T>::with::haded51ffdb0af20c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/local.rs:472:20
[INFO] [stdout]   34:     0x58583d9954f1 - tokio::runtime::context::set_scheduler::h3bf45523a93d3e0c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/context.rs:176:17
[INFO] [stdout]   35:     0x58583d99e8be - tokio::runtime::scheduler::current_thread::CoreGuard::enter::h28c5eceeed45586b
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/scheduler/current_thread/mod.rs:820:27
[INFO] [stdout]   36:     0x58583d99f030 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::hca6e16629d3bbf26
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/scheduler/current_thread/mod.rs:720:24
[INFO] [stdout]   37:     0x58583d99cc46 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::{{closure}}::h68517c59fd1021f5
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   38:     0x58583d99053c - tokio::runtime::context::runtime::enter_runtime::hd83521ebd608d21e
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   39:     0x58583d99c917 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::hc9fd193e02c1075a
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   40:     0x58583d99ae10 - tokio::runtime::runtime::Runtime::block_on_inner::h521b9893c1c04a2d
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/runtime.rs:356:52
[INFO] [stdout]   41:     0x58583d99b19f - tokio::runtime::runtime::Runtime::block_on::hd099ec18143907e2
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/runtime.rs:330:18
[INFO] [stdout]   42:     0x58583d98be80 - storage::file_storage::tests::file_storage_test::h8662f02fde4d669e
[INFO] [stdout]                                at /opt/rustwide/workdir/storage/src/file_storage/mod.rs:174:31
[INFO] [stdout]   43:     0x58583d98c2b7 - storage::file_storage::tests::file_storage_test::{{closure}}::h9ea67fc146b43604
[INFO] [stdout]                                at /opt/rustwide/workdir/storage/src/file_storage/mod.rs:166:37
[INFO] [stdout]   44:     0x58583d968bf6 - core::ops::function::FnOnce::call_once::h5cef94ef90861ffb
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   45:     0x58583d9cee9b - core::ops::function::FnOnce::call_once::ha729ee35d2fab541
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x58583d9cee9b - test::__rust_begin_short_backtrace::ha40f4db8207e1111
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:663:18
[INFO] [stdout]   47:     0x58583d9e2f1d - test::run_test_in_process::{{closure}}::hc1b77cda5d44f0f3
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:686:74
[INFO] [stdout]   48:     0x58583d9e2f1d - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h1dbea1de64785521
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   49:     0x58583d9e2f1d - std::panicking::catch_unwind::do_call::hd5febe9affd5a1b3
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:590:40
[INFO] [stdout]   50:     0x58583d9e2f1d - std::panicking::catch_unwind::h51ea89627559b6f4
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:553:19
[INFO] [stdout]   51:     0x58583d9e2f1d - std::panic::catch_unwind::hb8b8c2367cae3d66
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panic.rs:359:14
[INFO] [stdout]   52:     0x58583d9e2f1d - test::run_test_in_process::ha5b55801407ea100
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:686:27
[INFO] [stdout]   53:     0x58583d9e2f1d - test::run_test::{{closure}}::h0b9d4072b527abf5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:607:43
[INFO] [stdout]   54:     0x58583d9bc434 - test::run_test::{{closure}}::hb1056b5731205822
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:637:41
[INFO] [stdout]   55:     0x58583d9bc434 - std::sys::backtrace::__rust_begin_short_backtrace::hb61ff5a34023c7ef
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   56:     0x58583d9bfd6a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hb0a83c0e8b353cff
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/mod.rs:562:17
[INFO] [stdout]   57:     0x58583d9bfd6a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hb4f32cb008535298
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   58:     0x58583d9bfd6a - std::panicking::catch_unwind::do_call::h16d110e4fc35789a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:590:40
[INFO] [stdout]   59:     0x58583d9bfd6a - std::panicking::catch_unwind::hea9118f355699c4b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:553:19
[INFO] [stdout]   60:     0x58583d9bfd6a - std::panic::catch_unwind::hf4b3c2a06d3f42f5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panic.rs:359:14
[INFO] [stdout]   61:     0x58583d9bfd6a - std::thread::Builder::spawn_unchecked_::{{closure}}::h3f4cb733a52d53d5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/mod.rs:560:30
[INFO] [stdout]   62:     0x58583d9bfd6a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h4052f0967b37caeb
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   63:     0x58583dabc5ff - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h7ec433abd3f148b4
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2085:9
[INFO] [stdout]   64:     0x58583dabc5ff - std::sys::thread::unix::Thread::new::thread_start::he514622d3d7ba65c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/thread/unix.rs:124:17
[INFO] [stdout]   65:     0x784824523aa4 - <unknown>
[INFO] [stdout]   66:     0x7848245b0a64 - clone
[INFO] [stdout]   67:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     file_storage::tests::file_storage_test
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "2e058a0d5b276e9013ea19204b3dcfa399efdf064f6ac906536dbef9c80a58de", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2e058a0d5b276e9013ea19204b3dcfa399efdf064f6ac906536dbef9c80a58de", kill_on_drop: false }`
[INFO] [stdout] 2e058a0d5b276e9013ea19204b3dcfa399efdf064f6ac906536dbef9c80a58de
