[INFO] cloning repository https://github.com/kcculhwch/lovett
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/kcculhwch/lovett" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkcculhwch%2Flovett", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkcculhwch%2Flovett'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 4f3158a78001588a6f14e10286c6e9892604810d
[INFO] testing kcculhwch/lovett against master#2fd6efc32704647e64d3d646d21c4c68eae100e4 for pr-149852-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkcculhwch%2Flovett" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/kcculhwch/lovett
[INFO] finished tweaking git repo https://github.com/kcculhwch/lovett
[INFO] tweaked toml for git repo https://github.com/kcculhwch/lovett written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/kcculhwch/lovett on toolchain 2fd6efc32704647e64d3d646d21c4c68eae100e4
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/kcculhwch/lovett 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" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded num-iter v0.1.41
[INFO] [stderr]   Downloaded tiff v0.5.0
[INFO] [stderr]   Downloaded uuid v0.8.1
[INFO] [stderr]   Downloaded num-rational v0.3.0
[INFO] [stderr]   Downloaded hermit-abi v0.1.16
[INFO] [stderr]   Downloaded ab_glyph v0.2.5
[INFO] [stderr]   Downloaded glyph_brush_draw_cache v0.1.3
[INFO] [stderr]   Downloaded const_fn v0.4.2
[INFO] [stderr]   Downloaded ab_glyph_rasterizer v0.1.3
[INFO] [stderr]   Downloaded bincode v1.3.1
[INFO] [stderr]   Downloaded glyph_brush_layout v0.2.0
[INFO] [stderr]   Downloaded crossbeam-epoch v0.9.0
[INFO] [stderr]   Downloaded crossbeam-utils v0.8.0
[INFO] [stderr]   Downloaded owned_ttf_parser v0.8.0
[INFO] [stderr]   Downloaded framebuffer v0.2.0
[INFO] [stderr]   Downloaded rayon-core v1.8.1
[INFO] [stderr]   Downloaded ttf-parser v0.8.2
[INFO] [stderr]   Downloaded crossbeam-channel v0.5.0
[INFO] [stderr]   Downloaded rayon v1.4.0
[INFO] [stderr]   Downloaded xi-unicode v0.2.1
[INFO] [stderr]   Downloaded rppal v0.11.3
[INFO] [stderr]   Downloaded jpeg-decoder v0.1.20
[INFO] [stderr]   Downloaded syn v1.0.41
[INFO] [stderr]   Downloaded image v0.23.9
[INFO] [stderr]   Downloaded linked-hash-map v0.5.3
[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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] aef492cabd8b59674c03603ef80128df490d94b66127400a95c66a370cf5ba66
[INFO] running `Command { std: "docker" "start" "-a" "aef492cabd8b59674c03603ef80128df490d94b66127400a95c66a370cf5ba66", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "aef492cabd8b59674c03603ef80128df490d94b66127400a95c66a370cf5ba66", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "aef492cabd8b59674c03603ef80128df490d94b66127400a95c66a370cf5ba66", kill_on_drop: false }`
[INFO] [stdout] aef492cabd8b59674c03603ef80128df490d94b66127400a95c66a370cf5ba66
[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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] bdd6db1819ad58d43219ccfd030d5ec800b8a82b2e64155584e2a102e2642dce
[INFO] running `Command { std: "docker" "start" "-a" "bdd6db1819ad58d43219ccfd030d5ec800b8a82b2e64155584e2a102e2642dce", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.77
[INFO] [stderr]    Compiling memoffset v0.5.6
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling maybe-uninit v2.0.0
[INFO] [stderr]    Compiling num-traits v0.2.12
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]    Compiling byteorder v1.3.4
[INFO] [stderr]    Compiling const_fn v0.4.2
[INFO] [stderr]    Compiling proc-macro2 v1.0.21
[INFO] [stderr]    Compiling rayon-core v1.8.1
[INFO] [stderr]    Compiling crossbeam-utils v0.8.0
[INFO] [stderr]    Compiling num-integer v0.1.43
[INFO] [stderr]    Compiling getrandom v0.1.15
[INFO] [stderr]    Compiling unicode-xid v0.2.1
[INFO] [stderr]    Compiling rayon v1.4.0
[INFO] [stderr]    Compiling adler32 v1.2.0
[INFO] [stderr]    Compiling syn v1.0.41
[INFO] [stderr]    Compiling ttf-parser v0.8.2
[INFO] [stderr]    Compiling either v1.6.1
[INFO] [stderr]    Compiling serde_derive v1.0.116
[INFO] [stderr]    Compiling miniz_oxide v0.3.7
[INFO] [stderr]    Compiling num-iter v0.1.41
[INFO] [stderr]    Compiling num-rational v0.3.0
[INFO] [stderr]    Compiling ab_glyph_rasterizer v0.1.3
[INFO] [stderr]    Compiling serde v1.0.116
[INFO] [stderr]    Compiling lzw v0.10.0
[INFO] [stderr]    Compiling ppv-lite86 v0.2.9
[INFO] [stderr]    Compiling color_quant v1.0.1
[INFO] [stderr]    Compiling log v0.4.11
[INFO] [stderr]    Compiling gif v0.10.3
[INFO] [stderr]    Compiling xi-unicode v0.2.1
[INFO] [stderr]    Compiling bytemuck v1.4.1
[INFO] [stderr]    Compiling linked-hash-map v0.5.3
[INFO] [stderr]    Compiling deflate v0.8.6
[INFO] [stderr]    Compiling scoped_threadpool v0.1.9
[INFO] [stderr]    Compiling tiff v0.5.0
[INFO] [stderr]    Compiling quote v1.0.7
[INFO] [stderr]    Compiling png v0.16.7
[INFO] [stderr]    Compiling crossbeam-channel v0.4.4
[INFO] [stderr]    Compiling num_cpus v1.13.0
[INFO] [stderr]    Compiling crossbeam-deque v0.7.3
[INFO] [stderr]    Compiling time v0.1.44
[INFO] [stderr]    Compiling memmap v0.7.0
[INFO] [stderr]    Compiling rppal v0.11.3
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.0
[INFO] [stderr]    Compiling crossbeam-channel v0.5.0
[INFO] [stderr]    Compiling approx v0.3.2
[INFO] [stderr]    Compiling framebuffer v0.2.0
[INFO] [stderr]    Compiling rand_core v0.5.1
[INFO] [stderr]    Compiling crossbeam-deque v0.8.0
[INFO] [stderr]    Compiling owned_ttf_parser v0.8.0
[INFO] [stderr]    Compiling rand_chacha v0.2.2
[INFO] [stderr]    Compiling ab_glyph v0.2.5
[INFO] [stderr]    Compiling chrono v0.4.15
[INFO] [stderr]    Compiling rand v0.7.3
[INFO] [stderr]    Compiling glyph_brush_layout v0.2.0
[INFO] [stderr]    Compiling uuid v0.8.1
[INFO] [stderr]    Compiling jpeg-decoder v0.1.20
[INFO] [stderr]    Compiling glyph_brush_draw_cache v0.1.3
[INFO] [stderr]    Compiling image v0.23.9
[INFO] [stderr]    Compiling bincode v1.3.1
[INFO] [stderr]    Compiling lovett v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around match arm expression
[INFO] [stdout]    --> src/window_viewer/mod.rs:132:23
[INFO] [stdout]     |
[INFO] [stdout] 132 |             Err(_) => (false)
[INFO] [stdout]     |                       ^     ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 132 -             Err(_) => (false)
[INFO] [stdout] 132 +             Err(_) => false 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 19.12s
[INFO] running `Command { std: "docker" "inspect" "bdd6db1819ad58d43219ccfd030d5ec800b8a82b2e64155584e2a102e2642dce", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "bdd6db1819ad58d43219ccfd030d5ec800b8a82b2e64155584e2a102e2642dce", kill_on_drop: false }`
[INFO] [stdout] bdd6db1819ad58d43219ccfd030d5ec800b8a82b2e64155584e2a102e2642dce
[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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6730df5c0dc7d5e31f015cc63d3ff049f64a2842d3f0e4b1ecc8c414aec6e46d
[INFO] running `Command { std: "docker" "start" "-a" "6730df5c0dc7d5e31f015cc63d3ff049f64a2842d3f0e4b1ecc8c414aec6e46d", kill_on_drop: false }`
[INFO] [stderr]    Compiling lovett v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around match arm expression
[INFO] [stdout]    --> src/window_viewer/mod.rs:132:23
[INFO] [stdout]     |
[INFO] [stdout] 132 |             Err(_) => (false)
[INFO] [stdout]     |                       ^     ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 132 -             Err(_) => (false)
[INFO] [stdout] 132 +             Err(_) => false 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around match arm expression
[INFO] [stdout]    --> src/window_viewer/mod.rs:132:23
[INFO] [stdout]     |
[INFO] [stdout] 132 |             Err(_) => (false)
[INFO] [stdout]     |                       ^     ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 132 -             Err(_) => (false)
[INFO] [stdout] 132 +             Err(_) => false 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.13s
[INFO] running `Command { std: "docker" "inspect" "6730df5c0dc7d5e31f015cc63d3ff049f64a2842d3f0e4b1ecc8c414aec6e46d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6730df5c0dc7d5e31f015cc63d3ff049f64a2842d3f0e4b1ecc8c414aec6e46d", kill_on_drop: false }`
[INFO] [stdout] 6730df5c0dc7d5e31f015cc63d3ff049f64a2842d3f0e4b1ecc8c414aec6e46d
[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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+2fd6efc32704647e64d3d646d21c4c68eae100e4" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] a96a5b1a3f2f1bc2435bc1e5532960dc370623db8abb1b2a28d2c53e99e74d87
[INFO] running `Command { std: "docker" "start" "-a" "a96a5b1a3f2f1bc2435bc1e5532960dc370623db8abb1b2a28d2c53e99e74d87", kill_on_drop: false }`
[INFO] [stderr] warning: unnecessary parentheses around match arm expression
[INFO] [stderr]    --> src/window_viewer/mod.rs:132:23
[INFO] [stderr]     |
[INFO] [stderr] 132 |             Err(_) => (false)
[INFO] [stderr]     |                       ^     ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 132 -             Err(_) => (false)
[INFO] [stderr] 132 +             Err(_) => false 
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: `lovett` (lib) generated 1 warning (run `cargo fix --lib -p lovett` to apply 1 suggestion)
[INFO] [stderr] warning: `lovett` (lib test) generated 1 warning (1 duplicate)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.22s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/lovett-3d79b552b23b3487)
[INFO] [stderr]    Doc-tests lovett
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr] warning: unnecessary parentheses around match arm expression
[INFO] [stderr]    --> src/window_viewer/mod.rs:132:23
[INFO] [stderr]     |
[INFO] [stderr] 132 |             Err(_) => (false)
[INFO] [stderr]     |                       ^     ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 132 -             Err(_) => (false)
[INFO] [stderr] 132 +             Err(_) => false 
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: 1 warning emitted
[INFO] [stderr] 
[INFO] [stdout] 
[INFO] [stdout] running 7 tests
[INFO] [stdout] test src/lib.rs - (line 93) ... FAILED
[INFO] [stdout] test src/lib.rs - (line 49) ... FAILED
[INFO] [stdout] test src/lib.rs - (line 83) ... FAILED
[INFO] [stdout] test src/lib.rs - (line 117) ... FAILED
[INFO] [stdout] test src/lib.rs - (line 147) ... FAILED
[INFO] [stdout] test src/lib.rs - (line 171) ... FAILED
[INFO] [stdout] test src/lib.rs - (line 73) ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/lib.rs - (line 93) stdout ----
[INFO] [stdout] error[E0425]: cannot find type `App` in this scope
[INFO] [stdout]   --> src/lib.rs:94:21
[INFO] [stdout]    |
[INFO] [stdout] 94 | pub fn run_app(app: App) {
[INFO] [stdout]    |                     ^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `run_view` in this scope
[INFO] [stdout]   --> src/lib.rs:95:5
[INFO] [stdout]    |
[INFO] [stdout] 95 |     run_view(app.window_viewer);
[INFO] [stdout]    |     ^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `run_state` in this scope
[INFO] [stdout]   --> src/lib.rs:96:5
[INFO] [stdout]    |
[INFO] [stdout] 96 |     run_state(app.store);
[INFO] [stdout]    |     ^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `run_controller` in this scope
[INFO] [stdout]   --> src/lib.rs:98:5
[INFO] [stdout]    |
[INFO] [stdout] 98 |     run_controller(app.model_scheduler).join().expect("Couldn't join on the associated thread");
[INFO] [stdout]    |     ^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 4 previous errors
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0425`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 49) stdout ----
[INFO] [stdout] error[E0583]: file not found for module `app`
[INFO] [stdout]   --> src/lib.rs:57:1
[INFO] [stdout]    |
[INFO] [stdout] 57 | mod app;                  // the app module which we will outline below
[INFO] [stdout]    | ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: to create the module `app`, create file "src/app.rs" or "src/app/mod.rs"
[INFO] [stdout]    = note: if there is a `mod app` elsewhere in the crate already, import it with `use crate::...` instead
[INFO] [stdout] 
[INFO] [stdout] error[E0463]: can't find crate for `env_logger`
[INFO] [stdout]   --> src/lib.rs:55:1
[INFO] [stdout]    |
[INFO] [stdout] 55 | extern crate env_logger;
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^ can't find crate
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `App`
[INFO] [stdout]   --> src/lib.rs:63:15
[INFO] [stdout]    |
[INFO] [stdout] 63 |     let app = App::new(); // construct the app
[INFO] [stdout]    |               ^^^ use of undeclared type `App`
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `run_app` in this scope
[INFO] [stdout]   --> src/lib.rs:64:5
[INFO] [stdout]    |
[INFO] [stdout] 64 |     run_app(app);         // spin up the app threads
[INFO] [stdout]    |     ^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 4 previous errors
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0425, E0433, E0463, E0583.
[INFO] [stdout] For more information about an error, try `rustc --explain E0425`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 83) stdout ----
[INFO] [stdout] error: unexpected token: `...`
[INFO] [stdout]   --> src/lib.rs:87:5
[INFO] [stdout]    |
[INFO] [stdout] 87 |     ...
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout] help: use `..` for an exclusive range
[INFO] [stdout]    |
[INFO] [stdout] 87 -     ...
[INFO] [stdout] 87 +     ..
[INFO] [stdout]    |
[INFO] [stdout] help: or `..=` for an inclusive range
[INFO] [stdout]    |
[INFO] [stdout] 87 -     ...
[INFO] [stdout] 87 +     ..=
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0586]: inclusive range with no end
[INFO] [stdout]   --> src/lib.rs:87:5
[INFO] [stdout]    |
[INFO] [stdout] 87 |     ...
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: inclusive ranges must be bounded at the end (`..=b` or `a..=b`)
[INFO] [stdout] help: use `..` instead
[INFO] [stdout]    |
[INFO] [stdout] 87 -     ...
[INFO] [stdout] 87 +     ..
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find type `App` in this scope
[INFO] [stdout]   --> src/lib.rs:84:6
[INFO] [stdout]    |
[INFO] [stdout] 84 | impl App {
[INFO] [stdout]    |      ^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find type `App` in this scope
[INFO] [stdout]   --> src/lib.rs:86:21
[INFO] [stdout]    |
[INFO] [stdout] 86 |     pub fn new() -> App{
[INFO] [stdout]    |                     ^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 4 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0425, E0586.
[INFO] [stdout] For more information about an error, try `rustc --explain E0425`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 117) stdout ----
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `ButtonInitializer` in this scope
[INFO] [stdout]    --> src/lib.rs:120:13
[INFO] [stdout]     |
[INFO] [stdout] 120 |             ButtonInitializer {pin: 5, code: 0, key: "b"}, 
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 117 + use lovett::hid::ButtonInitializer;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `ButtonInitializer` in this scope
[INFO] [stdout]    --> src/lib.rs:121:13
[INFO] [stdout]     |
[INFO] [stdout] 121 |             ButtonInitializer {pin: 6, code: 1, key: "a"},
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 117 + use lovett::hid::ButtonInitializer;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `ButtonInitializer` in this scope
[INFO] [stdout]    --> src/lib.rs:122:13
[INFO] [stdout]     |
[INFO] [stdout] 122 |             ButtonInitializer {pin: 27, code: 2, key: "l"},
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 117 + use lovett::hid::ButtonInitializer;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `ButtonInitializer` in this scope
[INFO] [stdout]    --> src/lib.rs:123:13
[INFO] [stdout]     |
[INFO] [stdout] 123 |             ButtonInitializer {pin: 23, code: 3, key: "r"},
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 117 + use lovett::hid::ButtonInitializer;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `ButtonInitializer` in this scope
[INFO] [stdout]    --> src/lib.rs:124:13
[INFO] [stdout]     |
[INFO] [stdout] 124 |             ButtonInitializer {pin: 17, code: 4, key: "up"},
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 117 + use lovett::hid::ButtonInitializer;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `ButtonInitializer` in this scope
[INFO] [stdout]    --> src/lib.rs:125:13
[INFO] [stdout]     |
[INFO] [stdout] 125 |             ButtonInitializer {pin: 22, code: 5, key: "dn"},
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 117 + use lovett::hid::ButtonInitializer;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `ButtonInitializer` in this scope
[INFO] [stdout]    --> src/lib.rs:126:13
[INFO] [stdout]     |
[INFO] [stdout] 126 |             ButtonInitializer {pin: 4, code:  6, key: "hat"},
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 117 + use lovett::hid::ButtonInitializer;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `mpsc`
[INFO] [stdout]    --> src/lib.rs:131:36
[INFO] [stdout]     |
[INFO] [stdout] 131 |         let (input_tx, input_rx) = mpsc::channel();
[INFO] [stdout]     |                                    ^^^^ use of unresolved module or unlinked crate `mpsc`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `mpsc`, use `cargo add mpsc` to add it to your `Cargo.toml`
[INFO] [stdout] help: consider importing this module
[INFO] [stdout]     |
[INFO] [stdout] 117 + use std::sync::mpsc;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `ButtonPad`
[INFO] [stdout]    --> src/lib.rs:135:33
[INFO] [stdout]     |
[INFO] [stdout] 135 |         let button_pad =  match ButtonPad::new(&button_initializers, input_tx) {
[INFO] [stdout]     |                                 ^^^^^^^^^ use of undeclared type `ButtonPad`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 117 + use lovett::hid::ButtonPad;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 9 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0422, E0433.
[INFO] [stdout] For more information about an error, try `rustc --explain E0422`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 147) stdout ----
[INFO] [stdout] error: cannot declare a file module inside a block unless it has a path attribute
[INFO] [stdout]    --> src/lib.rs:149:1
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub mod reducers;                       // Include reducers
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: file modules are usually placed outside of blocks, at the top level of the file
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/lib.rs:166:21
[INFO] [stdout]     |
[INFO] [stdout] 166 |     pub fn new() -> State {
[INFO] [stdout]     |            ---      ^^^^^ expected `State`, found `()`
[INFO] [stdout]     |            |
[INFO] [stdout]     |            implicitly returns `()` as its body has no tail or `return` expression
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 2 previous errors
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0308`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 171) stdout ----
[INFO] [stdout] error: unexpected token: `...`
[INFO] [stdout]    --> src/lib.rs:186:9
[INFO] [stdout]     |
[INFO] [stdout] 186 |         ...
[INFO] [stdout]     |         ^^^
[INFO] [stdout]     |
[INFO] [stdout] help: use `..` for an exclusive range
[INFO] [stdout]     |
[INFO] [stdout] 186 -         ...
[INFO] [stdout] 186 +         ..
[INFO] [stdout]     |
[INFO] [stdout] help: or `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout] 186 -         ...
[INFO] [stdout] 186 +         ..=
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: there are too many leading `super` keywords
[INFO] [stdout]    --> src/lib.rs:175:5
[INFO] [stdout]     |
[INFO] [stdout] 175 | use super::*
[INFO] [stdout]     |     ^^^^^ there are too many leading `super` keywords
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `lovett::state`
[INFO] [stdout]    --> src/lib.rs:173:13
[INFO] [stdout]     |
[INFO] [stdout] 173 | use lovett::state::*;
[INFO] [stdout]     |             ^^^^^ could not find `state` in `lovett`
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0432, E0433.
[INFO] [stdout] For more information about an error, try `rustc --explain E0432`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 73) stdout ----
[INFO] [stdout] error[E0425]: cannot find type `ModelScheduler` in this scope
[INFO] [stdout]   --> src/lib.rs:75:26
[INFO] [stdout]    |
[INFO] [stdout] 75 |     pub model_scheduler: ModelScheduler,        // for handling GuiAction inputs on a mspc channel
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 73 + use lovett::model_scheduler::ModelScheduler;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find type `Store` in this scope
[INFO] [stdout]   --> src/lib.rs:76:16
[INFO] [stdout]    |
[INFO] [stdout] 76 |     pub store: Store,                  // for broadcasting state changes and receiving reducer requests
[INFO] [stdout]    |                ^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 73 + use lovett::store::Store;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find type `WindowViewer` in this scope
[INFO] [stdout]   --> src/lib.rs:77:24
[INFO] [stdout]    |
[INFO] [stdout] 77 |     pub window_viewer: WindowViewer,                    // receives state updates, handles gui and hid interactions 
[INFO] [stdout]    |                        ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 73 + use lovett::window_viewer::WindowViewer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0425`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/lib.rs - (line 117)
[INFO] [stdout]     src/lib.rs - (line 147)
[INFO] [stdout]     src/lib.rs - (line 171)
[INFO] [stdout]     src/lib.rs - (line 49)
[INFO] [stdout]     src/lib.rs - (line 73)
[INFO] [stdout]     src/lib.rs - (line 83)
[INFO] [stdout]     src/lib.rs - (line 93)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 7 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.36s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "a96a5b1a3f2f1bc2435bc1e5532960dc370623db8abb1b2a28d2c53e99e74d87", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a96a5b1a3f2f1bc2435bc1e5532960dc370623db8abb1b2a28d2c53e99e74d87", kill_on_drop: false }`
[INFO] [stdout] a96a5b1a3f2f1bc2435bc1e5532960dc370623db8abb1b2a28d2c53e99e74d87
