[INFO] cloning repository https://github.com/MadBull1995/protot
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/MadBull1995/protot" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMadBull1995%2Fprotot", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMadBull1995%2Fprotot'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 8da66c2c4bf8ee2ffac85581651f6935a484cfbe
[INFO] testing MadBull1995/protot against master#d98a5da813da67eb189387b8ccfb73cf481275d8+rustflags=-Copt-level=3 for pr-138759
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMadBull1995%2Fprotot" "/workspace/builds/worker-5-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/MadBull1995/protot
[INFO] finished tweaking git repo https://github.com/MadBull1995/protot
[INFO] tweaked toml for git repo https://github.com/MadBull1995/protot written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/MadBull1995/protot on toolchain d98a5da813da67eb189387b8ccfb73cf481275d8
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/MadBull1995/protot 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" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 17 packages to latest compatible versions
[INFO] [stderr]       Adding base-x v0.2.11
[INFO] [stderr]       Adding const_fn v0.4.11
[INFO] [stderr]       Adding discard v1.0.4
[INFO] [stderr]       Adding proc-macro-hack v0.5.20+deprecated
[INFO] [stderr]       Adding rustc_version v0.2.3
[INFO] [stderr]       Adding semver v0.9.0
[INFO] [stderr]       Adding semver-parser v0.7.0
[INFO] [stderr]       Adding sha1 v0.6.1
[INFO] [stderr]       Adding standback v0.2.17
[INFO] [stderr]       Adding stdweb v0.4.20
[INFO] [stderr]       Adding stdweb-derive v0.5.3
[INFO] [stderr]       Adding stdweb-internal-macros v0.2.9
[INFO] [stderr]       Adding stdweb-internal-runtime v0.1.5
[INFO] [stderr]       Adding time v0.2.27 (available: v0.3.44)
[INFO] [stderr]       Adding time-macros v0.1.1
[INFO] [stderr]       Adding time-macros-impl v0.1.2
[INFO] [stderr]       Adding version_check v0.9.5
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded matchit v0.7.2
[INFO] [stderr]   Downloaded socket2 v0.5.3
[INFO] [stderr]   Downloaded tonic-types v0.9.2
[INFO] [stderr]   Downloaded anstyle-wincon v2.1.0
[INFO] [stderr]   Downloaded anstream v0.5.0
[INFO] [stderr]   Downloaded unsafe-libyaml v0.2.9
[INFO] [stderr]   Downloaded thread-id v4.2.0
[INFO] [stderr]   Downloaded clap v4.4.2
[INFO] [stderr]   Downloaded clap_builder v4.4.2
[INFO] [stderr]   Downloaded chrono v0.4.28
[INFO] [stderr]   Downloaded thiserror-impl v1.0.47
[INFO] [stderr]   Downloaded anstyle v1.0.2
[INFO] [stderr]   Downloaded aho-corasick v1.0.5
[INFO] [stderr]   Downloaded base64 v0.21.3
[INFO] [stderr]   Downloaded const_fn v0.4.11
[INFO] [stderr]   Downloaded errno v0.3.3
[INFO] [stderr]   Downloaded rustix v0.38.10
[INFO] [stderr]   Downloaded redis v0.23.3
[INFO] [stderr]   Downloaded serde_yaml v0.9.25
[INFO] [stderr]   Downloaded memchr v2.6.1
[INFO] [stderr]   Downloaded object v0.32.0
[INFO] [stderr]   Downloaded prometheus v0.13.3
[INFO] [stderr]   Downloaded protobuf-support v3.2.0
[INFO] [stderr]   Downloaded thiserror v1.0.47
[INFO] [stderr]   Downloaded protobuf v3.2.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 8646989831e969417994c038c52a81213f45bc58e28da29a7d5cb32889e25c69
[INFO] running `Command { std: "docker" "start" "-a" "8646989831e969417994c038c52a81213f45bc58e28da29a7d5cb32889e25c69", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "8646989831e969417994c038c52a81213f45bc58e28da29a7d5cb32889e25c69", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8646989831e969417994c038c52a81213f45bc58e28da29a7d5cb32889e25c69", kill_on_drop: false }`
[INFO] [stdout] 8646989831e969417994c038c52a81213f45bc58e28da29a7d5cb32889e25c69
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] da07b98ade5fff5294a2367e61d6f2f9158e2a13b43cee984f64b07442cfcbe4
[INFO] running `Command { std: "docker" "start" "-a" "da07b98ade5fff5294a2367e61d6f2f9158e2a13b43cee984f64b07442cfcbe4", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.66
[INFO] [stderr]    Compiling unicode-ident v1.0.11
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling memchr v2.6.1
[INFO] [stderr]    Compiling anyhow v1.0.75
[INFO] [stderr]    Compiling once_cell v1.18.0
[INFO] [stderr]    Compiling socket2 v0.5.3
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling linux-raw-sys v0.4.5
[INFO] [stderr]    Compiling bitflags v2.4.0
[INFO] [stderr]    Compiling http v0.2.9
[INFO] [stderr]    Compiling getrandom v0.2.10
[INFO] [stderr]    Compiling async-trait v0.1.73
[INFO] [stderr]    Compiling hashbrown v0.14.0
[INFO] [stderr]    Compiling rustix v0.38.10
[INFO] [stderr]    Compiling num-traits v0.2.16
[INFO] [stderr]    Compiling bytes v1.4.0
[INFO] [stderr]    Compiling tracing-core v0.1.31
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling prettyplease v0.1.25
[INFO] [stderr]    Compiling try-lock v0.2.4
[INFO] [stderr]    Compiling regex-syntax v0.7.5
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling want v0.3.1
[INFO] [stderr]    Compiling standback v0.2.17
[INFO] [stderr]    Compiling thiserror v1.0.47
[INFO] [stderr]    Compiling fastrand v2.0.0
[INFO] [stderr]    Compiling fixedbitset v0.4.2
[INFO] [stderr]    Compiling axum v0.6.20
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling which v4.4.0
[INFO] [stderr]    Compiling indexmap v2.0.0
[INFO] [stderr]    Compiling anstyle-parse v0.2.1
[INFO] [stderr]    Compiling quote v1.0.33
[INFO] [stderr]    Compiling http-body v0.4.5
[INFO] [stderr]    Compiling syn v2.0.29
[INFO] [stderr]    Compiling aho-corasick v1.0.5
[INFO] [stderr]    Compiling regex-automata v0.3.7
[INFO] [stderr]    Compiling matchit v0.7.2
[INFO] [stderr]    Compiling anstyle v1.0.2
[INFO] [stderr]    Compiling petgraph v0.6.4
[INFO] [stderr]    Compiling destructure_traitobject v0.2.0
[INFO] [stderr]    Compiling const_fn v0.4.11
[INFO] [stderr]    Compiling serde_json v1.0.105
[INFO] [stderr]    Compiling anstream v0.5.0
[INFO] [stderr]    Compiling unsafe-any-ors v1.0.0
[INFO] [stderr]    Compiling ordered-float v2.10.0
[INFO] [stderr]    Compiling time v0.2.27
[INFO] [stderr]    Compiling time v0.1.45
[INFO] [stderr]    Compiling clap_lex v0.5.1
[INFO] [stderr]    Compiling iana-time-zone v0.1.57
[INFO] [stderr]    Compiling protobuf v3.2.0
[INFO] [stderr]    Compiling base64 v0.21.3
[INFO] [stderr]    Compiling chrono v0.4.28
[INFO] [stderr]    Compiling clap_builder v4.4.2
[INFO] [stderr]    Compiling tempfile v3.8.0
[INFO] [stderr]    Compiling is-terminal v0.4.9
[INFO] [stderr]    Compiling typemap-ors v1.0.0
[INFO] [stderr]    Compiling thread-id v4.2.0
[INFO] [stderr]    Compiling termcolor v1.2.0
[INFO] [stderr]    Compiling log-mdc v0.1.0
[INFO] [stderr]    Compiling sha1_smol v1.0.0
[INFO] [stderr]    Compiling unsafe-libyaml v0.2.9
[INFO] [stderr]    Compiling regex v1.9.4
[INFO] [stderr]    Compiling arc-swap v1.6.0
[INFO] [stderr]    Compiling uuid v1.4.1
[INFO] [stderr]    Compiling tokio-macros v2.1.0
[INFO] [stderr]    Compiling futures-macro v0.3.28
[INFO] [stderr]    Compiling serde_derive v1.0.188
[INFO] [stderr]    Compiling tracing-attributes v0.1.26
[INFO] [stderr]    Compiling pin-project-internal v1.1.3
[INFO] [stderr]    Compiling thiserror-impl v1.0.47
[INFO] [stderr]    Compiling clap_derive v4.4.2
[INFO] [stderr]    Compiling async-stream-impl v0.3.5
[INFO] [stderr]    Compiling prost-derive v0.11.9
[INFO] [stderr]    Compiling time-macros-impl v0.1.2
[INFO] [stderr]    Compiling derivative v2.2.0
[INFO] [stderr]    Compiling time-macros v0.1.1
[INFO] [stderr]    Compiling tokio v1.32.0
[INFO] [stderr]    Compiling futures-util v0.3.28
[INFO] [stderr]    Compiling async-stream v0.3.5
[INFO] [stderr]    Compiling protobuf-support v3.2.0
[INFO] [stderr]    Compiling futures-executor v0.3.28
[INFO] [stderr]    Compiling futures v0.3.28
[INFO] [stderr]    Compiling pin-project v1.1.3
[INFO] [stderr]    Compiling axum-core v0.3.4
[INFO] [stderr]    Compiling prost v0.11.9
[INFO] [stderr]    Compiling prost-types v0.11.9
[INFO] [stderr]    Compiling tokio-io-timeout v1.2.0
[INFO] [stderr]    Compiling tokio-stream v0.1.14
[INFO] [stderr]    Compiling clap v4.4.2
[INFO] [stderr]    Compiling tracing v0.1.37
[INFO] [stderr]    Compiling prost-build v0.11.9
[INFO] [stderr]    Compiling tokio-util v0.7.8
[INFO] [stderr]    Compiling h2 v0.3.21
[INFO] [stderr]    Compiling serde v1.0.188
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling combine v4.6.6
[INFO] [stderr]    Compiling tonic-build v0.9.2
[INFO] [stderr]    Compiling hyper v0.14.27
[INFO] [stderr]    Compiling log v0.4.20
[INFO] [stderr]    Compiling serde-value v0.7.0
[INFO] [stderr]    Compiling serde_yaml v0.8.26
[INFO] [stderr]    Compiling serde_yaml v0.9.25
[INFO] [stderr]    Compiling env_logger v0.10.0
[INFO] [stderr]    Compiling protot v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling log4rs v1.2.0
[INFO] [stderr]    Compiling redis v0.23.3
[INFO] [stderr]    Compiling hyper-timeout v0.4.1
[INFO] [stderr]    Compiling tonic v0.9.2
[INFO] [stderr]    Compiling tonic-types v0.9.2
[INFO] [stdout] warning: unused import: `error::Error`
[INFO] [stdout]   --> src/core/worker_pool.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 |     thread, error::Error
[INFO] [stdout]    |             ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Response` and `Status`
[INFO] [stdout]   --> src/core/worker_pool.rs:28:13
[INFO] [stdout]    |
[INFO] [stdout] 28 | use tonic::{Status, Response};
[INFO] [stdout]    |             ^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AssignTaskRequest`
[INFO] [stdout]   --> src/core/grpc_executor.rs:15:85
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::{internal::protot::{scheduler::v1::{SchedulerMessage, scheduler_message, AssignTaskRequest, ExecuteResponse}, core::TaskState}...
[INFO] [stdout]    |                                                                                     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `worker_pool::AsyncTaskExecutor`
[INFO] [stdout]   --> src/core/grpc_executor.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 | use super::{worker_pool::AsyncTaskExecutor, load_balancer::LoadBalancer};
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error::Error`
[INFO] [stdout]   --> src/core/grpc_executor.rs:18:33
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::{collections::HashMap, error::Error, sync::Arc, time::Instant};
[INFO] [stdout]    |                                 ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mpsc`
[INFO] [stdout]   --> src/core/grpc_executor.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     mpsc,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::debug`
[INFO] [stdout]  --> src/data/redis_store.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use log::debug;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ConnectionLike`, `RedisError`, and `RedisResult`
[INFO] [stdout]  --> src/data/redis_store.rs:6:21
[INFO] [stdout]   |
[INFO] [stdout] 6 | use redis::{Client, RedisError, aio::Connection, RedisResult, AsyncCommands, ConnectionLike};
[INFO] [stdout]   |                     ^^^^^^^^^^                   ^^^^^^^^^^^                 ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Task` and `utils::current_timestamp`
[INFO] [stdout]  --> src/data/redis_store.rs:8:70
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::{internal::protot::{scheduler::v1::ExecuteRequest, core::{Task, TaskState}}, SchedulerError, utils::current_timestamp};
[INFO] [stdout]   |                                                                      ^^^^                               ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DataStoreError`
[INFO] [stdout]   --> src/data/redis_store.rs:10:36
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::data_store::{DataStore, DataStoreError};
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::fmt`
[INFO] [stdout]   --> src/utils/mod.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use core::fmt;
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::internal::protot::core::Config`
[INFO] [stdout]   --> src/utils/mod.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use crate::internal::protot::core::Config;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `prost_types::Duration`
[INFO] [stdout]   --> src/utils/configs.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use prost_types::Duration;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::future::Future`
[INFO] [stdout]   --> src/server/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use std::future::Future;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio_util::sync::CancellationToken`
[INFO] [stdout]   --> src/server/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use tokio_util::sync::CancellationToken;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `core::NodeType` and `self`
[INFO] [stdout]   --> src/server/mod.rs:29:91
[INFO] [stdout]    |
[INFO] [stdout] 29 | use crate::{internal::protot::{scheduler::v1::{Ack, WorkerChannelStatus, worker_message::{self, WorkerMessageType}}, core::NodeType}, cor...
[INFO] [stdout]    |                                                                                           ^^^^                       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TryFutureExt`
[INFO] [stdout]   --> src/server/mod.rs:47:34
[INFO] [stdout]    |
[INFO] [stdout] 47 | use futures::{Stream, StreamExt, TryFutureExt};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `select` and `timeout`
[INFO] [stdout]   --> src/server/mod.rs:51:52
[INFO] [stdout]    |
[INFO] [stdout] 51 |     sync::{mpsc::{self, Receiver, Sender}, Mutex}, select, time::{timeout, sleep},
[INFO] [stdout]    |                                                    ^^^^^^         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DataStore`
[INFO] [stdout]   --> src/lib.rs:86:111
[INFO] [stdout]    |
[INFO] [stdout] 86 | use crate::{core::worker_pool::{TaskExecutor, TaskRegistry}, server::start_single_process_grpc_server, data::{DataStore, RedisDataStore},...
[INFO] [stdout]    |                                                                                                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]   --> src/lib.rs:88:11
[INFO] [stdout]    |
[INFO] [stdout] 88 | use log::{info, debug, error};
[INFO] [stdout]    |           ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/client/mod.rs:225:25
[INFO] [stdout]     |
[INFO] [stdout] 225 |                         _ => println!("unable to communicate with unknown scheduler message")
[INFO] [stdout]     |                         ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/client/mod.rs:225:25
[INFO] [stdout]     |
[INFO] [stdout] 199 |                         scheduler_message::SchedulerMessageType::AssignTask(t) => {
[INFO] [stdout]     |                         ------------------------------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 205 |                         scheduler_message::SchedulerMessageType::Disconnect(disconnect) => {
[INFO] [stdout]     |                         --------------------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 208 |                         scheduler_message::SchedulerMessageType::Ack(ack) => {
[INFO] [stdout]     |                         ------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 211 |                         scheduler_message::SchedulerMessageType::Heartbeat(_) => {
[INFO] [stdout]     |                         ----------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 225 |                         _ => println!("unable to communicate with unknown scheduler message")
[INFO] [stdout]     |                         ^ collectively making this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/data/redis_store.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     async fn add_task_execution(&self, execute: ExecuteRequest) -> Result<(), SchedulerError> {
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: FromRedisValue` will fail
[INFO] [stdout]   --> src/data/redis_store.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 |         db.hset(&key, "execution", &val.to_string())
[INFO] [stdout]    |            ^^^^
[INFO] [stdout]    = note: `#[warn(dependency_on_unit_never_type_fallback)]` on by default
[INFO] [stdout] help: use `()` annotations to avoid fallback changes
[INFO] [stdout]    |
[INFO] [stdout] 55 |         db.hset::<_, _, _, ()>(&key, "execution", &val.to_string())
[INFO] [stdout]    |                +++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state`
[INFO] [stdout]   --> src/data/redis_store.rs:62:51
[INFO] [stdout]    |
[INFO] [stdout] 62 |     async fn get_task_executions_by_worker(&self, state: TaskState) -> Result<Vec<ExecuteRequest>, SchedulerError> {
[INFO] [stdout]    |                                                   ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state`
[INFO] [stdout]   --> src/data/redis_store.rs:66:51
[INFO] [stdout]    |
[INFO] [stdout] 66 |     async fn get_tasks_executions_by_state(&self, state: TaskState) -> Result<Vec<ExecuteRequest>, SchedulerError> {
[INFO] [stdout]    |                                                   ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `task_id`
[INFO] [stdout]   --> src/data/redis_store.rs:70:49
[INFO] [stdout]    |
[INFO] [stdout] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stdout]    |                                                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_task_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `execution_id`
[INFO] [stdout]   --> src/data/redis_store.rs:70:64
[INFO] [stdout]    |
[INFO] [stdout] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stdout]    |                                                                ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_execution_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `new_state`
[INFO] [stdout]   --> src/data/redis_store.rs:70:84
[INFO] [stdout]    |
[INFO] [stdout] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stdout]    |                                                                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_new_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `shared_data`
[INFO] [stdout]    --> src/server/mod.rs:439:13
[INFO] [stdout]     |
[INFO] [stdout] 439 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout]     |             ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_shared_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `request`
[INFO] [stdout]    --> src/server/mod.rs:487:9
[INFO] [stdout]     |
[INFO] [stdout] 487 |         request: Request<ScheduleRequest>,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `res`
[INFO] [stdout]    --> src/server/mod.rs:545:16
[INFO] [stdout]     |
[INFO] [stdout] 545 |             Ok(res) => Ok(Response::new(ExecuteResponse {
[INFO] [stdout]     |                ^^^ help: if this is intentional, prefix it with an underscore: `_res`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `request`
[INFO] [stdout]    --> src/server/mod.rs:574:9
[INFO] [stdout]     |
[INFO] [stdout] 574 |         request: Request<ScheduleRequest>,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `shared_data`
[INFO] [stdout]    --> src/server/mod.rs:576:13
[INFO] [stdout]     |
[INFO] [stdout] 576 |         let shared_data = self.shared_data.clone();
[INFO] [stdout]     |             ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_shared_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/lib.rs:277:13
[INFO] [stdout]     |
[INFO] [stdout] 277 |         let data = Any::unpack::<struct_::Struct>(&data);
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/lib.rs:294:13
[INFO] [stdout]     |
[INFO] [stdout] 294 |         let data = Any::unpack::<struct_::Struct>(&data);
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `execute_channel` is never read
[INFO] [stdout]    --> src/core/worker_pool.rs:289:5
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub struct GrpcWorkerPool {
[INFO] [stdout]     |            -------------- field in this struct
[INFO] [stdout] 289 |     execute_channel: Option<Sender<ExecuteRequest>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `DropClient` is never used
[INFO] [stdout]   --> src/core/grpc_executor.rs:35:7
[INFO] [stdout]    |
[INFO] [stdout] 35 | trait DropClient {
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DataStoreError` is never used
[INFO] [stdout]  --> src/data/data_store.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub enum DataStoreError {
[INFO] [stdout]   |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RedisClient` is never constructed
[INFO] [stdout]   --> src/data/redis_store.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct RedisClient {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `WorkerChannels` is never used
[INFO] [stdout]   --> src/server/mod.rs:58:6
[INFO] [stdout]    |
[INFO] [stdout] 58 | type WorkerChannels = Arc<Mutex<HashMap<String, (Sender<Result<SchedulerMessage, Status>>, Sender<()>)>>>;
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_layer` is never read
[INFO] [stdout]   --> src/server/mod.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct SchedulerServer<B: LoadBalancer> {
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] 64 |     shared_state: Arc<GrpcSharedState<B>>,
[INFO] [stdout] 65 |     data_layer: Arc<Mutex<dyn DataStore>>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cancel_client` is never used
[INFO] [stdout]    --> src/server/mod.rs:197:10
[INFO] [stdout]     |
[INFO] [stdout] 197 | async fn cancel_client(tx: Sender<Result<SchedulerMessage, Status>>, rx_cancel:&mut Receiver<()>) {
[INFO] [stdout]     |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `worker_heartbeat` is never read
[INFO] [stdout]    --> src/server/mod.rs:207:9
[INFO] [stdout]     |
[INFO] [stdout] 205 | pub struct SharedData {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] 206 |     pub(crate) worker_pool: Arc<Mutex<WorkerPool>>,
[INFO] [stdout] 207 |     pub worker_heartbeat: Arc<Mutex<HashMap<String, Instant>>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/server/mod.rs:439:52
[INFO] [stdout]     |
[INFO] [stdout] 439 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout]     |                                                    ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `SharedData` does not implement `Clone`, so calling `clone` on `&SharedData` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout] 439 -         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout] 439 +         let shared_data = self.shared_data.as_ref();
[INFO] [stdout]     |
[INFO] [stdout] help: if you meant to clone `SharedData`, implement `Clone` for it
[INFO] [stdout]     |
[INFO] [stdout] 205 + #[derive(Clone)]
[INFO] [stdout] 206 | pub struct SharedData {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/server/mod.rs:445:9
[INFO] [stdout]     |
[INFO] [stdout] 445 |         db.add_task_execution(cloned_task).await;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 445 |         let _ = db.add_task_execution(cloned_task).await;
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/server/mod.rs:525:52
[INFO] [stdout]     |
[INFO] [stdout] 525 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout]     |                                                    ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `SharedData` does not implement `Clone`, so calling `clone` on `&SharedData` copies the reference, which does not do anything and can be removed
[INFO] [stdout] help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout] 525 -         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout] 525 +         let shared_data = self.shared_data.as_ref();
[INFO] [stdout]     |
[INFO] [stdout] help: if you meant to clone `SharedData`, implement `Clone` for it
[INFO] [stdout]     |
[INFO] [stdout] 205 + #[derive(Clone)]
[INFO] [stdout] 206 | pub struct SharedData {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DataStoreType`
[INFO] [stdout]   --> src/main.rs:18:57
[INFO] [stdout]    |
[INFO] [stdout] 18 | use protot::internal::protot::core::{Config, DataStore, DataStoreType, NodeType};
[INFO] [stdout]    |                                                         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TaskExecutorImpl1` and `TaskExecutorImpl2`
[INFO] [stdout]   --> src/main.rs:21:61
[INFO] [stdout]    |
[INFO] [stdout] 21 |     core::worker_pool::TaskRegistry, start, SchedulerError, TaskExecutorImpl1, TaskExecutorImpl2,
[INFO] [stdout]    |                                                             ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:110:9
[INFO] [stdout]     |
[INFO] [stdout] 110 |     let mut executors = TaskRegistry::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] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 7m 05s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: protot v0.1.0 (/opt/rustwide/workdir), redis v0.23.3
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] running `Command { std: "docker" "inspect" "da07b98ade5fff5294a2367e61d6f2f9158e2a13b43cee984f64b07442cfcbe4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "da07b98ade5fff5294a2367e61d6f2f9158e2a13b43cee984f64b07442cfcbe4", kill_on_drop: false }`
[INFO] [stdout] da07b98ade5fff5294a2367e61d6f2f9158e2a13b43cee984f64b07442cfcbe4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b1d416afff383bc382c733a85f5d66babb18dfb8343c8e75725f1d2fedee4741
[INFO] running `Command { std: "docker" "start" "-a" "b1d416afff383bc382c733a85f5d66babb18dfb8343c8e75725f1d2fedee4741", kill_on_drop: false }`
[INFO] [stdout] warning: unused import: `error::Error`
[INFO] [stdout]   --> src/core/worker_pool.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 |     thread, error::Error
[INFO] [stdout]    |             ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Response` and `Status`
[INFO] [stdout]   --> src/core/worker_pool.rs:28:13
[INFO] [stdout]    |
[INFO] [stdout] 28 | use tonic::{Status, Response};
[INFO] [stdout]    |             ^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AssignTaskRequest`
[INFO] [stdout]   --> src/core/grpc_executor.rs:15:85
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::{internal::protot::{scheduler::v1::{SchedulerMessage, scheduler_message, AssignTaskRequest, ExecuteResponse}, core::TaskState}...
[INFO] [stdout]    |                                                                                     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `worker_pool::AsyncTaskExecutor`
[INFO] [stdout]   --> src/core/grpc_executor.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 | use super::{worker_pool::AsyncTaskExecutor, load_balancer::LoadBalancer};
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error::Error`
[INFO] [stdout]   --> src/core/grpc_executor.rs:18:33
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::{collections::HashMap, error::Error, sync::Arc, time::Instant};
[INFO] [stdout]    |                                 ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mpsc`
[INFO] [stdout]   --> src/core/grpc_executor.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     mpsc,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::debug`
[INFO] [stdout]  --> src/data/redis_store.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use log::debug;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ConnectionLike`, `RedisError`, and `RedisResult`
[INFO] [stdout]  --> src/data/redis_store.rs:6:21
[INFO] [stdout]   |
[INFO] [stdout] 6 | use redis::{Client, RedisError, aio::Connection, RedisResult, AsyncCommands, ConnectionLike};
[INFO] [stdout]   |                     ^^^^^^^^^^                   ^^^^^^^^^^^                 ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Task` and `utils::current_timestamp`
[INFO] [stdout]  --> src/data/redis_store.rs:8:70
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::{internal::protot::{scheduler::v1::ExecuteRequest, core::{Task, TaskState}}, SchedulerError, utils::current_timestamp};
[INFO] [stdout]   |                                                                      ^^^^                               ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DataStoreError`
[INFO] [stdout]   --> src/data/redis_store.rs:10:36
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::data_store::{DataStore, DataStoreError};
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::fmt`
[INFO] [stdout]   --> src/utils/mod.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use core::fmt;
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::internal::protot::core::Config`
[INFO] [stdout]   --> src/utils/mod.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use crate::internal::protot::core::Config;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `prost_types::Duration`
[INFO] [stdout]   --> src/utils/configs.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use prost_types::Duration;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::future::Future`
[INFO] [stdout]   --> src/server/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use std::future::Future;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio_util::sync::CancellationToken`
[INFO] [stdout]   --> src/server/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use tokio_util::sync::CancellationToken;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `core::NodeType` and `self`
[INFO] [stdout]   --> src/server/mod.rs:29:91
[INFO] [stdout]    |
[INFO] [stdout] 29 | use crate::{internal::protot::{scheduler::v1::{Ack, WorkerChannelStatus, worker_message::{self, WorkerMessageType}}, core::NodeType}, cor...
[INFO] [stdout]    |                                                                                           ^^^^                       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TryFutureExt`
[INFO] [stdout]   --> src/server/mod.rs:47:34
[INFO] [stdout]    |
[INFO] [stdout] 47 | use futures::{Stream, StreamExt, TryFutureExt};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `select` and `timeout`
[INFO] [stdout]   --> src/server/mod.rs:51:52
[INFO] [stdout]    |
[INFO] [stdout] 51 |     sync::{mpsc::{self, Receiver, Sender}, Mutex}, select, time::{timeout, sleep},
[INFO] [stdout]    |                                                    ^^^^^^         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DataStore`
[INFO] [stdout]   --> src/lib.rs:86:111
[INFO] [stdout]    |
[INFO] [stdout] 86 | use crate::{core::worker_pool::{TaskExecutor, TaskRegistry}, server::start_single_process_grpc_server, data::{DataStore, RedisDataStore},...
[INFO] [stdout]    |                                                                                                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]   --> src/lib.rs:88:11
[INFO] [stdout]    |
[INFO] [stdout] 88 | use log::{info, debug, error};
[INFO] [stdout]    |           ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/client/mod.rs:225:25
[INFO] [stdout]     |
[INFO] [stdout] 225 |                         _ => println!("unable to communicate with unknown scheduler message")
[INFO] [stdout]     |                         ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/client/mod.rs:225:25
[INFO] [stdout]     |
[INFO] [stdout] 199 |                         scheduler_message::SchedulerMessageType::AssignTask(t) => {
[INFO] [stdout]     |                         ------------------------------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 205 |                         scheduler_message::SchedulerMessageType::Disconnect(disconnect) => {
[INFO] [stdout]     |                         --------------------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 208 |                         scheduler_message::SchedulerMessageType::Ack(ack) => {
[INFO] [stdout]     |                         ------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 211 |                         scheduler_message::SchedulerMessageType::Heartbeat(_) => {
[INFO] [stdout]     |                         ----------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 225 |                         _ => println!("unable to communicate with unknown scheduler message")
[INFO] [stdout]     |                         ^ collectively making this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling protot v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/data/redis_store.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     async fn add_task_execution(&self, execute: ExecuteRequest) -> Result<(), SchedulerError> {
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: FromRedisValue` will fail
[INFO] [stdout]   --> src/data/redis_store.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 |         db.hset(&key, "execution", &val.to_string())
[INFO] [stdout]    |            ^^^^
[INFO] [stdout]    = note: `#[warn(dependency_on_unit_never_type_fallback)]` on by default
[INFO] [stdout] help: use `()` annotations to avoid fallback changes
[INFO] [stdout]    |
[INFO] [stdout] 55 |         db.hset::<_, _, _, ()>(&key, "execution", &val.to_string())
[INFO] [stdout]    |                +++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state`
[INFO] [stdout]   --> src/data/redis_store.rs:62:51
[INFO] [stdout]    |
[INFO] [stdout] 62 |     async fn get_task_executions_by_worker(&self, state: TaskState) -> Result<Vec<ExecuteRequest>, SchedulerError> {
[INFO] [stdout]    |                                                   ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state`
[INFO] [stdout]   --> src/data/redis_store.rs:66:51
[INFO] [stdout]    |
[INFO] [stdout] 66 |     async fn get_tasks_executions_by_state(&self, state: TaskState) -> Result<Vec<ExecuteRequest>, SchedulerError> {
[INFO] [stdout]    |                                                   ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `task_id`
[INFO] [stdout]   --> src/data/redis_store.rs:70:49
[INFO] [stdout]    |
[INFO] [stdout] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stdout]    |                                                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_task_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `execution_id`
[INFO] [stdout]   --> src/data/redis_store.rs:70:64
[INFO] [stdout]    |
[INFO] [stdout] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stdout]    |                                                                ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_execution_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `new_state`
[INFO] [stdout]   --> src/data/redis_store.rs:70:84
[INFO] [stdout]    |
[INFO] [stdout] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stdout]    |                                                                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_new_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `shared_data`
[INFO] [stdout]    --> src/server/mod.rs:439:13
[INFO] [stdout]     |
[INFO] [stdout] 439 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout]     |             ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_shared_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `request`
[INFO] [stdout]    --> src/server/mod.rs:487:9
[INFO] [stdout]     |
[INFO] [stdout] 487 |         request: Request<ScheduleRequest>,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `res`
[INFO] [stdout]    --> src/server/mod.rs:545:16
[INFO] [stdout]     |
[INFO] [stdout] 545 |             Ok(res) => Ok(Response::new(ExecuteResponse {
[INFO] [stdout]     |                ^^^ help: if this is intentional, prefix it with an underscore: `_res`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `request`
[INFO] [stdout]    --> src/server/mod.rs:574:9
[INFO] [stdout]     |
[INFO] [stdout] 574 |         request: Request<ScheduleRequest>,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `shared_data`
[INFO] [stdout]    --> src/server/mod.rs:576:13
[INFO] [stdout]     |
[INFO] [stdout] 576 |         let shared_data = self.shared_data.clone();
[INFO] [stdout]     |             ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_shared_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/lib.rs:277:13
[INFO] [stdout]     |
[INFO] [stdout] 277 |         let data = Any::unpack::<struct_::Struct>(&data);
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/lib.rs:294:13
[INFO] [stdout]     |
[INFO] [stdout] 294 |         let data = Any::unpack::<struct_::Struct>(&data);
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `execute_channel` is never read
[INFO] [stdout]    --> src/core/worker_pool.rs:289:5
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub struct GrpcWorkerPool {
[INFO] [stdout]     |            -------------- field in this struct
[INFO] [stdout] 289 |     execute_channel: Option<Sender<ExecuteRequest>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `DropClient` is never used
[INFO] [stdout]   --> src/core/grpc_executor.rs:35:7
[INFO] [stdout]    |
[INFO] [stdout] 35 | trait DropClient {
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DataStoreError` is never used
[INFO] [stdout]  --> src/data/data_store.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub enum DataStoreError {
[INFO] [stdout]   |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RedisClient` is never constructed
[INFO] [stdout]   --> src/data/redis_store.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct RedisClient {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `WorkerChannels` is never used
[INFO] [stdout]   --> src/server/mod.rs:58:6
[INFO] [stdout]    |
[INFO] [stdout] 58 | type WorkerChannels = Arc<Mutex<HashMap<String, (Sender<Result<SchedulerMessage, Status>>, Sender<()>)>>>;
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_layer` is never read
[INFO] [stdout]   --> src/server/mod.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct SchedulerServer<B: LoadBalancer> {
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] 64 |     shared_state: Arc<GrpcSharedState<B>>,
[INFO] [stdout] 65 |     data_layer: Arc<Mutex<dyn DataStore>>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cancel_client` is never used
[INFO] [stdout]    --> src/server/mod.rs:197:10
[INFO] [stdout]     |
[INFO] [stdout] 197 | async fn cancel_client(tx: Sender<Result<SchedulerMessage, Status>>, rx_cancel:&mut Receiver<()>) {
[INFO] [stdout]     |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `worker_heartbeat` is never read
[INFO] [stdout]    --> src/server/mod.rs:207:9
[INFO] [stdout]     |
[INFO] [stdout] 205 | pub struct SharedData {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] 206 |     pub(crate) worker_pool: Arc<Mutex<WorkerPool>>,
[INFO] [stdout] 207 |     pub worker_heartbeat: Arc<Mutex<HashMap<String, Instant>>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/server/mod.rs:439:52
[INFO] [stdout]     |
[INFO] [stdout] 439 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout]     |                                                    ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `SharedData` does not implement `Clone`, so calling `clone` on `&SharedData` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout] 439 -         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout] 439 +         let shared_data = self.shared_data.as_ref();
[INFO] [stdout]     |
[INFO] [stdout] help: if you meant to clone `SharedData`, implement `Clone` for it
[INFO] [stdout]     |
[INFO] [stdout] 205 + #[derive(Clone)]
[INFO] [stdout] 206 | pub struct SharedData {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/server/mod.rs:445:9
[INFO] [stdout]     |
[INFO] [stdout] 445 |         db.add_task_execution(cloned_task).await;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 445 |         let _ = db.add_task_execution(cloned_task).await;
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/server/mod.rs:525:52
[INFO] [stdout]     |
[INFO] [stdout] 525 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout]     |                                                    ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `SharedData` does not implement `Clone`, so calling `clone` on `&SharedData` copies the reference, which does not do anything and can be removed
[INFO] [stdout] help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout] 525 -         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout] 525 +         let shared_data = self.shared_data.as_ref();
[INFO] [stdout]     |
[INFO] [stdout] help: if you meant to clone `SharedData`, implement `Clone` for it
[INFO] [stdout]     |
[INFO] [stdout] 205 + #[derive(Clone)]
[INFO] [stdout] 206 | pub struct SharedData {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DataStoreType`
[INFO] [stdout]   --> src/main.rs:18:57
[INFO] [stdout]    |
[INFO] [stdout] 18 | use protot::internal::protot::core::{Config, DataStore, DataStoreType, NodeType};
[INFO] [stdout]    |                                                         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TaskExecutorImpl1` and `TaskExecutorImpl2`
[INFO] [stdout]   --> src/main.rs:21:61
[INFO] [stdout]    |
[INFO] [stdout] 21 |     core::worker_pool::TaskRegistry, start, SchedulerError, TaskExecutorImpl1, TaskExecutorImpl2,
[INFO] [stdout]    |                                                             ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:110:9
[INFO] [stdout]     |
[INFO] [stdout] 110 |     let mut executors = TaskRegistry::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: unused import: `error::Error`
[INFO] [stdout]   --> src/core/worker_pool.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 |     thread, error::Error
[INFO] [stdout]    |             ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Response` and `Status`
[INFO] [stdout]   --> src/core/worker_pool.rs:28:13
[INFO] [stdout]    |
[INFO] [stdout] 28 | use tonic::{Status, Response};
[INFO] [stdout]    |             ^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AssignTaskRequest`
[INFO] [stdout]   --> src/core/grpc_executor.rs:15:85
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::{internal::protot::{scheduler::v1::{SchedulerMessage, scheduler_message, AssignTaskRequest, ExecuteResponse}, core::TaskState}...
[INFO] [stdout]    |                                                                                     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `worker_pool::AsyncTaskExecutor`
[INFO] [stdout]   --> src/core/grpc_executor.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 | use super::{worker_pool::AsyncTaskExecutor, load_balancer::LoadBalancer};
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error::Error`
[INFO] [stdout]   --> src/core/grpc_executor.rs:18:33
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::{collections::HashMap, error::Error, sync::Arc, time::Instant};
[INFO] [stdout]    |                                 ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mpsc`
[INFO] [stdout]   --> src/core/grpc_executor.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     mpsc,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::debug`
[INFO] [stdout]  --> src/data/redis_store.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use log::debug;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ConnectionLike`, `RedisError`, and `RedisResult`
[INFO] [stdout]  --> src/data/redis_store.rs:6:21
[INFO] [stdout]   |
[INFO] [stdout] 6 | use redis::{Client, RedisError, aio::Connection, RedisResult, AsyncCommands, ConnectionLike};
[INFO] [stdout]   |                     ^^^^^^^^^^                   ^^^^^^^^^^^                 ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Task` and `utils::current_timestamp`
[INFO] [stdout]  --> src/data/redis_store.rs:8:70
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::{internal::protot::{scheduler::v1::ExecuteRequest, core::{Task, TaskState}}, SchedulerError, utils::current_timestamp};
[INFO] [stdout]   |                                                                      ^^^^                               ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DataStoreError`
[INFO] [stdout]   --> src/data/redis_store.rs:10:36
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::data_store::{DataStore, DataStoreError};
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::fmt`
[INFO] [stdout]   --> src/utils/mod.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use core::fmt;
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::internal::protot::core::Config`
[INFO] [stdout]   --> src/utils/mod.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use crate::internal::protot::core::Config;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `prost_types::Duration`
[INFO] [stdout]   --> src/utils/configs.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use prost_types::Duration;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::future::Future`
[INFO] [stdout]   --> src/server/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use std::future::Future;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tokio_util::sync::CancellationToken`
[INFO] [stdout]   --> src/server/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use tokio_util::sync::CancellationToken;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `core::NodeType` and `self`
[INFO] [stdout]   --> src/server/mod.rs:29:91
[INFO] [stdout]    |
[INFO] [stdout] 29 | use crate::{internal::protot::{scheduler::v1::{Ack, WorkerChannelStatus, worker_message::{self, WorkerMessageType}}, core::NodeType}, cor...
[INFO] [stdout]    |                                                                                           ^^^^                       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TryFutureExt`
[INFO] [stdout]   --> src/server/mod.rs:47:34
[INFO] [stdout]    |
[INFO] [stdout] 47 | use futures::{Stream, StreamExt, TryFutureExt};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `select` and `timeout`
[INFO] [stdout]   --> src/server/mod.rs:51:52
[INFO] [stdout]    |
[INFO] [stdout] 51 |     sync::{mpsc::{self, Receiver, Sender}, Mutex}, select, time::{timeout, sleep},
[INFO] [stdout]    |                                                    ^^^^^^         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DataStore`
[INFO] [stdout]   --> src/lib.rs:86:111
[INFO] [stdout]    |
[INFO] [stdout] 86 | use crate::{core::worker_pool::{TaskExecutor, TaskRegistry}, server::start_single_process_grpc_server, data::{DataStore, RedisDataStore},...
[INFO] [stdout]    |                                                                                                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]   --> src/lib.rs:88:11
[INFO] [stdout]    |
[INFO] [stdout] 88 | use log::{info, debug, error};
[INFO] [stdout]    |           ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/client/mod.rs:225:25
[INFO] [stdout]     |
[INFO] [stdout] 225 |                         _ => println!("unable to communicate with unknown scheduler message")
[INFO] [stdout]     |                         ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/client/mod.rs:225:25
[INFO] [stdout]     |
[INFO] [stdout] 199 |                         scheduler_message::SchedulerMessageType::AssignTask(t) => {
[INFO] [stdout]     |                         ------------------------------------------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 205 |                         scheduler_message::SchedulerMessageType::Disconnect(disconnect) => {
[INFO] [stdout]     |                         --------------------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 208 |                         scheduler_message::SchedulerMessageType::Ack(ack) => {
[INFO] [stdout]     |                         ------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 211 |                         scheduler_message::SchedulerMessageType::Heartbeat(_) => {
[INFO] [stdout]     |                         ----------------------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 225 |                         _ => println!("unable to communicate with unknown scheduler message")
[INFO] [stdout]     |                         ^ collectively making this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/data/redis_store.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     async fn add_task_execution(&self, execute: ExecuteRequest) -> Result<(), SchedulerError> {
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: FromRedisValue` will fail
[INFO] [stdout]   --> src/data/redis_store.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 |         db.hset(&key, "execution", &val.to_string())
[INFO] [stdout]    |            ^^^^
[INFO] [stdout]    = note: `#[warn(dependency_on_unit_never_type_fallback)]` on by default
[INFO] [stdout] help: use `()` annotations to avoid fallback changes
[INFO] [stdout]    |
[INFO] [stdout] 55 |         db.hset::<_, _, _, ()>(&key, "execution", &val.to_string())
[INFO] [stdout]    |                +++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/worker.rs:275:13
[INFO] [stdout]     |
[INFO] [stdout] 275 |         let mut shared_data_clone = Arc::clone(&shared_data);
[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: `state`
[INFO] [stdout]   --> src/data/redis_store.rs:62:51
[INFO] [stdout]    |
[INFO] [stdout] 62 |     async fn get_task_executions_by_worker(&self, state: TaskState) -> Result<Vec<ExecuteRequest>, SchedulerError> {
[INFO] [stdout]    |                                                   ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state`
[INFO] [stdout]   --> src/data/redis_store.rs:66:51
[INFO] [stdout]    |
[INFO] [stdout] 66 |     async fn get_tasks_executions_by_state(&self, state: TaskState) -> Result<Vec<ExecuteRequest>, SchedulerError> {
[INFO] [stdout]    |                                                   ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `task_id`
[INFO] [stdout]   --> src/data/redis_store.rs:70:49
[INFO] [stdout]    |
[INFO] [stdout] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stdout]    |                                                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_task_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `execution_id`
[INFO] [stdout]   --> src/data/redis_store.rs:70:64
[INFO] [stdout]    |
[INFO] [stdout] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stdout]    |                                                                ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_execution_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `new_state`
[INFO] [stdout]   --> src/data/redis_store.rs:70:84
[INFO] [stdout]    |
[INFO] [stdout] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stdout]    |                                                                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_new_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `shared_data`
[INFO] [stdout]    --> src/server/mod.rs:439:13
[INFO] [stdout]     |
[INFO] [stdout] 439 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout]     |             ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_shared_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `request`
[INFO] [stdout]    --> src/server/mod.rs:487:9
[INFO] [stdout]     |
[INFO] [stdout] 487 |         request: Request<ScheduleRequest>,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `res`
[INFO] [stdout]    --> src/server/mod.rs:545:16
[INFO] [stdout]     |
[INFO] [stdout] 545 |             Ok(res) => Ok(Response::new(ExecuteResponse {
[INFO] [stdout]     |                ^^^ help: if this is intentional, prefix it with an underscore: `_res`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `request`
[INFO] [stdout]    --> src/server/mod.rs:574:9
[INFO] [stdout]     |
[INFO] [stdout] 574 |         request: Request<ScheduleRequest>,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `shared_data`
[INFO] [stdout]    --> src/server/mod.rs:576:13
[INFO] [stdout]     |
[INFO] [stdout] 576 |         let shared_data = self.shared_data.clone();
[INFO] [stdout]     |             ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_shared_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/lib.rs:277:13
[INFO] [stdout]     |
[INFO] [stdout] 277 |         let data = Any::unpack::<struct_::Struct>(&data);
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/lib.rs:294:13
[INFO] [stdout]     |
[INFO] [stdout] 294 |         let data = Any::unpack::<struct_::Struct>(&data);
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `execute_channel` is never read
[INFO] [stdout]    --> src/core/worker_pool.rs:289:5
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub struct GrpcWorkerPool {
[INFO] [stdout]     |            -------------- field in this struct
[INFO] [stdout] 289 |     execute_channel: Option<Sender<ExecuteRequest>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `DropClient` is never used
[INFO] [stdout]   --> src/core/grpc_executor.rs:35:7
[INFO] [stdout]    |
[INFO] [stdout] 35 | trait DropClient {
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DataStoreError` is never used
[INFO] [stdout]  --> src/data/data_store.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub enum DataStoreError {
[INFO] [stdout]   |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RedisClient` is never constructed
[INFO] [stdout]   --> src/data/redis_store.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct RedisClient {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `WorkerChannels` is never used
[INFO] [stdout]   --> src/server/mod.rs:58:6
[INFO] [stdout]    |
[INFO] [stdout] 58 | type WorkerChannels = Arc<Mutex<HashMap<String, (Sender<Result<SchedulerMessage, Status>>, Sender<()>)>>>;
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_layer` is never read
[INFO] [stdout]   --> src/server/mod.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct SchedulerServer<B: LoadBalancer> {
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] 64 |     shared_state: Arc<GrpcSharedState<B>>,
[INFO] [stdout] 65 |     data_layer: Arc<Mutex<dyn DataStore>>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cancel_client` is never used
[INFO] [stdout]    --> src/server/mod.rs:197:10
[INFO] [stdout]     |
[INFO] [stdout] 197 | async fn cancel_client(tx: Sender<Result<SchedulerMessage, Status>>, rx_cancel:&mut Receiver<()>) {
[INFO] [stdout]     |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `worker_heartbeat` is never read
[INFO] [stdout]    --> src/server/mod.rs:207:9
[INFO] [stdout]     |
[INFO] [stdout] 205 | pub struct SharedData {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] 206 |     pub(crate) worker_pool: Arc<Mutex<WorkerPool>>,
[INFO] [stdout] 207 |     pub worker_heartbeat: Arc<Mutex<HashMap<String, Instant>>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/server/mod.rs:439:52
[INFO] [stdout]     |
[INFO] [stdout] 439 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout]     |                                                    ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `SharedData` does not implement `Clone`, so calling `clone` on `&SharedData` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout] 439 -         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout] 439 +         let shared_data = self.shared_data.as_ref();
[INFO] [stdout]     |
[INFO] [stdout] help: if you meant to clone `SharedData`, implement `Clone` for it
[INFO] [stdout]     |
[INFO] [stdout] 205 + #[derive(Clone)]
[INFO] [stdout] 206 | pub struct SharedData {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/server/mod.rs:445:9
[INFO] [stdout]     |
[INFO] [stdout] 445 |         db.add_task_execution(cloned_task).await;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 445 |         let _ = db.add_task_execution(cloned_task).await;
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/server/mod.rs:525:52
[INFO] [stdout]     |
[INFO] [stdout] 525 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout]     |                                                    ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `SharedData` does not implement `Clone`, so calling `clone` on `&SharedData` copies the reference, which does not do anything and can be removed
[INFO] [stdout] help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout] 525 -         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stdout] 525 +         let shared_data = self.shared_data.as_ref();
[INFO] [stdout]     |
[INFO] [stdout] help: if you meant to clone `SharedData`, implement `Clone` for it
[INFO] [stdout]     |
[INFO] [stdout] 205 + #[derive(Clone)]
[INFO] [stdout] 206 | pub struct SharedData {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 5.89s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: protot v0.1.0 (/opt/rustwide/workdir), redis v0.23.3
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] running `Command { std: "docker" "inspect" "b1d416afff383bc382c733a85f5d66babb18dfb8343c8e75725f1d2fedee4741", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b1d416afff383bc382c733a85f5d66babb18dfb8343c8e75725f1d2fedee4741", kill_on_drop: false }`
[INFO] [stdout] b1d416afff383bc382c733a85f5d66babb18dfb8343c8e75725f1d2fedee4741
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] f60923c95aaf0f40155a0100776e8201703c142236943585e506fb20dc0fc330
[INFO] running `Command { std: "docker" "start" "-a" "f60923c95aaf0f40155a0100776e8201703c142236943585e506fb20dc0fc330", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `error::Error`
[INFO] [stderr]   --> src/core/worker_pool.rs:23:13
[INFO] [stderr]    |
[INFO] [stderr] 23 |     thread, error::Error
[INFO] [stderr]    |             ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Response` and `Status`
[INFO] [stderr]   --> src/core/worker_pool.rs:28:13
[INFO] [stderr]    |
[INFO] [stderr] 28 | use tonic::{Status, Response};
[INFO] [stderr]    |             ^^^^^^  ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `AssignTaskRequest`
[INFO] [stderr]   --> src/core/grpc_executor.rs:15:85
[INFO] [stderr]    |
[INFO] [stderr] 15 | use crate::{internal::protot::{scheduler::v1::{SchedulerMessage, scheduler_message, AssignTaskRequest, ExecuteResponse}, core::TaskState}...
[INFO] [stderr]    |                                                                                     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `worker_pool::AsyncTaskExecutor`
[INFO] [stderr]   --> src/core/grpc_executor.rs:17:13
[INFO] [stderr]    |
[INFO] [stderr] 17 | use super::{worker_pool::AsyncTaskExecutor, load_balancer::LoadBalancer};
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `error::Error`
[INFO] [stderr]   --> src/core/grpc_executor.rs:18:33
[INFO] [stderr]    |
[INFO] [stderr] 18 | use std::{collections::HashMap, error::Error, sync::Arc, time::Instant};
[INFO] [stderr]    |                                 ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `mpsc`
[INFO] [stderr]   --> src/core/grpc_executor.rs:22:5
[INFO] [stderr]    |
[INFO] [stderr] 22 |     mpsc,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `log::debug`
[INFO] [stderr]  --> src/data/redis_store.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use log::debug;
[INFO] [stderr]   |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `ConnectionLike`, `RedisError`, and `RedisResult`
[INFO] [stderr]  --> src/data/redis_store.rs:6:21
[INFO] [stderr]   |
[INFO] [stderr] 6 | use redis::{Client, RedisError, aio::Connection, RedisResult, AsyncCommands, ConnectionLike};
[INFO] [stderr]   |                     ^^^^^^^^^^                   ^^^^^^^^^^^                 ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Task` and `utils::current_timestamp`
[INFO] [stderr]  --> src/data/redis_store.rs:8:70
[INFO] [stderr]   |
[INFO] [stderr] 8 | use crate::{internal::protot::{scheduler::v1::ExecuteRequest, core::{Task, TaskState}}, SchedulerError, utils::current_timestamp};
[INFO] [stderr]   |                                                                      ^^^^                               ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `DataStoreError`
[INFO] [stderr]   --> src/data/redis_store.rs:10:36
[INFO] [stderr]    |
[INFO] [stderr] 10 | use super::data_store::{DataStore, DataStoreError};
[INFO] [stderr]    |                                    ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `core::fmt`
[INFO] [stderr]   --> src/utils/mod.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | use core::fmt;
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::internal::protot::core::Config`
[INFO] [stderr]   --> src/utils/mod.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr] 17 | use crate::internal::protot::core::Config;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `prost_types::Duration`
[INFO] [stderr]   --> src/utils/configs.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | use prost_types::Duration;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::future::Future`
[INFO] [stderr]   --> src/server/mod.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 | use std::future::Future;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `tokio_util::sync::CancellationToken`
[INFO] [stderr]   --> src/server/mod.rs:26:5
[INFO] [stderr]    |
[INFO] [stderr] 26 | use tokio_util::sync::CancellationToken;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `core::NodeType` and `self`
[INFO] [stderr]   --> src/server/mod.rs:29:91
[INFO] [stderr]    |
[INFO] [stderr] 29 | use crate::{internal::protot::{scheduler::v1::{Ack, WorkerChannelStatus, worker_message::{self, WorkerMessageType}}, core::NodeType}, cor...
[INFO] [stderr]    |                                                                                           ^^^^                       ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `TryFutureExt`
[INFO] [stderr]   --> src/server/mod.rs:47:34
[INFO] [stderr]    |
[INFO] [stderr] 47 | use futures::{Stream, StreamExt, TryFutureExt};
[INFO] [stderr]    |                                  ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `select` and `timeout`
[INFO] [stderr]   --> src/server/mod.rs:51:52
[INFO] [stderr]    |
[INFO] [stderr] 51 |     sync::{mpsc::{self, Receiver, Sender}, Mutex}, select, time::{timeout, sleep},
[INFO] [stderr]    |                                                    ^^^^^^         ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `DataStore`
[INFO] [stderr]   --> src/lib.rs:86:111
[INFO] [stderr]    |
[INFO] [stderr] 86 | use crate::{core::worker_pool::{TaskExecutor, TaskRegistry}, server::start_single_process_grpc_server, data::{DataStore, RedisDataStore},...
[INFO] [stderr]    |                                                                                                               ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `info`
[INFO] [stderr]   --> src/lib.rs:88:11
[INFO] [stderr]    |
[INFO] [stderr] 88 | use log::{info, debug, error};
[INFO] [stderr]    |           ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]    --> src/client/mod.rs:225:25
[INFO] [stderr]     |
[INFO] [stderr] 225 |                         _ => println!("unable to communicate with unknown scheduler message")
[INFO] [stderr]     |                         ^ no value can reach this
[INFO] [stderr]     |
[INFO] [stderr] note: multiple earlier patterns match some of the same values
[INFO] [stderr]    --> src/client/mod.rs:225:25
[INFO] [stderr]     |
[INFO] [stderr] 199 |                         scheduler_message::SchedulerMessageType::AssignTask(t) => {
[INFO] [stderr]     |                         ------------------------------------------------------ matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 205 |                         scheduler_message::SchedulerMessageType::Disconnect(disconnect) => {
[INFO] [stderr]     |                         --------------------------------------------------------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 208 |                         scheduler_message::SchedulerMessageType::Ack(ack) => {
[INFO] [stderr]     |                         ------------------------------------------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 211 |                         scheduler_message::SchedulerMessageType::Heartbeat(_) => {
[INFO] [stderr]     |                         ----------------------------------------------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 225 |                         _ => println!("unable to communicate with unknown scheduler message")
[INFO] [stderr]     |                         ^ collectively making this unreachable
[INFO] [stderr]     = note: `#[warn(unreachable_patterns)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: this function depends on never type fallback being `()`
[INFO] [stderr]   --> src/data/redis_store.rs:36:5
[INFO] [stderr]    |
[INFO] [stderr] 36 |     async fn add_task_execution(&self, execute: ExecuteRequest) -> Result<(), SchedulerError> {
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stderr]    = help: specify the types explicitly
[INFO] [stderr] note: in edition 2024, the requirement `!: FromRedisValue` will fail
[INFO] [stderr]   --> src/data/redis_store.rs:55:12
[INFO] [stderr]    |
[INFO] [stderr] 55 |         db.hset(&key, "execution", &val.to_string())
[INFO] [stderr]    |            ^^^^
[INFO] [stderr]    = note: `#[warn(dependency_on_unit_never_type_fallback)]` on by default
[INFO] [stderr] help: use `()` annotations to avoid fallback changes
[INFO] [stderr]    |
[INFO] [stderr] 55 |         db.hset::<_, _, _, ()>(&key, "execution", &val.to_string())
[INFO] [stderr]    |                +++++++++++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `state`
[INFO] [stderr]   --> src/data/redis_store.rs:62:51
[INFO] [stderr]    |
[INFO] [stderr] 62 |     async fn get_task_executions_by_worker(&self, state: TaskState) -> Result<Vec<ExecuteRequest>, SchedulerError> {
[INFO] [stderr]    |                                                   ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `state`
[INFO] [stderr]   --> src/data/redis_store.rs:66:51
[INFO] [stderr]    |
[INFO] [stderr] 66 |     async fn get_tasks_executions_by_state(&self, state: TaskState) -> Result<Vec<ExecuteRequest>, SchedulerError> {
[INFO] [stderr]    |                                                   ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `task_id`
[INFO] [stderr]   --> src/data/redis_store.rs:70:49
[INFO] [stderr]    |
[INFO] [stderr] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stderr]    |                                                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_task_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `execution_id`
[INFO] [stderr]   --> src/data/redis_store.rs:70:64
[INFO] [stderr]    |
[INFO] [stderr] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stderr]    |                                                                ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_execution_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `new_state`
[INFO] [stderr]   --> src/data/redis_store.rs:70:84
[INFO] [stderr]    |
[INFO] [stderr] 70 |     async fn update_task_execution_state(&self, task_id: &str, execution_id: &str, new_state: &TaskState) -> Result<(), SchedulerError> {
[INFO] [stderr]    |                                                                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_new_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `shared_data`
[INFO] [stderr]    --> src/server/mod.rs:439:13
[INFO] [stderr]     |
[INFO] [stderr] 439 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stderr]     |             ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_shared_data`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `request`
[INFO] [stderr]    --> src/server/mod.rs:487:9
[INFO] [stderr]     |
[INFO] [stderr] 487 |         request: Request<ScheduleRequest>,
[INFO] [stderr]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `res`
[INFO] [stderr]    --> src/server/mod.rs:545:16
[INFO] [stderr]     |
[INFO] [stderr] 545 |             Ok(res) => Ok(Response::new(ExecuteResponse {
[INFO] [stderr]     |                ^^^ help: if this is intentional, prefix it with an underscore: `_res`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `request`
[INFO] [stderr]    --> src/server/mod.rs:574:9
[INFO] [stderr]     |
[INFO] [stderr] 574 |         request: Request<ScheduleRequest>,
[INFO] [stderr]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `shared_data`
[INFO] [stderr]    --> src/server/mod.rs:576:13
[INFO] [stderr]     |
[INFO] [stderr] 576 |         let shared_data = self.shared_data.clone();
[INFO] [stderr]     |             ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_shared_data`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `data`
[INFO] [stderr]    --> src/lib.rs:277:13
[INFO] [stderr]     |
[INFO] [stderr] 277 |         let data = Any::unpack::<struct_::Struct>(&data);
[INFO] [stderr]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `data`
[INFO] [stderr]    --> src/lib.rs:294:13
[INFO] [stderr]     |
[INFO] [stderr] 294 |         let data = Any::unpack::<struct_::Struct>(&data);
[INFO] [stderr]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stderr] 
[INFO] [stderr] warning: field `execute_channel` is never read
[INFO] [stderr]    --> src/core/worker_pool.rs:289:5
[INFO] [stderr]     |
[INFO] [stderr] 288 | pub struct GrpcWorkerPool {
[INFO] [stderr]     |            -------------- field in this struct
[INFO] [stderr] 289 |     execute_channel: Option<Sender<ExecuteRequest>>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait `DropClient` is never used
[INFO] [stderr]   --> src/core/grpc_executor.rs:35:7
[INFO] [stderr]    |
[INFO] [stderr] 35 | trait DropClient {
[INFO] [stderr]    |       ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `DataStoreError` is never used
[INFO] [stderr]  --> src/data/data_store.rs:7:10
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub enum DataStoreError {
[INFO] [stderr]   |          ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `RedisClient` is never constructed
[INFO] [stderr]   --> src/data/redis_store.rs:12:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct RedisClient {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `WorkerChannels` is never used
[INFO] [stderr]   --> src/server/mod.rs:58:6
[INFO] [stderr]    |
[INFO] [stderr] 58 | type WorkerChannels = Arc<Mutex<HashMap<String, (Sender<Result<SchedulerMessage, Status>>, Sender<()>)>>>;
[INFO] [stderr]    |      ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `data_layer` is never read
[INFO] [stderr]   --> src/server/mod.rs:65:5
[INFO] [stderr]    |
[INFO] [stderr] 63 | pub struct SchedulerServer<B: LoadBalancer> {
[INFO] [stderr]    |            --------------- field in this struct
[INFO] [stderr] 64 |     shared_state: Arc<GrpcSharedState<B>>,
[INFO] [stderr] 65 |     data_layer: Arc<Mutex<dyn DataStore>>,
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `cancel_client` is never used
[INFO] [stderr]    --> src/server/mod.rs:197:10
[INFO] [stderr]     |
[INFO] [stderr] 197 | async fn cancel_client(tx: Sender<Result<SchedulerMessage, Status>>, rx_cancel:&mut Receiver<()>) {
[INFO] [stderr]     |          ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `worker_heartbeat` is never read
[INFO] [stderr]    --> src/server/mod.rs:207:9
[INFO] [stderr]     |
[INFO] [stderr] 205 | pub struct SharedData {
[INFO] [stderr]     |            ---------- field in this struct
[INFO] [stderr] 206 |     pub(crate) worker_pool: Arc<Mutex<WorkerPool>>,
[INFO] [stderr] 207 |     pub worker_heartbeat: Arc<Mutex<HashMap<String, Instant>>>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stderr]    --> src/server/mod.rs:439:52
[INFO] [stderr]     |
[INFO] [stderr] 439 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stderr]     |                                                    ^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: the type `SharedData` does not implement `Clone`, so calling `clone` on `&SharedData` copies the reference, which does not do anything and can be removed
[INFO] [stderr]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stderr] help: remove this redundant call
[INFO] [stderr]     |
[INFO] [stderr] 439 -         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stderr] 439 +         let shared_data = self.shared_data.as_ref();
[INFO] [stderr]     |
[INFO] [stderr] help: if you meant to clone `SharedData`, implement `Clone` for it
[INFO] [stderr]     |
[INFO] [stderr] 205 + #[derive(Clone)]
[INFO] [stderr] 206 | pub struct SharedData {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> src/server/mod.rs:445:9
[INFO] [stderr]     |
[INFO] [stderr] 445 |         db.add_task_execution(cloned_task).await;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 445 |         let _ = db.add_task_execution(cloned_task).await;
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stderr]    --> src/server/mod.rs:525:52
[INFO] [stderr]     |
[INFO] [stderr] 525 |         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stderr]     |                                                    ^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: the type `SharedData` does not implement `Clone`, so calling `clone` on `&SharedData` copies the reference, which does not do anything and can be removed
[INFO] [stderr] help: remove this redundant call
[INFO] [stderr]     |
[INFO] [stderr] 525 -         let shared_data = self.shared_data.as_ref().clone();
[INFO] [stderr] 525 +         let shared_data = self.shared_data.as_ref();
[INFO] [stderr]     |
[INFO] [stderr] help: if you meant to clone `SharedData`, implement `Clone` for it
[INFO] [stderr]     |
[INFO] [stderr] 205 + #[derive(Clone)]
[INFO] [stderr] 206 | pub struct SharedData {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/core/worker.rs:275:13
[INFO] [stderr]     |
[INFO] [stderr] 275 |         let mut shared_data_clone = Arc::clone(&shared_data);
[INFO] [stderr]     |             ----^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `protot` (lib) generated 45 warnings (run `cargo fix --lib -p protot` to apply 23 suggestions)
[INFO] [stderr] warning: `protot` (lib test) generated 46 warnings (45 duplicates) (run `cargo fix --lib -p protot --tests` to apply 1 suggestion)
[INFO] [stderr] warning: unused import: `DataStoreType`
[INFO] [stderr]   --> src/main.rs:18:57
[INFO] [stderr]    |
[INFO] [stderr] 18 | use protot::internal::protot::core::{Config, DataStore, DataStoreType, NodeType};
[INFO] [stderr]    |                                                         ^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `TaskExecutorImpl1` and `TaskExecutorImpl2`
[INFO] [stderr]   --> src/main.rs:21:61
[INFO] [stderr]    |
[INFO] [stderr] 21 |     core::worker_pool::TaskRegistry, start, SchedulerError, TaskExecutorImpl1, TaskExecutorImpl2,
[INFO] [stderr]    |                                                             ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/main.rs:110:9
[INFO] [stderr]     |
[INFO] [stderr] 110 |     let mut executors = TaskRegistry::new();
[INFO] [stderr]     |         ----^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `protot` (bin "protot" test) generated 3 warnings (run `cargo fix --bin "protot" --tests` to apply 3 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.32s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: protot v0.1.0 (/opt/rustwide/workdir), redis v0.23.3
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/protot-f8ced6b0f64ef9fe)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test utils::configs::tests::test_load_and_deserialize_configs_from_yaml ... ok
[INFO] [stdout] test utils::configs::tests::test_load_and_deserialize_configs_from_json ... ok
[INFO] [stdout] test core::worker::tests::test_local_worker_spawn ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.11s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/protot-92533c703368356f)
[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]    Doc-tests protot
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test src/core/worker_pool.rs - core::worker_pool::WorkerPool::clone (line 427) - compile ... FAILED
[INFO] [stdout] test src/utils/error.rs - utils::error::SchedulerError (line 25) - compile ... ok
[INFO] [stdout] test src/utils/configs.rs - utils::configs::config_load (line 120) - compile ... ok
[INFO] [stdout] test src/lib.rs - (line 52) ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/core/worker_pool.rs - core::worker_pool::WorkerPool::clone (line 427) stdout ----
[INFO] [stdout] error[E0433]: failed to resolve: could not find `sylklabs` in `internal`
[INFO] [stdout]  --> src/core/worker_pool.rs:430:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use protot::internal::sylklabs::scheduler::v1::ExecuteRequest;
[INFO] [stdout]   |                       ^^^^^^^^ could not find `sylklabs` in `internal`
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 1 previous error
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0433`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 52) stdout ----
[INFO] [stdout] error[E0425]: cannot find function `config_load` in this scope
[INFO] [stdout]  --> src/lib.rs:54:18
[INFO] [stdout]   |
[INFO] [stdout] 3 |     let config = config_load(String::from("my_config.yaml"));
[INFO] [stdout]   |                  ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]   |
[INFO] [stdout] help: consider importing this function
[INFO] [stdout]   |
[INFO] [stdout] 2 + use protot::config_load;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 1 previous error
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0425`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/core/worker_pool.rs - core::worker_pool::WorkerPool::clone (line 427)
[INFO] [stdout]     src/lib.rs - (line 52)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 2 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.47s
[INFO] [stdout] 
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] running `Command { std: "docker" "inspect" "f60923c95aaf0f40155a0100776e8201703c142236943585e506fb20dc0fc330", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f60923c95aaf0f40155a0100776e8201703c142236943585e506fb20dc0fc330", kill_on_drop: false }`
[INFO] [stdout] f60923c95aaf0f40155a0100776e8201703c142236943585e506fb20dc0fc330
