[INFO] updating cached repository mdsteele/syzygy [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/mdsteele/syzygy [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/mdsteele/syzygy" "work/ex/beta-1.38-1/sources/1.37.0/gh/mdsteele/syzygy"` [INFO] [stderr] Cloning into 'work/ex/beta-1.38-1/sources/1.37.0/gh/mdsteele/syzygy'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/mdsteele/syzygy" "work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/mdsteele/syzygy"` [INFO] [stderr] Cloning into 'work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/mdsteele/syzygy'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 5ba148fed7aae14bf35108d7303e4194e8ffe5e8 [INFO] sha for GitHub repo mdsteele/syzygy: 5ba148fed7aae14bf35108d7303e4194e8ffe5e8 [INFO] validating manifest of mdsteele/syzygy on toolchain 1.37.0 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+1.37.0" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of mdsteele/syzygy on toolchain beta-2019-08-13 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+beta-2019-08-13" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing mdsteele/syzygy [INFO] finished frobbing mdsteele/syzygy [INFO] frobbed toml for mdsteele/syzygy written to work/ex/beta-1.38-1/sources/1.37.0/gh/mdsteele/syzygy/Cargo.toml [INFO] started frobbing mdsteele/syzygy [INFO] finished frobbing mdsteele/syzygy [INFO] frobbed toml for mdsteele/syzygy written to work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/mdsteele/syzygy/Cargo.toml [INFO] crate mdsteele/syzygy already has a lockfile, it will not be regenerated [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+1.37.0" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+beta-2019-08-13" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] testing mdsteele/syzygy against 1.37.0 for beta-1.38-1 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-1/1.37.0:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/1.37.0/gh/mdsteele/syzygy:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+1.37.0" "build" "--frozen"` [INFO] [stdout] 7bf194e1ffa81966efc331d3d080ef08b6376b6a11bda1e2355b29c56d125217 [INFO] running `"docker" "start" "-a" "7bf194e1ffa81966efc331d3d080ef08b6376b6a11bda1e2355b29c56d125217"` [INFO] [stderr] Compiling itersynth v0.1.0 (https://github.com/mdsteele/itersynth?tag=v0.1.0#bc1e3ffe) [INFO] [stderr] Compiling ahi v0.1.0 (https://github.com/mdsteele/ahi?tag=v0.1.0#8dfd2b39) [INFO] [stderr] Compiling inflate v0.3.4 [INFO] [stderr] Compiling deflate v0.7.19 [INFO] [stderr] Compiling toml v0.4.5 [INFO] [stderr] Compiling sdl2-sys v0.31.0 (https://github.com/mdsteele/rust-sdl2?branch=hash#f277981d) [INFO] [stderr] Compiling png v0.11.0 [INFO] [stderr] Compiling ico v0.1.0 [INFO] [stderr] Compiling winres v0.1.6 (https://github.com/mdsteele/winres?branch=escape#d88139c3) [INFO] [stderr] Compiling sdl2 v0.31.0 (https://github.com/mdsteele/rust-sdl2?branch=hash#f277981d) [INFO] [stderr] Compiling syzygy v1.0.1 (/opt/crater/workdir) [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/ast.rs:73:62 [INFO] [stderr] | [INFO] [stderr] 73 | fn to_scene_node(self, resources: &mut Resources) -> Box { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(bare_trait_objects)] on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:38:20 [INFO] [stderr] | [INFO] [stderr] 38 | nodes: Vec>, [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:46:31 [INFO] [stderr] | [INFO] [stderr] 46 | pub fn new(nodes: Vec>) -> Scene { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:204:32 [INFO] [stderr] | [INFO] [stderr] 204 | fn box_clone(&self) -> Box; [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:221:20 [INFO] [stderr] | [INFO] [stderr] 221 | impl Clone for Box { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:222:28 [INFO] [stderr] | [INFO] [stderr] 222 | fn clone(&self) -> Box { self.box_clone() } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:229:20 [INFO] [stderr] | [INFO] [stderr] 229 | nodes: Vec>, [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:235:31 [INFO] [stderr] | [INFO] [stderr] 235 | pub fn new(nodes: Vec>) -> SequenceNode { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:247:32 [INFO] [stderr] | [INFO] [stderr] 247 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:319:20 [INFO] [stderr] | [INFO] [stderr] 319 | nodes: Vec>, [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:323:31 [INFO] [stderr] | [INFO] [stderr] 323 | pub fn new(nodes: Vec>) -> ParallelNode { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:329:32 [INFO] [stderr] | [INFO] [stderr] 329 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:385:15 [INFO] [stderr] | [INFO] [stderr] 385 | node: Box, [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:392:26 [INFO] [stderr] | [INFO] [stderr] 392 | pub fn new(node: Box, min_iterations: i32, [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:413:32 [INFO] [stderr] | [INFO] [stderr] 413 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:484:32 [INFO] [stderr] | [INFO] [stderr] 484 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:505:32 [INFO] [stderr] | [INFO] [stderr] 505 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:546:32 [INFO] [stderr] | [INFO] [stderr] 546 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:604:32 [INFO] [stderr] | [INFO] [stderr] 604 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:633:32 [INFO] [stderr] | [INFO] [stderr] 633 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:654:32 [INFO] [stderr] | [INFO] [stderr] 654 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:673:32 [INFO] [stderr] | [INFO] [stderr] 673 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:696:32 [INFO] [stderr] | [INFO] [stderr] 696 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:723:32 [INFO] [stderr] | [INFO] [stderr] 723 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:750:32 [INFO] [stderr] | [INFO] [stderr] 750 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:771:32 [INFO] [stderr] | [INFO] [stderr] 771 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:808:32 [INFO] [stderr] | [INFO] [stderr] 808 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:874:32 [INFO] [stderr] | [INFO] [stderr] 874 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:899:32 [INFO] [stderr] | [INFO] [stderr] 899 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:939:32 [INFO] [stderr] | [INFO] [stderr] 939 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:1000:32 [INFO] [stderr] | [INFO] [stderr] 1000 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/gui/background.rs:158:13 [INFO] [stderr] | [INFO] [stderr] 158 | b'A'...b'Z' => (byte - b'A') as usize, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] | [INFO] [stderr] = note: #[warn(ellipsis_inclusive_range_patterns)] on by default [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/gui/background.rs:159:13 [INFO] [stderr] | [INFO] [stderr] 159 | b'a'...b'z' => (byte - b'a') as usize + 26, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/gui/background.rs:160:13 [INFO] [stderr] | [INFO] [stderr] 160 | b'0'...b'9' => (byte - b'0') as usize + 52, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/blame/view.rs:129:34 [INFO] [stderr] | [INFO] [stderr] 129 | let mut top_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/blame/view.rs:142:45 [INFO] [stderr] | [INFO] [stderr] 142 | let mut platform_1_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/blame/view.rs:143:45 [INFO] [stderr] | [INFO] [stderr] 143 | let mut platform_2_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/blame/view.rs:144:41 [INFO] [stderr] | [INFO] [stderr] 144 | let mut mezure_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/gears/view.rs:141:34 [INFO] [stderr] | [INFO] [stderr] 141 | let mut top_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/gears/view.rs:151:43 [INFO] [stderr] | [INFO] [stderr] 151 | let mut platform_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/gears/view.rs:152:41 [INFO] [stderr] | [INFO] [stderr] 152 | let mut ugrent_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/ground/view.rs:126:34 [INFO] [stderr] | [INFO] [stderr] 126 | let mut top_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/ground/view.rs:136:43 [INFO] [stderr] | [INFO] [stderr] 136 | let mut platform_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/ground/view.rs:137:41 [INFO] [stderr] | [INFO] [stderr] 137 | let mut elinsa_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/noreturn/view.rs:68:54 [INFO] [stderr] | [INFO] [stderr] 68 | fn yttris_land_on_floor(&self, seq: &mut Vec>) { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/noreturn/view.rs:84:30 [INFO] [stderr] | [INFO] [stderr] 84 | let mut seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/noreturn/view.rs:102:38 [INFO] [stderr] | [INFO] [stderr] 102 | let mut par: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:36:16 [INFO] [stderr] | [INFO] [stderr] 36 | 'A'...'Z' | ' ' => true, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:37:16 [INFO] [stderr] | [INFO] [stderr] 37 | '0'...'9' => self == ValidChars::LettersAndNumbers, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:38:16 [INFO] [stderr] | [INFO] [stderr] 38 | '!'...'/' | ':'...'@' | '['...'`' | '{'...'~' => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:38:28 [INFO] [stderr] | [INFO] [stderr] 38 | '!'...'/' | ':'...'@' | '['...'`' | '{'...'~' => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:38:40 [INFO] [stderr] | [INFO] [stderr] 38 | '!'...'/' | ':'...'@' | '['...'`' | '{'...'~' => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:38:52 [INFO] [stderr] | [INFO] [stderr] 38 | '!'...'/' | ':'...'@' | '['...'`' | '{'...'~' => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/save/game.rs:169:51 [INFO] [stderr] | [INFO] [stderr] 169 | pub fn puzzle_state(&self, loc: Location) -> &PuzzleState { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn PuzzleState` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/save/game.rs:216:63 [INFO] [stderr] | [INFO] [stderr] 216 | pub fn puzzle_state_mut(&mut self, loc: Location) -> &mut PuzzleState { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn PuzzleState` [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 49.73s [INFO] running `"docker" "inspect" "7bf194e1ffa81966efc331d3d080ef08b6376b6a11bda1e2355b29c56d125217"` [INFO] running `"docker" "rm" "-f" "7bf194e1ffa81966efc331d3d080ef08b6376b6a11bda1e2355b29c56d125217"` [INFO] [stdout] 7bf194e1ffa81966efc331d3d080ef08b6376b6a11bda1e2355b29c56d125217 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-1/1.37.0:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/1.37.0/gh/mdsteele/syzygy:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+1.37.0" "test" "--frozen" "--no-run"` [INFO] [stdout] 93166e46cc230f8edaf76d8d2813e6634890f255cc724f632b756cc462880f9c [INFO] running `"docker" "start" "-a" "93166e46cc230f8edaf76d8d2813e6634890f255cc724f632b756cc462880f9c"` [INFO] [stderr] Compiling syzygy v1.0.1 (/opt/crater/workdir) [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/ast.rs:73:62 [INFO] [stderr] | [INFO] [stderr] 73 | fn to_scene_node(self, resources: &mut Resources) -> Box { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(bare_trait_objects)] on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:38:20 [INFO] [stderr] | [INFO] [stderr] 38 | nodes: Vec>, [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:46:31 [INFO] [stderr] | [INFO] [stderr] 46 | pub fn new(nodes: Vec>) -> Scene { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:204:32 [INFO] [stderr] | [INFO] [stderr] 204 | fn box_clone(&self) -> Box; [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:221:20 [INFO] [stderr] | [INFO] [stderr] 221 | impl Clone for Box { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:222:28 [INFO] [stderr] | [INFO] [stderr] 222 | fn clone(&self) -> Box { self.box_clone() } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:229:20 [INFO] [stderr] | [INFO] [stderr] 229 | nodes: Vec>, [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:235:31 [INFO] [stderr] | [INFO] [stderr] 235 | pub fn new(nodes: Vec>) -> SequenceNode { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:247:32 [INFO] [stderr] | [INFO] [stderr] 247 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:319:20 [INFO] [stderr] | [INFO] [stderr] 319 | nodes: Vec>, [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:323:31 [INFO] [stderr] | [INFO] [stderr] 323 | pub fn new(nodes: Vec>) -> ParallelNode { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:329:32 [INFO] [stderr] | [INFO] [stderr] 329 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:385:15 [INFO] [stderr] | [INFO] [stderr] 385 | node: Box, [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:392:26 [INFO] [stderr] | [INFO] [stderr] 392 | pub fn new(node: Box, min_iterations: i32, [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:413:32 [INFO] [stderr] | [INFO] [stderr] 413 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:484:32 [INFO] [stderr] | [INFO] [stderr] 484 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:505:32 [INFO] [stderr] | [INFO] [stderr] 505 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:546:32 [INFO] [stderr] | [INFO] [stderr] 546 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:604:32 [INFO] [stderr] | [INFO] [stderr] 604 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:633:32 [INFO] [stderr] | [INFO] [stderr] 633 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:654:32 [INFO] [stderr] | [INFO] [stderr] 654 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:673:32 [INFO] [stderr] | [INFO] [stderr] 673 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:696:32 [INFO] [stderr] | [INFO] [stderr] 696 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:723:32 [INFO] [stderr] | [INFO] [stderr] 723 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:750:32 [INFO] [stderr] | [INFO] [stderr] 750 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:771:32 [INFO] [stderr] | [INFO] [stderr] 771 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:808:32 [INFO] [stderr] | [INFO] [stderr] 808 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:874:32 [INFO] [stderr] | [INFO] [stderr] 874 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:899:32 [INFO] [stderr] | [INFO] [stderr] 899 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:939:32 [INFO] [stderr] | [INFO] [stderr] 939 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/elements/cutscene/scene.rs:1000:32 [INFO] [stderr] | [INFO] [stderr] 1000 | fn box_clone(&self) -> Box { Box::new(self.clone()) } [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/gui/background.rs:158:13 [INFO] [stderr] | [INFO] [stderr] 158 | b'A'...b'Z' => (byte - b'A') as usize, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] | [INFO] [stderr] = note: #[warn(ellipsis_inclusive_range_patterns)] on by default [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/gui/background.rs:159:13 [INFO] [stderr] | [INFO] [stderr] 159 | b'a'...b'z' => (byte - b'a') as usize + 26, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/gui/background.rs:160:13 [INFO] [stderr] | [INFO] [stderr] 160 | b'0'...b'9' => (byte - b'0') as usize + 52, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/blame/view.rs:129:34 [INFO] [stderr] | [INFO] [stderr] 129 | let mut top_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/blame/view.rs:142:45 [INFO] [stderr] | [INFO] [stderr] 142 | let mut platform_1_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/blame/view.rs:143:45 [INFO] [stderr] | [INFO] [stderr] 143 | let mut platform_2_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/blame/view.rs:144:41 [INFO] [stderr] | [INFO] [stderr] 144 | let mut mezure_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/gears/view.rs:141:34 [INFO] [stderr] | [INFO] [stderr] 141 | let mut top_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/gears/view.rs:151:43 [INFO] [stderr] | [INFO] [stderr] 151 | let mut platform_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/gears/view.rs:152:41 [INFO] [stderr] | [INFO] [stderr] 152 | let mut ugrent_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/ground/view.rs:126:34 [INFO] [stderr] | [INFO] [stderr] 126 | let mut top_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/ground/view.rs:136:43 [INFO] [stderr] | [INFO] [stderr] 136 | let mut platform_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/ground/view.rs:137:41 [INFO] [stderr] | [INFO] [stderr] 137 | let mut elinsa_seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/noreturn/view.rs:68:54 [INFO] [stderr] | [INFO] [stderr] 68 | fn yttris_land_on_floor(&self, seq: &mut Vec>) { [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/noreturn/view.rs:84:30 [INFO] [stderr] | [INFO] [stderr] 84 | let mut seq: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/modes/noreturn/view.rs:102:38 [INFO] [stderr] | [INFO] [stderr] 102 | let mut par: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^^^^ help: use `dyn`: `dyn SceneNode` [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:36:16 [INFO] [stderr] | [INFO] [stderr] 36 | 'A'...'Z' | ' ' => true, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:37:16 [INFO] [stderr] | [INFO] [stderr] 37 | '0'...'9' => self == ValidChars::LettersAndNumbers, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:38:16 [INFO] [stderr] | [INFO] [stderr] 38 | '!'...'/' | ':'...'@' | '['...'`' | '{'...'~' => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:38:28 [INFO] [stderr] | [INFO] [stderr] 38 | '!'...'/' | ':'...'@' | '['...'`' | '{'...'~' => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:38:40 [INFO] [stderr] | [INFO] [stderr] 38 | '!'...'/' | ':'...'@' | '['...'`' | '{'...'~' => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/save/crossword.rs:38:52 [INFO] [stderr] | [INFO] [stderr] 38 | '!'...'/' | ':'...'@' | '['...'`' | '{'...'~' => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/save/game.rs:169:51 [INFO] [stderr] | [INFO] [stderr] 169 | pub fn puzzle_state(&self, loc: Location) -> &PuzzleState { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn PuzzleState` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/save/game.rs:216:63 [INFO] [stderr] | [INFO] [stderr] 216 | pub fn puzzle_state_mut(&mut self, loc: Location) -> &mut PuzzleState { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn PuzzleState` [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 23.39s [INFO] running `"docker" "inspect" "93166e46cc230f8edaf76d8d2813e6634890f255cc724f632b756cc462880f9c"` [INFO] running `"docker" "rm" "-f" "93166e46cc230f8edaf76d8d2813e6634890f255cc724f632b756cc462880f9c"` [INFO] [stdout] 93166e46cc230f8edaf76d8d2813e6634890f255cc724f632b756cc462880f9c [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-1/1.37.0:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/1.37.0/gh/mdsteele/syzygy:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+1.37.0" "test" "--frozen"` [INFO] [stdout] 951ed76e1e1b53378c3c916fd11196838f3a931ef3a8fe6ad6aa6ec3fe1d97cb [INFO] running `"docker" "start" "-a" "951ed76e1e1b53378c3c916fd11196838f3a931ef3a8fe6ad6aa6ec3fe1d97cb"` [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 0.16s [INFO] [stderr] Running /opt/crater/target/debug/deps/syzygy-06e158eb996b1ce1 [INFO] [stdout] [INFO] [stdout] running 254 tests [INFO] [stdout] test gui::action::tests::merge_value ... ok [INFO] [stdout] test gui::event::tests::keymod_from_sdl2 ... ok [INFO] [stdout] test gui::event::tests::translate_event ... ok [INFO] [stdout] test modes::password::scenes::tests::slot_index_round_trip ... ok [INFO] [stdout] test modes::map::view::tests::no_repeated_locations_on_map ... ok [INFO] [stdout] test modes::map::view::tests::all_locations_represented_on_map ... ok [INFO] [stdout] test modes::failure::view::tests::no_repeated_locations_on_dashboard ... ok [INFO] [stdout] test modes::failure::scenes::tests::password_hint_indices ... ok [INFO] [stdout] test modes::failure::view::tests::all_puzzles_represented_on_dashboard ... ok [INFO] [stdout] test save::color::tests::mixed_color_rgb ... ok [INFO] [stdout] test save::device::tests::device_toml_round_trip ... ok [INFO] [stdout] test save::access::tests::toml_round_trip ... ok [INFO] [stdout] test save::color::tests::primary_color_toml_round_trip ... ok [INFO] [stdout] test save::direction::tests::rotated_by ... ok [INFO] [stdout] test modes::map::view::tests::nodes_do_not_overlap_on_map ... ok [INFO] [stdout] test save::direction::tests::toml_round_trip ... ok [INFO] [stdout] test save::direction::tests::rotated ... ok [INFO] [stdout] test save::ice::transform::tests::apply_identity ... ok [INFO] [stdout] test save::direction::tests::delta_round_trip ... ok [INFO] [stdout] test save::direction::tests::opposites ... ok [INFO] [stdout] test save::ice::symbol::tests::symbol_rotated ... ok [INFO] [stdout] test save::ice::symbol::tests::symbol_flipped ... ok [INFO] [stdout] test save::ice::symbol::tests::symbol_toml_round_trip ... ok [INFO] [stdout] test save::location::tests::come_from_prereq ... ok [INFO] [stdout] test save::ice::transform::tests::toml_round_trip ... ok [INFO] [stdout] test save::ice::transform::tests::flipped_twice ... ok [INFO] [stdout] test save::ice::transform::tests::compose_with_inverse ... ok [INFO] [stdout] test save::device::tests::grid_toml_round_trip ... ok [INFO] [stdout] test save::game::tests::new_game ... ok [INFO] [stdout] test save::ice::transform::tests::compose_with_identity ... ok [INFO] [stdout] test save::location::tests::leads_to_a_dependent ... ok [INFO] [stdout] test save::puzzles::attic::tests::from_invalid_toggled_toml ... ok [INFO] [stdout] test save::puzzles::attic::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::attic::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::auto::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::attic::tests::from_toggled_already_correct_toml ... ok [INFO] [stdout] test save::location::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::auto::tests::from_invalid_index_sequence_toml ... ok [INFO] [stdout] test save::puzzles::attic::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::auto::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::auto::tests::from_invalid_repeat_sequence_toml ... ok [INFO] [stdout] test save::puzzles::auto::tests::from_valid_sequence_toml ... ok [INFO] [stdout] test save::location::tests::transitive_dependencies ... ok [INFO] [stdout] test save::puzzles::auto::tests::transform_letters ... ok [INFO] [stdout] test save::puzzles::auto::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::blame::tests::fall_from_platform ... ok [INFO] [stdout] test save::puzzles::blame::tests::fall_from_stacked_platforms ... ok [INFO] [stdout] test save::puzzles::blame::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::blame::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::blame::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::blind::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::blind::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::blind::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::cube::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::cube::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::cube::tests::grid_sizes ... ok [INFO] [stdout] test save::puzzles::cube::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::cube::tests::vertical_rotation ... ok [INFO] [stdout] test save::puzzles::day::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::day::tests::from_invalid_stage_toml ... ok [INFO] [stdout] test save::puzzles::black::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::blame::tests::from_invalid_mezure_row_toml ... ok [INFO] [stdout] test save::puzzles::blame::tests::from_invalid_positions_toml ... ok [INFO] [stdout] test save::puzzles::day::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::blame::tests::from_mezure_already_at_top_toml ... ok [INFO] [stdout] test save::puzzles::day::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::discon::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::dots::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::dots::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::black::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::black::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::discon::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::discon::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::double::tests::from_current_already_done_toml ... ok [INFO] [stdout] test save::puzzles::double::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::double::tests::from_everything_done_toml ... ok [INFO] [stdout] test save::puzzles::dots::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::double::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::fiction::tests::from_invalid_index_sequence_toml ... ok [INFO] [stdout] test save::puzzles::double::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::failure::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::failure::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::fiction::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::double::tests::from_invalid_done_toml ... ok [INFO] [stdout] test save::puzzles::failure::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::double::tests::from_invalid_current_toml ... ok [INFO] [stdout] test save::puzzles::fiction::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::fiction::tests::from_valid_sequence_toml ... ok [INFO] [stdout] test save::puzzles::fiction::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::finale::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::gears::tests::fall_from_stacked_platforms_2 ... ok [INFO] [stdout] test save::puzzles::gears::tests::fall_from_stacked_platforms_3 ... ok [INFO] [stdout] test save::puzzles::gears::tests::fall_from_stacked_platforms_1 ... ok [INFO] [stdout] test save::puzzles::gears::tests::fall_from_platform ... ok [INFO] [stdout] test save::puzzles::gears::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::gears::tests::from_invalid_positions_toml ... ok [INFO] [stdout] test save::puzzles::gears::tests::from_invalid_ugrent_row_toml ... ok [INFO] [stdout] test save::puzzles::gears::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::ground::tests::fall_from_platform ... ok [INFO] [stdout] test save::puzzles::gears::tests::from_ugrent_already_at_top_toml ... ok [INFO] [stdout] test save::puzzles::gears::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::ground::tests::fall_from_stacked_platforms ... ok [INFO] [stdout] test save::puzzles::ground::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::ground::tests::from_elinsa_already_at_top_toml ... ok [INFO] [stdout] test save::puzzles::ground::tests::from_invalid_elinsa_row_toml ... ok [INFO] [stdout] test save::puzzles::ground::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::ground::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::ground::tests::from_invalid_positions_toml ... ok [INFO] [stdout] test save::puzzles::finale::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::finale::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::headed::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::headed::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::headed::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::hex::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::hex::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::hex::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::fiction::tests::from_invalid_repeat_sequence_toml ... ok [INFO] [stdout] test save::puzzles::fiction::tests::transform_letters ... ok [INFO] [stdout] test save::puzzles::icyem::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::hex::tests::from_invalid_tokens_toml ... ok [INFO] [stdout] test save::puzzles::jog::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::icyem::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::icyem::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::jog::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::jog::tests::from_invalid_num_placed_toml ... ok [INFO] [stdout] test save::puzzles::jog::tests::steps_are_well_formed ... ok [INFO] [stdout] test save::puzzles::jog::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::lane::tests::from_invalid_stage_toml ... ok [INFO] [stdout] test save::puzzles::lane::tests::stages_are_well_formed ... ok [INFO] [stdout] test save::puzzles::lane::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::lane::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::lane::tests::symbol_decay ... ok [INFO] [stdout] test save::puzzles::lane::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::levelup::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::levelup::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::line::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::line::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::levelup::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::line::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::loglevel::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::loglevel::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::loglevel::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::meet::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::meet::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::meet::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::missed::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::missed::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::missed::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::noreturn::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::noreturn::tests::solve ... ok [INFO] [stdout] test save::puzzles::noreturn::tests::from_invalid_order_toml ... ok [INFO] [stdout] test save::puzzles::noreturn::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::noreturn::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::order::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::order::tests::from_invalid_order_toml ... ok [INFO] [stdout] test save::puzzles::order::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::order::tests::from_invalid_row_toml ... ok [INFO] [stdout] test save::puzzles::order::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::password::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::password::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::password::tests::toml_round_trip_crosswords ... ok [INFO] [stdout] test save::puzzles::pov::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::pov::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::pov::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::right::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::prolog::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::sauce::tests::from_current_already_done_toml ... ok [INFO] [stdout] test save::puzzles::right::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::right::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::sauce::tests::from_everything_done_toml ... ok [INFO] [stdout] test save::puzzles::sauce::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::password::tests::toml_round_trip_sliders ... ok [INFO] [stdout] test save::puzzles::prolog::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::prolog::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::sauce::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::sauce::tests::from_invalid_current_toml ... ok [INFO] [stdout] test save::puzzles::sauce::tests::from_invalid_done_toml ... ok [INFO] [stdout] test save::puzzles::sauce::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::serves::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::serves::tests::from_invalid_num_placed_toml ... ok [INFO] [stdout] test save::puzzles::serves::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::simple::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::star::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::star::tests::from_invalid_found_words_toml ... ok [INFO] [stdout] test save::puzzles::star::tests::correct_removal_order_works ... ok [INFO] [stdout] test save::puzzles::star::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::star::tests::from_already_found_everything_toml ... ok [INFO] [stdout] test save::puzzles::star::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::simple::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::simple::tests::from_invalid_stage_toml ... ok [INFO] [stdout] test save::puzzles::simple::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::star::tests::word_insertion_indicies ... ok [INFO] [stdout] test save::puzzles::serves::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::serves::tests::steps_are_well_formed ... ok [INFO] [stdout] test save::puzzles::syrup::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::syrup::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::syrup::tests::index_to_pos_to_index ... ok [INFO] [stdout] test save::puzzles::syrup::tests::from_invalid_toggled_toml ... ok [INFO] [stdout] test save::puzzles::syrup::tests::from_toggled_already_correct_toml ... ok [INFO] [stdout] test save::puzzles::star::tests::words_are_ordered_alphabetically ... ok [INFO] [stdout] test save::puzzles::syrup::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::they::tests::from_invalid_index_sequence_toml ... ok [INFO] [stdout] test save::puzzles::syzygy::tests::stage_toml_round_trip ... ok [INFO] [stdout] test save::puzzles::they::tests::from_invalid_repeat_sequence_toml ... ok [INFO] [stdout] test save::puzzles::they::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::they::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::they::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::they::tests::transform_letters ... ok [INFO] [stdout] test save::puzzles::tread::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::tread::tests::from_invalid_toggled_toml ... ok [INFO] [stdout] test save::puzzles::tread::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::tread::tests::from_toggled_already_correct_toml ... ok [INFO] [stdout] test save::puzzles::they::tests::from_valid_sequence_toml ... ok [INFO] [stdout] test save::puzzles::tread::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::whatcha::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::whatcha::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::wrecked::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::wrecked::tests::from_empty_toml ... ok [INFO] [stdout] test save::puzzles::whatcha::tests::from_solved_toml ... ok [INFO] [stdout] test save::puzzles::wrecked::tests::shift_east ... ok [INFO] [stdout] test save::puzzles::wrecked::tests::shift_south ... ok [INFO] [stdout] test save::puzzles::wrecked::tests::shift_north ... ok [INFO] [stdout] test save::puzzles::wrecked::tests::toml_round_trip ... ok [INFO] [stdout] test save::puzzles::wrecked::tests::shift_west ... ok [INFO] [stdout] test save::pyramid::tests::all_coords ... ok [INFO] [stdout] test save::pyramid::tests::board_is_empty ... ok [INFO] [stdout] test save::pyramid::tests::board_favoribility ... ok [INFO] [stdout] test save::pyramid::tests::board_minimax ... ok [INFO] [stdout] test save::pyramid::tests::board_toml_round_trip ... ok [INFO] [stdout] test save::pyramid::tests::coords_from_index ... ok [INFO] [stdout] test save::pyramid::tests::coords_index_round_trip ... ok [INFO] [stdout] test save::tree::basic::tests::from_invalid_signature_with_loop ... ok [INFO] [stdout] test save::pyramid::tests::coords_index ... ok [INFO] [stdout] test save::pyramid::tests::team_values ... ok [INFO] [stdout] test save::tree::basic::tests::insertion ... ok [INFO] [stdout] test save::tree::basic::tests::removal_3 ... ok [INFO] [stdout] test save::tree::basic::tests::removal_2 ... ok [INFO] [stdout] test save::tree::basic::tests::removal_1 ... ok [INFO] [stdout] test save::tree::basic::tests::tree_structure ... ok [INFO] [stdout] test save::tree::redblack::tests::insertion ... ok [INFO] [stdout] test save::tree::basic::tests::toml_round_trip ... ok [INFO] [stdout] test save::tree::basic::tests::rotation ... ok [INFO] [stdout] test save::tree::redblack::tests::removal_1 ... ok [INFO] [stdout] test save::tree::redblack::tests::removal_4 ... ok [INFO] [stdout] test save::tree::redblack::tests::toml_round_trip ... ok [INFO] [stdout] test save::util::tests::deque_rotation ... ok [INFO] [stdout] test save::tree::redblack::tests::removal_3 ... ok [INFO] [stdout] test save::tree::redblack::tests::removal_2 ... ok [INFO] [stdout] test save::util::tests::i32_to_toml ... ok [INFO] [stdout] test save::util::tests::i8_to_toml ... ok [INFO] [stdout] test save::util::tests::u32_to_toml ... ok [INFO] [stdout] test save::puzzles::wrecked::tests::from_already_correct_toml ... ok [INFO] [stdout] test save::pyramid::tests::board_all_removals ... ok [INFO] [stdout] test save::puzzles::star::tests::words_can_only_be_found_in_order ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 254 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] running `"docker" "inspect" "951ed76e1e1b53378c3c916fd11196838f3a931ef3a8fe6ad6aa6ec3fe1d97cb"` [INFO] running `"docker" "rm" "-f" "951ed76e1e1b53378c3c916fd11196838f3a931ef3a8fe6ad6aa6ec3fe1d97cb"` [INFO] [stdout] 951ed76e1e1b53378c3c916fd11196838f3a931ef3a8fe6ad6aa6ec3fe1d97cb