[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] checking Lovepreet67/whispering-woods against master#5dbf4069dc98bbbca98dd600a65f50c258fbfd56 for pr-148477-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FLovepreet67%2Fwhispering-woods" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-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-7-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Lovepreet67/whispering-woods on toolchain 5dbf4069dc98bbbca98dd600a65f50c258fbfd56
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+5dbf4069dc98bbbca98dd600a65f50c258fbfd56" "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" "+5dbf4069dc98bbbca98dd600a65f50c258fbfd56" "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-7-tc1/source/Cargo.toml: unused manifest key: resolver
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded unicase_serde v0.1.0
[INFO] [stderr]   Downloaded opentelemetry-http v0.9.0
[INFO] [stderr]   Downloaded tonic-build v0.13.1
[INFO] [stderr]   Downloaded opentelemetry-otlp v0.13.0
[INFO] [stderr]   Downloaded prost-build v0.13.5
[INFO] [stderr]   Downloaded rcgen v0.14.4
[INFO] [stderr]   Downloaded rocket_cors v0.6.0
[INFO] [stderr]   Downloaded opentelemetry-semantic-conventions v0.12.0
[INFO] [stderr]   Downloaded opentelemetry-proto v0.3.0
[INFO] [stderr]   Downloaded x509-parser v0.18.0
[INFO] [stderr]   Downloaded tracing-opentelemetry v0.21.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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" "+5dbf4069dc98bbbca98dd600a65f50c258fbfd56" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] b877301a06555d8669cb47b3dc61b71375d8dfea090156f8dd3b32471d85a792
[INFO] running `Command { std: "docker" "start" "-a" "b877301a06555d8669cb47b3dc61b71375d8dfea090156f8dd3b32471d85a792", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "b877301a06555d8669cb47b3dc61b71375d8dfea090156f8dd3b32471d85a792", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b877301a06555d8669cb47b3dc61b71375d8dfea090156f8dd3b32471d85a792", kill_on_drop: false }`
[INFO] [stdout] b877301a06555d8669cb47b3dc61b71375d8dfea090156f8dd3b32471d85a792
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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" "+5dbf4069dc98bbbca98dd600a65f50c258fbfd56" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] daf6b0f81972b2ba86c951d9b7d5bf2812d45b68f7b4846a42db6e97cc8f45a1
[INFO] running `Command { std: "docker" "start" "-a" "daf6b0f81972b2ba86c951d9b7d5bf2812d45b68f7b4846a42db6e97cc8f45a1", 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]     Checking tracing-core v0.1.33
[INFO] [stderr]    Compiling libc v0.2.174
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking mio v1.0.3
[INFO] [stderr]     Checking socket2 v0.5.9
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]     Checking serde v1.0.219
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]     Checking time v0.3.41
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling getrandom v0.3.2
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]    Compiling rustix v1.0.7
[INFO] [stderr]    Compiling log v0.4.27
[INFO] [stderr]    Compiling thiserror-impl v2.0.16
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking crypto-common v0.1.6
[INFO] [stderr]    Compiling uncased v0.9.10
[INFO] [stderr]     Checking tokio v1.45.0
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling find-msvc-tools v0.1.2
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling axum-core v0.3.4
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]     Checking ordered-float v3.9.2
[INFO] [stderr]    Compiling cc v1.2.38
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling prettyplease v0.2.32
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling axum v0.6.20
[INFO] [stderr]    Compiling fixedbitset v0.5.7
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]     Checking axum-core v0.5.2
[INFO] [stderr]     Checking thiserror v2.0.16
[INFO] [stderr]     Checking rusticata-macros v4.1.0
[INFO] [stderr]    Compiling prost-derive v0.13.5
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling asn1-rs-derive v0.6.0
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking yoke v0.8.0
[INFO] [stderr]    Compiling is-terminal v0.4.16
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling yansi v1.0.1
[INFO] [stderr]     Checking zerovec v0.11.2
[INFO] [stderr]     Checking zerotrie v0.2.2
[INFO] [stderr]    Compiling proc-macro2-diagnostics v0.10.1
[INFO] [stderr]     Checking indexmap v2.9.0
[INFO] [stderr]     Checking serde_json v1.0.143
[INFO] [stderr]    Compiling pear_codegen v0.2.9
[INFO] [stderr]    Compiling tempfile v3.19.1
[INFO] [stderr]     Checking inout v0.1.4
[INFO] [stderr]    Compiling asn1-rs-impl v0.2.0
[INFO] [stderr]    Compiling multimap v0.10.0
[INFO] [stderr]    Compiling prost v0.13.5
[INFO] [stderr]    Compiling smallvec v1.15.0
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking opentelemetry_api v0.20.0
[INFO] [stderr]     Checking universal-hash v0.5.1
[INFO] [stderr]     Checking asn1-rs v0.7.1
[INFO] [stderr]     Checking cipher v0.4.4
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]    Compiling prost-types v0.13.5
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]     Checking tracing-serde v0.2.0
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking thread_local v1.1.8
[INFO] [stderr]     Checking winnow v0.7.13
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling oid-registry v0.8.1
[INFO] [stderr]     Checking tinystr v0.8.1
[INFO] [stderr]     Checking potential_utf v0.1.2
[INFO] [stderr]     Checking pear v0.2.9
[INFO] [stderr]     Checking tracing-subscriber v0.3.19
[INFO] [stderr]     Checking polyval v0.6.2
[INFO] [stderr]     Checking icu_collections v2.0.0
[INFO] [stderr]     Checking icu_locale_core v2.0.0
[INFO] [stderr]    Compiling signal-hook-registry v1.4.5
[INFO] [stderr]    Compiling prost-derive v0.11.9
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]     Checking pem v3.0.5
[INFO] [stderr]    Compiling petgraph v0.7.1
[INFO] [stderr]    Compiling figment v0.10.19
[INFO] [stderr]     Checking icu_provider v2.0.0
[INFO] [stderr]    Compiling ref-cast v1.0.24
[INFO] [stderr]     Checking unsafe-libyaml v0.2.11
[INFO] [stderr]     Checking tokio-util v0.7.15
[INFO] [stderr]     Checking tokio-stream v0.1.17
[INFO] [stderr]     Checking tokio-io-timeout v1.2.0
[INFO] [stderr]     Checking icu_normalizer v2.0.0
[INFO] [stderr]     Checking icu_properties v2.0.1
[INFO] [stderr]     Checking der-parser v10.0.0
[INFO] [stderr]     Checking h2 v0.3.26
[INFO] [stderr]     Checking h2 v0.4.10
[INFO] [stderr]     Checking opentelemetry_sdk v0.20.0
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking serde_yaml v0.9.34+deprecated
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]     Checking ghash v0.5.1
[INFO] [stderr]     Checking aes v0.8.4
[INFO] [stderr]     Checking prost v0.11.9
[INFO] [stderr]     Checking ctr v0.9.2
[INFO] [stderr]     Checking simple_asn1 v0.6.3
[INFO] [stderr]    Compiling prost-build v0.13.5
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking aead v0.5.2
[INFO] [stderr]     Checking tracing-log v0.1.4
[INFO] [stderr]     Checking axum v0.8.4
[INFO] [stderr]    Compiling ref-cast-impl v1.0.24
[INFO] [stderr]     Checking idna v1.0.3
[INFO] [stderr]    Compiling powerfmt v0.2.0
[INFO] [stderr]     Checking x509-parser v0.18.0
[INFO] [stderr]     Checking tracing-appender v0.2.3
[INFO] [stderr]    Compiling deranged v0.4.0
[INFO] [stderr]     Checking aes-gcm v0.10.3
[INFO] [stderr]    Compiling try-lock v0.2.5
[INFO] [stderr]    Compiling http-body v0.4.6
[INFO] [stderr]    Compiling want v0.3.1
[INFO] [stderr]     Checking jsonwebtoken v9.3.1
[INFO] [stderr]     Checking url v2.5.4
[INFO] [stderr]     Checking opentelemetry v0.20.0
[INFO] [stderr]    Compiling tonic-build v0.13.1
[INFO] [stderr]     Checking opentelemetry-semantic-conventions v0.12.0
[INFO] [stderr]     Checking tracing-opentelemetry v0.21.0
[INFO] [stderr]     Checking webpki v0.22.4
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]    Compiling devise_core v0.4.2
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling httpdate v1.0.3
[INFO] [stderr]    Compiling tower-service v0.3.3
[INFO] [stderr]    Compiling nix v0.30.1
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]    Compiling stable-pattern v0.1.0
[INFO] [stderr]    Compiling multer v3.1.0
[INFO] [stderr]    Compiling state v0.6.0
[INFO] [stderr]     Checking cookie v0.18.1
[INFO] [stderr]    Compiling rocket v0.5.1
[INFO] [stderr]     Checking spin v0.9.8
[INFO] [stderr]    Compiling glob v0.3.3
[INFO] [stderr]     Checking ubyte v0.10.4
[INFO] [stderr]     Checking atomic v0.5.3
[INFO] [stderr]     Checking hyper v1.6.0
[INFO] [stderr]     Checking rustls-pki-types v1.12.0
[INFO] [stderr]     Checking unicase_serde v0.1.0
[INFO] [stderr]     Checking yasna v0.5.2
[INFO] [stderr]     Checking uuid v1.17.0
[INFO] [stderr]    Compiling devise_codegen v0.4.2
[INFO] [stderr]    Compiling devise v0.4.2
[INFO] [stderr]    Compiling proto v0.1.0 (/opt/rustwide/workdir/proto)
[INFO] [stderr]     Checking hyper-util v0.1.11
[INFO] [stderr]     Checking rcgen v0.14.4
[INFO] [stderr]     Checking 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] [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]     Checking hyper-timeout v0.4.1
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking rocket_http v0.5.1
[INFO] [stderr]     Checking hyper-timeout v0.5.2
[INFO] [stderr]     Checking tonic v0.13.1
[INFO] [stderr]     Checking opentelemetry-http v0.9.0
[INFO] [stderr]     Checking tonic v0.9.2
[INFO] [stderr]     Checking opentelemetry-proto v0.3.0
[INFO] [stderr]     Checking opentelemetry-otlp v0.13.0
[INFO] [stderr]     Checking 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] [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]     Checking client v0.1.0 (/opt/rustwide/workdir/client)
[INFO] [stderr]     Checking 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: `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 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]   --> 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] [stderr]    Compiling rocket_codegen v0.5.1
[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] [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]     Checking rocket_cors v0.6.0
[INFO] [stderr]     Checking 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] [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 45s
[INFO] running `Command { std: "docker" "inspect" "daf6b0f81972b2ba86c951d9b7d5bf2812d45b68f7b4846a42db6e97cc8f45a1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "daf6b0f81972b2ba86c951d9b7d5bf2812d45b68f7b4846a42db6e97cc8f45a1", kill_on_drop: false }`
[INFO] [stdout] daf6b0f81972b2ba86c951d9b7d5bf2812d45b68f7b4846a42db6e97cc8f45a1
