[INFO] cloning repository https://github.com/tch1001/micah
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/tch1001/micah" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftch1001%2Fmicah", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftch1001%2Fmicah'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] e416cb4d25adf47bcfa83594141152c19c6268f3
[INFO] testing tch1001/micah against 1.94.0 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftch1001%2Fmicah" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/tch1001/micah
[INFO] finished tweaking git repo https://github.com/tch1001/micah
[INFO] tweaked toml for git repo https://github.com/tch1001/micah written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/tch1001/micah on toolchain 1.94.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.94.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/tch1001/micah 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.94.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: file `/workspace/builds/worker-1-tc1/source/src/main.rs` found to be present in multiple build targets:
[INFO] [stderr]   * `lib` target `dashboard`
[INFO] [stderr]   * `bin` target `main`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded rustls-pemfile v2.1.3
[INFO] [stderr]   Downloaded ipnet v2.10.0
[INFO] [stderr]   Downloaded redox_syscall v0.5.6
[INFO] [stderr]   Downloaded alloy-eip7702 v0.1.0
[INFO] [stderr]   Downloaded alloy v0.3.6
[INFO] [stderr]   Downloaded alloy-signer v0.3.6
[INFO] [stderr]   Downloaded alloy-rpc-types v0.3.6
[INFO] [stderr]   Downloaded alloy-eip2930 v0.1.0
[INFO] [stderr]   Downloaded alloy-rlp v0.3.8
[INFO] [stderr]   Downloaded alloy-sol-macro-input v0.8.5
[INFO] [stderr]   Downloaded alloy-core v0.8.5
[INFO] [stderr]   Downloaded alloy-contract v0.3.6
[INFO] [stderr]   Downloaded alloy-rpc-client v0.3.6
[INFO] [stderr]   Downloaded alloy-provider v0.3.6
[INFO] [stderr]   Downloaded alloy-dyn-abi v0.8.5
[INFO] [stderr]   Downloaded alloy-sol-types v0.8.5
[INFO] [stderr]   Downloaded alloy-primitives v0.8.5
[INFO] [stderr]   Downloaded interprocess v2.2.1
[INFO] [stderr]   Downloaded pest v2.7.13
[INFO] [stderr]   Downloaded axum v0.7.7
[INFO] [stderr]   Downloaded rdkafka v0.36.2
[INFO] [stderr]   Downloaded proptest v1.5.0
[INFO] [stderr]   Downloaded cxx-build v1.0.128
[INFO] [stderr]   Downloaded gimli v0.31.0
[INFO] [stderr]   Downloaded alloy-genesis v0.3.6
[INFO] [stderr]   Downloaded cxx v1.0.128
[INFO] [stderr]   Downloaded rustls v0.23.13
[INFO] [stderr]   Downloaded redis v0.27.2
[INFO] [stderr]   Downloaded reqwest v0.12.7
[INFO] [stderr]   Downloaded blst v0.3.13
[INFO] [stderr]   Downloaded cxxbridge-macro v1.0.128
[INFO] [stderr]   Downloaded alloy-consensus v0.3.6
[INFO] [stderr]   Downloaded alloy-rpc-types-eth v0.3.6
[INFO] [stderr]   Downloaded syn-solidity v0.8.5
[INFO] [stderr]   Downloaded alloy-rpc-types-engine v0.3.6
[INFO] [stderr]   Downloaded alloy-sol-macro-expander v0.8.5
[INFO] [stderr]   Downloaded alloy-chains v0.1.34
[INFO] [stderr]   Downloaded alloy-eips v0.3.6
[INFO] [stderr]   Downloaded bb8-redis v0.17.0
[INFO] [stderr]   Downloaded alloy-serde v0.3.6
[INFO] [stderr]   Downloaded bimap v0.6.3
[INFO] [stderr]   Downloaded alloy-rlp-derive v0.3.8
[INFO] [stderr]   Downloaded alloy-json-abi v0.8.5
[INFO] [stderr]   Downloaded alloy-sol-macro v0.8.5
[INFO] [stderr]   Downloaded alloy-json-rpc v0.3.6
[INFO] [stderr]   Downloaded alloy-network-primitives v0.3.6
[INFO] [stderr]   Downloaded alloy-network v0.3.6
[INFO] [stderr]   Downloaded alloy-transport-ipc v0.3.6
[INFO] [stderr]   Downloaded alloy-pubsub v0.3.6
[INFO] [stderr]   Downloaded link-cplusplus v1.0.9
[INFO] [stderr]   Downloaded alloy-signer-local v0.3.6
[INFO] [stderr]   Downloaded alloy-transport-http v0.3.6
[INFO] [stderr]   Downloaded alloy-transport-ws v0.3.6
[INFO] [stderr]   Downloaded cxxbridge-flags v1.0.128
[INFO] [stderr]   Downloaded scratch v1.0.7
[INFO] [stderr]   Downloaded rustls-pki-types v1.9.0
[INFO] [stderr]   Downloaded alloy-sol-type-parser v0.8.5
[INFO] [stderr]   Downloaded alloy-transport v0.3.6
[INFO] [stderr]   Downloaded bb8 v0.8.5
[INFO] [stderr]   Downloaded schannel v0.1.24
[INFO] [stderr]   Downloaded addr2line v0.24.1
[INFO] [stderr]   Downloaded c-kzg v1.0.3
[INFO] [stderr]   Downloaded rdkafka-sys v4.7.0+2.3.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 0a70f4ab2fd06a952b045638ff283b0970e5a6ed687bf2d217885e95ed9e3c82
[INFO] running `Command { std: "docker" "start" "-a" "0a70f4ab2fd06a952b045638ff283b0970e5a6ed687bf2d217885e95ed9e3c82", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "0a70f4ab2fd06a952b045638ff283b0970e5a6ed687bf2d217885e95ed9e3c82", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0a70f4ab2fd06a952b045638ff283b0970e5a6ed687bf2d217885e95ed9e3c82", kill_on_drop: false }`
[INFO] [stdout] 0a70f4ab2fd06a952b045638ff283b0970e5a6ed687bf2d217885e95ed9e3c82
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5eb98654fa600ac6b83046f963b48e7120b2c3ace65e94b0fb708db70bc8304a
[INFO] running `Command { std: "docker" "start" "-a" "5eb98654fa600ac6b83046f963b48e7120b2c3ace65e94b0fb708db70bc8304a", kill_on_drop: false }`
[INFO] [stderr] warning: file `/opt/rustwide/workdir/src/main.rs` found to be present in multiple build targets:
[INFO] [stderr]   * `lib` target `dashboard`
[INFO] [stderr]   * `bin` target `main`
[INFO] [stderr]    Compiling proc-macro2 v1.0.86
[INFO] [stderr]    Compiling libc v0.2.159
[INFO] [stderr]    Compiling serde v1.0.210
[INFO] [stderr]    Compiling cpufeatures v0.2.14
[INFO] [stderr]    Compiling cc v1.1.18
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]    Compiling hex-literal v0.4.1
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling log v0.4.22
[INFO] [stderr]    Compiling serde_json v1.0.128
[INFO] [stderr]    Compiling winnow v0.6.20
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]    Compiling memchr v2.7.4
[INFO] [stderr]    Compiling thiserror v1.0.64
[INFO] [stderr]    Compiling httparse v1.9.4
[INFO] [stderr]    Compiling unicode-normalization v0.1.24
[INFO] [stderr]    Compiling rustls-pki-types v1.9.0
[INFO] [stderr]    Compiling openssl v0.10.66
[INFO] [stderr]    Compiling hex v0.4.3
[INFO] [stderr]    Compiling futures-utils-wasm v0.1.0
[INFO] [stderr]    Compiling bitflags v2.6.0
[INFO] [stderr]    Compiling rustversion v1.0.17
[INFO] [stderr]    Compiling native-tls v0.2.12
[INFO] [stderr]    Compiling rustls v0.23.13
[INFO] [stderr]    Compiling sync_wrapper v1.0.1
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling data-encoding v2.6.0
[INFO] [stderr]    Compiling bimap v0.6.3
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling doctest-file v1.0.0
[INFO] [stderr]    Compiling idna v0.5.0
[INFO] [stderr]    Compiling ipnet v2.10.0
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling rdkafka-sys v4.7.0+2.3.0
[INFO] [stderr]    Compiling indexmap v2.5.0
[INFO] [stderr]    Compiling rustls-pemfile v2.1.3
[INFO] [stderr]    Compiling webpki-roots v0.26.6
[INFO] [stderr]    Compiling cxxbridge-flags v1.0.128
[INFO] [stderr]    Compiling quote v1.0.37
[INFO] [stderr]    Compiling num-bigint v0.4.6
[INFO] [stderr]    Compiling eyre v0.6.12
[INFO] [stderr]    Compiling matchit v0.7.3
[INFO] [stderr]    Compiling dotenv v0.15.0
[INFO] [stderr]    Compiling syn v2.0.77
[INFO] [stderr]    Compiling url v2.5.2
[INFO] [stderr]    Compiling proc-macro-error-attr2 v2.0.0
[INFO] [stderr]    Compiling blst v0.3.13
[INFO] [stderr]    Compiling openssl-sys v0.9.103
[INFO] [stderr]    Compiling ring v0.17.8
[INFO] [stderr]    Compiling c-kzg v1.0.3
[INFO] [stderr]    Compiling libz-sys v1.1.20
[INFO] [stderr]    Compiling link-cplusplus v1.0.9
[INFO] [stderr]    Compiling cxx v1.0.128
[INFO] [stderr]    Compiling toml_edit v0.19.15
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling signal-hook-registry v1.4.2
[INFO] [stderr]    Compiling mio v1.0.2
[INFO] [stderr]    Compiling socket2 v0.5.7
[INFO] [stderr]    Compiling parking_lot v0.12.3
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling num_cpus v1.16.0
[INFO] [stderr]    Compiling ff v0.13.0
[INFO] [stderr]    Compiling threadpool v1.8.1
[INFO] [stderr]    Compiling group v0.13.0
[INFO] [stderr]    Compiling proc-macro-crate v1.3.1
[INFO] [stderr]    Compiling num_enum_derive v0.5.11
[INFO] [stderr]    Compiling num_enum v0.5.11
[INFO] [stderr]    Compiling rustls-webpki v0.102.8
[INFO] [stderr]    Compiling syn-solidity v0.8.5
[INFO] [stderr]    Compiling proc-macro-error2 v2.0.1
[INFO] [stderr]    Compiling serde_derive v1.0.210
[INFO] [stderr]    Compiling zeroize_derive v1.4.2
[INFO] [stderr]    Compiling derive_more-impl v1.0.0
[INFO] [stderr]    Compiling tokio-macros v2.4.0
[INFO] [stderr]    Compiling alloy-rlp-derive v0.3.8
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]    Compiling zeroize v1.8.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.64
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling der v0.7.9
[INFO] [stderr]    Compiling futures-util v0.3.30
[INFO] [stderr]    Compiling zerocopy v0.7.35
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-bigint v0.5.5
[INFO] [stderr]    Compiling tracing v0.1.40
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling sec1 v0.7.3
[INFO] [stderr]    Compiling spki v0.7.3
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling signature v2.2.0
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling rfc6979 v0.4.0
[INFO] [stderr]    Compiling async-trait v0.1.83
[INFO] [stderr]    Compiling ppv-lite86 v0.2.20
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling pin-project-internal v1.1.5
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling auto_impl v1.2.0
[INFO] [stderr]    Compiling num_enum_derive v0.7.3
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling derive_more v1.0.0
[INFO] [stderr]    Compiling async-stream-impl v0.3.5
[INFO] [stderr]    Compiling cxxbridge-macro v1.0.128
[INFO] [stderr]    Compiling elliptic-curve v0.13.8
[INFO] [stderr]    Compiling pin-project v1.1.5
[INFO] [stderr]    Compiling num_enum v0.7.3
[INFO] [stderr]    Compiling async-stream v0.3.5
[INFO] [stderr]    Compiling ecdsa v0.16.9
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling alloy-chains v0.1.34
[INFO] [stderr]    Compiling k256 v0.13.4
[INFO] [stderr]    Compiling futures-executor v0.3.30
[INFO] [stderr]    Compiling futures v0.3.30
[INFO] [stderr]    Compiling bytes v1.7.2
[INFO] [stderr]    Compiling const-hex v1.12.0
[INFO] [stderr]    Compiling ruint v1.12.3
[INFO] [stderr]    Compiling alloy-sol-type-parser v0.8.5
[INFO] [stderr]    Compiling alloy-rlp v0.3.8
[INFO] [stderr]    Compiling tokio v1.40.0
[INFO] [stderr]    Compiling alloy-primitives v0.8.5
[INFO] [stderr]    Compiling http v1.1.0
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling serde_path_to_error v0.1.16
[INFO] [stderr]    Compiling dashmap v6.1.0
[INFO] [stderr]    Compiling lru v0.12.4
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling tungstenite v0.23.0
[INFO] [stderr]    Compiling http-body-util v0.1.2
[INFO] [stderr]    Compiling axum-core v0.4.5
[INFO] [stderr]    Compiling alloy-json-abi v0.8.5
[INFO] [stderr]    Compiling alloy-sol-macro-input v0.8.5
[INFO] [stderr]    Compiling alloy-eip7702 v0.1.0
[INFO] [stderr]    Compiling alloy-eip2930 v0.1.0
[INFO] [stderr]    Compiling alloy-serde v0.3.6
[INFO] [stderr]    Compiling alloy-signer v0.3.6
[INFO] [stderr]    Compiling alloy-sol-macro-expander v0.8.5
[INFO] [stderr]    Compiling alloy-eips v0.3.6
[INFO] [stderr]    Compiling alloy-network-primitives v0.3.6
[INFO] [stderr]    Compiling alloy-consensus v0.3.6
[INFO] [stderr]    Compiling alloy-sol-macro v0.8.5
[INFO] [stderr]    Compiling alloy-sol-types v0.8.5
[INFO] [stderr]    Compiling tokio-util v0.7.12
[INFO] [stderr]    Compiling tower v0.5.1
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tokio-rustls v0.26.0
[INFO] [stderr]    Compiling interprocess v2.2.1
[INFO] [stderr]    Compiling bb8 v0.8.5
[INFO] [stderr]    Compiling tokio-tungstenite v0.23.1
[INFO] [stderr]    Compiling h2 v0.4.6
[INFO] [stderr]    Compiling tokio-stream v0.1.16
[INFO] [stderr]    Compiling combine v4.6.7
[INFO] [stderr]    Compiling rdkafka v0.36.2
[INFO] [stderr]    Compiling hyper v1.4.1
[INFO] [stderr]    Compiling redis v0.27.2
[INFO] [stderr]    Compiling hyper-util v0.1.9
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling axum v0.7.7
[INFO] [stderr]    Compiling reqwest v0.12.7
[INFO] [stderr]    Compiling alloy-json-rpc v0.3.6
[INFO] [stderr]    Compiling alloy-rpc-types-eth v0.3.6
[INFO] [stderr]    Compiling alloy-dyn-abi v0.8.5
[INFO] [stderr]    Compiling alloy-transport v0.3.6
[INFO] [stderr]    Compiling alloy-core v0.8.5
[INFO] [stderr]    Compiling alloy-pubsub v0.3.6
[INFO] [stderr]    Compiling alloy-transport-http v0.3.6
[INFO] [stderr]    Compiling alloy-transport-ws v0.3.6
[INFO] [stderr]    Compiling alloy-transport-ipc v0.3.6
[INFO] [stderr]    Compiling alloy-rpc-client v0.3.6
[INFO] [stderr]    Compiling alloy-network v0.3.6
[INFO] [stderr]    Compiling alloy-rpc-types v0.3.6
[INFO] [stderr]    Compiling alloy-provider v0.3.6
[INFO] [stderr]    Compiling alloy-signer-local v0.3.6
[INFO] [stderr]    Compiling bb8-redis v0.17.0
[INFO] [stderr]    Compiling alloy-contract v0.3.6
[INFO] [stderr]    Compiling alloy v0.3.6
[INFO] [stderr]    Compiling dashboard v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `futures::StreamExt`
[INFO] [stdout]  --> src/listener.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use futures::StreamExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::time`
[INFO] [stdout]  --> src/main.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use core::time;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FutureProducer` and `FutureRecord`
[INFO] [stdout]  --> src/main.rs:2:25
[INFO] [stdout]   |
[INFO] [stdout] 2 | use rdkafka::producer::{FutureProducer, FutureRecord};
[INFO] [stdout]   |                         ^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::time`
[INFO] [stdout]  --> src/main.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use core::time;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FutureProducer` and `FutureRecord`
[INFO] [stdout]  --> src/main.rs:2:25
[INFO] [stdout]   |
[INFO] [stdout] 2 | use rdkafka::producer::{FutureProducer, FutureRecord};
[INFO] [stdout]   |                         ^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ffi::c_char` and `hash::Hash`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     ffi::c_char,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 6 |     hash::Hash,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Block` and `Transaction`
[INFO] [stdout]   --> src/main.rs:19:18
[INFO] [stdout]    |
[INFO] [stdout] 19 |     rpc::types::{Block, BlockTransactionsKind, Transaction},
[INFO] [stdout]    |                  ^^^^^                         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `runtime` and `sync::futures`
[INFO] [stdout]   --> src/main.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 | use tokio::{runtime, sync::futures, task};
[INFO] [stdout]    |             ^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Mutex as StdMutex`
[INFO] [stdout]   --> src/main.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | use std::sync::Mutex as StdMutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ffi::c_char` and `hash::Hash`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     ffi::c_char,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 6 |     hash::Hash,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Block` and `Transaction`
[INFO] [stdout]   --> src/main.rs:19:18
[INFO] [stdout]    |
[INFO] [stdout] 19 |     rpc::types::{Block, BlockTransactionsKind, Transaction},
[INFO] [stdout]    |                  ^^^^^                         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `runtime` and `sync::futures`
[INFO] [stdout]   --> src/main.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 | use tokio::{runtime, sync::futures, task};
[INFO] [stdout]    |             ^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Mutex as StdMutex`
[INFO] [stdout]   --> src/main.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | use std::sync::Mutex as StdMutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `admin::AdminOptions` and `config::FromClientConfig`
[INFO] [stdout]   --> src/process.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     admin::AdminOptions,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 11 |     config::FromClientConfig,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `topic`
[INFO] [stdout]  --> src/listener.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 |     let topic = std::env::var("TOPIC").expect("TOPIC must be set");
[INFO] [stdout]   |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_topic`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `producer`
[INFO] [stdout]  --> src/listener.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 |     let producer: FutureProducer = rdkafka::config::ClientConfig::new()
[INFO] [stdout]   |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_producer`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sub`
[INFO] [stdout]   --> src/listener.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 |     let sub = provider.subscribe_pending_transactions().await?;
[INFO] [stdout]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_sub`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `admin::AdminOptions` and `config::FromClientConfig`
[INFO] [stdout]   --> src/process.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     admin::AdminOptions,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 11 |     config::FromClientConfig,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::hash`
[INFO] [stdout]  --> src/web.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use core::hash;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]  --> src/web.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::error::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `net::TcpListener` and `sync::Arc`
[INFO] [stdout]  --> src/web.rs:4:11
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::{net::TcpListener, sync::Arc};
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::Mutex`
[INFO] [stdout]   --> src/web.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use tokio::sync::Mutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:149:9
[INFO] [stdout]     |
[INFO] [stdout] 149 |     let mut local_cache = eth_usdt_price_cache.lock().await;
[INFO] [stdout]     |         ----^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:268:9
[INFO] [stdout]     |
[INFO] [stdout] 268 |     let mut cache: HashMap<String, (u64, u128)> = HashMap::new();
[INFO] [stdout]     |         ----^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:270:9
[INFO] [stdout]     |
[INFO] [stdout] 270 |     let mut eth_usdt_price_cache: HashMap<u64, (u64, f64)> = HashMap::new();
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:149:9
[INFO] [stdout]     |
[INFO] [stdout] 149 |     let mut local_cache = eth_usdt_price_cache.lock().await;
[INFO] [stdout]     |         ----^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `startblock`
[INFO] [stdout]   --> src/main.rs:38:38
[INFO] [stdout]    |
[INFO] [stdout] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stdout]    |                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_startblock`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `endblock`
[INFO] [stdout]   --> src/main.rs:38:55
[INFO] [stdout]    |
[INFO] [stdout] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stdout]    |                                                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_endblock`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rpc_url_http`
[INFO] [stdout]    --> src/main.rs:265:9
[INFO] [stdout]     |
[INFO] [stdout] 265 |     let rpc_url_http: String = std::env::var("RPC_URL_HTTP").unwrap();
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rpc_url_http`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> src/process.rs:56:9
[INFO] [stdout]    |
[INFO] [stdout] 56 |     for i in 0..10 {
[INFO] [stdout]    |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/process.rs:158:13
[INFO] [stdout]     |
[INFO] [stdout] 158 |         let mut hash = match message {
[INFO] [stdout]     |             ----^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:268:9
[INFO] [stdout]     |
[INFO] [stdout] 268 |     let mut cache: HashMap<String, (u64, u128)> = HashMap::new();
[INFO] [stdout]     |         ----^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:270:9
[INFO] [stdout]     |
[INFO] [stdout] 270 |     let mut eth_usdt_price_cache: HashMap<u64, (u64, f64)> = HashMap::new();
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `startblock`
[INFO] [stdout]   --> src/main.rs:38:38
[INFO] [stdout]    |
[INFO] [stdout] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stdout]    |                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_startblock`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `endblock`
[INFO] [stdout]   --> src/main.rs:38:55
[INFO] [stdout]    |
[INFO] [stdout] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stdout]    |                                                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_endblock`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rpc_url_http`
[INFO] [stdout]    --> src/main.rs:265:9
[INFO] [stdout]     |
[INFO] [stdout] 265 |     let rpc_url_http: String = std::env::var("RPC_URL_HTTP").unwrap();
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rpc_url_http`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_file` is never used
[INFO] [stdout]   --> src/main.rs:29:4
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn read_file(existing_hashes: &mut Vec<String>, file: &std::fs::File) {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `UNISWAP_V3` is never used
[INFO] [stdout]   --> src/main.rs:37:8
[INFO] [stdout]    |
[INFO] [stdout] 37 | static UNISWAP_V3: &str = "0x88e6a0c2ddd26feeb64f039a2c41296fcb3f5640";
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `erc20_token_transfer_events` is never used
[INFO] [stdout]   --> src/main.rs:38:10
[INFO] [stdout]    |
[INFO] [stdout] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `decode_tx` is never used
[INFO] [stdout]    --> src/main.rs:102:10
[INFO] [stdout]     |
[INFO] [stdout] 102 | async fn decode_tx(
[INFO] [stdout]     |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `process_tx_rust` is never used
[INFO] [stdout]    --> src/main.rs:156:10
[INFO] [stdout]     |
[INFO] [stdout] 156 | async fn process_tx_rust(
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `handle_connection` is never used
[INFO] [stdout]    --> src/main.rs:171:10
[INFO] [stdout]     |
[INFO] [stdout] 171 | async fn handle_connection(
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `new_blocks_listener` is never used
[INFO] [stdout]    --> src/main.rs:253:10
[INFO] [stdout]     |
[INFO] [stdout] 253 | async fn new_blocks_listener(
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Point` is never constructed
[INFO] [stdout]    --> src/main.rs:317:8
[INFO] [stdout]     |
[INFO] [stdout] 317 | struct Point {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Nat` is never used
[INFO] [stdout]    --> src/main.rs:321:6
[INFO] [stdout]     |
[INFO] [stdout] 321 | enum Nat {
[INFO] [stdout]     |      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MyBox` is never constructed
[INFO] [stdout]    --> src/main.rs:326:8
[INFO] [stdout]     |
[INFO] [stdout] 326 | struct MyBox<T> {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/main.rs:331:8
[INFO] [stdout]     |
[INFO] [stdout] 330 | impl<T> MyBox<T> {
[INFO] [stdout]     | ---------------- associated function in this implementation
[INFO] [stdout] 331 |     fn new(x: T) -> MyBox<T> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Wolf` is never constructed
[INFO] [stdout]    --> src/main.rs:336:8
[INFO] [stdout]     |
[INFO] [stdout] 336 | struct Wolf {}
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `MyClone` is never used
[INFO] [stdout]    --> src/main.rs:339:7
[INFO] [stdout]     |
[INFO] [stdout] 339 | trait MyClone<T> {
[INFO] [stdout]     |       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `id` is never used
[INFO] [stdout]    --> src/main.rs:350:4
[INFO] [stdout]     |
[INFO] [stdout] 350 | fn id(p: Point) -> Point {
[INFO] [stdout]     |    ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `main` is never used
[INFO] [stdout]    --> src/main.rs:355:10
[INFO] [stdout]     |
[INFO] [stdout] 355 | async fn main() -> Result<()> {
[INFO] [stdout]     |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_file` is never used
[INFO] [stdout]   --> src/main.rs:29:4
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn read_file(existing_hashes: &mut Vec<String>, file: &std::fs::File) {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Point` is never constructed
[INFO] [stdout]    --> src/main.rs:317:8
[INFO] [stdout]     |
[INFO] [stdout] 317 | struct Point {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Nat` is never used
[INFO] [stdout]    --> src/main.rs:321:6
[INFO] [stdout]     |
[INFO] [stdout] 321 | enum Nat {
[INFO] [stdout]     |      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MyBox` is never constructed
[INFO] [stdout]    --> src/main.rs:326:8
[INFO] [stdout]     |
[INFO] [stdout] 326 | struct MyBox<T> {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/main.rs:331:8
[INFO] [stdout]     |
[INFO] [stdout] 330 | impl<T> MyBox<T> {
[INFO] [stdout]     | ---------------- associated function in this implementation
[INFO] [stdout] 331 |     fn new(x: T) -> MyBox<T> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Wolf` is never constructed
[INFO] [stdout]    --> src/main.rs:336:8
[INFO] [stdout]     |
[INFO] [stdout] 336 | struct Wolf {}
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `MyClone` is never used
[INFO] [stdout]    --> src/main.rs:339:7
[INFO] [stdout]     |
[INFO] [stdout] 339 | trait MyClone<T> {
[INFO] [stdout]     |       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `id` is never used
[INFO] [stdout]    --> src/main.rs:350:4
[INFO] [stdout]     |
[INFO] [stdout] 350 | fn id(p: Point) -> Point {
[INFO] [stdout]     |    ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> src/process.rs:56:9
[INFO] [stdout]    |
[INFO] [stdout] 56 |     for i in 0..10 {
[INFO] [stdout]    |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/process.rs:158:13
[INFO] [stdout]     |
[INFO] [stdout] 158 |         let mut hash = match message {
[INFO] [stdout]     |             ----^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start_block`
[INFO] [stdout]   --> src/web.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 78 |     start_block: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `end_block`
[INFO] [stdout]   --> src/web.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 79 |     end_block: u64,
[INFO] [stdout]    |     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_end_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/web.rs:158:23
[INFO] [stdout]     |
[INFO] [stdout] 158 |             .map_err(|e| {
[INFO] [stdout]     |                       ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pool`
[INFO] [stdout]    --> src/web.rs:124:11
[INFO] [stdout]     |
[INFO] [stdout] 124 |     State(pool): State<bb8::Pool<RedisConnectionManager>>,
[INFO] [stdout]     |           ^^^^ help: if this is intentional, prefix it with an underscore: `_pool`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `send_to_cache` is never used
[INFO] [stdout]    --> src/process.rs:100:14
[INFO] [stdout]     |
[INFO] [stdout] 100 | pub async fn send_to_cache(
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `main` is never used
[INFO] [stdout]    --> src/process.rs:113:10
[INFO] [stdout]     |
[INFO] [stdout] 113 | async fn main() {
[INFO] [stdout]     |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 42s
[INFO] running `Command { std: "docker" "inspect" "5eb98654fa600ac6b83046f963b48e7120b2c3ace65e94b0fb708db70bc8304a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5eb98654fa600ac6b83046f963b48e7120b2c3ace65e94b0fb708db70bc8304a", kill_on_drop: false }`
[INFO] [stdout] 5eb98654fa600ac6b83046f963b48e7120b2c3ace65e94b0fb708db70bc8304a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 3a7c75f969f03ab46691c6d578494bebbe3898556bf415a2a57df27a78d7c69d
[INFO] running `Command { std: "docker" "start" "-a" "3a7c75f969f03ab46691c6d578494bebbe3898556bf415a2a57df27a78d7c69d", kill_on_drop: false }`
[INFO] [stderr] warning: file `/opt/rustwide/workdir/src/main.rs` found to be present in multiple build targets:
[INFO] [stderr]   * `lib` target `dashboard`
[INFO] [stderr]   * `bin` target `main`
[INFO] [stderr]    Compiling dashboard v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `core::time`
[INFO] [stdout]  --> src/main.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use core::time;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FutureProducer` and `FutureRecord`
[INFO] [stdout]  --> src/main.rs:2:25
[INFO] [stdout]   |
[INFO] [stdout] 2 | use rdkafka::producer::{FutureProducer, FutureRecord};
[INFO] [stdout]   |                         ^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ffi::c_char` and `hash::Hash`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     ffi::c_char,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 6 |     hash::Hash,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Block` and `Transaction`
[INFO] [stdout]   --> src/main.rs:19:18
[INFO] [stdout]    |
[INFO] [stdout] 19 |     rpc::types::{Block, BlockTransactionsKind, Transaction},
[INFO] [stdout]    |                  ^^^^^                         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `runtime` and `sync::futures`
[INFO] [stdout]   --> src/main.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 | use tokio::{runtime, sync::futures, task};
[INFO] [stdout]    |             ^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Mutex as StdMutex`
[INFO] [stdout]   --> src/main.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | use std::sync::Mutex as StdMutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `admin::AdminOptions` and `config::FromClientConfig`
[INFO] [stdout]   --> src/process.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     admin::AdminOptions,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 11 |     config::FromClientConfig,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::StreamExt`
[INFO] [stdout]  --> src/listener.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use futures::StreamExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> src/process.rs:56:9
[INFO] [stdout]    |
[INFO] [stdout] 56 |     for i in 0..10 {
[INFO] [stdout]    |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `admin::AdminOptions` and `config::FromClientConfig`
[INFO] [stdout]   --> src/process.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     admin::AdminOptions,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 11 |     config::FromClientConfig,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::hash`
[INFO] [stdout]  --> src/web.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use core::hash;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]  --> src/web.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::error::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `net::TcpListener` and `sync::Arc`
[INFO] [stdout]  --> src/web.rs:4:11
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::{net::TcpListener, sync::Arc};
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::Mutex`
[INFO] [stdout]   --> src/web.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use tokio::sync::Mutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/process.rs:158:13
[INFO] [stdout]     |
[INFO] [stdout] 158 |         let mut hash = match message {
[INFO] [stdout]     |             ----^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::time`
[INFO] [stdout]  --> src/main.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use core::time;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FutureProducer` and `FutureRecord`
[INFO] [stdout]  --> src/main.rs:2:25
[INFO] [stdout]   |
[INFO] [stdout] 2 | use rdkafka::producer::{FutureProducer, FutureRecord};
[INFO] [stdout]   |                         ^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ffi::c_char` and `hash::Hash`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     ffi::c_char,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 6 |     hash::Hash,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Block` and `Transaction`
[INFO] [stdout]   --> src/main.rs:19:18
[INFO] [stdout]    |
[INFO] [stdout] 19 |     rpc::types::{Block, BlockTransactionsKind, Transaction},
[INFO] [stdout]    |                  ^^^^^                         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `runtime` and `sync::futures`
[INFO] [stdout]   --> src/main.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 | use tokio::{runtime, sync::futures, task};
[INFO] [stdout]    |             ^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Mutex as StdMutex`
[INFO] [stdout]   --> src/main.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | use std::sync::Mutex as StdMutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:149:9
[INFO] [stdout]     |
[INFO] [stdout] 149 |     let mut local_cache = eth_usdt_price_cache.lock().await;
[INFO] [stdout]     |         ----^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `topic`
[INFO] [stdout]  --> src/listener.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 |     let topic = std::env::var("TOPIC").expect("TOPIC must be set");
[INFO] [stdout]   |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_topic`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `producer`
[INFO] [stdout]  --> src/listener.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 |     let producer: FutureProducer = rdkafka::config::ClientConfig::new()
[INFO] [stdout]   |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_producer`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sub`
[INFO] [stdout]   --> src/listener.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 |     let sub = provider.subscribe_pending_transactions().await?;
[INFO] [stdout]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_sub`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:268:9
[INFO] [stdout]     |
[INFO] [stdout] 268 |     let mut cache: HashMap<String, (u64, u128)> = HashMap::new();
[INFO] [stdout]     |         ----^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:270:9
[INFO] [stdout]     |
[INFO] [stdout] 270 |     let mut eth_usdt_price_cache: HashMap<u64, (u64, f64)> = HashMap::new();
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `startblock`
[INFO] [stdout]   --> src/main.rs:38:38
[INFO] [stdout]    |
[INFO] [stdout] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stdout]    |                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_startblock`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `endblock`
[INFO] [stdout]   --> src/main.rs:38:55
[INFO] [stdout]    |
[INFO] [stdout] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stdout]    |                                                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_endblock`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rpc_url_http`
[INFO] [stdout]    --> src/main.rs:265:9
[INFO] [stdout]     |
[INFO] [stdout] 265 |     let rpc_url_http: String = std::env::var("RPC_URL_HTTP").unwrap();
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rpc_url_http`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:149:9
[INFO] [stdout]     |
[INFO] [stdout] 149 |     let mut local_cache = eth_usdt_price_cache.lock().await;
[INFO] [stdout]     |         ----^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_file` is never used
[INFO] [stdout]   --> src/main.rs:29:4
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn read_file(existing_hashes: &mut Vec<String>, file: &std::fs::File) {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Point` is never constructed
[INFO] [stdout]    --> src/main.rs:317:8
[INFO] [stdout]     |
[INFO] [stdout] 317 | struct Point {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Nat` is never used
[INFO] [stdout]    --> src/main.rs:321:6
[INFO] [stdout]     |
[INFO] [stdout] 321 | enum Nat {
[INFO] [stdout]     |      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MyBox` is never constructed
[INFO] [stdout]    --> src/main.rs:326:8
[INFO] [stdout]     |
[INFO] [stdout] 326 | struct MyBox<T> {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/main.rs:331:8
[INFO] [stdout]     |
[INFO] [stdout] 330 | impl<T> MyBox<T> {
[INFO] [stdout]     | ---------------- associated function in this implementation
[INFO] [stdout] 331 |     fn new(x: T) -> MyBox<T> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Wolf` is never constructed
[INFO] [stdout]    --> src/main.rs:336:8
[INFO] [stdout]     |
[INFO] [stdout] 336 | struct Wolf {}
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `MyClone` is never used
[INFO] [stdout]    --> src/main.rs:339:7
[INFO] [stdout]     |
[INFO] [stdout] 339 | trait MyClone<T> {
[INFO] [stdout]     |       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `id` is never used
[INFO] [stdout]    --> src/main.rs:350:4
[INFO] [stdout]     |
[INFO] [stdout] 350 | fn id(p: Point) -> Point {
[INFO] [stdout]     |    ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:268:9
[INFO] [stdout]     |
[INFO] [stdout] 268 |     let mut cache: HashMap<String, (u64, u128)> = HashMap::new();
[INFO] [stdout]     |         ----^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:270:9
[INFO] [stdout]     |
[INFO] [stdout] 270 |     let mut eth_usdt_price_cache: HashMap<u64, (u64, f64)> = HashMap::new();
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `startblock`
[INFO] [stdout]   --> src/main.rs:38:38
[INFO] [stdout]    |
[INFO] [stdout] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stdout]    |                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_startblock`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `endblock`
[INFO] [stdout]   --> src/main.rs:38:55
[INFO] [stdout]    |
[INFO] [stdout] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stdout]    |                                                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_endblock`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rpc_url_http`
[INFO] [stdout]    --> src/main.rs:265:9
[INFO] [stdout]     |
[INFO] [stdout] 265 |     let rpc_url_http: String = std::env::var("RPC_URL_HTTP").unwrap();
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rpc_url_http`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_file` is never used
[INFO] [stdout]   --> src/main.rs:29:4
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn read_file(existing_hashes: &mut Vec<String>, file: &std::fs::File) {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Point` is never constructed
[INFO] [stdout]    --> src/main.rs:317:8
[INFO] [stdout]     |
[INFO] [stdout] 317 | struct Point {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Nat` is never used
[INFO] [stdout]    --> src/main.rs:321:6
[INFO] [stdout]     |
[INFO] [stdout] 321 | enum Nat {
[INFO] [stdout]     |      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MyBox` is never constructed
[INFO] [stdout]    --> src/main.rs:326:8
[INFO] [stdout]     |
[INFO] [stdout] 326 | struct MyBox<T> {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/main.rs:331:8
[INFO] [stdout]     |
[INFO] [stdout] 330 | impl<T> MyBox<T> {
[INFO] [stdout]     | ---------------- associated function in this implementation
[INFO] [stdout] 331 |     fn new(x: T) -> MyBox<T> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Wolf` is never constructed
[INFO] [stdout]    --> src/main.rs:336:8
[INFO] [stdout]     |
[INFO] [stdout] 336 | struct Wolf {}
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `MyClone` is never used
[INFO] [stdout]    --> src/main.rs:339:7
[INFO] [stdout]     |
[INFO] [stdout] 339 | trait MyClone<T> {
[INFO] [stdout]     |       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `id` is never used
[INFO] [stdout]    --> src/main.rs:350:4
[INFO] [stdout]     |
[INFO] [stdout] 350 | fn id(p: Point) -> Point {
[INFO] [stdout]     |    ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> src/process.rs:56:9
[INFO] [stdout]    |
[INFO] [stdout] 56 |     for i in 0..10 {
[INFO] [stdout]    |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/process.rs:158:13
[INFO] [stdout]     |
[INFO] [stdout] 158 |         let mut hash = match message {
[INFO] [stdout]     |             ----^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start_block`
[INFO] [stdout]   --> src/web.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 78 |     start_block: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `end_block`
[INFO] [stdout]   --> src/web.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 79 |     end_block: u64,
[INFO] [stdout]    |     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_end_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/web.rs:158:23
[INFO] [stdout]     |
[INFO] [stdout] 158 |             .map_err(|e| {
[INFO] [stdout]     |                       ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pool`
[INFO] [stdout]    --> src/web.rs:124:11
[INFO] [stdout]     |
[INFO] [stdout] 124 |     State(pool): State<bb8::Pool<RedisConnectionManager>>,
[INFO] [stdout]     |           ^^^^ help: if this is intentional, prefix it with an underscore: `_pool`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `send_to_cache` is never used
[INFO] [stdout]    --> src/process.rs:100:14
[INFO] [stdout]     |
[INFO] [stdout] 100 | pub async fn send_to_cache(
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `main` is never used
[INFO] [stdout]    --> src/process.rs:113:10
[INFO] [stdout]     |
[INFO] [stdout] 113 | async fn main() {
[INFO] [stdout]     |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 6.06s
[INFO] running `Command { std: "docker" "inspect" "3a7c75f969f03ab46691c6d578494bebbe3898556bf415a2a57df27a78d7c69d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3a7c75f969f03ab46691c6d578494bebbe3898556bf415a2a57df27a78d7c69d", kill_on_drop: false }`
[INFO] [stdout] 3a7c75f969f03ab46691c6d578494bebbe3898556bf415a2a57df27a78d7c69d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 0c2be3e6b6953c1bd540786bcd231c763e59e7cf85f2766a50bb1f8a31b27784
[INFO] running `Command { std: "docker" "start" "-a" "0c2be3e6b6953c1bd540786bcd231c763e59e7cf85f2766a50bb1f8a31b27784", kill_on_drop: false }`
[INFO] [stderr] warning: file `/opt/rustwide/workdir/src/main.rs` found to be present in multiple build targets:
[INFO] [stderr]   * `lib` target `dashboard`
[INFO] [stderr]   * `bin` target `main`
[INFO] [stderr] warning: unused import: `core::time`
[INFO] [stderr]  --> src/main.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use core::time;
[INFO] [stderr]   |     ^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `FutureProducer` and `FutureRecord`
[INFO] [stderr]  --> src/main.rs:2:25
[INFO] [stderr]   |
[INFO] [stderr] 2 | use rdkafka::producer::{FutureProducer, FutureRecord};
[INFO] [stderr]   |                         ^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `ffi::c_char` and `hash::Hash`
[INFO] [stderr]  --> src/main.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 |     ffi::c_char,
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 6 |     hash::Hash,
[INFO] [stderr]   |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Block` and `Transaction`
[INFO] [stderr]   --> src/main.rs:19:18
[INFO] [stderr]    |
[INFO] [stderr] 19 |     rpc::types::{Block, BlockTransactionsKind, Transaction},
[INFO] [stderr]    |                  ^^^^^                         ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `runtime` and `sync::futures`
[INFO] [stderr]   --> src/main.rs:23:13
[INFO] [stderr]    |
[INFO] [stderr] 23 | use tokio::{runtime, sync::futures, task};
[INFO] [stderr]    |             ^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::sync::Mutex as StdMutex`
[INFO] [stderr]   --> src/main.rs:27:5
[INFO] [stderr]    |
[INFO] [stderr] 27 | use std::sync::Mutex as StdMutex;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/main.rs:149:9
[INFO] [stderr]     |
[INFO] [stderr] 149 |     let mut local_cache = eth_usdt_price_cache.lock().await;
[INFO] [stderr]     |         ----^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/main.rs:268:9
[INFO] [stderr]     |
[INFO] [stderr] 268 |     let mut cache: HashMap<String, (u64, u128)> = HashMap::new();
[INFO] [stderr]     |         ----^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/main.rs:270:9
[INFO] [stderr]     |
[INFO] [stderr] 270 |     let mut eth_usdt_price_cache: HashMap<u64, (u64, f64)> = HashMap::new();
[INFO] [stderr]     |         ----^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `startblock`
[INFO] [stderr]   --> src/main.rs:38:38
[INFO] [stderr]    |
[INFO] [stderr] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stderr]    |                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_startblock`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `endblock`
[INFO] [stderr]   --> src/main.rs:38:55
[INFO] [stderr]    |
[INFO] [stderr] 38 | async fn erc20_token_transfer_events(startblock: u64, endblock: u64) -> Vec<String> {
[INFO] [stderr]    |                                                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_endblock`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rpc_url_http`
[INFO] [stderr]    --> src/main.rs:265:9
[INFO] [stderr]     |
[INFO] [stderr] 265 |     let rpc_url_http: String = std::env::var("RPC_URL_HTTP").unwrap();
[INFO] [stderr]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rpc_url_http`
[INFO] [stderr] 
[INFO] [stderr] warning: function `read_file` is never used
[INFO] [stderr]   --> src/main.rs:29:4
[INFO] [stderr]    |
[INFO] [stderr] 29 | fn read_file(existing_hashes: &mut Vec<String>, file: &std::fs::File) {
[INFO] [stderr]    |    ^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Point` is never constructed
[INFO] [stderr]    --> src/main.rs:317:8
[INFO] [stderr]     |
[INFO] [stderr] 317 | struct Point {
[INFO] [stderr]     |        ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `Nat` is never used
[INFO] [stderr]    --> src/main.rs:321:6
[INFO] [stderr]     |
[INFO] [stderr] 321 | enum Nat {
[INFO] [stderr]     |      ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `MyBox` is never constructed
[INFO] [stderr]    --> src/main.rs:326:8
[INFO] [stderr]     |
[INFO] [stderr] 326 | struct MyBox<T> {
[INFO] [stderr]     |        ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]    --> src/main.rs:331:8
[INFO] [stderr]     |
[INFO] [stderr] 330 | impl<T> MyBox<T> {
[INFO] [stderr]     | ---------------- associated function in this implementation
[INFO] [stderr] 331 |     fn new(x: T) -> MyBox<T> {
[INFO] [stderr]     |        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Wolf` is never constructed
[INFO] [stderr]    --> src/main.rs:336:8
[INFO] [stderr]     |
[INFO] [stderr] 336 | struct Wolf {}
[INFO] [stderr]     |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `MyClone` is never used
[INFO] [stderr]    --> src/main.rs:339:7
[INFO] [stderr]     |
[INFO] [stderr] 339 | trait MyClone<T> {
[INFO] [stderr]     |       ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `id` is never used
[INFO] [stderr]    --> src/main.rs:350:4
[INFO] [stderr]     |
[INFO] [stderr] 350 | fn id(p: Point) -> Point {
[INFO] [stderr]     |    ^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `futures::StreamExt`
[INFO] [stderr]  --> src/listener.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use futures::StreamExt;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `topic`
[INFO] [stderr]  --> src/listener.rs:7:9
[INFO] [stderr]   |
[INFO] [stderr] 7 |     let topic = std::env::var("TOPIC").expect("TOPIC must be set");
[INFO] [stderr]   |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_topic`
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `producer`
[INFO] [stderr]  --> src/listener.rs:9:9
[INFO] [stderr]   |
[INFO] [stderr] 9 |     let producer: FutureProducer = rdkafka::config::ClientConfig::new()
[INFO] [stderr]   |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_producer`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `sub`
[INFO] [stderr]   --> src/listener.rs:19:9
[INFO] [stderr]    |
[INFO] [stderr] 19 |     let sub = provider.subscribe_pending_transactions().await?;
[INFO] [stderr]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_sub`
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `admin::AdminOptions` and `config::FromClientConfig`
[INFO] [stderr]   --> src/process.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 |     admin::AdminOptions,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 11 |     config::FromClientConfig,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `i`
[INFO] [stderr]   --> src/process.rs:56:9
[INFO] [stderr]    |
[INFO] [stderr] 56 |     for i in 0..10 {
[INFO] [stderr]    |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/process.rs:158:13
[INFO] [stderr]     |
[INFO] [stderr] 158 |         let mut hash = match message {
[INFO] [stderr]     |             ----^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `core::hash`
[INFO] [stderr]  --> src/web.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use core::hash;
[INFO] [stderr]   |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::error::Error`
[INFO] [stderr]  --> src/web.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::error::Error;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `net::TcpListener` and `sync::Arc`
[INFO] [stderr]  --> src/web.rs:4:11
[INFO] [stderr]   |
[INFO] [stderr] 4 | use std::{net::TcpListener, sync::Arc};
[INFO] [stderr]   |           ^^^^^^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `tokio::sync::Mutex`
[INFO] [stderr]   --> src/web.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | use tokio::sync::Mutex;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `start_block`
[INFO] [stderr]   --> src/web.rs:78:5
[INFO] [stderr]    |
[INFO] [stderr] 78 |     start_block: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_block`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `end_block`
[INFO] [stderr]   --> src/web.rs:79:5
[INFO] [stderr]    |
[INFO] [stderr] 79 |     end_block: u64,
[INFO] [stderr]    |     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_end_block`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/web.rs:158:23
[INFO] [stderr]     |
[INFO] [stderr] 158 |             .map_err(|e| {
[INFO] [stderr]     |                       ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `pool`
[INFO] [stderr]    --> src/web.rs:124:11
[INFO] [stderr]     |
[INFO] [stderr] 124 |     State(pool): State<bb8::Pool<RedisConnectionManager>>,
[INFO] [stderr]     |           ^^^^ help: if this is intentional, prefix it with an underscore: `_pool`
[INFO] [stderr] 
[INFO] [stderr] warning: function `send_to_cache` is never used
[INFO] [stderr]    --> src/process.rs:100:14
[INFO] [stderr]     |
[INFO] [stderr] 100 | pub async fn send_to_cache(
[INFO] [stderr]     |              ^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `main` is never used
[INFO] [stderr]    --> src/process.rs:113:10
[INFO] [stderr]     |
[INFO] [stderr] 113 | async fn main() {
[INFO] [stderr]     |          ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `dashboard` (lib test) generated 20 warnings (run `cargo fix --lib -p dashboard --tests` to apply 12 suggestions)
[INFO] [stderr] warning: `dashboard` (bin "listener" test) generated 4 warnings (run `cargo fix --bin "listener" -p dashboard --tests` to apply 4 suggestions)
[INFO] [stderr] warning: `dashboard` (bin "process" test) generated 3 warnings (run `cargo fix --bin "process" -p dashboard --tests` to apply 3 suggestions)
[INFO] [stderr] warning: `dashboard` (bin "web" test) generated 13 warnings (3 duplicates) (run `cargo fix --bin "web" -p dashboard --tests` to apply 8 suggestions)
[INFO] [stderr] warning: `dashboard` (bin "main" test) generated 20 warnings (20 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.57s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/dashboard-b420333b18f74fd4)
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/listener.rs (/opt/rustwide/target/debug/deps/listener-b85699874d08cf14)
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/main-15e11571987b22e2)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/feline.rs (/opt/rustwide/target/debug/deps/meow-8ded27a5159c8d39)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/process.rs (/opt/rustwide/target/debug/deps/process-dce13f16a4490445)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test tests::test_decode_tx ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- tests::test_decode_tx stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'tests::test_decode_tx' (29) panicked at src/process.rs:212:58:
[INFO] [stdout] RPC_URL_HTTP must be set: NotPresent
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x634e4dd1edf2 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x634e4dd1edf2 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x634e4dd1edf2 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x634e4dd1edf2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x634e4dd310ea - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x634e4dd310ea - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x634e4dcec126 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x634e4dcec126 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x634e4dcfdc99 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x634e4dcfdc99 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x634e4dcfdb31 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x634e4d8bb3de - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x634e4d8bb3de - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x634e4dcfdfc2 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x634e4dcfdfc2 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x634e4dcfdd58 - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x634e4dcf8e09 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x634e4dce0efd - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x634e4dd399cc - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x634e4dd38f72 - core::result::unwrap_failed::hf2d1f30a3ac850fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/result.rs:1867:5
[INFO] [stdout]   20:     0x634e4d8113ae - core::result::Result<T,E>::expect::he76d4d640289a324
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/result.rs:1185:23
[INFO] [stdout]   21:     0x634e4d840eb1 - process::tests::test_decode_tx::{{closure}}::hca0170b1f5d702db
[INFO] [stdout]                                at /opt/rustwide/workdir/src/process.rs:212:58
[INFO] [stdout]   22:     0x634e4d822e62 - <core::pin::Pin<P> as core::future::future::Future>::poll::h7545d471fb721482
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x634e4d822e9d - <core::pin::Pin<P> as core::future::future::Future>::poll::h7f0727fe11b8c2a5
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x634e4d889dfd - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::{{closure}}::h155f79899c7e78f3
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/scheduler/current_thread/mod.rs:696:73
[INFO] [stdout]   25:     0x634e4d889bab - tokio::runtime::coop::with_budget::h75266a92431fefc9
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/coop.rs:107:5
[INFO] [stdout]   26:     0x634e4d889bab - tokio::runtime::coop::budget::h8a83a1f7e3e148ad
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/coop.rs:73:5
[INFO] [stdout]   27:     0x634e4d889bab - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::hd180fb29499b350c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/scheduler/current_thread/mod.rs:696:25
[INFO] [stdout]   28:     0x634e4d886e60 - tokio::runtime::scheduler::current_thread::Context::enter::h8fd31900e75d67cd
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/scheduler/current_thread/mod.rs:423:19
[INFO] [stdout]   29:     0x634e4d889260 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::h387ce3c0bc70724b
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/scheduler/current_thread/mod.rs:695:44
[INFO] [stdout]   30:     0x634e4d888424 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::{{closure}}::h9867ea8afa3d07eb
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/scheduler/current_thread/mod.rs:774:68
[INFO] [stdout]   31:     0x634e4d885e7b - tokio::runtime::context::scoped::Scoped<T>::set::h7a4ea86bac0f5bf8
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x634e4d865729 - tokio::runtime::context::set_scheduler::{{closure}}::h2fc874b7efdbdbb2
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/context.rs:180:38
[INFO] [stdout]   33:     0x634e4d883472 - std::thread::local::LocalKey<T>::try_with::h769b5775fc44ac4f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/local.rs:513:12
[INFO] [stdout]   34:     0x634e4d882e9e - std::thread::local::LocalKey<T>::with::h11e3d48cdcc5b99e
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/local.rs:477:20
[INFO] [stdout]   35:     0x634e4d8656dd - tokio::runtime::context::set_scheduler::h8b26fb7ccfc397f2
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/context.rs:180:17
[INFO] [stdout]   36:     0x634e4d887db0 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::h059de4ddcd7d1a8a
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/scheduler/current_thread/mod.rs:774:27
[INFO] [stdout]   37:     0x634e4d888506 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::h8b97e53b39067210
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/scheduler/current_thread/mod.rs:683:24
[INFO] [stdout]   38:     0x634e4d8863f3 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::{{closure}}::he3462d20124114cb
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/scheduler/current_thread/mod.rs:191:33
[INFO] [stdout]   39:     0x634e4d85cce3 - tokio::runtime::context::runtime::enter_runtime::h40f4808908088e9d
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x634e4d8860f1 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::h0ec14dffe0f295d2
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/scheduler/current_thread/mod.rs:179:9
[INFO] [stdout]   41:     0x634e4d831eaa - tokio::runtime::runtime::Runtime::block_on_inner::he7f293cabb5d1af1
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/runtime.rs:361:52
[INFO] [stdout]   42:     0x634e4d831f95 - tokio::runtime::runtime::Runtime::block_on::h0c069129d0ec66a7
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.40.0/src/runtime/runtime.rs:335:18
[INFO] [stdout]   43:     0x634e4d840cc3 - process::tests::test_decode_tx::h780e75c0290ab268
[INFO] [stdout]                                at /opt/rustwide/workdir/src/process.rs:219:46
[INFO] [stdout]   44:     0x634e4d840d57 - process::tests::test_decode_tx::{{closure}}::hbd9e57c2b372d76a
[INFO] [stdout]                                at /opt/rustwide/workdir/src/process.rs:209:30
[INFO] [stdout]   45:     0x634e4d8063e6 - core::ops::function::FnOnce::call_once::h1c8fda144c6a898d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x634e4d8bb19b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x634e4d8bb19b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   48:     0x634e4d8cebaa - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   49:     0x634e4d8cebaa - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   50:     0x634e4d8cebaa - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   51:     0x634e4d8cebaa - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   52:     0x634e4d8cebaa - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   53:     0x634e4d8cebaa - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   54:     0x634e4d8cebaa - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   55:     0x634e4d8a9004 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   56:     0x634e4d8a9004 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   57:     0x634e4d8ac9a2 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   58:     0x634e4d8ac9a2 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   59:     0x634e4d8ac9a2 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   60:     0x634e4d8ac9a2 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   61:     0x634e4d8ac9a2 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   62:     0x634e4d8ac9a2 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   63:     0x634e4d8ac9a2 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   64:     0x634e4dcf3f3f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   65:     0x634e4dcf3f3f - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   66:     0x70cbbe821aa4 - <unknown>
[INFO] [stdout]   67:     0x70cbbe8aea64 - clone
[INFO] [stdout]   68:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     tests::test_decode_tx
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.12s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin process`
[INFO] running `Command { std: "docker" "inspect" "0c2be3e6b6953c1bd540786bcd231c763e59e7cf85f2766a50bb1f8a31b27784", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0c2be3e6b6953c1bd540786bcd231c763e59e7cf85f2766a50bb1f8a31b27784", kill_on_drop: false }`
[INFO] [stdout] 0c2be3e6b6953c1bd540786bcd231c763e59e7cf85f2766a50bb1f8a31b27784
