[INFO] cloning repository https://github.com/juant72/prozchain
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/juant72/prozchain" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjuant72%2Fprozchain", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjuant72%2Fprozchain'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] fd277308b9a45c83dcf9bbaeb42df1c5d558366e
[INFO] testing juant72/prozchain against 1.90.0 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjuant72%2Fprozchain" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/juant72/prozchain
[INFO] finished tweaking git repo https://github.com/juant72/prozchain
[INFO] tweaked toml for git repo https://github.com/juant72/prozchain written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/juant72/prozchain on toolchain 1.90.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/juant72/prozchain 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" "+1.90.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded resolv-conf v0.7.1
[INFO] [stderr]   Downloaded libp2p-allow-block-list v0.3.0
[INFO] [stderr]   Downloaded termtree v0.5.1
[INFO] [stderr]   Downloaded dlv-list v0.5.2
[INFO] [stderr]   Downloaded libp2p-core v0.41.3
[INFO] [stderr]   Downloaded widestring v1.2.0
[INFO] [stderr]   Downloaded pest v2.7.15
[INFO] [stderr]   Downloaded pest_generator v2.7.15
[INFO] [stderr]   Downloaded pathdiff v0.2.3
[INFO] [stderr]   Downloaded pest_meta v2.7.15
[INFO] [stderr]   Downloaded env_logger v0.11.7
[INFO] [stderr]   Downloaded yaml-rust2 v0.8.1
[INFO] [stderr]   Downloaded hickory-resolver v0.24.4
[INFO] [stderr]   Downloaded libp2p-kad v0.45.3
[INFO] [stderr]   Downloaded procfs-core v0.16.0
[INFO] [stderr]   Downloaded libp2p-swarm v0.44.2
[INFO] [stderr]   Downloaded netlink-packet-route v0.17.1
[INFO] [stderr]   Downloaded hickory-proto v0.24.4
[INFO] [stderr]   Downloaded typemap-ors v1.0.0
[INFO] [stderr]   Downloaded procfs v0.16.0
[INFO] [stderr]   Downloaded rust-ini v0.20.0
[INFO] [stderr]   Downloaded libp2p-connection-limits v0.3.1
[INFO] [stderr]   Downloaded prometheus-client-derive-encode v0.4.2
[INFO] [stderr]   Downloaded prometheus-client v0.22.3
[INFO] [stderr]   Downloaded libp2p-request-response v0.26.3
[INFO] [stderr]   Downloaded thread-id v4.2.2
[INFO] [stderr]   Downloaded unsafe-any-ors v1.0.0
[INFO] [stderr]   Downloaded jiff-static v0.2.5
[INFO] [stderr]   Downloaded log4rs v1.3.0
[INFO] [stderr]   Downloaded jiff v0.2.5
[INFO] [stderr]   Downloaded metrics v0.21.1
[INFO] [stderr]   Downloaded mockall_derive v0.12.1
[INFO] [stderr]   Downloaded predicates-core v1.0.9
[INFO] [stderr]   Downloaded ordered-multimap v0.7.3
[INFO] [stderr]   Downloaded config v0.14.1
[INFO] [stderr]   Downloaded libp2p-dns v0.41.1
[INFO] [stderr]   Downloaded asynchronous-codec v0.7.0
[INFO] [stderr]   Downloaded libp2p-relay v0.17.2
[INFO] [stderr]   Downloaded futures-bounded v0.2.4
[INFO] [stderr]   Downloaded if-addrs v0.10.2
[INFO] [stderr]   Downloaded netlink-packet-utils v0.5.2
[INFO] [stderr]   Downloaded netlink-packet-core v0.7.0
[INFO] [stderr]   Downloaded quick-protobuf v0.8.1
[INFO] [stderr]   Downloaded multiaddr v0.18.2
[INFO] [stderr]   Downloaded destructure_traitobject v0.2.0
[INFO] [stderr]   Downloaded metrics-macros v0.7.1
[INFO] [stderr]   Downloaded downcast v0.11.0
[INFO] [stderr]   Downloaded fragile v2.0.0
[INFO] [stderr]   Downloaded predicates v3.1.3
[INFO] [stderr]   Downloaded predicates-tree v1.0.12
[INFO] [stderr]   Downloaded mockall v0.12.1
[INFO] [stderr]   Downloaded wait-timeout v0.2.1
[INFO] [stderr]   Downloaded snow v0.9.6
[INFO] [stderr]   Downloaded pest_derive v2.7.15
[INFO] [stderr]   Downloaded arraydeque v0.5.1
[INFO] [stderr]   Downloaded libp2p-identify v0.44.2
[INFO] [stderr]   Downloaded libp2p-metrics v0.14.1
[INFO] [stderr]   Downloaded libp2p-noise v0.44.0
[INFO] [stderr]   Downloaded libp2p-ping v0.44.1
[INFO] [stderr]   Downloaded quick-protobuf-codec v0.3.1
[INFO] [stderr]   Downloaded netlink-proto v0.11.5
[INFO] [stderr]   Downloaded netlink-sys v0.8.7
[INFO] [stderr]   Downloaded rtnetlink v0.13.1
[INFO] [stderr]   Downloaded if-watch v3.2.1
[INFO] [stderr]   Downloaded libp2p-tcp v0.41.0
[INFO] [stderr]   Downloaded soketto v0.8.1
[INFO] [stderr]   Downloaded libp2p-websocket v0.43.2
[INFO] [stderr]   Downloaded multistream-select v0.13.0
[INFO] [stderr]   Downloaded yamux v0.12.1
[INFO] [stderr]   Downloaded libp2p-yamux v0.45.2
[INFO] [stderr]   Downloaded libp2p-identity v0.2.10
[INFO] [stderr]   Downloaded data-encoding-macro-internal v0.1.15
[INFO] [stderr]   Downloaded core2 v0.4.0
[INFO] [stderr]   Downloaded multihash v0.19.3
[INFO] [stderr]   Downloaded rw-stream-sink v0.4.0
[INFO] [stderr]   Downloaded libp2p v0.53.2
[INFO] [stderr]   Downloaded log-mdc v0.1.0
[INFO] [stderr]   Downloaded ordered-float v2.10.1
[INFO] [stderr]   Downloaded proptest v1.6.0
[INFO] [stderr]   Downloaded rustls v0.22.4
[INFO] [stderr]   Downloaded futures-rustls v0.26.0
[INFO] [stderr]   Downloaded yamux v0.13.4
[INFO] [stderr]   Downloaded base-x v0.2.11
[INFO] [stderr]   Downloaded data-encoding-macro v0.1.17
[INFO] [stderr]   Downloaded multibase v0.9.1
[INFO] [stderr]   Downloaded hostname v0.4.0
[INFO] [stderr]   Downloaded x25519-dalek v2.0.1
[INFO] [stderr]   Downloaded quickcheck v1.0.3
[INFO] [stderr]   Downloaded unsigned-varint v0.8.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 9c515969a47fe1ca519fecac32b70e050dbeb1084e138a9c390917656da96ce8
[INFO] running `Command { std: "docker" "start" "-a" "9c515969a47fe1ca519fecac32b70e050dbeb1084e138a9c390917656da96ce8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "9c515969a47fe1ca519fecac32b70e050dbeb1084e138a9c390917656da96ce8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9c515969a47fe1ca519fecac32b70e050dbeb1084e138a9c390917656da96ce8", kill_on_drop: false }`
[INFO] [stdout] 9c515969a47fe1ca519fecac32b70e050dbeb1084e138a9c390917656da96ce8
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d7982dc672d2d38cb379a241885c0082a956be627b4f651d7f4e20f25b22fc51
[INFO] running `Command { std: "docker" "start" "-a" "d7982dc672d2d38cb379a241885c0082a956be627b4f651d7f4e20f25b22fc51", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.171
[INFO] [stderr]    Compiling once_cell v1.21.1
[INFO] [stderr]    Compiling subtle v2.6.1
[INFO] [stderr]    Compiling smallvec v1.14.0
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling futures-core v0.3.31
[INFO] [stderr]    Compiling futures-task v0.3.31
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling zerocopy v0.8.24
[INFO] [stderr]    Compiling allocator-api2 v0.2.21
[INFO] [stderr]    Compiling signature v2.2.0
[INFO] [stderr]    Compiling unsigned-varint v0.8.0
[INFO] [stderr]    Compiling data-encoding v2.8.0
[INFO] [stderr]    Compiling curve25519-dalek v4.1.3
[INFO] [stderr]    Compiling quick-protobuf v0.8.1
[INFO] [stderr]    Compiling core2 v0.4.0
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling ed25519 v2.2.3
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling syn v2.0.100
[INFO] [stderr]    Compiling tracing-core v0.1.33
[INFO] [stderr]    Compiling base-x v0.2.11
[INFO] [stderr]    Compiling bs58 v0.5.1
[INFO] [stderr]    Compiling multihash v0.19.3
[INFO] [stderr]    Compiling unsigned-varint v0.7.2
[INFO] [stderr]    Compiling void v1.0.2
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling hashbrown v0.15.2
[INFO] [stderr]    Compiling cc v1.2.17
[INFO] [stderr]    Compiling anyhow v1.0.97
[INFO] [stderr]    Compiling instant v0.1.13
[INFO] [stderr]    Compiling inout v0.1.4
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]    Compiling crunchy v0.2.3
[INFO] [stderr]    Compiling tinyvec v1.9.0
[INFO] [stderr]    Compiling zerocopy v0.7.35
[INFO] [stderr]    Compiling opaque-debug v0.3.1
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]    Compiling rustls-pki-types v1.11.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling ucd-trie v0.1.7
[INFO] [stderr]    Compiling rustls v0.23.25
[INFO] [stderr]    Compiling linked-hash-map v0.5.6
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling lru v0.12.5
[INFO] [stderr]    Compiling indexmap v2.8.0
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling lru-cache v0.1.2
[INFO] [stderr]    Compiling snow v0.9.6
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling prometheus-client v0.22.3
[INFO] [stderr]    Compiling uint v0.9.5
[INFO] [stderr]    Compiling linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling winnow v0.7.4
[INFO] [stderr]    Compiling dtoa v1.0.10
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling const-random-macro v0.1.16
[INFO] [stderr]    Compiling unicode-normalization v0.1.24
[INFO] [stderr]    Compiling procfs v0.16.0
[INFO] [stderr]    Compiling unicode-bidi v0.3.18
[INFO] [stderr]    Compiling base64 v0.22.1
[INFO] [stderr]    Compiling destructure_traitobject v0.2.0
[INFO] [stderr]    Compiling unsafe-any-ors v1.0.0
[INFO] [stderr]    Compiling hashlink v0.8.4
[INFO] [stderr]    Compiling arraydeque v0.5.1
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling webpki-roots v0.25.4
[INFO] [stderr]    Compiling unsafe-libyaml v0.2.11
[INFO] [stderr]    Compiling const-random v0.1.18
[INFO] [stderr]    Compiling dlv-list v0.5.2
[INFO] [stderr]    Compiling ordered-float v2.10.1
[INFO] [stderr]    Compiling rustls v0.22.4
[INFO] [stderr]    Compiling prometheus v0.13.4
[INFO] [stderr]    Compiling chrono v0.4.40
[INFO] [stderr]    Compiling yaml-rust2 v0.8.1
[INFO] [stderr]    Compiling idna v0.4.0
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling anstream v0.6.18
[INFO] [stderr]    Compiling typemap-ors v1.0.0
[INFO] [stderr]    Compiling ordered-multimap v0.7.3
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling thread_local v1.1.8
[INFO] [stderr]    Compiling prozchain v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling num_cpus v1.16.0
[INFO] [stderr]    Compiling socket2 v0.5.8
[INFO] [stderr]    Compiling hostname v0.4.0
[INFO] [stderr]    Compiling nix v0.26.4
[INFO] [stderr]    Compiling mio v1.0.3
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling parking_lot v0.12.3
[INFO] [stderr]    Compiling resolv-conf v0.7.1
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling universal-hash v0.5.1
[INFO] [stderr]    Compiling aead v0.5.2
[INFO] [stderr]    Compiling polyval v0.6.2
[INFO] [stderr]    Compiling poly1305 v0.8.0
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling hkdf v0.12.4
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling blake2 v0.10.6
[INFO] [stderr]    Compiling ghash v0.5.1
[INFO] [stderr]    Compiling signal-hook-registry v1.4.2
[INFO] [stderr]    Compiling rust-ini v0.20.0
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling convert_case v0.6.0
[INFO] [stderr]    Compiling thread-id v4.2.2
[INFO] [stderr]    Compiling log-mdc v0.1.0
[INFO] [stderr]    Compiling humantime v2.2.0
[INFO] [stderr]    Compiling pathdiff v0.2.3
[INFO] [stderr]    Compiling arc-swap v1.7.1
[INFO] [stderr]    Compiling jiff v0.2.5
[INFO] [stderr]    Compiling dashmap v5.5.3
[INFO] [stderr]    Compiling derivative v2.2.0
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.7.5
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling zeroize_derive v1.4.2
[INFO] [stderr]    Compiling zerovec-derive v0.10.3
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.28
[INFO] [stderr]    Compiling curve25519-dalek-derive v0.1.1
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling data-encoding-macro-internal v0.1.15
[INFO] [stderr]    Compiling zeroize v1.8.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.12
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling cipher v0.4.4
[INFO] [stderr]    Compiling data-encoding-macro v0.1.17
[INFO] [stderr]    Compiling async-trait v0.1.88
[INFO] [stderr]    Compiling multibase v0.9.1
[INFO] [stderr]    Compiling enum-as-inner v0.6.1
[INFO] [stderr]    Compiling chacha20 v0.9.1
[INFO] [stderr]    Compiling aes v0.8.4
[INFO] [stderr]    Compiling ctr v0.9.2
[INFO] [stderr]    Compiling chacha20poly1305 v0.10.1
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling netlink-packet-utils v0.5.2
[INFO] [stderr]    Compiling prometheus-client-derive-encode v0.4.2
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling ed25519-dalek v2.1.1
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling netlink-packet-core v0.7.0
[INFO] [stderr]    Compiling aes-gcm v0.10.3
[INFO] [stderr]    Compiling netlink-packet-route v0.17.1
[INFO] [stderr]    Compiling x25519-dalek v2.0.1
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.7.5
[INFO] [stderr]    Compiling libp2p-identity v0.2.10
[INFO] [stderr]    Compiling pin-project v1.1.10
[INFO] [stderr]    Compiling tokio v1.44.1
[INFO] [stderr]    Compiling zerovec v0.10.4
[INFO] [stderr]    Compiling rustls-webpki v0.103.0
[INFO] [stderr]    Compiling rustls-webpki v0.102.8
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling thiserror v2.0.12
[INFO] [stderr]    Compiling pest v2.7.15
[INFO] [stderr]    Compiling tinystr v0.7.6
[INFO] [stderr]    Compiling icu_collections v1.5.0
[INFO] [stderr]    Compiling icu_locid v1.5.0
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling asynchronous-codec v0.7.0
[INFO] [stderr]    Compiling futures-bounded v0.2.4
[INFO] [stderr]    Compiling icu_provider v1.5.0
[INFO] [stderr]    Compiling pest_meta v2.7.15
[INFO] [stderr]    Compiling quick-protobuf-codec v0.3.1
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling icu_locid_transform v1.5.0
[INFO] [stderr]    Compiling rw-stream-sink v0.4.0
[INFO] [stderr]    Compiling icu_properties v1.5.1
[INFO] [stderr]    Compiling pest_generator v2.7.15
[INFO] [stderr]    Compiling pest_derive v2.7.15
[INFO] [stderr]    Compiling log v0.4.26
[INFO] [stderr]    Compiling bitflags v2.9.0
[INFO] [stderr]    Compiling toml_datetime v0.6.8
[INFO] [stderr]    Compiling serde_spanned v0.6.8
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling serde_yaml v0.9.34+deprecated
[INFO] [stderr]    Compiling serde-value v0.7.0
[INFO] [stderr]    Compiling bincode v1.3.3
[INFO] [stderr]    Compiling toml_edit v0.22.24
[INFO] [stderr]    Compiling procfs-core v0.16.0
[INFO] [stderr]    Compiling ron v0.8.1
[INFO] [stderr]    Compiling multistream-select v0.13.0
[INFO] [stderr]    Compiling netlink-sys v0.8.7
[INFO] [stderr]    Compiling yamux v0.12.1
[INFO] [stderr]    Compiling soketto v0.8.1
[INFO] [stderr]    Compiling netlink-proto v0.11.5
[INFO] [stderr]    Compiling futures-rustls v0.26.0
[INFO] [stderr]    Compiling yamux v0.13.4
[INFO] [stderr]    Compiling rtnetlink v0.13.1
[INFO] [stderr]    Compiling json5 v0.4.1
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling env_filter v0.1.3
[INFO] [stderr]    Compiling tracing-subscriber v0.3.19
[INFO] [stderr]    Compiling icu_normalizer v1.5.0
[INFO] [stderr]    Compiling env_logger v0.11.7
[INFO] [stderr]    Compiling log4rs v1.3.0
[INFO] [stderr]    Compiling idna_adapter v1.2.0
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling if-watch v3.2.1
[INFO] [stderr]    Compiling toml v0.8.20
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling config v0.14.1
[INFO] [stderr]    Compiling multiaddr v0.18.2
[INFO] [stderr]    Compiling hickory-proto v0.24.4
[INFO] [stderr]    Compiling trust-dns-proto v0.23.2
[INFO] [stderr]    Compiling libp2p-core v0.41.3
[INFO] [stderr]    Compiling libp2p-swarm v0.44.2
[INFO] [stderr]    Compiling libp2p-tcp v0.41.0
[INFO] [stderr]    Compiling libp2p-yamux v0.45.2
[INFO] [stderr]    Compiling libp2p-websocket v0.43.2
[INFO] [stderr]    Compiling libp2p-noise v0.44.0
[INFO] [stderr]    Compiling trust-dns-resolver v0.23.2
[INFO] [stderr]    Compiling hickory-resolver v0.24.4
[INFO] [stderr]    Compiling libp2p-relay v0.17.2
[INFO] [stderr]    Compiling libp2p-ping v0.44.1
[INFO] [stderr]    Compiling libp2p-identify v0.44.2
[INFO] [stderr]    Compiling libp2p-kad v0.45.3
[INFO] [stderr]    Compiling libp2p-allow-block-list v0.3.0
[INFO] [stderr]    Compiling libp2p-connection-limits v0.3.1
[INFO] [stderr]    Compiling libp2p-request-response v0.26.3
[INFO] [stderr]    Compiling libp2p-dns v0.41.1
[INFO] [stderr]    Compiling libp2p-metrics v0.14.1
[INFO] [stderr]    Compiling libp2p v0.53.2
[INFO] [stdout] warning: unused import: `crate::network::message::Message`
[INFO] [stdout]  --> src/network/block_propagation.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::network::message::Message;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AsyncRead` and `AsyncWrite`
[INFO] [stdout]  --> src/network/connection.rs:8:17
[INFO] [stdout]   |
[INFO] [stdout] 8 | use tokio::io::{AsyncRead, AsyncWrite};
[INFO] [stdout]   |                 ^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TcpListener`
[INFO] [stdout]  --> src/network/connection.rs:9:18
[INFO] [stdout]   |
[INFO] [stdout] 9 | use tokio::net::{TcpListener, TcpStream};
[INFO] [stdout]   |                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Mutex` and `RwLock`
[INFO] [stdout]   --> src/network/connection.rs:10:25
[INFO] [stdout]    |
[INFO] [stdout] 10 | use tokio::sync::{mpsc, Mutex, RwLock};
[INFO] [stdout]    |                         ^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Counter`, `Gauge`, and `Histogram`
[INFO] [stdout]  --> src/network/metrics/mod.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     Counter, Gauge, Histogram, HistogramOpts, HistogramVec, IntCounter, IntGauge, Registry
[INFO] [stdout]   |     ^^^^^^^  ^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `full_block_msg`
[INFO] [stdout]    --> src/network/block_propagation.rs:157:13
[INFO] [stdout]     |
[INFO] [stdout] 157 |         let full_block_msg = BlockAnnouncement::FullBlock(block.clone());
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_full_block_msg`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `compact_block`
[INFO] [stdout]    --> src/network/block_propagation.rs:159:13
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let compact_block = if self.compact_blocks_enabled {
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_compact_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header_only_msg`
[INFO] [stdout]    --> src/network/block_propagation.rs:165:13
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let header_only_msg = BlockAnnouncement::HeaderOnly {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_header_only_msg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message_tx`
[INFO] [stdout]    --> src/network/service.rs:351:9
[INFO] [stdout]     |
[INFO] [stdout] 351 |         message_tx: mpsc::Sender<NetworkMessage>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_tx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `protocol_version`
[INFO] [stdout]    --> src/network/connection.rs:141:33
[INFO] [stdout]     |
[INFO] [stdout] 141 |                 Ok(Ok((peer_id, protocol_version, user_agent))) => {
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_protocol_version`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `user_agent`
[INFO] [stdout]    --> src/network/connection.rs:141:51
[INFO] [stdout]     |
[INFO] [stdout] 141 |                 Ok(Ok((peer_id, protocol_version, user_agent))) => {
[INFO] [stdout]     |                                                   ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_agent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `first_seen` is never read
[INFO] [stdout]   --> src/network/discovery.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 31 | struct LocalPeerRecord {
[INFO] [stdout]    |        --------------- field in this struct
[INFO] [stdout] 32 |     first_seen: Instant,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `LocalPeerRecord` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `PeerExchange` and `LocalDiscovery` are never constructed
[INFO] [stdout]   --> src/network/discovery.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | enum PeerSource {
[INFO] [stdout]    |      ---------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 45 |     PeerExchange,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 46 |     LocalDiscovery,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PeerSource` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `local_peer_id` is never read
[INFO] [stdout]    --> src/network/propagation.rs:239:5
[INFO] [stdout]     |
[INFO] [stdout] 233 | pub struct GossipManager {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 239 |     local_peer_id: PeerId,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `broadcast_manager`, `compact_announcements`, and `seen_transactions` are never read
[INFO] [stdout]    --> src/network/propagation.rs:410:5
[INFO] [stdout]     |
[INFO] [stdout] 409 | pub struct TransactionPropagator {
[INFO] [stdout]     |            --------------------- fields in this struct
[INFO] [stdout] 410 |     broadcast_manager: BroadcastManager,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 411 |     compact_announcements: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 412 |     seen_transactions: HashSet<[u8; 32]>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `min_outbound_connections` and `peer_reputation` are never read
[INFO] [stdout]   --> src/network/security.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub struct SybilProtection {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 68 |     min_outbound_connections: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 69 |     max_inbound_per_ip: usize,
[INFO] [stdout] 70 |     peer_reputation: ReputationTracker,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ttl` is never read
[INFO] [stdout]    --> src/network/security.rs:379:5
[INFO] [stdout]     |
[INFO] [stdout] 377 | pub struct ExpiringCache<K, V> {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] 378 |     entries: HashMap<K, (V, Instant)>,
[INFO] [stdout] 379 |     ttl: Duration,
[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]  --> src/network/interfaces.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     async fn connected_peer_count(&self) -> usize;
[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] 9 -     async fn connected_peer_count(&self) -> usize;
[INFO] [stdout] 9 +     fn connected_peer_count(&self) -> impl std::future::Future<Output = usize> + 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]   --> src/network/interfaces.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     async fn connected_validator_count(&self) -> usize;
[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 connected_validator_count(&self) -> usize;
[INFO] [stdout] 12 +     fn connected_validator_count(&self) -> impl std::future::Future<Output = usize> + 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]   --> src/network/interfaces.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     async fn average_peer_latency(&self) -> Duration;
[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 average_peer_latency(&self) -> Duration;
[INFO] [stdout] 15 +     fn average_peer_latency(&self) -> impl std::future::Future<Output = Duration> + 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]   --> src/network/interfaces.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     async fn trigger_peer_discovery(&self);
[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] 18 -     async fn trigger_peer_discovery(&self);
[INFO] [stdout] 18 +     fn trigger_peer_discovery(&self) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     async fn prioritize_validator_connections(&self);
[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] 21 -     async fn prioritize_validator_connections(&self);
[INFO] [stdout] 21 +     fn prioritize_validator_connections(&self) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     async fn propagate_block(&self, block_data: Vec<u8>) -> Result<(), 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] 27 -     async fn propagate_block(&self, block_data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 27 +     fn propagate_block(&self, block_data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     async fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), 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] 30 -     async fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 30 +     fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     async fn propagate_transaction(&self, tx_data: Vec<u8>) -> Result<(), 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] 36 -     async fn propagate_transaction(&self, tx_data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 36 +     fn propagate_transaction(&self, tx_data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     async fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), 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] 39 -     async fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 39 +     fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     async fn discover_peers(&self) -> Result<Vec<crate::network::discovery::PeerInfo>, 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] 45 -     async fn discover_peers(&self) -> Result<Vec<crate::network::discovery::PeerInfo>, String>;
[INFO] [stdout] 45 +     fn discover_peers(&self) -> impl std::future::Future<Output = Result<Vec<crate::network::discovery::PeerInfo>, 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]   --> src/network/interfaces.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     async fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo);
[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] 48 -     async fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo);
[INFO] [stdout] 48 +     fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 51 |     async fn get_known_peers(&self) -> Vec<crate::network::discovery::PeerInfo>;
[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] 51 -     async fn get_known_peers(&self) -> Vec<crate::network::discovery::PeerInfo>;
[INFO] [stdout] 51 +     fn get_known_peers(&self) -> impl std::future::Future<Output = Vec<crate::network::discovery::PeerInfo>> + 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]   --> src/network/interfaces.rs:57:5
[INFO] [stdout]    |
[INFO] [stdout] 57 |     async fn connect_to_peer(&self, address: std::net::SocketAddr) -> Result<PeerId, 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] 57 -     async fn connect_to_peer(&self, address: std::net::SocketAddr) -> Result<PeerId, String>;
[INFO] [stdout] 57 +     fn connect_to_peer(&self, address: std::net::SocketAddr) -> impl std::future::Future<Output = Result<PeerId, 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]   --> src/network/interfaces.rs:60:5
[INFO] [stdout]    |
[INFO] [stdout] 60 |     async fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason);
[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] 60 -     async fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason);
[INFO] [stdout] 60 +     fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 63 |     async fn is_connected_to(&self, peer_id: &PeerId) -> 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] 63 -     async fn is_connected_to(&self, peer_id: &PeerId) -> bool;
[INFO] [stdout] 63 +     fn is_connected_to(&self, peer_id: &PeerId) -> impl std::future::Future<Output = 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]   --> src/network/interfaces.rs:66:5
[INFO] [stdout]    |
[INFO] [stdout] 66 |     async fn connection_count(&self) -> usize;
[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] 66 -     async fn connection_count(&self) -> usize;
[INFO] [stdout] 66 +     fn connection_count(&self) -> impl std::future::Future<Output = usize> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused implementer of `Future` that must be used
[INFO] [stdout]    --> src/network/security.rs:523:13
[INFO] [stdout]     |
[INFO] [stdout] 523 |             self.connection_manager.disconnect(peer_id, DisconnectReason::PeerBanned);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `log` is never read
[INFO] [stdout]    --> src/main.rs:235:13
[INFO] [stdout]     |
[INFO] [stdout] 232 |     pub struct Config {
[INFO] [stdout]     |                ------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 235 |         pub log: Option<Log>,
[INFO] [stdout]     |             ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `level`, `enable_file_logging`, and `log_file` are never read
[INFO] [stdout]    --> src/main.rs:271:13
[INFO] [stdout]     |
[INFO] [stdout] 270 |     pub struct Log {
[INFO] [stdout]     |                --- fields in this struct
[INFO] [stdout] 271 |         pub level: String,
[INFO] [stdout]     |             ^^^^^
[INFO] [stdout] 272 |         pub enable_file_logging: bool,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 273 |         pub log_file: String,
[INFO] [stdout]     |             ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 13s
[INFO] running `Command { std: "docker" "inspect" "d7982dc672d2d38cb379a241885c0082a956be627b4f651d7f4e20f25b22fc51", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d7982dc672d2d38cb379a241885c0082a956be627b4f651d7f4e20f25b22fc51", kill_on_drop: false }`
[INFO] [stdout] d7982dc672d2d38cb379a241885c0082a956be627b4f651d7f4e20f25b22fc51
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a4799382206b38ee0e222a01fbd0a4ff4bc1bacd484a981810dbe87d3c8c8e85
[INFO] running `Command { std: "docker" "start" "-a" "a4799382206b38ee0e222a01fbd0a4ff4bc1bacd484a981810dbe87d3c8c8e85", kill_on_drop: false }`
[INFO] [stderr]    Compiling futures-core v0.3.31
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling tokio v1.44.1
[INFO] [stderr]    Compiling getrandom v0.3.2
[INFO] [stderr]    Compiling rustix v1.0.3
[INFO] [stderr]    Compiling linux-raw-sys v0.9.3
[INFO] [stderr]    Compiling rstest_macros v0.18.2
[INFO] [stderr]    Compiling predicates-core v1.0.9
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling wait-timeout v0.2.1
[INFO] [stderr]    Compiling termtree v0.5.1
[INFO] [stderr]    Compiling quick-error v1.2.3
[INFO] [stderr]    Compiling relative-path v1.9.3
[INFO] [stderr]    Compiling rand_xorshift v0.3.0
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling mockall_derive v0.12.1
[INFO] [stderr]    Compiling unarray v0.1.4
[INFO] [stderr]    Compiling predicates-tree v1.0.12
[INFO] [stderr]    Compiling predicates v3.1.3
[INFO] [stderr]    Compiling downcast v0.11.0
[INFO] [stderr]    Compiling fragile v2.0.0
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling libp2p-identity v0.2.10
[INFO] [stderr]    Compiling log4rs v1.3.0
[INFO] [stderr]    Compiling multiaddr v0.18.2
[INFO] [stderr]    Compiling tempfile v3.19.1
[INFO] [stderr]    Compiling mockall v0.12.1
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling rusty-fork v0.3.0
[INFO] [stderr]    Compiling proptest v1.6.0
[INFO] [stderr]    Compiling env_filter v0.1.3
[INFO] [stderr]    Compiling tracing-subscriber v0.3.19
[INFO] [stderr]    Compiling env_logger v0.8.4
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling asynchronous-codec v0.7.0
[INFO] [stderr]    Compiling futures-bounded v0.2.4
[INFO] [stderr]    Compiling hickory-proto v0.24.4
[INFO] [stderr]    Compiling env_logger v0.11.7
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling quick-protobuf-codec v0.3.1
[INFO] [stderr]    Compiling multistream-select v0.13.0
[INFO] [stderr]    Compiling rw-stream-sink v0.4.0
[INFO] [stderr]    Compiling netlink-proto v0.11.5
[INFO] [stderr]    Compiling soketto v0.8.1
[INFO] [stderr]    Compiling yamux v0.12.1
[INFO] [stderr]    Compiling yamux v0.13.4
[INFO] [stderr]    Compiling quickcheck v1.0.3
[INFO] [stderr]    Compiling rtnetlink v0.13.1
[INFO] [stderr]    Compiling libp2p-core v0.41.3
[INFO] [stderr]    Compiling if-watch v3.2.1
[INFO] [stderr]    Compiling libp2p-swarm v0.44.2
[INFO] [stderr]    Compiling libp2p-websocket v0.43.2
[INFO] [stderr]    Compiling libp2p-noise v0.44.0
[INFO] [stderr]    Compiling libp2p-yamux v0.45.2
[INFO] [stderr]    Compiling libp2p-tcp v0.41.0
[INFO] [stderr]    Compiling rstest v0.18.2
[INFO] [stderr]    Compiling trust-dns-proto v0.23.2
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling hickory-resolver v0.24.4
[INFO] [stderr]    Compiling tokio-test v0.4.4
[INFO] [stderr]    Compiling libp2p-relay v0.17.2
[INFO] [stderr]    Compiling libp2p-ping v0.44.1
[INFO] [stderr]    Compiling libp2p-kad v0.45.3
[INFO] [stderr]    Compiling libp2p-identify v0.44.2
[INFO] [stderr]    Compiling libp2p-allow-block-list v0.3.0
[INFO] [stderr]    Compiling libp2p-request-response v0.26.3
[INFO] [stderr]    Compiling libp2p-connection-limits v0.3.1
[INFO] [stderr]    Compiling libp2p-dns v0.41.1
[INFO] [stderr]    Compiling libp2p-metrics v0.14.1
[INFO] [stderr]    Compiling trust-dns-resolver v0.23.2
[INFO] [stderr]    Compiling libp2p v0.53.2
[INFO] [stderr]    Compiling prozchain v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `crate::network::message::Message`
[INFO] [stdout]  --> src/network/block_propagation.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::network::message::Message;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AsyncRead` and `AsyncWrite`
[INFO] [stdout]  --> src/network/connection.rs:8:17
[INFO] [stdout]   |
[INFO] [stdout] 8 | use tokio::io::{AsyncRead, AsyncWrite};
[INFO] [stdout]   |                 ^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TcpListener`
[INFO] [stdout]  --> src/network/connection.rs:9:18
[INFO] [stdout]   |
[INFO] [stdout] 9 | use tokio::net::{TcpListener, TcpStream};
[INFO] [stdout]   |                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Mutex` and `RwLock`
[INFO] [stdout]   --> src/network/connection.rs:10:25
[INFO] [stdout]    |
[INFO] [stdout] 10 | use tokio::sync::{mpsc, Mutex, RwLock};
[INFO] [stdout]    |                         ^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Counter`, `Gauge`, and `Histogram`
[INFO] [stdout]  --> src/network/metrics/mod.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     Counter, Gauge, Histogram, HistogramOpts, HistogramVec, IntCounter, IntGauge, Registry
[INFO] [stdout]   |     ^^^^^^^  ^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `full_block_msg`
[INFO] [stdout]    --> src/network/block_propagation.rs:157:13
[INFO] [stdout]     |
[INFO] [stdout] 157 |         let full_block_msg = BlockAnnouncement::FullBlock(block.clone());
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_full_block_msg`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `compact_block`
[INFO] [stdout]    --> src/network/block_propagation.rs:159:13
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let compact_block = if self.compact_blocks_enabled {
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_compact_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header_only_msg`
[INFO] [stdout]    --> src/network/block_propagation.rs:165:13
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let header_only_msg = BlockAnnouncement::HeaderOnly {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_header_only_msg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message_tx`
[INFO] [stdout]    --> src/network/service.rs:351:9
[INFO] [stdout]     |
[INFO] [stdout] 351 |         message_tx: mpsc::Sender<NetworkMessage>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_tx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `protocol_version`
[INFO] [stdout]    --> src/network/connection.rs:141:33
[INFO] [stdout]     |
[INFO] [stdout] 141 |                 Ok(Ok((peer_id, protocol_version, user_agent))) => {
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_protocol_version`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `user_agent`
[INFO] [stdout]    --> src/network/connection.rs:141:51
[INFO] [stdout]     |
[INFO] [stdout] 141 |                 Ok(Ok((peer_id, protocol_version, user_agent))) => {
[INFO] [stdout]     |                                                   ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_agent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::network::message::Message`
[INFO] [stdout]  --> src/network/block_propagation.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::network::message::Message;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AsyncRead` and `AsyncWrite`
[INFO] [stdout]  --> src/network/connection.rs:8:17
[INFO] [stdout]   |
[INFO] [stdout] 8 | use tokio::io::{AsyncRead, AsyncWrite};
[INFO] [stdout]   |                 ^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TcpListener`
[INFO] [stdout]  --> src/network/connection.rs:9:18
[INFO] [stdout]   |
[INFO] [stdout] 9 | use tokio::net::{TcpListener, TcpStream};
[INFO] [stdout]   |                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Mutex` and `RwLock`
[INFO] [stdout]   --> src/network/connection.rs:10:25
[INFO] [stdout]    |
[INFO] [stdout] 10 | use tokio::sync::{mpsc, Mutex, RwLock};
[INFO] [stdout]    |                         ^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Counter`, `Gauge`, and `Histogram`
[INFO] [stdout]  --> src/network/metrics/mod.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     Counter, Gauge, Histogram, HistogramOpts, HistogramVec, IntCounter, IntGauge, Registry
[INFO] [stdout]   |     ^^^^^^^  ^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `first_seen` is never read
[INFO] [stdout]   --> src/network/discovery.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 31 | struct LocalPeerRecord {
[INFO] [stdout]    |        --------------- field in this struct
[INFO] [stdout] 32 |     first_seen: Instant,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `LocalPeerRecord` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `PeerExchange` and `LocalDiscovery` are never constructed
[INFO] [stdout]   --> src/network/discovery.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | enum PeerSource {
[INFO] [stdout]    |      ---------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 45 |     PeerExchange,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 46 |     LocalDiscovery,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PeerSource` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `local_peer_id` is never read
[INFO] [stdout]    --> src/network/propagation.rs:239:5
[INFO] [stdout]     |
[INFO] [stdout] 233 | pub struct GossipManager {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 239 |     local_peer_id: PeerId,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `broadcast_manager`, `compact_announcements`, and `seen_transactions` are never read
[INFO] [stdout]    --> src/network/propagation.rs:410:5
[INFO] [stdout]     |
[INFO] [stdout] 409 | pub struct TransactionPropagator {
[INFO] [stdout]     |            --------------------- fields in this struct
[INFO] [stdout] 410 |     broadcast_manager: BroadcastManager,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 411 |     compact_announcements: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 412 |     seen_transactions: HashSet<[u8; 32]>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `min_outbound_connections` and `peer_reputation` are never read
[INFO] [stdout]   --> src/network/security.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub struct SybilProtection {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 68 |     min_outbound_connections: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 69 |     max_inbound_per_ip: usize,
[INFO] [stdout] 70 |     peer_reputation: ReputationTracker,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ttl` is never read
[INFO] [stdout]    --> src/network/security.rs:379:5
[INFO] [stdout]     |
[INFO] [stdout] 377 | pub struct ExpiringCache<K, V> {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] 378 |     entries: HashMap<K, (V, Instant)>,
[INFO] [stdout] 379 |     ttl: Duration,
[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]  --> src/network/interfaces.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     async fn connected_peer_count(&self) -> usize;
[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] 9 -     async fn connected_peer_count(&self) -> usize;
[INFO] [stdout] 9 +     fn connected_peer_count(&self) -> impl std::future::Future<Output = usize> + 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]   --> src/network/interfaces.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     async fn connected_validator_count(&self) -> usize;
[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 connected_validator_count(&self) -> usize;
[INFO] [stdout] 12 +     fn connected_validator_count(&self) -> impl std::future::Future<Output = usize> + 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]   --> src/network/interfaces.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     async fn average_peer_latency(&self) -> Duration;
[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 average_peer_latency(&self) -> Duration;
[INFO] [stdout] 15 +     fn average_peer_latency(&self) -> impl std::future::Future<Output = Duration> + 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]   --> src/network/interfaces.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     async fn trigger_peer_discovery(&self);
[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] 18 -     async fn trigger_peer_discovery(&self);
[INFO] [stdout] 18 +     fn trigger_peer_discovery(&self) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     async fn prioritize_validator_connections(&self);
[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] 21 -     async fn prioritize_validator_connections(&self);
[INFO] [stdout] 21 +     fn prioritize_validator_connections(&self) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     async fn propagate_block(&self, block_data: Vec<u8>) -> Result<(), 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] 27 -     async fn propagate_block(&self, block_data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 27 +     fn propagate_block(&self, block_data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     async fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), 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] 30 -     async fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 30 +     fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     async fn propagate_transaction(&self, tx_data: Vec<u8>) -> Result<(), 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] 36 -     async fn propagate_transaction(&self, tx_data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 36 +     fn propagate_transaction(&self, tx_data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     async fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), 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] 39 -     async fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 39 +     fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     async fn discover_peers(&self) -> Result<Vec<crate::network::discovery::PeerInfo>, 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] 45 -     async fn discover_peers(&self) -> Result<Vec<crate::network::discovery::PeerInfo>, String>;
[INFO] [stdout] 45 +     fn discover_peers(&self) -> impl std::future::Future<Output = Result<Vec<crate::network::discovery::PeerInfo>, 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]   --> src/network/interfaces.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     async fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo);
[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] 48 -     async fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo);
[INFO] [stdout] 48 +     fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 51 |     async fn get_known_peers(&self) -> Vec<crate::network::discovery::PeerInfo>;
[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] 51 -     async fn get_known_peers(&self) -> Vec<crate::network::discovery::PeerInfo>;
[INFO] [stdout] 51 +     fn get_known_peers(&self) -> impl std::future::Future<Output = Vec<crate::network::discovery::PeerInfo>> + 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]   --> src/network/interfaces.rs:57:5
[INFO] [stdout]    |
[INFO] [stdout] 57 |     async fn connect_to_peer(&self, address: std::net::SocketAddr) -> Result<PeerId, 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] 57 -     async fn connect_to_peer(&self, address: std::net::SocketAddr) -> Result<PeerId, String>;
[INFO] [stdout] 57 +     fn connect_to_peer(&self, address: std::net::SocketAddr) -> impl std::future::Future<Output = Result<PeerId, 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]   --> src/network/interfaces.rs:60:5
[INFO] [stdout]    |
[INFO] [stdout] 60 |     async fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason);
[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] 60 -     async fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason);
[INFO] [stdout] 60 +     fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 63 |     async fn is_connected_to(&self, peer_id: &PeerId) -> 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] 63 -     async fn is_connected_to(&self, peer_id: &PeerId) -> bool;
[INFO] [stdout] 63 +     fn is_connected_to(&self, peer_id: &PeerId) -> impl std::future::Future<Output = 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]   --> src/network/interfaces.rs:66:5
[INFO] [stdout]    |
[INFO] [stdout] 66 |     async fn connection_count(&self) -> usize;
[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] 66 -     async fn connection_count(&self) -> usize;
[INFO] [stdout] 66 +     fn connection_count(&self) -> impl std::future::Future<Output = usize> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused implementer of `Future` that must be used
[INFO] [stdout]    --> src/network/security.rs:523:13
[INFO] [stdout]     |
[INFO] [stdout] 523 |             self.connection_manager.disconnect(peer_id, DisconnectReason::PeerBanned);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `full_block_msg`
[INFO] [stdout]    --> src/network/block_propagation.rs:157:13
[INFO] [stdout]     |
[INFO] [stdout] 157 |         let full_block_msg = BlockAnnouncement::FullBlock(block.clone());
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_full_block_msg`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `compact_block`
[INFO] [stdout]    --> src/network/block_propagation.rs:159:13
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let compact_block = if self.compact_blocks_enabled {
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_compact_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header_only_msg`
[INFO] [stdout]    --> src/network/block_propagation.rs:165:13
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let header_only_msg = BlockAnnouncement::HeaderOnly {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_header_only_msg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message_tx`
[INFO] [stdout]    --> src/network/service.rs:351:9
[INFO] [stdout]     |
[INFO] [stdout] 351 |         message_tx: mpsc::Sender<NetworkMessage>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_tx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `protocol_version`
[INFO] [stdout]    --> src/network/connection.rs:141:33
[INFO] [stdout]     |
[INFO] [stdout] 141 |                 Ok(Ok((peer_id, protocol_version, user_agent))) => {
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_protocol_version`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `user_agent`
[INFO] [stdout]    --> src/network/connection.rs:141:51
[INFO] [stdout]     |
[INFO] [stdout] 141 |                 Ok(Ok((peer_id, protocol_version, user_agent))) => {
[INFO] [stdout]     |                                                   ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_agent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `first_seen` is never read
[INFO] [stdout]   --> src/network/discovery.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 31 | struct LocalPeerRecord {
[INFO] [stdout]    |        --------------- field in this struct
[INFO] [stdout] 32 |     first_seen: Instant,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `LocalPeerRecord` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `PeerExchange` and `LocalDiscovery` are never constructed
[INFO] [stdout]   --> src/network/discovery.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | enum PeerSource {
[INFO] [stdout]    |      ---------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 45 |     PeerExchange,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 46 |     LocalDiscovery,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PeerSource` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `local_peer_id` is never read
[INFO] [stdout]    --> src/network/propagation.rs:239:5
[INFO] [stdout]     |
[INFO] [stdout] 233 | pub struct GossipManager {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 239 |     local_peer_id: PeerId,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `broadcast_manager`, `compact_announcements`, and `seen_transactions` are never read
[INFO] [stdout]    --> src/network/propagation.rs:410:5
[INFO] [stdout]     |
[INFO] [stdout] 409 | pub struct TransactionPropagator {
[INFO] [stdout]     |            --------------------- fields in this struct
[INFO] [stdout] 410 |     broadcast_manager: BroadcastManager,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 411 |     compact_announcements: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 412 |     seen_transactions: HashSet<[u8; 32]>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `min_outbound_connections` and `peer_reputation` are never read
[INFO] [stdout]   --> src/network/security.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub struct SybilProtection {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 68 |     min_outbound_connections: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 69 |     max_inbound_per_ip: usize,
[INFO] [stdout] 70 |     peer_reputation: ReputationTracker,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ttl` is never read
[INFO] [stdout]    --> src/network/security.rs:379:5
[INFO] [stdout]     |
[INFO] [stdout] 377 | pub struct ExpiringCache<K, V> {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] 378 |     entries: HashMap<K, (V, Instant)>,
[INFO] [stdout] 379 |     ttl: Duration,
[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]  --> src/network/interfaces.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     async fn connected_peer_count(&self) -> usize;
[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] 9 -     async fn connected_peer_count(&self) -> usize;
[INFO] [stdout] 9 +     fn connected_peer_count(&self) -> impl std::future::Future<Output = usize> + 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]   --> src/network/interfaces.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     async fn connected_validator_count(&self) -> usize;
[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 connected_validator_count(&self) -> usize;
[INFO] [stdout] 12 +     fn connected_validator_count(&self) -> impl std::future::Future<Output = usize> + 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]   --> src/network/interfaces.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     async fn average_peer_latency(&self) -> Duration;
[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 average_peer_latency(&self) -> Duration;
[INFO] [stdout] 15 +     fn average_peer_latency(&self) -> impl std::future::Future<Output = Duration> + 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]   --> src/network/interfaces.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     async fn trigger_peer_discovery(&self);
[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] 18 -     async fn trigger_peer_discovery(&self);
[INFO] [stdout] 18 +     fn trigger_peer_discovery(&self) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     async fn prioritize_validator_connections(&self);
[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] 21 -     async fn prioritize_validator_connections(&self);
[INFO] [stdout] 21 +     fn prioritize_validator_connections(&self) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     async fn propagate_block(&self, block_data: Vec<u8>) -> Result<(), 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] 27 -     async fn propagate_block(&self, block_data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 27 +     fn propagate_block(&self, block_data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     async fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), 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] 30 -     async fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 30 +     fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     async fn propagate_transaction(&self, tx_data: Vec<u8>) -> Result<(), 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] 36 -     async fn propagate_transaction(&self, tx_data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 36 +     fn propagate_transaction(&self, tx_data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     async fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), 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] 39 -     async fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), String>;
[INFO] [stdout] 39 +     fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     async fn discover_peers(&self) -> Result<Vec<crate::network::discovery::PeerInfo>, 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] 45 -     async fn discover_peers(&self) -> Result<Vec<crate::network::discovery::PeerInfo>, String>;
[INFO] [stdout] 45 +     fn discover_peers(&self) -> impl std::future::Future<Output = Result<Vec<crate::network::discovery::PeerInfo>, 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]   --> src/network/interfaces.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     async fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo);
[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] 48 -     async fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo);
[INFO] [stdout] 48 +     fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 51 |     async fn get_known_peers(&self) -> Vec<crate::network::discovery::PeerInfo>;
[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] 51 -     async fn get_known_peers(&self) -> Vec<crate::network::discovery::PeerInfo>;
[INFO] [stdout] 51 +     fn get_known_peers(&self) -> impl std::future::Future<Output = Vec<crate::network::discovery::PeerInfo>> + 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]   --> src/network/interfaces.rs:57:5
[INFO] [stdout]    |
[INFO] [stdout] 57 |     async fn connect_to_peer(&self, address: std::net::SocketAddr) -> Result<PeerId, 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] 57 -     async fn connect_to_peer(&self, address: std::net::SocketAddr) -> Result<PeerId, String>;
[INFO] [stdout] 57 +     fn connect_to_peer(&self, address: std::net::SocketAddr) -> impl std::future::Future<Output = Result<PeerId, 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]   --> src/network/interfaces.rs:60:5
[INFO] [stdout]    |
[INFO] [stdout] 60 |     async fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason);
[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] 60 -     async fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason);
[INFO] [stdout] 60 +     fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 63 |     async fn is_connected_to(&self, peer_id: &PeerId) -> 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] 63 -     async fn is_connected_to(&self, peer_id: &PeerId) -> bool;
[INFO] [stdout] 63 +     fn is_connected_to(&self, peer_id: &PeerId) -> impl std::future::Future<Output = 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]   --> src/network/interfaces.rs:66:5
[INFO] [stdout]    |
[INFO] [stdout] 66 |     async fn connection_count(&self) -> usize;
[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] 66 -     async fn connection_count(&self) -> usize;
[INFO] [stdout] 66 +     fn connection_count(&self) -> impl std::future::Future<Output = usize> + Send;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused implementer of `Future` that must be used
[INFO] [stdout]    --> src/network/security.rs:523:13
[INFO] [stdout]     |
[INFO] [stdout] 523 |             self.connection_manager.disconnect(peer_id, DisconnectReason::PeerBanned);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `log` is never read
[INFO] [stdout]    --> src/main.rs:235:13
[INFO] [stdout]     |
[INFO] [stdout] 232 |     pub struct Config {
[INFO] [stdout]     |                ------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 235 |         pub log: Option<Log>,
[INFO] [stdout]     |             ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `level`, `enable_file_logging`, and `log_file` are never read
[INFO] [stdout]    --> src/main.rs:271:13
[INFO] [stdout]     |
[INFO] [stdout] 270 |     pub struct Log {
[INFO] [stdout]     |                --- fields in this struct
[INFO] [stdout] 271 |         pub level: String,
[INFO] [stdout]     |             ^^^^^
[INFO] [stdout] 272 |         pub enable_file_logging: bool,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 273 |         pub log_file: String,
[INFO] [stdout]     |             ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 17.80s
[INFO] running `Command { std: "docker" "inspect" "a4799382206b38ee0e222a01fbd0a4ff4bc1bacd484a981810dbe87d3c8c8e85", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a4799382206b38ee0e222a01fbd0a4ff4bc1bacd484a981810dbe87d3c8c8e85", kill_on_drop: false }`
[INFO] [stdout] a4799382206b38ee0e222a01fbd0a4ff4bc1bacd484a981810dbe87d3c8c8e85
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] fd985ef00c15f14d12cda9e113047462bff53e691328c2bb2014cd7b10a8cfe7
[INFO] running `Command { std: "docker" "start" "-a" "fd985ef00c15f14d12cda9e113047462bff53e691328c2bb2014cd7b10a8cfe7", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `crate::network::message::Message`
[INFO] [stderr]  --> src/network/block_propagation.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::network::message::Message;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `AsyncRead` and `AsyncWrite`
[INFO] [stderr]  --> src/network/connection.rs:8:17
[INFO] [stderr]   |
[INFO] [stderr] 8 | use tokio::io::{AsyncRead, AsyncWrite};
[INFO] [stderr]   |                 ^^^^^^^^^  ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `TcpListener`
[INFO] [stderr]  --> src/network/connection.rs:9:18
[INFO] [stderr]   |
[INFO] [stderr] 9 | use tokio::net::{TcpListener, TcpStream};
[INFO] [stderr]   |                  ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Mutex` and `RwLock`
[INFO] [stderr]   --> src/network/connection.rs:10:25
[INFO] [stderr]    |
[INFO] [stderr] 10 | use tokio::sync::{mpsc, Mutex, RwLock};
[INFO] [stderr]    |                         ^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Counter`, `Gauge`, and `Histogram`
[INFO] [stderr]  --> src/network/metrics/mod.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 |     Counter, Gauge, Histogram, HistogramOpts, HistogramVec, IntCounter, IntGauge, Registry
[INFO] [stderr]   |     ^^^^^^^  ^^^^^  ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `full_block_msg`
[INFO] [stderr]    --> src/network/block_propagation.rs:157:13
[INFO] [stderr]     |
[INFO] [stderr] 157 |         let full_block_msg = BlockAnnouncement::FullBlock(block.clone());
[INFO] [stderr]     |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_full_block_msg`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `compact_block`
[INFO] [stderr]    --> src/network/block_propagation.rs:159:13
[INFO] [stderr]     |
[INFO] [stderr] 159 |         let compact_block = if self.compact_blocks_enabled {
[INFO] [stderr]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_compact_block`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header_only_msg`
[INFO] [stderr]    --> src/network/block_propagation.rs:165:13
[INFO] [stderr]     |
[INFO] [stderr] 165 |         let header_only_msg = BlockAnnouncement::HeaderOnly {
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_header_only_msg`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `message_tx`
[INFO] [stderr]    --> src/network/service.rs:351:9
[INFO] [stderr]     |
[INFO] [stderr] 351 |         message_tx: mpsc::Sender<NetworkMessage>,
[INFO] [stderr]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_tx`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `protocol_version`
[INFO] [stderr]    --> src/network/connection.rs:141:33
[INFO] [stderr]     |
[INFO] [stderr] 141 |                 Ok(Ok((peer_id, protocol_version, user_agent))) => {
[INFO] [stderr]     |                                 ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_protocol_version`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `user_agent`
[INFO] [stderr]    --> src/network/connection.rs:141:51
[INFO] [stderr]     |
[INFO] [stderr] 141 |                 Ok(Ok((peer_id, protocol_version, user_agent))) => {
[INFO] [stderr]     |                                                   ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_agent`
[INFO] [stderr] 
[INFO] [stderr] warning: field `first_seen` is never read
[INFO] [stderr]   --> src/network/discovery.rs:32:5
[INFO] [stderr]    |
[INFO] [stderr] 31 | struct LocalPeerRecord {
[INFO] [stderr]    |        --------------- field in this struct
[INFO] [stderr] 32 |     first_seen: Instant,
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `LocalPeerRecord` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variants `PeerExchange` and `LocalDiscovery` are never constructed
[INFO] [stderr]   --> src/network/discovery.rs:45:5
[INFO] [stderr]    |
[INFO] [stderr] 42 | enum PeerSource {
[INFO] [stderr]    |      ---------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 45 |     PeerExchange,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 46 |     LocalDiscovery,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `PeerSource` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `local_peer_id` is never read
[INFO] [stderr]    --> src/network/propagation.rs:239:5
[INFO] [stderr]     |
[INFO] [stderr] 233 | pub struct GossipManager {
[INFO] [stderr]     |            ------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 239 |     local_peer_id: PeerId,
[INFO] [stderr]     |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `broadcast_manager`, `compact_announcements`, and `seen_transactions` are never read
[INFO] [stderr]    --> src/network/propagation.rs:410:5
[INFO] [stderr]     |
[INFO] [stderr] 409 | pub struct TransactionPropagator {
[INFO] [stderr]     |            --------------------- fields in this struct
[INFO] [stderr] 410 |     broadcast_manager: BroadcastManager,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 411 |     compact_announcements: bool,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 412 |     seen_transactions: HashSet<[u8; 32]>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `min_outbound_connections` and `peer_reputation` are never read
[INFO] [stderr]   --> src/network/security.rs:68:5
[INFO] [stderr]    |
[INFO] [stderr] 67 | pub struct SybilProtection {
[INFO] [stderr]    |            --------------- fields in this struct
[INFO] [stderr] 68 |     min_outbound_connections: usize,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 69 |     max_inbound_per_ip: usize,
[INFO] [stderr] 70 |     peer_reputation: ReputationTracker,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `ttl` is never read
[INFO] [stderr]    --> src/network/security.rs:379:5
[INFO] [stderr]     |
[INFO] [stderr] 377 | pub struct ExpiringCache<K, V> {
[INFO] [stderr]     |            ------------- field in this struct
[INFO] [stderr] 378 |     entries: HashMap<K, (V, Instant)>,
[INFO] [stderr] 379 |     ttl: Duration,
[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]  --> src/network/interfaces.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 |     async fn connected_peer_count(&self) -> usize;
[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] 9 -     async fn connected_peer_count(&self) -> usize;
[INFO] [stderr] 9 +     fn connected_peer_count(&self) -> impl std::future::Future<Output = usize> + 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]   --> src/network/interfaces.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 12 |     async fn connected_validator_count(&self) -> usize;
[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 connected_validator_count(&self) -> usize;
[INFO] [stderr] 12 +     fn connected_validator_count(&self) -> impl std::future::Future<Output = usize> + 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]   --> src/network/interfaces.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 |     async fn average_peer_latency(&self) -> Duration;
[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 average_peer_latency(&self) -> Duration;
[INFO] [stderr] 15 +     fn average_peer_latency(&self) -> impl std::future::Future<Output = Duration> + 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]   --> src/network/interfaces.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 |     async fn trigger_peer_discovery(&self);
[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] 18 -     async fn trigger_peer_discovery(&self);
[INFO] [stderr] 18 +     fn trigger_peer_discovery(&self) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 21 |     async fn prioritize_validator_connections(&self);
[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] 21 -     async fn prioritize_validator_connections(&self);
[INFO] [stderr] 21 +     fn prioritize_validator_connections(&self) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:27:5
[INFO] [stderr]    |
[INFO] [stderr] 27 |     async fn propagate_block(&self, block_data: Vec<u8>) -> Result<(), 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] 27 -     async fn propagate_block(&self, block_data: Vec<u8>) -> Result<(), String>;
[INFO] [stderr] 27 +     fn propagate_block(&self, block_data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:30:5
[INFO] [stderr]    |
[INFO] [stderr] 30 |     async fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), 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] 30 -     async fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), String>;
[INFO] [stderr] 30 +     fn handle_block_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:36:5
[INFO] [stderr]    |
[INFO] [stderr] 36 |     async fn propagate_transaction(&self, tx_data: Vec<u8>) -> Result<(), 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] 36 -     async fn propagate_transaction(&self, tx_data: Vec<u8>) -> Result<(), String>;
[INFO] [stderr] 36 +     fn propagate_transaction(&self, tx_data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:39:5
[INFO] [stderr]    |
[INFO] [stderr] 39 |     async fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), 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] 39 -     async fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> Result<(), String>;
[INFO] [stderr] 39 +     fn handle_transaction_announcement(&self, peer_id: PeerId, data: Vec<u8>) -> impl std::future::Future<Output = Result<(), 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]   --> src/network/interfaces.rs:45:5
[INFO] [stderr]    |
[INFO] [stderr] 45 |     async fn discover_peers(&self) -> Result<Vec<crate::network::discovery::PeerInfo>, 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] 45 -     async fn discover_peers(&self) -> Result<Vec<crate::network::discovery::PeerInfo>, String>;
[INFO] [stderr] 45 +     fn discover_peers(&self) -> impl std::future::Future<Output = Result<Vec<crate::network::discovery::PeerInfo>, 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]   --> src/network/interfaces.rs:48:5
[INFO] [stderr]    |
[INFO] [stderr] 48 |     async fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo);
[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] 48 -     async fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo);
[INFO] [stderr] 48 +     fn register_peer(&self, peer_info: crate::network::discovery::PeerInfo) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:51:5
[INFO] [stderr]    |
[INFO] [stderr] 51 |     async fn get_known_peers(&self) -> Vec<crate::network::discovery::PeerInfo>;
[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] 51 -     async fn get_known_peers(&self) -> Vec<crate::network::discovery::PeerInfo>;
[INFO] [stderr] 51 +     fn get_known_peers(&self) -> impl std::future::Future<Output = Vec<crate::network::discovery::PeerInfo>> + 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]   --> src/network/interfaces.rs:57:5
[INFO] [stderr]    |
[INFO] [stderr] 57 |     async fn connect_to_peer(&self, address: std::net::SocketAddr) -> Result<PeerId, 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] 57 -     async fn connect_to_peer(&self, address: std::net::SocketAddr) -> Result<PeerId, String>;
[INFO] [stderr] 57 +     fn connect_to_peer(&self, address: std::net::SocketAddr) -> impl std::future::Future<Output = Result<PeerId, 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]   --> src/network/interfaces.rs:60:5
[INFO] [stderr]    |
[INFO] [stderr] 60 |     async fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason);
[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] 60 -     async fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason);
[INFO] [stderr] 60 +     fn disconnect_peer(&self, peer_id: &PeerId, reason: crate::types::DisconnectReason) -> impl std::future::Future<Output = ()> + 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]   --> src/network/interfaces.rs:63:5
[INFO] [stderr]    |
[INFO] [stderr] 63 |     async fn is_connected_to(&self, peer_id: &PeerId) -> 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] 63 -     async fn is_connected_to(&self, peer_id: &PeerId) -> bool;
[INFO] [stderr] 63 +     fn is_connected_to(&self, peer_id: &PeerId) -> impl std::future::Future<Output = 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]   --> src/network/interfaces.rs:66:5
[INFO] [stderr]    |
[INFO] [stderr] 66 |     async fn connection_count(&self) -> usize;
[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] 66 -     async fn connection_count(&self) -> usize;
[INFO] [stderr] 66 +     fn connection_count(&self) -> impl std::future::Future<Output = usize> + Send;
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused implementer of `Future` that must be used
[INFO] [stderr]    --> src/network/security.rs:523:13
[INFO] [stderr]     |
[INFO] [stderr] 523 |             self.connection_manager.disconnect(peer_id, DisconnectReason::PeerBanned);
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `prozchain` (lib) generated 34 warnings (run `cargo fix --lib -p prozchain` to apply 5 suggestions)
[INFO] [stderr] warning: field `log` is never read
[INFO] [stderr]    --> src/main.rs:235:13
[INFO] [stderr]     |
[INFO] [stderr] 232 |     pub struct Config {
[INFO] [stderr]     |                ------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 235 |         pub log: Option<Log>,
[INFO] [stderr]     |             ^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: fields `level`, `enable_file_logging`, and `log_file` are never read
[INFO] [stderr]    --> src/main.rs:271:13
[INFO] [stderr]     |
[INFO] [stderr] 270 |     pub struct Log {
[INFO] [stderr]     |                --- fields in this struct
[INFO] [stderr] 271 |         pub level: String,
[INFO] [stderr]     |             ^^^^^
[INFO] [stderr] 272 |         pub enable_file_logging: bool,
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 273 |         pub log_file: String,
[INFO] [stderr]     |             ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `prozchain` (lib test) generated 34 warnings (34 duplicates)
[INFO] [stderr] warning: `prozchain` (bin "prozchain" test) generated 2 warnings
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.60s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/prozchain_lib-3ab2f3dfd70745b7)
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test network::tests::tests::test_network_service_startup ... ignored
[INFO] [stdout] test network::tests::tests::test_peer_discovery ... ok
[INFO] [stdout] test network::tests::tests::test_create_node ... ok
[INFO] [stdout] test network::tests::tests::test_message_serialization ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- network::tests::tests::test_message_serialization stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'network::tests::tests::test_message_serialization' panicked at src/network/tests.rs:38:9:
[INFO] [stdout] Should deserialize successfully
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5a8e6c8b7e02 - std::backtrace_rs::backtrace::libunwind::trace::h2d45396358f41939
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5a8e6c8b7e02 - std::backtrace_rs::backtrace::trace_unsynchronized::hffcefc0b67f1d6e2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5a8e6c8b7e02 - std::sys::backtrace::_print_fmt::hd72f71d23b436b92
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5a8e6c8b7e02 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::hdcfcb6d4c8489523
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5a8e6c8e04d3 - core::fmt::rt::Argument::fmt::h2c56b3114963061a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5a8e6c8e04d3 - core::fmt::write::h8a494366950f23bb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x5a8e6c8b4503 - std::io::default_write_fmt::h7b8824096454f323
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5a8e6c8b4503 - std::io::Write::write_fmt::h4e71294925c334d0
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5a8e6c8b7c52 - std::sys::backtrace::BacktraceLock::print::hb2a626a81e06b2dc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5a8e6c8b9379 - std::panicking::default_hook::{{closure}}::h4f78485264f12d10
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x5a8e6c8b91ae - std::panicking::default_hook::h2c66fc99e962531d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x5a8e6c7828a4 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hb6bd65493727d71a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x5a8e6c7828a4 - test::test_main_with_exit_callback::{{closure}}::h60217ec76a0ece4a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5a8e6c8b9d4e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h318e4efb8c1a5689
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x5a8e6c8b9d4e - std::panicking::rust_panic_with_hook::h33ac55f64bbd807d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x5a8e6c8b9ae6 - std::panicking::begin_panic_handler::{{closure}}::h30e7cb89678a57fe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:699:13
[INFO] [stdout]   16:     0x5a8e6c8b82f9 - std::sys::backtrace::__rust_end_short_backtrace::hed60f27456c16ced
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x5a8e6c8b97ad - __rustc[de2ca18b4c54d5b8]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x5a8e6c8dea40 - core::panicking::panic_fmt::h62f63d096dd276af
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x5a8e6c6e399e - prozchain_lib::network::tests::tests::test_message_serialization::{{closure}}::hc93aad8897f6c1f3
[INFO] [stdout]                                at /opt/rustwide/workdir/src/network/tests.rs:38:9
[INFO] [stdout]   20:     0x5a8e6c6f8d42 - <core::pin::Pin<P> as core::future::future::Future>::poll::hc699f507494afe0b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/future/future.rs:133:9
[INFO] [stdout]   21:     0x5a8e6c6f8d7d - <core::pin::Pin<P> as core::future::future::Future>::poll::hd61b89bf31bd31c5
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/future/future.rs:133:9
[INFO] [stdout]   22:     0x5a8e6c6f0cad - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::{{closure}}::he6be781039e15a5d
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/scheduler/current_thread/mod.rs:733:70
[INFO] [stdout]   23:     0x5a8e6c6f0bbb - tokio::task::coop::with_budget::hf5a39c3d4db62214
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/task/coop/mod.rs:167:5
[INFO] [stdout]   24:     0x5a8e6c6f0bbb - tokio::task::coop::budget::hf8c41b024491f24c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/task/coop/mod.rs:133:5
[INFO] [stdout]   25:     0x5a8e6c6f0bbb - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::hbdc8b81d548c1a9f
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/scheduler/current_thread/mod.rs:733:25
[INFO] [stdout]   26:     0x5a8e6c6ee000 - tokio::runtime::scheduler::current_thread::Context::enter::h936457b65dad03a3
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/scheduler/current_thread/mod.rs:432:19
[INFO] [stdout]   27:     0x5a8e6c6f00d0 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::hf5d952edb46ee8b2
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/scheduler/current_thread/mod.rs:732:44
[INFO] [stdout]   28:     0x5a8e6c6ef2d4 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::{{closure}}::ha63d1af9f0771e74
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/scheduler/current_thread/mod.rs:820:68
[INFO] [stdout]   29:     0x5a8e6c7219fb - tokio::runtime::context::scoped::Scoped<T>::set::h473a764be98dbd50
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   30:     0x5a8e6c725ab9 - tokio::runtime::context::set_scheduler::{{closure}}::h074346f819214f9c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/context.rs:180:38
[INFO] [stdout]   31:     0x5a8e6c72bd12 - std::thread::local::LocalKey<T>::try_with::h2396ea3f4fa7b03d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/local.rs:315:12
[INFO] [stdout]   32:     0x5a8e6c72b8de - std::thread::local::LocalKey<T>::with::h3f8d0da04c8c297a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/local.rs:279:20
[INFO] [stdout]   33:     0x5a8e6c725a2d - tokio::runtime::context::set_scheduler::h125b476510a53848
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/context.rs:180:17
[INFO] [stdout]   34:     0x5a8e6c6eec60 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::h247e5257316dcbe7
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/scheduler/current_thread/mod.rs:820:27
[INFO] [stdout]   35:     0x5a8e6c6ef373 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::hfc6d89e8fa08de2d
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/scheduler/current_thread/mod.rs:720:24
[INFO] [stdout]   36:     0x5a8e6c6eb8b3 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::{{closure}}::h93ce6d50d4d256fa
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   37:     0x5a8e6c6ea980 - tokio::runtime::context::runtime::enter_runtime::h80b9aeb84eb99f65
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   38:     0x5a8e6c6eb5b1 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::h3897115362a611f6
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   39:     0x5a8e6c6e1124 - tokio::runtime::runtime::Runtime::block_on_inner::hd8c419544cb5a57c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/runtime.rs:368:52
[INFO] [stdout]   40:     0x5a8e6c6e12e7 - tokio::runtime::runtime::Runtime::block_on::h80f94a9d05580ece
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.44.1/src/runtime/runtime.rs:342:18
[INFO] [stdout]   41:     0x5a8e6c6e3429 - prozchain_lib::network::tests::tests::test_message_serialization::h3367e50638f2103c
[INFO] [stdout]                                at /opt/rustwide/workdir/src/network/tests.rs:42:109
[INFO] [stdout]   42:     0x5a8e6c6e32f7 - prozchain_lib::network::tests::tests::test_message_serialization::{{closure}}::h61157c83d21cb219
[INFO] [stdout]                                at /opt/rustwide/workdir/src/network/tests.rs:29:42
[INFO] [stdout]   43:     0x5a8e6c696116 - core::ops::function::FnOnce::call_once::ha4ae7ae75c7e7bc1
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   44:     0x5a8e6c78810b - core::ops::function::FnOnce::call_once::h1f9474f1347fff52
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   45:     0x5a8e6c78810b - test::__rust_begin_short_backtrace::ha52ab26e77157f03
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:648:18
[INFO] [stdout]   46:     0x5a8e6c787245 - test::run_test_in_process::{{closure}}::h229c1a11a50b261f
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:74
[INFO] [stdout]   47:     0x5a8e6c787245 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h78821afbf97b39a9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   48:     0x5a8e6c787245 - std::panicking::catch_unwind::do_call::h53abf3ed5bd32ba3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   49:     0x5a8e6c787245 - std::panicking::catch_unwind::h6deb5fe1e91873c9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   50:     0x5a8e6c787245 - std::panic::catch_unwind::hea0829b6b565654b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   51:     0x5a8e6c787245 - test::run_test_in_process::hdc44dfecea3db21b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:27
[INFO] [stdout]   52:     0x5a8e6c787245 - test::run_test::{{closure}}::h0364ba59bf23f652
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:592:43
[INFO] [stdout]   53:     0x5a8e6c74ae44 - test::run_test::{{closure}}::h32730b304eec05da
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:622:41
[INFO] [stdout]   54:     0x5a8e6c74ae44 - std::sys::backtrace::__rust_begin_short_backtrace::h177cb952fc54ad2c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   55:     0x5a8e6c74e81a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h119d903520007597
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   56:     0x5a8e6c74e81a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hab88401d606702a6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   57:     0x5a8e6c74e81a - std::panicking::catch_unwind::do_call::h163fe12cca9901c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   58:     0x5a8e6c74e81a - std::panicking::catch_unwind::he81557d0e17cc1bc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   59:     0x5a8e6c74e81a - std::panic::catch_unwind::hc2b8e79c20593955
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   60:     0x5a8e6c74e81a - std::thread::Builder::spawn_unchecked_::{{closure}}::hfa6b4978e07815cc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   61:     0x5a8e6c74e81a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hddcd7484a13fd793
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   62:     0x5a8e6c8bceef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h5924238c754de3b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   63:     0x5a8e6c8bceef - std::sys::pal::unix::thread::Thread::new::thread_start::hb6e99e73da4d28f8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/pal/unix/thread.rs:107:17
[INFO] [stdout]   64:     0x7ef0b8c2baa4 - <unknown>
[INFO] [stdout]   65:     0x7ef0b8cb8a34 - clone
[INFO] [stdout]   66:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     network::tests::tests::test_message_serialization
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 2 passed; 1 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.09s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "fd985ef00c15f14d12cda9e113047462bff53e691328c2bb2014cd7b10a8cfe7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fd985ef00c15f14d12cda9e113047462bff53e691328c2bb2014cd7b10a8cfe7", kill_on_drop: false }`
[INFO] [stdout] fd985ef00c15f14d12cda9e113047462bff53e691328c2bb2014cd7b10a8cfe7
