[INFO] cloning repository https://github.com/wgolling/WorkLedger [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/wgolling/WorkLedger" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwgolling%2FWorkLedger", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwgolling%2FWorkLedger'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 791d9c6d43754e9e41214fbabb60efed8b296d45 [INFO] testing wgolling/WorkLedger against 1.60.0 for beta-1.61-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwgolling%2FWorkLedger" "/workspace/builds/worker-8/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-8/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/wgolling/WorkLedger on toolchain 1.60.0 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.60.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/wgolling/WorkLedger [INFO] finished tweaking git repo https://github.com/wgolling/WorkLedger [INFO] tweaked toml for git repo https://github.com/wgolling/WorkLedger written to /workspace/builds/worker-8/source/Cargo.toml [INFO] crate git repo https://github.com/wgolling/WorkLedger already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.60.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded bstr v0.2.7 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/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:eaef2f80f755933c374d2ae5edccceec0c1312ceb8a4e0b6404e8ab76561e1e5" "/opt/rustwide/cargo-home/bin/cargo" "+1.60.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] ee049da9cc697bc872ab2f3a17c1914af038058e487f84b227dd4e624ff9338b [INFO] running `Command { std: "docker" "start" "-a" "ee049da9cc697bc872ab2f3a17c1914af038058e487f84b227dd4e624ff9338b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "ee049da9cc697bc872ab2f3a17c1914af038058e487f84b227dd4e624ff9338b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ee049da9cc697bc872ab2f3a17c1914af038058e487f84b227dd4e624ff9338b", kill_on_drop: false }` [INFO] [stdout] ee049da9cc697bc872ab2f3a17c1914af038058e487f84b227dd4e624ff9338b [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "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:eaef2f80f755933c374d2ae5edccceec0c1312ceb8a4e0b6404e8ab76561e1e5" "/opt/rustwide/cargo-home/bin/cargo" "+1.60.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 955028901bb73d39bb37345a5aff3dfa33d017bbac83803099e17586f7047b2f [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "955028901bb73d39bb37345a5aff3dfa33d017bbac83803099e17586f7047b2f", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.61 [INFO] [stderr] Compiling byteorder v1.3.2 [INFO] [stderr] Compiling memchr v2.2.1 [INFO] [stderr] Compiling syn v0.15.44 [INFO] [stderr] Compiling num-traits v0.2.8 [INFO] [stderr] Compiling num-integer v0.1.41 [INFO] [stderr] Compiling regex-automata v0.1.8 [INFO] [stderr] Compiling time v0.1.42 [INFO] [stderr] Compiling bstr v0.2.7 [INFO] [stderr] Compiling csv-core v0.1.6 [INFO] [stderr] Compiling chrono v0.4.7 [INFO] [stderr] Compiling csv v1.1.1 [INFO] [stderr] Compiling serde_derive v1.0.98 [INFO] [stderr] Compiling record_keeper v0.1.0 (/opt/rustwide/workdir/record_keeper) [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> record_keeper/src/lib.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Datelike`, `Timelike` [INFO] [stdout] --> record_keeper/src/record.rs:3:24 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, Datelike, Timelike, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> record_keeper/src/error.rs:28:32 [INFO] [stdout] | [INFO] [stdout] 28 | fn cause(&self) -> Option<&Error> { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 28 - fn cause(&self) -> Option<&Error> { [INFO] [stdout] 28 + fn cause(&self) -> Option<&dyn Error> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> record_keeper/src/error.rs:52:32 [INFO] [stdout] | [INFO] [stdout] 52 | fn cause(&self) -> Option<&Error> { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 52 - fn cause(&self) -> Option<&Error> { [INFO] [stdout] 52 + fn cause(&self) -> Option<&dyn Error> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> record_keeper/src/lib.rs:171:21 [INFO] [stdout] | [INFO] [stdout] 171 | let mut v = self.task_names.get_mut(&name).unwrap(); [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: field is never read: `name` [INFO] [stdout] --> record_keeper/src/lib.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | name: String, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_name` [INFO] [stdout] --> record_keeper/src/lib.rs:29:8 [INFO] [stdout] | [INFO] [stdout] 29 | fn get_name(&self) -> &str { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `name` [INFO] [stdout] --> record_keeper/src/lib.rs:36:5 [INFO] [stdout] | [INFO] [stdout] 36 | name: String, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_name` [INFO] [stdout] --> record_keeper/src/lib.rs:46:8 [INFO] [stdout] | [INFO] [stdout] 46 | fn get_name(&self) -> &str { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 9 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling cmd_interface v0.1.0 (/opt/rustwide/workdir/cmd_interface) [INFO] [stdout] warning: unused import: `Duration` [INFO] [stdout] --> cmd_interface/src/main.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use std::time::{Duration, Instant}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `super::enums::*` [INFO] [stdout] --> cmd_interface/src/app/engine.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use super::enums::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `record_keeper::ErrorType` [INFO] [stdout] --> cmd_interface/src/app/engine.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use record_keeper::ErrorType; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:13:15 [INFO] [stdout] | [INFO] [stdout] 13 | view: Box, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 13 - view: Box, [INFO] [stdout] 13 + view: Box, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:15:17 [INFO] [stdout] | [INFO] [stdout] 15 | parser: Box, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 15 - parser: Box, [INFO] [stdout] 15 + parser: Box, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:20:19 [INFO] [stdout] | [INFO] [stdout] 20 | view: Box, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 20 - view: Box, [INFO] [stdout] 20 + view: Box, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:22:21 [INFO] [stdout] | [INFO] [stdout] 22 | parser: Box, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 22 - parser: Box, [INFO] [stdout] 22 + parser: Box, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:132:46 [INFO] [stdout] | [INFO] [stdout] 132 | pub fn change_view(& mut self, view: Box) { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 132 - pub fn change_view(& mut self, view: Box) { [INFO] [stdout] 132 + pub fn change_view(& mut self, view: Box) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:135:50 [INFO] [stdout] | [INFO] [stdout] 135 | pub fn change_parser(& mut self, parser: Box) { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 135 - pub fn change_parser(& mut self, parser: Box) { [INFO] [stdout] 135 + pub fn change_parser(& mut self, parser: Box) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:119:13 [INFO] [stdout] | [INFO] [stdout] 119 | _ => panic!("State not recognized"), [INFO] [stdout] | ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rest_of_input` [INFO] [stdout] --> cmd_interface/src/app/parser.rs:138:26 [INFO] [stdout] | [INFO] [stdout] 138 | let (first_word, rest_of_input) = split_at_first_space(s); [INFO] [stdout] | ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rest_of_input` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `model` [INFO] [stdout] --> cmd_interface/src/app/parser.rs:137:33 [INFO] [stdout] | [INFO] [stdout] 137 | fn parse(&self, s: &String, model: &User) -> Command { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `model` [INFO] [stdout] --> cmd_interface/src/app/views/menu.rs:22:23 [INFO] [stdout] | [INFO] [stdout] 22 | fn display(&self, model: &User) { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `model` [INFO] [stdout] --> cmd_interface/src/app/views/menu.rs:34:23 [INFO] [stdout] | [INFO] [stdout] 34 | fn display(&self, model: &User) { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> cmd_interface/src/app/views/menu.rs:71:17 [INFO] [stdout] | [INFO] [stdout] 71 | Err(e) => panic!("TaskMenu was constructed with an invalid client."), [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `model` [INFO] [stdout] --> cmd_interface/src/app/views/menu.rs:97:23 [INFO] [stdout] | [INFO] [stdout] 97 | fn display(&self, model: &User) { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> cmd_interface/src/app/engine.rs:24:13 [INFO] [stdout] | [INFO] [stdout] 24 | let mut user = load_user(); [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: field is never read: `records` [INFO] [stdout] --> cmd_interface/src/app/parser.rs:128:5 [INFO] [stdout] | [INFO] [stdout] 128 | records: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `add_client` [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:140:12 [INFO] [stdout] | [INFO] [stdout] 140 | pub fn add_client(& mut self, name: String) -> Result<(), ErrorType> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_client_names` [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:145:12 [INFO] [stdout] | [INFO] [stdout] 145 | pub fn get_client_names(&self) -> Vec<&String> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_owned_names` [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:148:12 [INFO] [stdout] | [INFO] [stdout] 148 | pub fn get_owned_names(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `add_task` [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:153:12 [INFO] [stdout] | [INFO] [stdout] 153 | pub fn add_task(& mut self, client_name: String, task_name: String) [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_owned_tasks_for_client` [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:160:12 [INFO] [stdout] | [INFO] [stdout] 160 | pub fn get_owned_tasks_for_client(&self, client_name: String) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_client_names` [INFO] [stdout] --> cmd_interface/src/app/models/user.rs:23:12 [INFO] [stdout] | [INFO] [stdout] 23 | pub fn get_client_names(&self) -> Vec<&String> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_owned_names` [INFO] [stdout] --> cmd_interface/src/app/models/user.rs:26:12 [INFO] [stdout] | [INFO] [stdout] 26 | pub fn get_owned_names(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_owned_tasks_for_client` [INFO] [stdout] --> cmd_interface/src/app/models/user.rs:41:12 [INFO] [stdout] | [INFO] [stdout] 41 | pub fn get_owned_tasks_for_client(&self, client_name: String) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `SplashPage` [INFO] [stdout] --> cmd_interface/src/app/enums/engine_enums.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | SplashPage, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> cmd_interface/src/app/engine.rs:59:5 [INFO] [stdout] | [INFO] [stdout] 59 | user.add_client("Client 1".to_string()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> cmd_interface/src/app/engine.rs:60:5 [INFO] [stdout] | [INFO] [stdout] 60 | user.add_task("Client 1".to_string(), "Task 1".to_string()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> cmd_interface/src/app/engine.rs:61:5 [INFO] [stdout] | [INFO] [stdout] 61 | user.add_task("Client 1".to_string(), "Task 2".to_string()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> cmd_interface/src/app/engine.rs:62:5 [INFO] [stdout] | [INFO] [stdout] 62 | user.add_client("Client 3".to_string()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> cmd_interface/src/app/engine.rs:63:5 [INFO] [stdout] | [INFO] [stdout] 63 | user.add_client("Client 2".to_string()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 32 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 32.25s [INFO] running `Command { std: "docker" "inspect" "955028901bb73d39bb37345a5aff3dfa33d017bbac83803099e17586f7047b2f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "955028901bb73d39bb37345a5aff3dfa33d017bbac83803099e17586f7047b2f", kill_on_drop: false }` [INFO] [stdout] 955028901bb73d39bb37345a5aff3dfa33d017bbac83803099e17586f7047b2f [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "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:eaef2f80f755933c374d2ae5edccceec0c1312ceb8a4e0b6404e8ab76561e1e5" "/opt/rustwide/cargo-home/bin/cargo" "+1.60.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 7265595785eb2d1f33165e5335e2db32b939f5d593c18a66899eb5e05058e7a1 [INFO] running `Command { std: "docker" "start" "-a" "7265595785eb2d1f33165e5335e2db32b939f5d593c18a66899eb5e05058e7a1", kill_on_drop: false }` [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> record_keeper/src/lib.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Datelike`, `Timelike` [INFO] [stdout] --> record_keeper/src/record.rs:3:24 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, Datelike, Timelike, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling record_keeper v0.1.0 (/opt/rustwide/workdir/record_keeper) [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> record_keeper/src/error.rs:28:32 [INFO] [stdout] | [INFO] [stdout] 28 | fn cause(&self) -> Option<&Error> { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 28 - fn cause(&self) -> Option<&Error> { [INFO] [stdout] 28 + fn cause(&self) -> Option<&dyn Error> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling cmd_interface v0.1.0 (/opt/rustwide/workdir/cmd_interface) [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> record_keeper/src/error.rs:52:32 [INFO] [stdout] | [INFO] [stdout] 52 | fn cause(&self) -> Option<&Error> { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 52 - fn cause(&self) -> Option<&Error> { [INFO] [stdout] 52 + fn cause(&self) -> Option<&dyn Error> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> record_keeper/src/lib.rs:171:21 [INFO] [stdout] | [INFO] [stdout] 171 | let mut v = self.task_names.get_mut(&name).unwrap(); [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: field is never read: `name` [INFO] [stdout] --> record_keeper/src/lib.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | name: String, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_name` [INFO] [stdout] --> record_keeper/src/lib.rs:29:8 [INFO] [stdout] | [INFO] [stdout] 29 | fn get_name(&self) -> &str { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `name` [INFO] [stdout] --> record_keeper/src/lib.rs:36:5 [INFO] [stdout] | [INFO] [stdout] 36 | name: String, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_name` [INFO] [stdout] --> record_keeper/src/lib.rs:46:8 [INFO] [stdout] | [INFO] [stdout] 46 | fn get_name(&self) -> &str { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 9 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> record_keeper/src/lib.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Datelike`, `Timelike` [INFO] [stdout] --> record_keeper/src/record.rs:3:24 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, Datelike, Timelike, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `super::*` [INFO] [stdout] --> record_keeper/src/record.rs:18:9 [INFO] [stdout] | [INFO] [stdout] 18 | use super::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> record_keeper/src/error.rs:28:32 [INFO] [stdout] | [INFO] [stdout] 28 | fn cause(&self) -> Option<&Error> { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 28 - fn cause(&self) -> Option<&Error> { [INFO] [stdout] 28 + fn cause(&self) -> Option<&dyn Error> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> record_keeper/src/error.rs:52:32 [INFO] [stdout] | [INFO] [stdout] 52 | fn cause(&self) -> Option<&Error> { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 52 - fn cause(&self) -> Option<&Error> { [INFO] [stdout] 52 + fn cause(&self) -> Option<&dyn Error> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Duration` [INFO] [stdout] --> cmd_interface/src/main.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use std::time::{Duration, Instant}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `super::enums::*` [INFO] [stdout] --> cmd_interface/src/app/engine.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use super::enums::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `record_keeper::ErrorType` [INFO] [stdout] --> cmd_interface/src/app/engine.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use record_keeper::ErrorType; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:13:15 [INFO] [stdout] | [INFO] [stdout] 13 | view: Box, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 13 - view: Box, [INFO] [stdout] 13 + view: Box, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:15:17 [INFO] [stdout] | [INFO] [stdout] 15 | parser: Box, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 15 - parser: Box, [INFO] [stdout] 15 + parser: Box, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:20:19 [INFO] [stdout] | [INFO] [stdout] 20 | view: Box, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 20 - view: Box, [INFO] [stdout] 20 + view: Box, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:22:21 [INFO] [stdout] | [INFO] [stdout] 22 | parser: Box, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 22 - parser: Box, [INFO] [stdout] 22 + parser: Box, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:132:46 [INFO] [stdout] | [INFO] [stdout] 132 | pub fn change_view(& mut self, view: Box) { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 132 - pub fn change_view(& mut self, view: Box) { [INFO] [stdout] 132 + pub fn change_view(& mut self, view: Box) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:135:50 [INFO] [stdout] | [INFO] [stdout] 135 | pub fn change_parser(& mut self, parser: Box) { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 135 - pub fn change_parser(& mut self, parser: Box) { [INFO] [stdout] 135 + pub fn change_parser(& mut self, parser: Box) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:119:13 [INFO] [stdout] | [INFO] [stdout] 119 | _ => panic!("State not recognized"), [INFO] [stdout] | ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rest_of_input` [INFO] [stdout] --> cmd_interface/src/app/parser.rs:138:26 [INFO] [stdout] | [INFO] [stdout] 138 | let (first_word, rest_of_input) = split_at_first_space(s); [INFO] [stdout] | ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rest_of_input` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `model` [INFO] [stdout] --> cmd_interface/src/app/parser.rs:137:33 [INFO] [stdout] | [INFO] [stdout] 137 | fn parse(&self, s: &String, model: &User) -> Command { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `model` [INFO] [stdout] --> cmd_interface/src/app/views/menu.rs:22:23 [INFO] [stdout] | [INFO] [stdout] 22 | fn display(&self, model: &User) { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `model` [INFO] [stdout] --> cmd_interface/src/app/views/menu.rs:34:23 [INFO] [stdout] | [INFO] [stdout] 34 | fn display(&self, model: &User) { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> cmd_interface/src/app/views/menu.rs:71:17 [INFO] [stdout] | [INFO] [stdout] 71 | Err(e) => panic!("TaskMenu was constructed with an invalid client."), [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `model` [INFO] [stdout] --> cmd_interface/src/app/views/menu.rs:97:23 [INFO] [stdout] | [INFO] [stdout] 97 | fn display(&self, model: &User) { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> cmd_interface/src/app/engine.rs:24:13 [INFO] [stdout] | [INFO] [stdout] 24 | let mut user = load_user(); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> record_keeper/src/lib.rs:171:21 [INFO] [stdout] | [INFO] [stdout] 171 | let mut v = self.task_names.get_mut(&name).unwrap(); [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: field is never read: `records` [INFO] [stdout] --> cmd_interface/src/app/parser.rs:128:5 [INFO] [stdout] | [INFO] [stdout] 128 | records: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `add_client` [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:140:12 [INFO] [stdout] | [INFO] [stdout] 140 | pub fn add_client(& mut self, name: String) -> Result<(), ErrorType> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_client_names` [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:145:12 [INFO] [stdout] | [INFO] [stdout] 145 | pub fn get_client_names(&self) -> Vec<&String> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_owned_names` [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:148:12 [INFO] [stdout] | [INFO] [stdout] 148 | pub fn get_owned_names(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `add_task` [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:153:12 [INFO] [stdout] | [INFO] [stdout] 153 | pub fn add_task(& mut self, client_name: String, task_name: String) [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_owned_tasks_for_client` [INFO] [stdout] --> cmd_interface/src/app/controllers/app_controller.rs:160:12 [INFO] [stdout] | [INFO] [stdout] 160 | pub fn get_owned_tasks_for_client(&self, client_name: String) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_client_names` [INFO] [stdout] --> cmd_interface/src/app/models/user.rs:23:12 [INFO] [stdout] | [INFO] [stdout] 23 | pub fn get_client_names(&self) -> Vec<&String> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_owned_names` [INFO] [stdout] --> cmd_interface/src/app/models/user.rs:26:12 [INFO] [stdout] | [INFO] [stdout] 26 | pub fn get_owned_names(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `get_owned_tasks_for_client` [INFO] [stdout] --> cmd_interface/src/app/models/user.rs:41:12 [INFO] [stdout] | [INFO] [stdout] 41 | pub fn get_owned_tasks_for_client(&self, client_name: String) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `SplashPage` [INFO] [stdout] --> cmd_interface/src/app/enums/engine_enums.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | SplashPage, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> cmd_interface/src/app/engine.rs:59:5 [INFO] [stdout] | [INFO] [stdout] 59 | user.add_client("Client 1".to_string()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> cmd_interface/src/app/engine.rs:60:5 [INFO] [stdout] | [INFO] [stdout] 60 | user.add_task("Client 1".to_string(), "Task 1".to_string()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> cmd_interface/src/app/engine.rs:61:5 [INFO] [stdout] | [INFO] [stdout] 61 | user.add_task("Client 1".to_string(), "Task 2".to_string()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> cmd_interface/src/app/engine.rs:62:5 [INFO] [stdout] | [INFO] [stdout] 62 | user.add_client("Client 3".to_string()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> cmd_interface/src/app/engine.rs:63:5 [INFO] [stdout] | [INFO] [stdout] 63 | user.add_client("Client 2".to_string()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> record_keeper/src/tests.rs:100:9 [INFO] [stdout] | [INFO] [stdout] 100 | let mut rk = RecordKeeper::new(); [INFO] [stdout] | ----^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `validating_client_names_for_get` [INFO] [stdout] --> record_keeper/src/tests.rs:77:4 [INFO] [stdout] | [INFO] [stdout] 77 | fn validating_client_names_for_get() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:28:5 [INFO] [stdout] | [INFO] [stdout] 28 | client.add_task(test_name.clone()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:40:5 [INFO] [stdout] | [INFO] [stdout] 40 | client.add_validated_task(bad_data); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:45:5 [INFO] [stdout] | [INFO] [stdout] 45 | client.add_task(String::from("Test Task")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:46:5 [INFO] [stdout] | [INFO] [stdout] 46 | client.add_task(String::from("Test Task 2")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:71:13 [INFO] [stdout] | [INFO] [stdout] 71 | rk.add_validated_client(data); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:84:5 [INFO] [stdout] | [INFO] [stdout] 84 | rk.add_client(test_name.clone()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:95:5 [INFO] [stdout] | [INFO] [stdout] 95 | rk.add_validated_client(bad_data); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:102:5 [INFO] [stdout] | [INFO] [stdout] 102 | rk.get_tasks_for_validated_client(bad_data); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:109:5 [INFO] [stdout] | [INFO] [stdout] 109 | rk.add_task_for_validated_client(bad_data, String::from("Test Task")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:115:5 [INFO] [stdout] | [INFO] [stdout] 115 | rk.add_client(String::from("Test Client")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:123:5 [INFO] [stdout] | [INFO] [stdout] 123 | rk.add_client(String::from("Test Client 2")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:124:5 [INFO] [stdout] | [INFO] [stdout] 124 | rk.add_client(String::from("Test Client")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:143:5 [INFO] [stdout] | [INFO] [stdout] 143 | rk.add_client(test_client.clone()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:144:5 [INFO] [stdout] | [INFO] [stdout] 144 | rk.add_client(String::from("Test Client 2")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:145:5 [INFO] [stdout] | [INFO] [stdout] 145 | rk.add_task(test_client.clone(), test_task.clone()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:151:5 [INFO] [stdout] | [INFO] [stdout] 151 | rk.add_task(String::from("Test Client 2"), test_task.clone()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:152:5 [INFO] [stdout] | [INFO] [stdout] 152 | rk.add_task(test_client.clone(), String::from("Test Task 2")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:160:5 [INFO] [stdout] | [INFO] [stdout] 160 | rk.add_client(String::from("Test Client")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:161:5 [INFO] [stdout] | [INFO] [stdout] 161 | rk.add_task(String::from("Test Client"), String::from("Test Task")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> record_keeper/src/tests.rs:162:5 [INFO] [stdout] | [INFO] [stdout] 162 | rk.add_task(String::from("Test Client"), String::from("Test Task 2")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 32 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 28 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 2.59s [INFO] running `Command { std: "docker" "inspect" "7265595785eb2d1f33165e5335e2db32b939f5d593c18a66899eb5e05058e7a1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7265595785eb2d1f33165e5335e2db32b939f5d593c18a66899eb5e05058e7a1", kill_on_drop: false }` [INFO] [stdout] 7265595785eb2d1f33165e5335e2db32b939f5d593c18a66899eb5e05058e7a1 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "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:eaef2f80f755933c374d2ae5edccceec0c1312ceb8a4e0b6404e8ab76561e1e5" "/opt/rustwide/cargo-home/bin/cargo" "+1.60.0" "test" "--frozen", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 5e7450bbd9545e030864aef464476e0cdfea9fb2f22bf0fca4b6b88f94307bdb [INFO] running `Command { std: "docker" "start" "-a" "5e7450bbd9545e030864aef464476e0cdfea9fb2f22bf0fca4b6b88f94307bdb", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> record_keeper/src/lib.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Datelike`, `Timelike` [INFO] [stderr] --> record_keeper/src/record.rs:3:24 [INFO] [stderr] | [INFO] [stderr] 3 | use chrono::{DateTime, Datelike, Timelike, Utc}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> record_keeper/src/error.rs:28:32 [INFO] [stderr] | [INFO] [stderr] 28 | fn cause(&self) -> Option<&Error> { [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 28 - fn cause(&self) -> Option<&Error> { [INFO] [stderr] 28 + fn cause(&self) -> Option<&dyn Error> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> record_keeper/src/error.rs:52:32 [INFO] [stderr] | [INFO] [stderr] 52 | fn cause(&self) -> Option<&Error> { [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 52 - fn cause(&self) -> Option<&Error> { [INFO] [stderr] 52 + fn cause(&self) -> Option<&dyn Error> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> record_keeper/src/lib.rs:171:21 [INFO] [stderr] | [INFO] [stderr] 171 | let mut v = self.task_names.get_mut(&name).unwrap(); [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: field is never read: `name` [INFO] [stderr] --> record_keeper/src/lib.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | name: String, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `get_name` [INFO] [stderr] --> record_keeper/src/lib.rs:29:8 [INFO] [stderr] | [INFO] [stderr] 29 | fn get_name(&self) -> &str { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `name` [INFO] [stderr] --> record_keeper/src/lib.rs:36:5 [INFO] [stderr] | [INFO] [stderr] 36 | name: String, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `get_name` [INFO] [stderr] --> record_keeper/src/lib.rs:46:8 [INFO] [stderr] | [INFO] [stderr] 46 | fn get_name(&self) -> &str { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `super::*` [INFO] [stderr] --> record_keeper/src/record.rs:18:9 [INFO] [stderr] | [INFO] [stderr] 18 | use super::*; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> record_keeper/src/tests.rs:100:9 [INFO] [stderr] | [INFO] [stderr] 100 | let mut rk = RecordKeeper::new(); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: function is never used: `validating_client_names_for_get` [INFO] [stderr] --> record_keeper/src/tests.rs:77:4 [INFO] [stderr] | [INFO] [stderr] 77 | fn validating_client_names_for_get() { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:28:5 [INFO] [stderr] | [INFO] [stderr] 28 | client.add_task(test_name.clone()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:40:5 [INFO] [stderr] | [INFO] [stderr] 40 | client.add_validated_task(bad_data); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:45:5 [INFO] [stderr] | [INFO] [stderr] 45 | client.add_task(String::from("Test Task")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:46:5 [INFO] [stderr] | [INFO] [stderr] 46 | client.add_task(String::from("Test Task 2")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:71:13 [INFO] [stderr] | [INFO] [stderr] 71 | rk.add_validated_client(data); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:84:5 [INFO] [stderr] | [INFO] [stderr] 84 | rk.add_client(test_name.clone()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:95:5 [INFO] [stderr] | [INFO] [stderr] 95 | rk.add_validated_client(bad_data); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:102:5 [INFO] [stderr] | [INFO] [stderr] 102 | rk.get_tasks_for_validated_client(bad_data); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:109:5 [INFO] [stderr] | [INFO] [stderr] 109 | rk.add_task_for_validated_client(bad_data, String::from("Test Task")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:115:5 [INFO] [stderr] | [INFO] [stderr] 115 | rk.add_client(String::from("Test Client")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:123:5 [INFO] [stderr] | [INFO] [stderr] 123 | rk.add_client(String::from("Test Client 2")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:124:5 [INFO] [stderr] | [INFO] [stderr] 124 | rk.add_client(String::from("Test Client")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:143:5 [INFO] [stderr] | [INFO] [stderr] 143 | rk.add_client(test_client.clone()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:144:5 [INFO] [stderr] | [INFO] [stderr] 144 | rk.add_client(String::from("Test Client 2")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:145:5 [INFO] [stderr] | [INFO] [stderr] 145 | rk.add_task(test_client.clone(), test_task.clone()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:151:5 [INFO] [stderr] | [INFO] [stderr] 151 | rk.add_task(String::from("Test Client 2"), test_task.clone()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:152:5 [INFO] [stderr] | [INFO] [stderr] 152 | rk.add_task(test_client.clone(), String::from("Test Task 2")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:160:5 [INFO] [stderr] | [INFO] [stderr] 160 | rk.add_client(String::from("Test Client")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:161:5 [INFO] [stderr] | [INFO] [stderr] 161 | rk.add_task(String::from("Test Client"), String::from("Test Task")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> record_keeper/src/tests.rs:162:5 [INFO] [stderr] | [INFO] [stderr] 162 | rk.add_task(String::from("Test Client"), String::from("Test Task 2")); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: `record_keeper` (lib) generated 9 warnings [INFO] [stderr] warning: `record_keeper` (lib test) generated 28 warnings (5 duplicates) [INFO] [stderr] warning: unused import: `Duration` [INFO] [stderr] --> cmd_interface/src/main.rs:2:17 [INFO] [stderr] | [INFO] [stderr] 2 | use std::time::{Duration, Instant}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `super::enums::*` [INFO] [stderr] --> cmd_interface/src/app/engine.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use super::enums::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `record_keeper::ErrorType` [INFO] [stderr] --> cmd_interface/src/app/engine.rs:9:5 [INFO] [stderr] | [INFO] [stderr] 9 | use record_keeper::ErrorType; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:13:15 [INFO] [stderr] | [INFO] [stderr] 13 | view: Box, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 13 - view: Box, [INFO] [stderr] 13 + view: Box, [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:15:17 [INFO] [stderr] | [INFO] [stderr] 15 | parser: Box, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 15 - parser: Box, [INFO] [stderr] 15 + parser: Box, [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:20:19 [INFO] [stderr] | [INFO] [stderr] 20 | view: Box, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 20 - view: Box, [INFO] [stderr] 20 + view: Box, [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:22:21 [INFO] [stderr] | [INFO] [stderr] 22 | parser: Box, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 22 - parser: Box, [INFO] [stderr] 22 + parser: Box, [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:132:46 [INFO] [stderr] | [INFO] [stderr] 132 | pub fn change_view(& mut self, view: Box) { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 132 - pub fn change_view(& mut self, view: Box) { [INFO] [stderr] 132 + pub fn change_view(& mut self, view: Box) { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:135:50 [INFO] [stderr] | [INFO] [stderr] 135 | pub fn change_parser(& mut self, parser: Box) { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 135 - pub fn change_parser(& mut self, parser: Box) { [INFO] [stderr] 135 + pub fn change_parser(& mut self, parser: Box) { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:119:13 [INFO] [stderr] | [INFO] [stderr] 119 | _ => panic!("State not recognized"), [INFO] [stderr] | ^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `rest_of_input` [INFO] [stderr] --> cmd_interface/src/app/parser.rs:138:26 [INFO] [stderr] | [INFO] [stderr] 138 | let (first_word, rest_of_input) = split_at_first_space(s); [INFO] [stderr] | ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rest_of_input` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `model` [INFO] [stderr] --> cmd_interface/src/app/parser.rs:137:33 [INFO] [stderr] | [INFO] [stderr] 137 | fn parse(&self, s: &String, model: &User) -> Command { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `model` [INFO] [stderr] --> cmd_interface/src/app/views/menu.rs:22:23 [INFO] [stderr] | [INFO] [stderr] 22 | fn display(&self, model: &User) { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `model` [INFO] [stderr] --> cmd_interface/src/app/views/menu.rs:34:23 [INFO] [stderr] | [INFO] [stderr] 34 | fn display(&self, model: &User) { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> cmd_interface/src/app/views/menu.rs:71:17 [INFO] [stderr] | [INFO] [stderr] 71 | Err(e) => panic!("TaskMenu was constructed with an invalid client."), [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `model` [INFO] [stderr] --> cmd_interface/src/app/views/menu.rs:97:23 [INFO] [stderr] | [INFO] [stderr] 97 | fn display(&self, model: &User) { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_model` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> cmd_interface/src/app/engine.rs:24:13 [INFO] [stderr] | [INFO] [stderr] 24 | let mut user = load_user(); [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: field is never read: `records` [INFO] [stderr] --> cmd_interface/src/app/parser.rs:128:5 [INFO] [stderr] | [INFO] [stderr] 128 | records: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `add_client` [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:140:12 [INFO] [stderr] | [INFO] [stderr] 140 | pub fn add_client(& mut self, name: String) -> Result<(), ErrorType> { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `get_client_names` [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:145:12 [INFO] [stderr] | [INFO] [stderr] 145 | pub fn get_client_names(&self) -> Vec<&String> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `get_owned_names` [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:148:12 [INFO] [stderr] | [INFO] [stderr] 148 | pub fn get_owned_names(&self) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `add_task` [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:153:12 [INFO] [stderr] | [INFO] [stderr] 153 | pub fn add_task(& mut self, client_name: String, task_name: String) [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `get_owned_tasks_for_client` [INFO] [stderr] --> cmd_interface/src/app/controllers/app_controller.rs:160:12 [INFO] [stderr] | [INFO] [stderr] 160 | pub fn get_owned_tasks_for_client(&self, client_name: String) [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `get_client_names` [INFO] [stderr] --> cmd_interface/src/app/models/user.rs:23:12 [INFO] [stderr] | [INFO] [stderr] 23 | pub fn get_client_names(&self) -> Vec<&String> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `get_owned_names` [INFO] [stderr] --> cmd_interface/src/app/models/user.rs:26:12 [INFO] [stderr] | [INFO] [stderr] 26 | pub fn get_owned_names(&self) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `get_owned_tasks_for_client` [INFO] [stderr] --> cmd_interface/src/app/models/user.rs:41:12 [INFO] [stderr] | [INFO] [stderr] 41 | pub fn get_owned_tasks_for_client(&self, client_name: String) [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `SplashPage` [INFO] [stderr] --> cmd_interface/src/app/enums/engine_enums.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | SplashPage, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> cmd_interface/src/app/engine.rs:59:5 [INFO] [stderr] | [INFO] [stderr] 59 | user.add_client("Client 1".to_string()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> cmd_interface/src/app/engine.rs:60:5 [INFO] [stderr] | [INFO] [stderr] 60 | user.add_task("Client 1".to_string(), "Task 1".to_string()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> cmd_interface/src/app/engine.rs:61:5 [INFO] [stderr] | [INFO] [stderr] 61 | user.add_task("Client 1".to_string(), "Task 2".to_string()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> cmd_interface/src/app/engine.rs:62:5 [INFO] [stderr] | [INFO] [stderr] 62 | user.add_client("Client 3".to_string()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> cmd_interface/src/app/engine.rs:63:5 [INFO] [stderr] | [INFO] [stderr] 63 | user.add_client("Client 2".to_string()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: `cmd_interface` (bin "cmd_interface" test) generated 32 warnings [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.03s [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/cmd_interface-a813f5c843659edd) [INFO] [stdout] [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/record_keeper-ed2c2d6015541651) [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 15 tests [INFO] [stdout] test record::tests::test_working ... ok [INFO] [stdout] test tests::add_clients ... ok [INFO] [stdout] test tests::add_task_to_client ... ok [INFO] [stdout] test tests::add_tasks ... ok [INFO] [stdout] test tests::get_client_tasks ... ok [INFO] [stdout] test tests::make_client ... ok [INFO] [stdout] test tests::make_task ... ok [INFO] [stdout] test tests::validating_client_names_for_add ... ok [INFO] [stdout] test tests::make_new_record_keeper ... ok [INFO] [stdout] test tests::get_client_names ... ok [INFO] [stdout] test tests::validating_task_names ... ok [INFO] [stdout] test tests::invalid_task_data - should panic ... ok [INFO] [stderr] Doc-tests record_keeper [INFO] [stdout] test tests::invalid_client_name_for_add - should panic ... ok [INFO] [stdout] test tests::invalid_client_name_for_add_tasks - should panic ... ok [INFO] [stdout] test tests::invalid_client_name_for_get_tasks - should panic ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 15 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.05s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "5e7450bbd9545e030864aef464476e0cdfea9fb2f22bf0fca4b6b88f94307bdb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5e7450bbd9545e030864aef464476e0cdfea9fb2f22bf0fca4b6b88f94307bdb", kill_on_drop: false }` [INFO] [stdout] 5e7450bbd9545e030864aef464476e0cdfea9fb2f22bf0fca4b6b88f94307bdb