[INFO] cloning repository https://github.com/CMU-Blockchain-Group/rust-workshop-0
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/CMU-Blockchain-Group/rust-workshop-0" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FCMU-Blockchain-Group%2Frust-workshop-0", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FCMU-Blockchain-Group%2Frust-workshop-0'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 88e8e82df47bb6e2955ab850f906248baad9c8fe
[INFO] building CMU-Blockchain-Group/rust-workshop-0 against master#ad211ced81509462cdfe4c29ed10f97279a0acae for pr-135216
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FCMU-Blockchain-Group%2Frust-workshop-0" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/CMU-Blockchain-Group/rust-workshop-0 on toolchain ad211ced81509462cdfe4c29ed10f97279a0acae
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ad211ced81509462cdfe4c29ed10f97279a0acae" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/CMU-Blockchain-Group/rust-workshop-0
[INFO] finished tweaking git repo https://github.com/CMU-Blockchain-Group/rust-workshop-0
[INFO] tweaked toml for git repo https://github.com/CMU-Blockchain-Group/rust-workshop-0 written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] crate git repo https://github.com/CMU-Blockchain-Group/rust-workshop-0 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" "+ad211ced81509462cdfe4c29ed10f97279a0acae" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:f3a9d4ad9d972b27faf3965f35b62e55ba32bbce8f20bc8fe909558a86702fde" "/opt/rustwide/cargo-home/bin/cargo" "+ad211ced81509462cdfe4c29ed10f97279a0acae" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 27d726fe73f9fcd2a28af930d6342b7dbd1649a65ac13d08a11c384187e4c40b
[INFO] running `Command { std: "docker" "start" "-a" "27d726fe73f9fcd2a28af930d6342b7dbd1649a65ac13d08a11c384187e4c40b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "27d726fe73f9fcd2a28af930d6342b7dbd1649a65ac13d08a11c384187e4c40b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "27d726fe73f9fcd2a28af930d6342b7dbd1649a65ac13d08a11c384187e4c40b", kill_on_drop: false }`
[INFO] [stdout] 27d726fe73f9fcd2a28af930d6342b7dbd1649a65ac13d08a11c384187e4c40b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:f3a9d4ad9d972b27faf3965f35b62e55ba32bbce8f20bc8fe909558a86702fde" "/opt/rustwide/cargo-home/bin/cargo" "+ad211ced81509462cdfe4c29ed10f97279a0acae" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 20abe711f8f86ba8899e0991cd7f2548a71379efe078d31e4c6d0dd977850507
[INFO] running `Command { std: "docker" "start" "-a" "20abe711f8f86ba8899e0991cd7f2548a71379efe078d31e4c6d0dd977850507", kill_on_drop: false }`
[INFO] [stderr]    Compiling rust-workshop-0 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]  --> src/exercises.rs:3:18
[INFO] [stdout]   |
[INFO] [stdout] 3 | fn swap_two_ints(a: &mut i32, b: &mut i32) {
[INFO] [stdout]   |                  ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]  --> src/exercises.rs:3:31
[INFO] [stdout]   |
[INFO] [stdout] 3 | fn swap_two_ints(a: &mut i32, b: &mut i32) {
[INFO] [stdout]   |                               ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> src/exercises.rs:14:18
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn rect_overlaps(a: &Rectangle, b: &Rectangle) -> bool {
[INFO] [stdout]    |                  ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]   --> src/exercises.rs:14:33
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn rect_overlaps(a: &Rectangle, b: &Rectangle) -> bool {
[INFO] [stdout]    |                                 ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `play`
[INFO] [stdout]   --> src/exercises.rs:27:17
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn rps_weakness(play: RockPaperScissors) -> RockPaperScissors {
[INFO] [stdout]    |                 ^^^^ help: if this is intentional, prefix it with an underscore: `_play`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> src/exercises.rs:34:16
[INFO] [stdout]    |
[INFO] [stdout] 34 | fn dot_product(a: &[i32], b: &[i32]) -> i32 {
[INFO] [stdout]    |                ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]   --> src/exercises.rs:34:27
[INFO] [stdout]    |
[INFO] [stdout] 34 | fn dot_product(a: &[i32], b: &[i32]) -> i32 {
[INFO] [stdout]    |                           ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]   --> src/exercises.rs:40:16
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn first_n_fib(n: usize) -> Vec<u32> {
[INFO] [stdout]    |                ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> src/exercises.rs:48:28
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn recursive_binary_search(a: &[i32]) -> Option<usize> {
[INFO] [stdout]    |                            ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `strs`
[INFO] [stdout]   --> src/exercises.rs:55:28
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn flatten_slice_of_slices(strs: &[&[&str]]) -> String {
[INFO] [stdout]    |                            ^^^^ help: if this is intentional, prefix it with an underscore: `_strs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `buf`
[INFO] [stdout]   --> src/main.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 |     let buf = string_to_mine.as_bytes();
[INFO] [stdout]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_buf`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DIFFICULTY` is never used
[INFO] [stdout]  --> src/main.rs:4:7
[INFO] [stdout]   |
[INFO] [stdout] 4 | const DIFFICULTY: usize = 4;
[INFO] [stdout]   |       ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `swap_two_ints` is never used
[INFO] [stdout]  --> src/exercises.rs:3:4
[INFO] [stdout]   |
[INFO] [stdout] 3 | fn swap_two_ints(a: &mut i32, b: &mut i32) {
[INFO] [stdout]   |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Rectangle` is never constructed
[INFO] [stdout]  --> src/exercises.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | struct Rectangle {
[INFO] [stdout]   |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `rect_overlaps` is never used
[INFO] [stdout]   --> src/exercises.rs:14:4
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn rect_overlaps(a: &Rectangle, b: &Rectangle) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `RockPaperScissors` is never used
[INFO] [stdout]   --> src/exercises.rs:19:6
[INFO] [stdout]    |
[INFO] [stdout] 19 | enum RockPaperScissors {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `rps_weakness` is never used
[INFO] [stdout]   --> src/exercises.rs:27:4
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn rps_weakness(play: RockPaperScissors) -> RockPaperScissors {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dot_product` is never used
[INFO] [stdout]   --> src/exercises.rs:34:4
[INFO] [stdout]    |
[INFO] [stdout] 34 | fn dot_product(a: &[i32], b: &[i32]) -> i32 {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `first_n_fib` is never used
[INFO] [stdout]   --> src/exercises.rs:40:4
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn first_n_fib(n: usize) -> Vec<u32> {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `recursive_binary_search` is never used
[INFO] [stdout]   --> src/exercises.rs:48:4
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn recursive_binary_search(a: &[i32]) -> Option<usize> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `flatten_slice_of_slices` is never used
[INFO] [stdout]   --> src/exercises.rs:55:4
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn flatten_slice_of_slices(strs: &[&[&str]]) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 0.38s
[INFO] running `Command { std: "docker" "inspect" "20abe711f8f86ba8899e0991cd7f2548a71379efe078d31e4c6d0dd977850507", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "20abe711f8f86ba8899e0991cd7f2548a71379efe078d31e4c6d0dd977850507", kill_on_drop: false }`
[INFO] [stdout] 20abe711f8f86ba8899e0991cd7f2548a71379efe078d31e4c6d0dd977850507
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:f3a9d4ad9d972b27faf3965f35b62e55ba32bbce8f20bc8fe909558a86702fde" "/opt/rustwide/cargo-home/bin/cargo" "+ad211ced81509462cdfe4c29ed10f97279a0acae" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 756c5d3d95e55c26aa1f16aff2ca6f9fda12588ce609cea334d74b5a3d8ff31b
[INFO] running `Command { std: "docker" "start" "-a" "756c5d3d95e55c26aa1f16aff2ca6f9fda12588ce609cea334d74b5a3d8ff31b", kill_on_drop: false }`
[INFO] [stderr]    Compiling rust-workshop-0 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]  --> src/exercises.rs:3:18
[INFO] [stdout]   |
[INFO] [stdout] 3 | fn swap_two_ints(a: &mut i32, b: &mut i32) {
[INFO] [stdout]   |                  ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]  --> src/exercises.rs:3:31
[INFO] [stdout]   |
[INFO] [stdout] 3 | fn swap_two_ints(a: &mut i32, b: &mut i32) {
[INFO] [stdout]   |                               ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> src/exercises.rs:14:18
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn rect_overlaps(a: &Rectangle, b: &Rectangle) -> bool {
[INFO] [stdout]    |                  ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]   --> src/exercises.rs:14:33
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn rect_overlaps(a: &Rectangle, b: &Rectangle) -> bool {
[INFO] [stdout]    |                                 ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `play`
[INFO] [stdout]   --> src/exercises.rs:27:17
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn rps_weakness(play: RockPaperScissors) -> RockPaperScissors {
[INFO] [stdout]    |                 ^^^^ help: if this is intentional, prefix it with an underscore: `_play`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> src/exercises.rs:34:16
[INFO] [stdout]    |
[INFO] [stdout] 34 | fn dot_product(a: &[i32], b: &[i32]) -> i32 {
[INFO] [stdout]    |                ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]   --> src/exercises.rs:34:27
[INFO] [stdout]    |
[INFO] [stdout] 34 | fn dot_product(a: &[i32], b: &[i32]) -> i32 {
[INFO] [stdout]    |                           ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]   --> src/exercises.rs:40:16
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn first_n_fib(n: usize) -> Vec<u32> {
[INFO] [stdout]    |                ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> src/exercises.rs:48:28
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn recursive_binary_search(a: &[i32]) -> Option<usize> {
[INFO] [stdout]    |                            ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `strs`
[INFO] [stdout]   --> src/exercises.rs:55:28
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn flatten_slice_of_slices(strs: &[&[&str]]) -> String {
[INFO] [stdout]    |                            ^^^^ help: if this is intentional, prefix it with an underscore: `_strs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `buf`
[INFO] [stdout]   --> src/main.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 |     let buf = string_to_mine.as_bytes();
[INFO] [stdout]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_buf`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DIFFICULTY` is never used
[INFO] [stdout]  --> src/main.rs:4:7
[INFO] [stdout]   |
[INFO] [stdout] 4 | const DIFFICULTY: usize = 4;
[INFO] [stdout]   |       ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Rectangle` is never constructed
[INFO] [stdout]  --> src/exercises.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | struct Rectangle {
[INFO] [stdout]   |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `rect_overlaps` is never used
[INFO] [stdout]   --> src/exercises.rs:14:4
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn rect_overlaps(a: &Rectangle, b: &Rectangle) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `RockPaperScissors` is never used
[INFO] [stdout]   --> src/exercises.rs:19:6
[INFO] [stdout]    |
[INFO] [stdout] 19 | enum RockPaperScissors {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `rps_weakness` is never used
[INFO] [stdout]   --> src/exercises.rs:27:4
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn rps_weakness(play: RockPaperScissors) -> RockPaperScissors {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dot_product` is never used
[INFO] [stdout]   --> src/exercises.rs:34:4
[INFO] [stdout]    |
[INFO] [stdout] 34 | fn dot_product(a: &[i32], b: &[i32]) -> i32 {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `first_n_fib` is never used
[INFO] [stdout]   --> src/exercises.rs:40:4
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn first_n_fib(n: usize) -> Vec<u32> {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `recursive_binary_search` is never used
[INFO] [stdout]   --> src/exercises.rs:48:4
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn recursive_binary_search(a: &[i32]) -> Option<usize> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `flatten_slice_of_slices` is never used
[INFO] [stdout]   --> src/exercises.rs:55:4
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn flatten_slice_of_slices(strs: &[&[&str]]) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.25s
[INFO] running `Command { std: "docker" "inspect" "756c5d3d95e55c26aa1f16aff2ca6f9fda12588ce609cea334d74b5a3d8ff31b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "756c5d3d95e55c26aa1f16aff2ca6f9fda12588ce609cea334d74b5a3d8ff31b", kill_on_drop: false }`
[INFO] [stdout] 756c5d3d95e55c26aa1f16aff2ca6f9fda12588ce609cea334d74b5a3d8ff31b
