[INFO] cloning repository https://github.com/6480689/MapReduceLite
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/6480689/MapReduceLite" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F6480689%2FMapReduceLite", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F6480689%2FMapReduceLite'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 2c3bb9b9e1aa58bb412831aa147598768e1c5b7d
[INFO] checking 6480689/MapReduceLite against master#3129d37ef7075ee3cbaa3d6cbe1b5794f67192b0 for pr-143164
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F6480689%2FMapReduceLite" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/6480689/MapReduceLite
[INFO] finished tweaking git repo https://github.com/6480689/MapReduceLite
[INFO] tweaked toml for git repo https://github.com/6480689/MapReduceLite written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/6480689/MapReduceLite on toolchain 3129d37ef7075ee3cbaa3d6cbe1b5794f67192b0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+3129d37ef7075ee3cbaa3d6cbe1b5794f67192b0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/6480689/MapReduceLite 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" "+3129d37ef7075ee3cbaa3d6cbe1b5794f67192b0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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:cf8efcab8866f2cf4285301c7418e2f4f2a9b088c91ba69c40d5b659f81557f7" "/opt/rustwide/cargo-home/bin/cargo" "+3129d37ef7075ee3cbaa3d6cbe1b5794f67192b0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] e3302628fa2fac5f4b68746585b86fb266b71e4b7a8460ce7cb2d9921edf30ea
[INFO] running `Command { std: "docker" "start" "-a" "e3302628fa2fac5f4b68746585b86fb266b71e4b7a8460ce7cb2d9921edf30ea", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "e3302628fa2fac5f4b68746585b86fb266b71e4b7a8460ce7cb2d9921edf30ea", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e3302628fa2fac5f4b68746585b86fb266b71e4b7a8460ce7cb2d9921edf30ea", kill_on_drop: false }`
[INFO] [stdout] e3302628fa2fac5f4b68746585b86fb266b71e4b7a8460ce7cb2d9921edf30ea
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cf8efcab8866f2cf4285301c7418e2f4f2a9b088c91ba69c40d5b659f81557f7" "/opt/rustwide/cargo-home/bin/cargo" "+3129d37ef7075ee3cbaa3d6cbe1b5794f67192b0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 008950e5385e6b0f96b60ba59b3bb2bb43259acfaedb39940f525fd7b5d87846
[INFO] running `Command { std: "docker" "start" "-a" "008950e5385e6b0f96b60ba59b3bb2bb43259acfaedb39940f525fd7b5d87846", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.83
[INFO] [stderr]    Compiling libc v0.2.155
[INFO] [stderr]    Compiling version_check v0.9.4
[INFO] [stderr]     Checking bytes v1.6.0
[INFO] [stderr]     Checking memchr v2.7.2
[INFO] [stderr]     Checking smallvec v1.13.2
[INFO] [stderr]     Checking either v1.9.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking subtle v2.5.0
[INFO] [stderr]     Checking zeroize v1.8.1
[INFO] [stderr]     Checking zerocopy v0.7.34
[INFO] [stderr]     Checking allocator-api2 v0.2.18
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]     Checking http v0.2.12
[INFO] [stderr]     Checking http v1.1.0
[INFO] [stderr]     Checking deranged v0.3.11
[INFO] [stderr]    Compiling quote v1.0.36
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]    Compiling syn v2.0.65
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking mio v0.8.11
[INFO] [stderr]     Checking socket2 v0.5.7
[INFO] [stderr]     Checking signal-hook-registry v1.4.2
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking http-body v0.4.6
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking http-body v1.0.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking vsimd v0.8.0
[INFO] [stderr]     Checking crypto-common v0.1.6
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]     Checking outref v0.5.1
[INFO] [stderr]     Checking time-core v0.1.2
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking bytes-utils v0.1.4
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]    Compiling cc v1.0.99
[INFO] [stderr]    Compiling semver v1.0.23
[INFO] [stderr]     Checking time v0.3.36
[INFO] [stderr]     Checking const-oid v0.9.6
[INFO] [stderr]     Checking log v0.4.22
[INFO] [stderr]     Checking untrusted v0.9.0
[INFO] [stderr]     Checking spin v0.9.8
[INFO] [stderr]    Compiling rustc_version v0.4.0
[INFO] [stderr]     Checking der v0.6.1
[INFO] [stderr]    Compiling httparse v1.8.0
[INFO] [stderr]     Checking base64-simd v0.8.0
[INFO] [stderr]     Checking tower-service v0.3.2
[INFO] [stderr]     Checking stable_deref_trait v1.2.0
[INFO] [stderr]     Checking base64ct v1.6.0
[INFO] [stderr]    Compiling itertools v0.12.1
[INFO] [stderr]     Checking indexmap v2.2.6
[INFO] [stderr]    Compiling anyhow v1.0.86
[INFO] [stderr]    Compiling rustix v0.38.34
[INFO] [stderr]     Checking spki v0.6.0
[INFO] [stderr]     Checking ff v0.12.1
[INFO] [stderr]     Checking pkcs8 v0.9.0
[INFO] [stderr]     Checking crypto-bigint v0.4.9
[INFO] [stderr]     Checking httpdate v1.0.3
[INFO] [stderr]     Checking base16ct v0.1.1
[INFO] [stderr]     Checking fastrand v2.1.0
[INFO] [stderr]     Checking cpufeatures v0.2.12
[INFO] [stderr]     Checking sec1 v0.3.0
[INFO] [stderr]     Checking group v0.12.1
[INFO] [stderr]     Checking hmac v0.12.1
[INFO] [stderr]     Checking base64 v0.21.7
[INFO] [stderr]    Compiling rustls v0.21.12
[INFO] [stderr]     Checking sha2 v0.10.8
[INFO] [stderr]     Checking signature v1.6.4
[INFO] [stderr]    Compiling ring v0.17.8
[INFO] [stderr]     Checking writeable v0.5.5
[INFO] [stderr]    Compiling rustversion v1.0.17
[INFO] [stderr]    Compiling prettyplease v0.2.20
[INFO] [stderr]     Checking litemap v0.7.3
[INFO] [stderr]     Checking rustls-pemfile v1.0.4
[INFO] [stderr]     Checking rfc6979 v0.3.1
[INFO] [stderr]     Checking elliptic-curve v0.12.3
[INFO] [stderr]    Compiling aws-types v1.3.1
[INFO] [stderr]    Compiling memoffset v0.9.0
[INFO] [stderr]    Compiling crossbeam-utils v0.8.16
[INFO] [stderr]     Checking rustls-native-certs v0.6.3
[INFO] [stderr]     Checking crypto-bigint v0.5.5
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.15
[INFO] [stderr]     Checking icu_locid_transform_data v1.5.0
[INFO] [stderr]    Compiling serde v1.0.202
[INFO] [stderr]     Checking ecdsa v0.14.8
[INFO] [stderr]     Checking uuid v1.8.0
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]     Checking p256 v0.11.1
[INFO] [stderr]     Checking icu_properties_data v1.5.0
[INFO] [stderr]    Compiling equivalent v1.0.1
[INFO] [stderr]    Compiling bitflags v2.5.0
[INFO] [stderr]     Checking unicode-ident v1.0.12
[INFO] [stderr]    Compiling linux-raw-sys v0.4.14
[INFO] [stderr]    Compiling regex-syntax v0.8.4
[INFO] [stderr]     Checking regex-automata v0.4.7
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling fixedbitset v0.4.2
[INFO] [stderr]     Checking utf8_iter v1.0.4
[INFO] [stderr]     Checking ppv-lite86 v0.2.17
[INFO] [stderr]     Checking write16 v1.0.0
[INFO] [stderr]     Checking icu_normalizer_data v1.5.0
[INFO] [stderr]    Compiling paste v1.0.15
[INFO] [stderr]     Checking utf8parse v0.2.1
[INFO] [stderr]     Checking regex-lite v0.1.6
[INFO] [stderr]     Checking utf16_iter v1.0.5
[INFO] [stderr]    Compiling rayon-core v1.12.0
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]     Checking sct v0.7.1
[INFO] [stderr]     Checking rustls-webpki v0.101.7
[INFO] [stderr]     Checking regex v1.10.5
[INFO] [stderr]    Compiling tempfile v3.10.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking anstyle-parse v0.2.4
[INFO] [stderr]    Compiling petgraph v0.6.5
[INFO] [stderr]     Checking crossbeam-deque v0.8.3
[INFO] [stderr]    Compiling axum-core v0.3.4
[INFO] [stderr]    Compiling crc32c v0.6.5
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]     Checking is_terminal_polyfill v1.70.0
[INFO] [stderr]    Compiling once_cell v1.19.0
[INFO] [stderr]     Checking xmlparser v0.13.6
[INFO] [stderr]     Checking tower-layer v0.3.2
[INFO] [stderr]    Compiling tokio-macros v2.3.0
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]    Compiling zerofrom-derive v0.1.4
[INFO] [stderr]    Compiling yoke-derive v0.7.4
[INFO] [stderr]     Checking tokio v1.38.0
[INFO] [stderr]    Compiling zerovec-derive v0.10.2
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]    Compiling displaydoc v0.2.4
[INFO] [stderr]    Compiling prost-derive v0.12.6
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking zerofrom v0.1.4
[INFO] [stderr]    Compiling icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling serde_derive v1.0.202
[INFO] [stderr]     Checking yoke v0.7.4
[INFO] [stderr]    Compiling pin-project-internal v1.1.5
[INFO] [stderr]     Checking zerovec v0.10.2
[INFO] [stderr]     Checking anstyle v1.0.7
[INFO] [stderr]     Checking anstyle-query v1.0.3
[INFO] [stderr]     Checking colorchoice v1.0.1
[INFO] [stderr]    Compiling multimap v0.10.0
[INFO] [stderr]     Checking anstream v0.6.14
[INFO] [stderr]     Checking aws-smithy-xml v0.60.8
[INFO] [stderr]    Compiling async-trait v0.1.80
[INFO] [stderr]     Checking pin-project v1.1.5
[INFO] [stderr]     Checking tinystr v0.7.6
[INFO] [stderr]     Checking icu_collections v1.5.0
[INFO] [stderr]    Compiling prost v0.12.6
[INFO] [stderr]     Checking icu_locid v1.5.0
[INFO] [stderr]    Compiling prost-types v0.12.6
[INFO] [stderr]     Checking icu_provider v1.5.0
[INFO] [stderr]     Checking http-body-util v0.1.2
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling axum v0.6.20
[INFO] [stderr]     Checking icu_locid_transform v1.5.0
[INFO] [stderr]     Checking urlencoding v2.1.3
[INFO] [stderr]     Checking rmp v0.8.14
[INFO] [stderr]     Checking icu_properties v1.5.0
[INFO] [stderr]    Compiling prost-build v0.12.6
[INFO] [stderr]     Checking tokio-util v0.7.11
[INFO] [stderr]     Checking aws-smithy-async v1.2.1
[INFO] [stderr]     Checking tokio-rustls v0.24.1
[INFO] [stderr]     Checking tokio-io-timeout v1.2.0
[INFO] [stderr]     Checking aws-smithy-types v1.2.0
[INFO] [stderr]     Checking h2 v0.3.26
[INFO] [stderr]    Compiling tonic-build v0.11.0
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking aws-smithy-runtime-api v1.6.3
[INFO] [stderr]     Checking aws-smithy-eventstream v0.60.4
[INFO] [stderr]     Checking aws-smithy-json v0.60.7
[INFO] [stderr]    Compiling deepsize_derive v0.1.2
[INFO] [stderr]     Checking aws-smithy-query v0.60.7
[INFO] [stderr]     Checking aws-smithy-http v0.60.8
[INFO] [stderr]     Checking aws-credential-types v1.2.0
[INFO] [stderr]     Checking rayon v1.8.0
[INFO] [stderr]     Checking icu_normalizer v1.5.0
[INFO] [stderr]     Checking aws-sigv4 v1.2.1
[INFO] [stderr]    Compiling async-stream-impl v0.3.5
[INFO] [stderr]     Checking idna v1.0.0
[INFO] [stderr]     Checking aws-runtime v1.2.2
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking url v2.5.1
[INFO] [stderr]     Checking md-5 v0.10.6
[INFO] [stderr]     Checking heck v0.5.0
[INFO] [stderr]     Checking matchit v0.7.3
[INFO] [stderr]     Checking clap_lex v0.7.0
[INFO] [stderr]     Checking sync_wrapper v0.1.2
[INFO] [stderr]     Checking bitflags v1.3.2
[INFO] [stderr]     Checking hyper v0.14.29
[INFO] [stderr]    Compiling serde_json v1.0.117
[INFO] [stderr]     Checking clap_builder v4.5.2
[INFO] [stderr]     Checking rmp-serde v1.3.0
[INFO] [stderr]     Checking aws-smithy-checksums v0.60.9
[INFO] [stderr]     Checking async-stream v0.3.5
[INFO] [stderr]     Checking deepsize v0.2.0
[INFO] [stderr]    Compiling mrlite v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> build.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking tokio-stream v0.1.15
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]    Compiling clap_derive v4.5.4
[INFO] [stderr]     Checking env_filter v0.1.0
[INFO] [stderr]     Checking lru v0.12.3
[INFO] [stderr]     Checking rand v0.4.6
[INFO] [stderr]     Checking humantime v2.1.0
[INFO] [stderr]     Checking remove_dir_all v0.5.3
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]     Checking env_logger v0.11.3
[INFO] [stderr]     Checking dashmap v5.5.3
[INFO] [stderr]     Checking ext-sort v0.1.4
[INFO] [stderr]     Checking itertools v0.13.0
[INFO] [stderr]     Checking glob v0.3.1
[INFO] [stderr]     Checking tempdir v0.3.7
[INFO] [stderr]     Checking bytesize v1.3.0
[INFO] [stderr]     Checking clap v4.5.4
[INFO] [stderr]     Checking hyper-rustls v0.24.2
[INFO] [stderr]     Checking hyper-timeout v0.4.1
[INFO] [stderr]     Checking aws-smithy-runtime v1.5.7
[INFO] [stderr]     Checking aws-sdk-sso v1.29.0
[INFO] [stderr]     Checking aws-sdk-sts v1.29.0
[INFO] [stderr]     Checking aws-sdk-ssooidc v1.30.0
[INFO] [stderr]     Checking aws-sdk-s3 v1.34.0
[INFO] [stderr]     Checking aws-config v1.5.1
[INFO] [stderr]     Checking tonic v0.11.0
[INFO] [stdout] warning: unused import: `PresigningConfig`
[INFO] [stdout]  --> src/lib.rs:9:48
[INFO] [stdout]   |
[INFO] [stdout] 9 | use aws_sdk_s3::presigning::{PresignedRequest, PresigningConfig};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::SocketAddr`
[INFO] [stdout]  --> src/rpc/coordinator_ctl_server.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::SocketAddr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::rpc::server::MySay`
[INFO] [stdout]  --> src/rpc/coordinator_ctl_server.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::rpc::server::MySay;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Status` and `transport::Channel`
[INFO] [stdout]  --> src/rpc/coordinator_ctl_client.rs:1:13
[INFO] [stdout]   |
[INFO] [stdout] 1 | use tonic::{transport::Channel, Request, Response, Status};
[INFO] [stdout]   |             ^^^^^^^^^^^^^^^^^^                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `glob::glob`
[INFO] [stdout]  --> src/distributed/engine.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use glob::glob;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> src/distributed/engine.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 9 |     io::{Read, Write},
[INFO] [stdout]   |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `decode` and `encode`
[INFO] [stdout]   --> src/distributed/engine.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 | use base64::{encode, decode, engine, Engine};
[INFO] [stdout]    |              ^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashSet`
[INFO] [stdout]   --> src/distributed/engine.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::collections::HashSet;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `io`
[INFO] [stdout]   --> src/distributed/engine.rs:19:17
[INFO] [stdout]    |
[INFO] [stdout] 19 | use tokio::{fs, io};
[INFO] [stdout]    |                 ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::distributed::s3::download_file`
[INFO] [stdout]   --> src/distributed/engine.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use crate::distributed::s3::download_file;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path`
[INFO] [stdout]   --> src/distributed/engine.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | use std::path;
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/distributed/engine.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::Mutex`
[INFO] [stdout]   --> src/distributed/engine.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use tokio::sync::Mutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bytesize::MB`
[INFO] [stdout]   --> src/distributed/engine.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use bytesize::MB;
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `env_logger`
[INFO] [stdout]   --> src/distributed/engine.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | use env_logger;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ExternalSorterBuilder`, `ExternalSorter`, and `buffer::mem::MemoryLimitedBufferBuilder`
[INFO] [stdout]   --> src/distributed/engine.rs:30:16
[INFO] [stdout]    |
[INFO] [stdout] 30 | use ext_sort::{buffer::mem::MemoryLimitedBufferBuilder, ExternalSorter, ExternalSorterBuilder};
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/distributed/engine.rs:329:16
[INFO] [stdout]     |
[INFO] [stdout] 329 |             if (!key_string.clone().chars().all(|arg0: char| char::is_ascii_alphanumeric(&arg0))) {
[INFO] [stdout]     |                ^                                                                                ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 329 -             if (!key_string.clone().chars().all(|arg0: char| char::is_ascii_alphanumeric(&arg0))) {
[INFO] [stdout] 329 +             if !key_string.clone().chars().all(|arg0: char| char::is_ascii_alphanumeric(&arg0)) {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]  --> src/distributed/s3.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::fs::File;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BufReader`
[INFO] [stdout]  --> src/distributed/s3.rs:4:24
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::io::{BufRead, BufReader};
[INFO] [stdout]   |                        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/distributed/s3.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::Mutex`
[INFO] [stdout]  --> src/distributed/s3.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use tokio::sync::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `aws_sdk_s3::Client`
[INFO] [stdout]   --> src/distributed/s3.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use aws_sdk_s3::Client;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BufMut`, `BytesMut`, and `Bytes`
[INFO] [stdout]   --> src/distributed/s3.rs:12:13
[INFO] [stdout]    |
[INFO] [stdout] 12 | use bytes::{BufMut, Bytes, BytesMut};
[INFO] [stdout]    |             ^^^^^^  ^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::KeyValue`
[INFO] [stdout]   --> src/distributed/s3.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | use crate::KeyValue;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `env_logger`
[INFO] [stdout]  --> src/distributed/external_sort.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use env_logger;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log`
[INFO] [stdout]  --> src/distributed/external_sort.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use log;
[INFO] [stdout]   |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]   --> src/distributed/engine.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 | use base64::{encode, decode, engine, Engine};
[INFO] [stdout]    |              ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode
[INFO] [stdout]   --> src/distributed/engine.rs:11:22
[INFO] [stdout]    |
[INFO] [stdout] 11 | use base64::{encode, decode, engine, Engine};
[INFO] [stdout]    |                      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PresigningConfig`
[INFO] [stdout]  --> src/lib.rs:9:48
[INFO] [stdout]   |
[INFO] [stdout] 9 | use aws_sdk_s3::presigning::{PresignedRequest, PresigningConfig};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::SocketAddr`
[INFO] [stdout]  --> src/rpc/coordinator_ctl_server.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::SocketAddr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::rpc::server::MySay`
[INFO] [stdout]  --> src/rpc/coordinator_ctl_server.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::rpc::server::MySay;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Status` and `transport::Channel`
[INFO] [stdout]  --> src/rpc/coordinator_ctl_client.rs:1:13
[INFO] [stdout]   |
[INFO] [stdout] 1 | use tonic::{transport::Channel, Request, Response, Status};
[INFO] [stdout]   |             ^^^^^^^^^^^^^^^^^^                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `glob::glob`
[INFO] [stdout]  --> src/distributed/engine.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use glob::glob;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> src/distributed/engine.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 9 |     io::{Read, Write},
[INFO] [stdout]   |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `decode` and `encode`
[INFO] [stdout]   --> src/distributed/engine.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 | use base64::{encode, decode, engine, Engine};
[INFO] [stdout]    |              ^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashSet`
[INFO] [stdout]   --> src/distributed/engine.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::collections::HashSet;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `io`
[INFO] [stdout]   --> src/distributed/engine.rs:19:17
[INFO] [stdout]    |
[INFO] [stdout] 19 | use tokio::{fs, io};
[INFO] [stdout]    |                 ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::distributed::s3::download_file`
[INFO] [stdout]   --> src/distributed/engine.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use crate::distributed::s3::download_file;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path`
[INFO] [stdout]   --> src/distributed/engine.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | use std::path;
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/distributed/engine.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::Mutex`
[INFO] [stdout]   --> src/distributed/engine.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use tokio::sync::Mutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bytesize::MB`
[INFO] [stdout]   --> src/distributed/engine.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use bytesize::MB;
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `env_logger`
[INFO] [stdout]   --> src/distributed/engine.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | use env_logger;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ExternalSorterBuilder`, `ExternalSorter`, and `buffer::mem::MemoryLimitedBufferBuilder`
[INFO] [stdout]   --> src/distributed/engine.rs:30:16
[INFO] [stdout]    |
[INFO] [stdout] 30 | use ext_sort::{buffer::mem::MemoryLimitedBufferBuilder, ExternalSorter, ExternalSorterBuilder};
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/distributed/engine.rs:329:16
[INFO] [stdout]     |
[INFO] [stdout] 329 |             if (!key_string.clone().chars().all(|arg0: char| char::is_ascii_alphanumeric(&arg0))) {
[INFO] [stdout]     |                ^                                                                                ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 329 -             if (!key_string.clone().chars().all(|arg0: char| char::is_ascii_alphanumeric(&arg0))) {
[INFO] [stdout] 329 +             if !key_string.clone().chars().all(|arg0: char| char::is_ascii_alphanumeric(&arg0)) {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]  --> src/distributed/s3.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::fs::File;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BufReader`
[INFO] [stdout]  --> src/distributed/s3.rs:4:24
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::io::{BufRead, BufReader};
[INFO] [stdout]   |                        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/distributed/s3.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::sync::Mutex`
[INFO] [stdout]  --> src/distributed/s3.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use tokio::sync::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `aws_sdk_s3::Client`
[INFO] [stdout]   --> src/distributed/s3.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use aws_sdk_s3::Client;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BufMut`, `BytesMut`, and `Bytes`
[INFO] [stdout]   --> src/distributed/s3.rs:12:13
[INFO] [stdout]    |
[INFO] [stdout] 12 | use bytes::{BufMut, Bytes, BytesMut};
[INFO] [stdout]    |             ^^^^^^  ^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::KeyValue`
[INFO] [stdout]   --> src/distributed/s3.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | use crate::KeyValue;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `env_logger`
[INFO] [stdout]  --> src/distributed/external_sort.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use env_logger;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log`
[INFO] [stdout]  --> src/distributed/external_sort.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use log;
[INFO] [stdout]   |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]   --> src/distributed/engine.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 | use base64::{encode, decode, engine, Engine};
[INFO] [stdout]    |              ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode
[INFO] [stdout]   --> src/distributed/engine.rs:11:22
[INFO] [stdout]    |
[INFO] [stdout] 11 | use base64::{encode, decode, engine, Engine};
[INFO] [stdout]    |                      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/distributed/engine.rs:138:9
[INFO] [stdout]     |
[INFO] [stdout] 138 |     let mut buckets: Buckets = Buckets::new();
[INFO] [stdout]     |         ----^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/distributed/engine.rs:150:9
[INFO] [stdout]     |
[INFO] [stdout] 150 |     let mut entries = fs::read_dir("upload").await;
[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/distributed/engine.rs:249:9
[INFO] [stdout]     |
[INFO] [stdout] 249 |     let mut entries = fs::read_dir("download").await;
[INFO] [stdout]     |         ----^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `value` is never read
[INFO] [stdout]    --> src/distributed/engine.rs:377:13
[INFO] [stdout]     |
[INFO] [stdout] 377 |     let mut value = Bytes::new();
[INFO] [stdout]     |             ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/distributed/engine.rs:138:9
[INFO] [stdout]     |
[INFO] [stdout] 138 |     let mut buckets: Buckets = Buckets::new();
[INFO] [stdout]     |         ----^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/distributed/engine.rs:150:9
[INFO] [stdout]     |
[INFO] [stdout] 150 |     let mut entries = fs::read_dir("upload").await;
[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/distributed/engine.rs:249:9
[INFO] [stdout]     |
[INFO] [stdout] 249 |     let mut entries = fs::read_dir("download").await;
[INFO] [stdout]     |         ----^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `unique_filename` is never read
[INFO] [stdout]    --> src/distributed/s3.rs:203:13
[INFO] [stdout]     |
[INFO] [stdout] 203 |     let mut unique_filename = filename.clone();
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `value` is never read
[INFO] [stdout]    --> src/distributed/engine.rs:377:13
[INFO] [stdout]     |
[INFO] [stdout] 377 |     let mut value = Bytes::new();
[INFO] [stdout]     |             ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `unique_filename` is never read
[INFO] [stdout]    --> src/distributed/s3.rs:203:13
[INFO] [stdout]     |
[INFO] [stdout] 203 |     let mut unique_filename = filename.clone();
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::io::AsyncWriteExt`
[INFO] [stdout]   --> src/distributed/engine.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use tokio::io::AsyncWriteExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `itertools::Itertools`
[INFO] [stdout]  --> src/distributed/engine.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use itertools::Itertools;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::io::AsyncBufReadExt`
[INFO] [stdout]   --> src/distributed/engine.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use tokio::io::AsyncBufReadExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures_util::StreamExt`
[INFO] [stdout]   --> src/distributed/s3.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use futures_util::StreamExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tonic::codegen::Body`
[INFO] [stdout]   --> src/distributed/s3.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use tonic::codegen::Body;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BufRead`
[INFO] [stdout]  --> src/distributed/s3.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::io::{BufRead, BufReader};
[INFO] [stdout]   |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `key`
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     key: Bytes,
[INFO] [stdout]    |     ^^^ help: if this is intentional, prefix it with an underscore: `_key`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `aux`
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:76:27
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub fn map2(kv: KeyValue, aux: Bytes) -> MapOutput{
[INFO] [stdout]    |                           ^^^ help: if this is intentional, prefix it with an underscore: `_aux`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::io::AsyncWriteExt`
[INFO] [stdout]   --> src/distributed/engine.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use tokio::io::AsyncWriteExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `itertools::Itertools`
[INFO] [stdout]  --> src/distributed/engine.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use itertools::Itertools;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio::io::AsyncBufReadExt`
[INFO] [stdout]   --> src/distributed/engine.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use tokio::io::AsyncBufReadExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures_util::StreamExt`
[INFO] [stdout]   --> src/distributed/s3.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use futures_util::StreamExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tonic::codegen::Body`
[INFO] [stdout]   --> src/distributed/s3.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use tonic::codegen::Body;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BufRead`
[INFO] [stdout]  --> src/distributed/s3.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::io::{BufRead, BufReader};
[INFO] [stdout]   |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `key`
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     key: Bytes,
[INFO] [stdout]    |     ^^^ help: if this is intentional, prefix it with an underscore: `_key`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `aux`
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:76:27
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub fn map2(kv: KeyValue, aux: Bytes) -> MapOutput{
[INFO] [stdout]    |                           ^^^ help: if this is intentional, prefix it with an underscore: `_aux`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_object` is never used
[INFO] [stdout]   --> src/minio/bucket_sandbox.rs:11:10
[INFO] [stdout]    |
[INFO] [stdout] 11 | async fn get_object(
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `put_object` is never used
[INFO] [stdout]   --> src/minio/bucket_sandbox.rs:30:10
[INFO] [stdout]    |
[INFO] [stdout] 30 | async fn put_object(
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize_key_value` is never used
[INFO] [stdout]   --> src/distributed/engine.rs:88:4
[INFO] [stdout]    |
[INFO] [stdout] 88 | fn serialize_key_value(key: &Bytes, value: &Bytes, CUSTOM_ENGINE: &engine::GeneralPurpose) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CUSTOM_ENGINE` is never used
[INFO] [stdout]    --> src/distributed/engine.rs:441:11
[INFO] [stdout]     |
[INFO] [stdout] 441 |     const CUSTOM_ENGINE: engine::GeneralPurpose =
[INFO] [stdout]     |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `mat_A` should have a snake case name
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:53:13
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let mut mat_A = Vec::new();
[INFO] [stdout]    |             ^^^^^ help: convert the identifier to snake case: `mat_a`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `mat_B` should have a snake case name
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:54:13
[INFO] [stdout]    |
[INFO] [stdout] 54 |     let mut mat_B = Vec::new();
[INFO] [stdout]    |             ^^^^^ help: convert the identifier to snake case: `mat_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `val_A` should have a snake case name
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:67:15
[INFO] [stdout]    |
[INFO] [stdout] 67 |     for (row, val_A) in mat_A{
[INFO] [stdout]    |               ^^^^^ help: convert the identifier to snake case: `val_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `val_B` should have a snake case name
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:68:19
[INFO] [stdout]    |
[INFO] [stdout] 68 |         for (col, val_B) in mat_B.iter(){
[INFO] [stdout]    |                   ^^^^^ help: convert the identifier to snake case: `val_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `CUSTOM_ENGINE` should have a snake case name
[INFO] [stdout]   --> src/distributed/engine.rs:88:52
[INFO] [stdout]    |
[INFO] [stdout] 88 | fn serialize_key_value(key: &Bytes, value: &Bytes, CUSTOM_ENGINE: &engine::GeneralPurpose) -> String {
[INFO] [stdout]    |                                                    ^^^^^^^^^^^^^ help: convert the identifier to snake case: `custom_engine`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/distributed/s3.rs:297:22
[INFO] [stdout]     |
[INFO] [stdout] 297 |         .key(filename.clone())
[INFO] [stdout]     |                      ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/distributed/s3.rs:342:26
[INFO] [stdout]     |
[INFO] [stdout] 342 |             .key(filename.clone())
[INFO] [stdout]     |                          ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/distributed/s3.rs:363:22
[INFO] [stdout]     |
[INFO] [stdout] 363 |         .key(filename.clone())
[INFO] [stdout]     |                      ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_object` is never used
[INFO] [stdout]   --> src/minio/bucket_sandbox.rs:11:10
[INFO] [stdout]    |
[INFO] [stdout] 11 | async fn get_object(
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `put_object` is never used
[INFO] [stdout]   --> src/minio/bucket_sandbox.rs:30:10
[INFO] [stdout]    |
[INFO] [stdout] 30 | async fn put_object(
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize_key_value` is never used
[INFO] [stdout]   --> src/distributed/engine.rs:88:4
[INFO] [stdout]    |
[INFO] [stdout] 88 | fn serialize_key_value(key: &Bytes, value: &Bytes, CUSTOM_ENGINE: &engine::GeneralPurpose) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CUSTOM_ENGINE` is never used
[INFO] [stdout]    --> src/distributed/engine.rs:441:11
[INFO] [stdout]     |
[INFO] [stdout] 441 |     const CUSTOM_ENGINE: engine::GeneralPurpose =
[INFO] [stdout]     |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `mat_A` should have a snake case name
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:53:13
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let mut mat_A = Vec::new();
[INFO] [stdout]    |             ^^^^^ help: convert the identifier to snake case: `mat_a`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `mat_B` should have a snake case name
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:54:13
[INFO] [stdout]    |
[INFO] [stdout] 54 |     let mut mat_B = Vec::new();
[INFO] [stdout]    |             ^^^^^ help: convert the identifier to snake case: `mat_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `val_A` should have a snake case name
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:67:15
[INFO] [stdout]    |
[INFO] [stdout] 67 |     for (row, val_A) in mat_A{
[INFO] [stdout]    |               ^^^^^ help: convert the identifier to snake case: `val_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `val_B` should have a snake case name
[INFO] [stdout]   --> src/workload/matrix_multiply.rs:68:19
[INFO] [stdout]    |
[INFO] [stdout] 68 |         for (col, val_B) in mat_B.iter(){
[INFO] [stdout]    |                   ^^^^^ help: convert the identifier to snake case: `val_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `CUSTOM_ENGINE` should have a snake case name
[INFO] [stdout]   --> src/distributed/engine.rs:88:52
[INFO] [stdout]    |
[INFO] [stdout] 88 | fn serialize_key_value(key: &Bytes, value: &Bytes, CUSTOM_ENGINE: &engine::GeneralPurpose) -> String {
[INFO] [stdout]    |                                                    ^^^^^^^^^^^^^ help: convert the identifier to snake case: `custom_engine`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/distributed/s3.rs:297:22
[INFO] [stdout]     |
[INFO] [stdout] 297 |         .key(filename.clone())
[INFO] [stdout]     |                      ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/distributed/s3.rs:342:26
[INFO] [stdout]     |
[INFO] [stdout] 342 |             .key(filename.clone())
[INFO] [stdout]     |                          ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/distributed/s3.rs:363:22
[INFO] [stdout]     |
[INFO] [stdout] 363 |         .key(filename.clone())
[INFO] [stdout]     |                      ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]  --> src/app/standalone.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fs::File;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]   --> src/app/standalone.rs:45:32
[INFO] [stdout]    |
[INFO] [stdout] 45 |     let _ = fs::create_dir_all((&"download"));
[INFO] [stdout]    |                                ^           ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 45 -     let _ = fs::create_dir_all((&"download"));
[INFO] [stdout] 45 +     let _ = fs::create_dir_all(&"download");
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]   --> src/app/standalone.rs:46:32
[INFO] [stdout]    |
[INFO] [stdout] 46 |     let _ = fs::create_dir_all((&"upload"));
[INFO] [stdout]    |                                ^         ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 46 -     let _ = fs::create_dir_all((&"upload"));
[INFO] [stdout] 46 +     let _ = fs::create_dir_all(&"upload");
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n_reduce`
[INFO] [stdout]   --> src/app/standalone.rs:43:9
[INFO] [stdout]    |
[INFO] [stdout] 43 |     let n_reduce = 11;
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_n_reduce`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n_reduce`
[INFO] [stdout]   --> src/app/standalone.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let n_reduce = 11;
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_n_reduce`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_distributed_mr_job` is never used
[INFO] [stdout]   --> src/app/standalone.rs:41:10
[INFO] [stdout]    |
[INFO] [stdout] 41 | async fn run_distributed_mr_job(job: Job, engine: String) -> Result<()> {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]  --> src/app/standalone.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fs::File;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]   --> src/app/standalone.rs:45:32
[INFO] [stdout]    |
[INFO] [stdout] 45 |     let _ = fs::create_dir_all((&"download"));
[INFO] [stdout]    |                                ^           ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 45 -     let _ = fs::create_dir_all((&"download"));
[INFO] [stdout] 45 +     let _ = fs::create_dir_all(&"download");
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]   --> src/app/standalone.rs:46:32
[INFO] [stdout]    |
[INFO] [stdout] 46 |     let _ = fs::create_dir_all((&"upload"));
[INFO] [stdout]    |                                ^         ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 46 -     let _ = fs::create_dir_all((&"upload"));
[INFO] [stdout] 46 +     let _ = fs::create_dir_all(&"upload");
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary braces around block return value
[INFO] [stdout]    --> src/app/mrl-ctl.rs:210:13
[INFO] [stdout]     |
[INFO] [stdout] 210 |             {job_queue.lock().await.enqueue(parsed_args).await}
[INFO] [stdout]     |             ^                                                 ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_braces)]` on by default
[INFO] [stdout] help: remove these braces
[INFO] [stdout]     |
[INFO] [stdout] 210 -             {job_queue.lock().await.enqueue(parsed_args).await}
[INFO] [stdout] 210 +             job_queue.lock().await.enqueue(parsed_args).await
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error` and `info`
[INFO] [stdout]    --> src/app/mrl-ctl.rs:218:11
[INFO] [stdout]     |
[INFO] [stdout] 218 | use log::{info, error};
[INFO] [stdout]     |           ^^^^  ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary braces around block return value
[INFO] [stdout]    --> src/app/mrl-ctl.rs:210:13
[INFO] [stdout]     |
[INFO] [stdout] 210 |             {job_queue.lock().await.enqueue(parsed_args).await}
[INFO] [stdout]     |             ^                                                 ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_braces)]` on by default
[INFO] [stdout] help: remove these braces
[INFO] [stdout]     |
[INFO] [stdout] 210 -             {job_queue.lock().await.enqueue(parsed_args).await}
[INFO] [stdout] 210 +             job_queue.lock().await.enqueue(parsed_args).await
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error` and `info`
[INFO] [stdout]    --> src/app/mrl-ctl.rs:218:11
[INFO] [stdout]     |
[INFO] [stdout] 218 | use log::{info, error};
[INFO] [stdout]     |           ^^^^  ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n_reduce`
[INFO] [stdout]   --> src/app/standalone.rs:43:9
[INFO] [stdout]    |
[INFO] [stdout] 43 |     let n_reduce = 11;
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_n_reduce`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n_reduce`
[INFO] [stdout]   --> src/app/standalone.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let n_reduce = 11;
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_n_reduce`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::sleep`
[INFO] [stdout]  --> src/app/mrl-worker.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::thread::sleep;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Builder`
[INFO] [stdout]  --> src/app/mrl-worker.rs:5:26
[INFO] [stdout]   |
[INFO] [stdout] 5 | use aws_sdk_s3::config::{Builder, Credentials};
[INFO] [stdout]   |                          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `aws_smithy_types::timeout::TimeoutConfig`
[INFO] [stdout]  --> src/app/mrl-worker.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use aws_smithy_types::timeout::TimeoutConfig;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Status`
[INFO] [stdout]   --> src/app/mrl-worker.rs:11:51
[INFO] [stdout]    |
[INFO] [stdout] 11 | use tonic::{transport::Server, Request, Response, Status};
[INFO] [stdout]    |                                                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::coordinator::coordinator_service_client::CoordinatorServiceClient`
[INFO] [stdout]   --> src/app/mrl-worker.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crate::coordinator::coordinator_service_client::CoordinatorServiceClient;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::sleep`
[INFO] [stdout]  --> src/app/mrl-worker.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::thread::sleep;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Builder`
[INFO] [stdout]  --> src/app/mrl-worker.rs:5:26
[INFO] [stdout]   |
[INFO] [stdout] 5 | use aws_sdk_s3::config::{Builder, Credentials};
[INFO] [stdout]   |                          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `aws_smithy_types::timeout::TimeoutConfig`
[INFO] [stdout]  --> src/app/mrl-worker.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use aws_smithy_types::timeout::TimeoutConfig;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Status`
[INFO] [stdout]   --> src/app/mrl-worker.rs:11:51
[INFO] [stdout]    |
[INFO] [stdout] 11 | use tonic::{transport::Server, Request, Response, Status};
[INFO] [stdout]    |                                                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::coordinator::coordinator_service_client::CoordinatorServiceClient`
[INFO] [stdout]   --> src/app/mrl-worker.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crate::coordinator::coordinator_service_client::CoordinatorServiceClient;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_distributed_mr_job` is never used
[INFO] [stdout]   --> src/app/standalone.rs:41:10
[INFO] [stdout]    |
[INFO] [stdout] 41 | async fn run_distributed_mr_job(job: Job, engine: String) -> Result<()> {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mpsc`
[INFO] [stdout]   --> src/app/mrl-coordinator.rs:13:19
[INFO] [stdout]    |
[INFO] [stdout] 13 | use tokio::sync::{mpsc, Mutex};
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `JobStatusResponse`
[INFO] [stdout]   --> src/app/mrl-coordinator.rs:16:43
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::coordinator::{HistoryResponse, JobStatusResponse};
[INFO] [stdout]    |                                           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mpsc`
[INFO] [stdout]   --> src/app/mrl-coordinator.rs:13:19
[INFO] [stdout]    |
[INFO] [stdout] 13 | use tokio::sync::{mpsc, Mutex};
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `JobStatusResponse`
[INFO] [stdout]   --> src/app/mrl-coordinator.rs:16:43
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::coordinator::{HistoryResponse, JobStatusResponse};
[INFO] [stdout]    |                                           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/app/mrl-ctl.rs:224:17
[INFO] [stdout]     |
[INFO] [stdout] 224 |             let mut jobs = job_queue.lock().await;
[INFO] [stdout]     |                 ----^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/app/mrl-ctl.rs:224:17
[INFO] [stdout]     |
[INFO] [stdout] 224 |             let mut jobs = job_queue.lock().await;
[INFO] [stdout]     |                 ----^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_map`
[INFO] [stdout]   --> src/app/mrl-worker.rs:91:35
[INFO] [stdout]    |
[INFO] [stdout] 91 |     async fn send_feedback(&self, is_map: bool) {
[INFO] [stdout]    |                                   ^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_map`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `client`
[INFO] [stdout]   --> src/app/mrl-worker.rs:92:17
[INFO] [stdout]    |
[INFO] [stdout] 92 | ...   let mut client = coordinator::coordinator_service_client::CoordinatorServiceClient::connect(self.coordinator_address.clone()).await...
[INFO] [stdout]    |               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_client`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/app/mrl-worker.rs:92:13
[INFO] [stdout]    |
[INFO] [stdout] 92 | ...   let mut client = coordinator::coordinator_service_client::CoordinatorServiceClient::connect(self.coordinator_address.clone()).await...
[INFO] [stdout]    |           ----^^^^^^
[INFO] [stdout]    |           |
[INFO] [stdout]    |           help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_map`
[INFO] [stdout]   --> src/app/mrl-worker.rs:91:35
[INFO] [stdout]    |
[INFO] [stdout] 91 |     async fn send_feedback(&self, is_map: bool) {
[INFO] [stdout]    |                                   ^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_map`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `client`
[INFO] [stdout]   --> src/app/mrl-worker.rs:92:17
[INFO] [stdout]    |
[INFO] [stdout] 92 | ...   let mut client = coordinator::coordinator_service_client::CoordinatorServiceClient::connect(self.coordinator_address.clone()).await...
[INFO] [stdout]    |               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_client`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/app/mrl-worker.rs:92:13
[INFO] [stdout]    |
[INFO] [stdout] 92 | ...   let mut client = coordinator::coordinator_service_client::CoordinatorServiceClient::connect(self.coordinator_address.clone()).await...
[INFO] [stdout]    |           ----^^^^^^
[INFO] [stdout]    |           |
[INFO] [stdout]    |           help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `reduce_output`
[INFO] [stdout]    --> src/app/mrl-worker.rs:123:13
[INFO] [stdout]     |
[INFO] [stdout] 123 |         let reduce_output = perform_reduce(
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_reduce_output`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `reduce_output`
[INFO] [stdout]    --> src/app/mrl-worker.rs:123:13
[INFO] [stdout]     |
[INFO] [stdout] 123 |         let reduce_output = perform_reduce(
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_reduce_output`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `provider_name_clone`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:117:9
[INFO] [stdout]     |
[INFO] [stdout] 117 |     let provider_name_clone = details.provider_name.clone();
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_provider_name_clone`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `provider_name_clone`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:117:9
[INFO] [stdout]     |
[INFO] [stdout] 117 |     let provider_name_clone = details.provider_name.clone();
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_provider_name_clone`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `reduce_done` is never read
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:382:17
[INFO] [stdout]     |
[INFO] [stdout] 382 |         let mut reduce_done = false;
[INFO] [stdout]     |                 ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:394:127
[INFO] [stdout]     |
[INFO] [stdout] 394 | ...tails.is_complete).for_each(|(index, task_details)| {
[INFO] [stdout]     |                                  ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `reduce_done` is never read
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:382:17
[INFO] [stdout]     |
[INFO] [stdout] 382 |         let mut reduce_done = false;
[INFO] [stdout]     |                 ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:505:130
[INFO] [stdout]     |
[INFO] [stdout] 505 | ...tails.is_complete).for_each(|(index, task_details)| {
[INFO] [stdout]     |                                  ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:394:127
[INFO] [stdout]     |
[INFO] [stdout] 394 | ...tails.is_complete).for_each(|(index, task_details)| {
[INFO] [stdout]     |                                  ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:505:130
[INFO] [stdout]     |
[INFO] [stdout] 505 | ...tails.is_complete).for_each(|(index, task_details)| {
[INFO] [stdout]     |                                  ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::stream::StreamExt`
[INFO] [stdout]  --> src/app/mrl-coordinator.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use futures::stream::StreamExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::stream::StreamExt`
[INFO] [stdout]  --> src/app/mrl-coordinator.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use futures::stream::StreamExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `foo`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:100:9
[INFO] [stdout]     |
[INFO] [stdout] 100 |     let foo = re.captures(s3_path);
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_foo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `match_job_status` is never read
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:665:17
[INFO] [stdout]     |
[INFO] [stdout] 665 |         let mut match_job_status = JobStatus::STARTING;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `registration_result` is never read
[INFO] [stdout]    --> src/app/mrl-worker.rs:214:13
[INFO] [stdout]     |
[INFO] [stdout] 214 |     let mut registration_result: Option<coordinator::RegisterResponse> = None;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `registration_result` is never read
[INFO] [stdout]    --> src/app/mrl-worker.rs:214:13
[INFO] [stdout]     |
[INFO] [stdout] 214 |     let mut registration_result: Option<coordinator::RegisterResponse> = None;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `request`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:748:39
[INFO] [stdout]     |
[INFO] [stdout] 748 |     async fn get_previous_jobs(&self, request: tonic::Request<Empty>) -> std::result::Result<tonic::Response<coordinator::HistoryResponse...
[INFO] [stdout]     |                                       ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `request`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:763:36
[INFO] [stdout]     |
[INFO] [stdout] 763 |     async fn get_job_status(&self, request: Request<Empty>) -> Result<Response<coordinator::JobStatusResponse>, Status> {
[INFO] [stdout]     |                                    ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `foo`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:100:9
[INFO] [stdout]     |
[INFO] [stdout] 100 |     let foo = re.captures(s3_path);
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_foo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `send_feedback` is never used
[INFO] [stdout]   --> src/app/mrl-worker.rs:91:14
[INFO] [stdout]    |
[INFO] [stdout] 86 | impl WorkerServiceImpl {
[INFO] [stdout]    | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 91 |     async fn send_feedback(&self, is_map: bool) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `send_feedback` is never used
[INFO] [stdout]   --> src/app/mrl-worker.rs:91:14
[INFO] [stdout]    |
[INFO] [stdout] 86 | impl WorkerServiceImpl {
[INFO] [stdout]    | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 91 |     async fn send_feedback(&self, is_map: bool) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `JobStatus` is more private than the item `JobWithStatus::status`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:200:5
[INFO] [stdout]     |
[INFO] [stdout] 200 |     pub status: JobStatus,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^ field `JobWithStatus::status` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `JobStatus` is only usable at visibility `pub(crate)`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | enum JobStatus { STARTING, MAP, SHUFFLE, REDUCE, #[default] DONE }
[INFO] [stdout]     | ^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `is_reassigned` is never read
[INFO] [stdout]   --> src/app/mrl-coordinator.rs:94:9
[INFO] [stdout]    |
[INFO] [stdout] 89 | struct TaskDetails {
[INFO] [stdout]    |        ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 94 |     pub is_reassigned: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TaskDetails` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_s3_path` is never used
[INFO] [stdout]   --> src/app/mrl-coordinator.rs:97:4
[INFO] [stdout]    |
[INFO] [stdout] 97 | fn parse_s3_path(s3_path: &str) -> Option<S3Path> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `call_connect_s3` is never used
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:111:10
[INFO] [stdout]     |
[INFO] [stdout] 111 | async fn call_connect_s3() {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `SHUFFLE` is never constructed
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:165:33
[INFO] [stdout]     |
[INFO] [stdout] 165 | enum JobStatus { STARTING, MAP, SHUFFLE, REDUCE, #[default] DONE }
[INFO] [stdout]     |      ---------                  ^^^^^^^
[INFO] [stdout]     |      |
[INFO] [stdout]     |      variant in this enum
[INFO] [stdout]     |
[INFO] [stdout]     = note: `JobStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `map_tasks` and `reduce_tasks` are never read
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:207:5
[INFO] [stdout]     |
[INFO] [stdout] 204 | pub struct CoordinatorServiceImpl {
[INFO] [stdout]     |            ---------------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 207 |     map_tasks: Arc<Mutex<VecDeque<Task>>>, // Task queue produced when job is received
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout] 208 |     reduce_tasks: Arc<Mutex<VecDeque<Task>>>, // Task queue produced when job is received
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `match_directory` is never used
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:233:4
[INFO] [stdout]     |
[INFO] [stdout] 233 | fn match_directory(input_dir: &str, file_path: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `list_files_in_directory` is never used
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:239:10
[INFO] [stdout]     |
[INFO] [stdout] 239 | async fn list_files_in_directory(bucket: &str, directory: &str, client: &aws_sdk_s3::Client) -> Result<Vec<String>, Box<dyn Error>> {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `match_job_status` is never read
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:665:17
[INFO] [stdout]     |
[INFO] [stdout] 665 |         let mut match_job_status = JobStatus::STARTING;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `request`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:748:39
[INFO] [stdout]     |
[INFO] [stdout] 748 |     async fn get_previous_jobs(&self, request: tonic::Request<Empty>) -> std::result::Result<tonic::Response<coordinator::HistoryResponse...
[INFO] [stdout]     |                                       ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `request`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:763:36
[INFO] [stdout]     |
[INFO] [stdout] 763 |     async fn get_job_status(&self, request: Request<Empty>) -> Result<Response<coordinator::JobStatusResponse>, Status> {
[INFO] [stdout]     |                                    ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `JobStatus` is more private than the item `JobWithStatus::status`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:200:5
[INFO] [stdout]     |
[INFO] [stdout] 200 |     pub status: JobStatus,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^ field `JobWithStatus::status` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `JobStatus` is only usable at visibility `pub(crate)`
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | enum JobStatus { STARTING, MAP, SHUFFLE, REDUCE, #[default] DONE }
[INFO] [stdout]     | ^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `is_reassigned` is never read
[INFO] [stdout]   --> src/app/mrl-coordinator.rs:94:9
[INFO] [stdout]    |
[INFO] [stdout] 89 | struct TaskDetails {
[INFO] [stdout]    |        ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 94 |     pub is_reassigned: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TaskDetails` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_s3_path` is never used
[INFO] [stdout]   --> src/app/mrl-coordinator.rs:97:4
[INFO] [stdout]    |
[INFO] [stdout] 97 | fn parse_s3_path(s3_path: &str) -> Option<S3Path> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `call_connect_s3` is never used
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:111:10
[INFO] [stdout]     |
[INFO] [stdout] 111 | async fn call_connect_s3() {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `SHUFFLE` is never constructed
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:165:33
[INFO] [stdout]     |
[INFO] [stdout] 165 | enum JobStatus { STARTING, MAP, SHUFFLE, REDUCE, #[default] DONE }
[INFO] [stdout]     |      ---------                  ^^^^^^^
[INFO] [stdout]     |      |
[INFO] [stdout]     |      variant in this enum
[INFO] [stdout]     |
[INFO] [stdout]     = note: `JobStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `map_tasks` and `reduce_tasks` are never read
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:207:5
[INFO] [stdout]     |
[INFO] [stdout] 204 | pub struct CoordinatorServiceImpl {
[INFO] [stdout]     |            ---------------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 207 |     map_tasks: Arc<Mutex<VecDeque<Task>>>, // Task queue produced when job is received
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout] 208 |     reduce_tasks: Arc<Mutex<VecDeque<Task>>>, // Task queue produced when job is received
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `match_directory` is never used
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:233:4
[INFO] [stdout]     |
[INFO] [stdout] 233 | fn match_directory(input_dir: &str, file_path: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `list_files_in_directory` is never used
[INFO] [stdout]    --> src/app/mrl-coordinator.rs:239:10
[INFO] [stdout]     |
[INFO] [stdout] 239 | async fn list_files_in_directory(bucket: &str, directory: &str, client: &aws_sdk_s3::Client) -> Result<Vec<String>, Box<dyn Error>> {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 44s
[INFO] running `Command { std: "docker" "inspect" "008950e5385e6b0f96b60ba59b3bb2bb43259acfaedb39940f525fd7b5d87846", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "008950e5385e6b0f96b60ba59b3bb2bb43259acfaedb39940f525fd7b5d87846", kill_on_drop: false }`
[INFO] [stdout] 008950e5385e6b0f96b60ba59b3bb2bb43259acfaedb39940f525fd7b5d87846
