[INFO] cloning repository https://github.com/dseisun/workouts
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/dseisun/workouts" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdseisun%2Fworkouts", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdseisun%2Fworkouts'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 33acfd6f910a582523199d67421205289a65d1a3
[INFO] building dseisun/workouts against master#c7f6aa2869acdbf014d094c6e427e554e160b6db for pr-146237-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdseisun%2Fworkouts" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/dseisun/workouts
[INFO] finished tweaking git repo https://github.com/dseisun/workouts
[INFO] tweaked toml for git repo https://github.com/dseisun/workouts written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/dseisun/workouts on toolchain c7f6aa2869acdbf014d094c6e427e554e160b6db
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c7f6aa2869acdbf014d094c6e427e554e160b6db" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/dseisun/workouts 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" "+c7f6aa2869acdbf014d094c6e427e554e160b6db" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded shlex v1.2.0
[INFO] [stderr]   Downloaded speech-dispatcher-sys v0.7.0
[INFO] [stderr]   Downloaded speech-dispatcher v0.16.0
[INFO] [stderr]   Downloaded which v4.4.0
[INFO] [stderr]   Downloaded thiserror v1.0.48
[INFO] [stderr]   Downloaded thiserror-impl v1.0.48
[INFO] [stderr]   Downloaded cocoa-foundation v0.1.1
[INFO] [stderr]   Downloaded dyn-clone v1.0.13
[INFO] [stderr]   Downloaded env_logger v0.10.0
[INFO] [stderr]   Downloaded clap v4.3.23
[INFO] [stderr]   Downloaded serde v1.0.185
[INFO] [stderr]   Downloaded indexmap v2.0.0
[INFO] [stderr]   Downloaded toml_edit v0.19.14
[INFO] [stderr]   Downloaded clap_builder v4.3.23
[INFO] [stderr]   Downloaded portable-atomic v1.4.3
[INFO] [stderr]   Downloaded hashbrown v0.14.0
[INFO] [stderr]   Downloaded aho-corasick v1.0.5
[INFO] [stderr]   Downloaded bindgen v0.66.1
[INFO] [stderr]   Downloaded prettyplease v0.2.12
[INFO] [stderr]   Downloaded indicatif v0.17.6
[INFO] [stderr]   Downloaded clang-sys v1.6.1
[INFO] [stderr]   Downloaded tts v0.25.5
[INFO] [stderr]   Downloaded serde_derive v1.0.185
[INFO] [stderr]   Downloaded oxilangtag v0.1.3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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" "+c7f6aa2869acdbf014d094c6e427e554e160b6db" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 88cb6df7f5137ff1f90cfcd9f2d49db4e447613cb5641a83b64194f365a7e4a7
[INFO] running `Command { std: "docker" "start" "-a" "88cb6df7f5137ff1f90cfcd9f2d49db4e447613cb5641a83b64194f365a7e4a7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "88cb6df7f5137ff1f90cfcd9f2d49db4e447613cb5641a83b64194f365a7e4a7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "88cb6df7f5137ff1f90cfcd9f2d49db4e447613cb5641a83b64194f365a7e4a7", kill_on_drop: false }`
[INFO] [stdout] 88cb6df7f5137ff1f90cfcd9f2d49db4e447613cb5641a83b64194f365a7e4a7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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" "-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" "+c7f6aa2869acdbf014d094c6e427e554e160b6db" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] bd30074914511d851b4aad696cb9b74730e82f366f1c736f858ed67b1a6be46d
[INFO] running `Command { std: "docker" "start" "-a" "bd30074914511d851b4aad696cb9b74730e82f366f1c736f858ed67b1a6be46d", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.66
[INFO] [stderr]    Compiling unicode-ident v1.0.11
[INFO] [stderr]    Compiling libc v0.2.147
[INFO] [stderr]    Compiling prettyplease v0.2.12
[INFO] [stderr]    Compiling regex-syntax v0.7.5
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling memchr v2.6.3
[INFO] [stderr]    Compiling rustix v0.38.8
[INFO] [stderr]    Compiling either v1.9.0
[INFO] [stderr]    Compiling bindgen v0.66.1
[INFO] [stderr]    Compiling bitflags v2.4.0
[INFO] [stderr]    Compiling peeking_take_while v0.1.2
[INFO] [stderr]    Compiling shlex v1.2.0
[INFO] [stderr]    Compiling clang-sys v1.6.1
[INFO] [stderr]    Compiling libloading v0.7.4
[INFO] [stderr]    Compiling linux-raw-sys v0.4.5
[INFO] [stderr]    Compiling log v0.4.20
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling lazycell v1.3.0
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling aho-corasick v1.0.5
[INFO] [stderr]    Compiling anstyle-parse v0.2.1
[INFO] [stderr]    Compiling anstyle-query v1.0.0
[INFO] [stderr]    Compiling serde v1.0.185
[INFO] [stderr]    Compiling anstyle v1.0.1
[INFO] [stderr]    Compiling thiserror v1.0.48
[INFO] [stderr]    Compiling colorchoice v1.0.0
[INFO] [stderr]    Compiling portable-atomic v1.4.3
[INFO] [stderr]    Compiling serde_json v1.0.105
[INFO] [stderr]    Compiling tts v0.25.5
[INFO] [stderr]    Compiling dyn-clone v1.0.13
[INFO] [stderr]    Compiling clap_lex v0.5.0
[INFO] [stderr]    Compiling unicode-width v0.1.10
[INFO] [stderr]    Compiling oxilangtag v0.1.3
[INFO] [stderr]    Compiling termcolor v1.2.0
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling number_prefix v0.4.0
[INFO] [stderr]    Compiling strfmt v0.2.4
[INFO] [stderr]    Compiling quote v1.0.32
[INFO] [stderr]    Compiling syn v2.0.28
[INFO] [stderr]    Compiling is-terminal v0.4.9
[INFO] [stderr]    Compiling which v4.4.0
[INFO] [stderr]    Compiling getrandom v0.2.10
[INFO] [stderr]    Compiling anstream v0.3.2
[INFO] [stderr]    Compiling console v0.15.7
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling clap_builder v4.3.23
[INFO] [stderr]    Compiling regex-automata v0.3.8
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling indicatif v0.17.6
[INFO] [stderr]    Compiling regex v1.9.5
[INFO] [stderr]    Compiling cexpr v0.6.0
[INFO] [stderr]    Compiling env_logger v0.10.0
[INFO] [stderr]    Compiling dyn-clonable-impl v0.9.0
[INFO] [stderr]    Compiling dyn-clonable v0.9.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.48
[INFO] [stderr]    Compiling serde_derive v1.0.185
[INFO] [stderr]    Compiling clap_derive v4.3.12
[INFO] [stderr]    Compiling clap v4.3.23
[INFO] [stderr]    Compiling speech-dispatcher-sys v0.7.0
[INFO] [stderr]    Compiling speech-dispatcher v0.16.0
[INFO] [stderr]    Compiling workout v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `crate::models::ConfigPath`
[INFO] [stdout]  --> src/args.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::ConfigPath;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `fs::File` and `io::BufReader`
[INFO] [stdout]  --> src/models.rs:1:11
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{io::BufReader, fs::File};
[INFO] [stdout]   |           ^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `unwrap_or_default_config` and `unwrap_or_default_exercises`
[INFO] [stdout]  --> src/models.rs:5:19
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::args::{unwrap_or_default_config, unwrap_or_default_exercises};
[INFO] [stdout]   |                   ^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ConfigPath`
[INFO] [stdout]  --> src/generate_workout.rs:1:101
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::{models::{load_exercises_from_json, load_config, CategoryConfig, Exercise, CategoryType, ConfigPath}, args::{GenerateParams, u...
[INFO] [stdout]   |                                                                                                     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `default` and `ops::Deref`
[INFO] [stdout]  --> src/generate_workout.rs:2:33
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::{collections::HashMap, ops::Deref, default};
[INFO] [stdout]   |                                 ^^^^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ProgressIterator`
[INFO] [stdout]  --> src/run_workout.rs:3:45
[INFO] [stdout]   |
[INFO] [stdout] 3 | use indicatif::{ProgressBar, ProgressStyle, ProgressIterator};
[INFO] [stdout]   |                                             ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ConfigPath`, `GenerateParams`, `NotImplSpeak`, `OSXSpeak`, `generate_workout`, `load_exercises_from_json`, and `unwrap_or_default_exercises`
[INFO] [stdout]  --> src/run_workout.rs:5:32
[INFO] [stdout]   |
[INFO] [stdout] 5 | ...e, ConfigPath, Side, load_exercises_from_json}, generate_workout, tts::{OSXSpeak, Speak, NotImplSpeak}, args::{GenerateParams, unwrap_or_default_exercises}};
[INFO] [stdout]   |       ^^^^^^^^^^        ^^^^^^^^^^^^^^^^^^^^^^^^   ^^^^^^^^^^^^^^^^        ^^^^^^^^         ^^^^^^^^^^^^          ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ConfigPath`
[INFO] [stdout]   --> src/main.rs:13:33
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::{args::Cli, models::{ConfigPath, load_exercises_from_json}, generate_workout::generate_workout};
[INFO] [stdout]    |                                 ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `text`
[INFO] [stdout]   --> src/tts.rs:27:19
[INFO] [stdout]    |
[INFO] [stdout] 27 |     fn tts(&self, text: &str) {
[INFO] [stdout]    |                   ^^^^ help: if this is intentional, prefix it with an underscore: `_text`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `unwrap_or_default` is never used
[INFO] [stdout]    --> src/models.rs:169:6
[INFO] [stdout]     |
[INFO] [stdout] 168 | impl WorkoutPath {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] 169 |   fn unwrap_or_default(self) -> String {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `category` is never read
[INFO] [stdout]  --> src/generate_workout.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct HydratedCategoryConfig<'a> {
[INFO] [stdout]   |            ---------------------- field in this struct
[INFO] [stdout] 7 |     category: &'a CategoryType,
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TestSpeak` is never constructed
[INFO] [stdout]   --> src/tts.rs:31:19
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub(crate) struct TestSpeak;
[INFO] [stdout]    |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 46.24s
[INFO] running `Command { std: "docker" "inspect" "bd30074914511d851b4aad696cb9b74730e82f366f1c736f858ed67b1a6be46d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "bd30074914511d851b4aad696cb9b74730e82f366f1c736f858ed67b1a6be46d", kill_on_drop: false }`
[INFO] [stdout] bd30074914511d851b4aad696cb9b74730e82f366f1c736f858ed67b1a6be46d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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" "-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" "+c7f6aa2869acdbf014d094c6e427e554e160b6db" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 22298d65f58724f4e2fc6e931d76d8ca723c377a554867bd1b1dfc3440ca0cca
[INFO] running `Command { std: "docker" "start" "-a" "22298d65f58724f4e2fc6e931d76d8ca723c377a554867bd1b1dfc3440ca0cca", kill_on_drop: false }`
[INFO] [stderr]    Compiling workout v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `crate::models::ConfigPath`
[INFO] [stdout]  --> src/args.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::ConfigPath;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `fs::File` and `io::BufReader`
[INFO] [stdout]  --> src/models.rs:1:11
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{io::BufReader, fs::File};
[INFO] [stdout]   |           ^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ConfigPath`
[INFO] [stdout]  --> src/generate_workout.rs:1:101
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::{models::{load_exercises_from_json, load_config, CategoryConfig, Exercise, CategoryType, ConfigPath}, args::{GenerateParams, u...
[INFO] [stdout]   |                                                                                                     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `default` and `ops::Deref`
[INFO] [stdout]  --> src/generate_workout.rs:2:33
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::{collections::HashMap, ops::Deref, default};
[INFO] [stdout]   |                                 ^^^^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ProgressIterator`
[INFO] [stdout]  --> src/run_workout.rs:3:45
[INFO] [stdout]   |
[INFO] [stdout] 3 | use indicatif::{ProgressBar, ProgressStyle, ProgressIterator};
[INFO] [stdout]   |                                             ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ConfigPath`, `NotImplSpeak`, and `OSXSpeak`
[INFO] [stdout]  --> src/run_workout.rs:5:32
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::{models::{Exercise, ConfigPath, Side, load_exercises_from_json}, generate_workout, tts::{OSXSpeak, Speak, NotImplSpeak}, args:...
[INFO] [stdout]   |                                ^^^^^^^^^^                                                           ^^^^^^^^         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ConfigPath`
[INFO] [stdout]   --> src/main.rs:13:33
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::{args::Cli, models::{ConfigPath, load_exercises_from_json}, generate_workout::generate_workout};
[INFO] [stdout]    |                                 ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cli`
[INFO] [stdout]   --> src/args.rs:50:9
[INFO] [stdout]    |
[INFO] [stdout] 50 |     let cli = Cli::parse_from(cmd_opts);
[INFO] [stdout]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_cli`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cli`
[INFO] [stdout]   --> src/args.rs:56:9
[INFO] [stdout]    |
[INFO] [stdout] 56 |     let cli = Cli::parse_from(cmd_opts);
[INFO] [stdout]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_cli`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/models.rs:132:11
[INFO] [stdout]     |
[INFO] [stdout] 132 |       let t: Config = serde_json::from_str(&data).unwrap();
[INFO] [stdout]     |           ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `workout`
[INFO] [stdout]   --> src/generate_workout.rs:56:9
[INFO] [stdout]    |
[INFO] [stdout] 56 |     let workout = generate_workout(GenerateParams {minutes: 1000, config_path: None, exercises_path: None});
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_workout`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `text`
[INFO] [stdout]   --> src/tts.rs:27:19
[INFO] [stdout]    |
[INFO] [stdout] 27 |     fn tts(&self, text: &str) {
[INFO] [stdout]    |                   ^^^^ help: if this is intentional, prefix it with an underscore: `_text`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `unwrap_or_default` is never used
[INFO] [stdout]    --> src/models.rs:169:6
[INFO] [stdout]     |
[INFO] [stdout] 168 | impl WorkoutPath {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] 169 |   fn unwrap_or_default(self) -> String {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `write_to_shell` is never used
[INFO] [stdout]  --> src/tts.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub(crate) trait Speak {
[INFO] [stdout]   |                  ----- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 6 |     fn write_to_shell(&self, output: &Output) {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `OSXSpeak` is never constructed
[INFO] [stdout]   --> src/tts.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct OSXSpeak;
[INFO] [stdout]    |                   ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NotImplSpeak` is never constructed
[INFO] [stdout]   --> src/tts.rs:25:19
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub(crate) struct NotImplSpeak;
[INFO] [stdout]    |                   ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 2.05s
[INFO] running `Command { std: "docker" "inspect" "22298d65f58724f4e2fc6e931d76d8ca723c377a554867bd1b1dfc3440ca0cca", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "22298d65f58724f4e2fc6e931d76d8ca723c377a554867bd1b1dfc3440ca0cca", kill_on_drop: false }`
[INFO] [stdout] 22298d65f58724f4e2fc6e931d76d8ca723c377a554867bd1b1dfc3440ca0cca
