[INFO] fetching crate shedron 0.1.4... [INFO] testing shedron-0.1.4 against 1.91.0 for beta-1.92-2 [INFO] extracting crate shedron 0.1.4 into /workspace/builds/worker-2-tc1/source [INFO] started tweaking crates.io crate shedron 0.1.4 [INFO] finished tweaking crates.io crate shedron 0.1.4 [INFO] tweaked toml for crates.io crate shedron 0.1.4 written to /workspace/builds/worker-2-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate shedron 0.1.4 on toolchain 1.91.0 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.91.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.91.0" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 21 packages to latest compatible versions [INFO] [stderr] Adding logos v0.12.1 (available: v0.15.1) [INFO] [stderr] Adding rand v0.8.5 (available: v0.9.2) [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.91.0" "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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 4fbc28987da594d36aa3d4dfb91e972cb10f5de8631b44fe050f955ea3c9ba48 [INFO] running `Command { std: "docker" "start" "-a" "4fbc28987da594d36aa3d4dfb91e972cb10f5de8631b44fe050f955ea3c9ba48", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "4fbc28987da594d36aa3d4dfb91e972cb10f5de8631b44fe050f955ea3c9ba48", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4fbc28987da594d36aa3d4dfb91e972cb10f5de8631b44fe050f955ea3c9ba48", kill_on_drop: false }` [INFO] [stdout] 4fbc28987da594d36aa3d4dfb91e972cb10f5de8631b44fe050f955ea3c9ba48 [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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] f5a2fbb81d568965bb2fe64bd458dc385d75b24c48d61bc98a21f953d72c86ab [INFO] running `Command { std: "docker" "start" "-a" "f5a2fbb81d568965bb2fe64bd458dc385d75b24c48d61bc98a21f953d72c86ab", kill_on_drop: false }` [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling logos-derive v0.12.1 [INFO] [stderr] Compiling logos v0.12.1 [INFO] [stderr] Compiling shedron v0.1.4 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 7.14s [INFO] running `Command { std: "docker" "inspect" "f5a2fbb81d568965bb2fe64bd458dc385d75b24c48d61bc98a21f953d72c86ab", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f5a2fbb81d568965bb2fe64bd458dc385d75b24c48d61bc98a21f953d72c86ab", kill_on_drop: false }` [INFO] [stdout] f5a2fbb81d568965bb2fe64bd458dc385d75b24c48d61bc98a21f953d72c86ab [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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] bc4051f105fae182448344fd29b30efa2258b184eb97d249bf524cd0f9e3797b [INFO] running `Command { std: "docker" "start" "-a" "bc4051f105fae182448344fd29b30efa2258b184eb97d249bf524cd0f9e3797b", kill_on_drop: false }` [INFO] [stderr] Compiling shedron v0.1.4 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 1.25s [INFO] running `Command { std: "docker" "inspect" "bc4051f105fae182448344fd29b30efa2258b184eb97d249bf524cd0f9e3797b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "bc4051f105fae182448344fd29b30efa2258b184eb97d249bf524cd0f9e3797b", kill_on_drop: false }` [INFO] [stdout] bc4051f105fae182448344fd29b30efa2258b184eb97d249bf524cd0f9e3797b [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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] df53d43e4f7eadf50661e2a278fe6dbea6ee08ffa0f431f2a427d32013d6685a [INFO] running `Command { std: "docker" "start" "-a" "df53d43e4f7eadf50661e2a278fe6dbea6ee08ffa0f431f2a427d32013d6685a", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.06s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/shedron-df826959d7d4aab7) [INFO] [stdout] [INFO] [stdout] running 14 tests [INFO] [stdout] test interpret::test::test_drop ... ok [INFO] [stdout] test interpret::test::test_append ... ok [INFO] [stdout] test interpret::test::test_negative ... ok [INFO] [stdout] test interpret::test::test_run_blind ... ok [INFO] [stdout] test parser::test::parse_brackets ... ok [INFO] [stdout] test parser::test::parse_invalid_syntax ... ok [INFO] [stdout] test parser::test::display ... ok [INFO] [stdout] test parser::test::parse_things ... ok [INFO] [stdout] test parser::test::parse_parenthesis ... ok [INFO] [stdout] test interpret::test::test_fail_len - should panic ... ok [INFO] [stdout] test interpret::test::test_expect_dice ... FAILED [INFO] [stdout] test interpret::test::test_fail_index_out_of_bounds - should panic ... ok [INFO] [stdout] test interpret::test::test_fail_range - should panic ... ok [INFO] [stdout] test parser::test::parse_complicated_syntax ... ok [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- interpret::test::test_expect_dice stdout ---- [INFO] [stdout] parsing [1] [INFO] [stdout] [src/parser.rs:233:9] call_depth = 0 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "[" [INFO] [stdout] [src/parser.rs:236:9] &next.data = OpenSquare [INFO] [stdout] -> eval content of open_square [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "1" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = CloseSquare [INFO] [stdout] lhs num(1) [INFO] [stdout] <- close square 1 [INFO] [stdout] ::: emitting sum sum(num(1)) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 0 [INFO] [stdout] evaluating [1] [INFO] [stdout] evaluated [1] [INFO] [stdout] [src/interpret.rs:371:9] &result = Ok( [INFO] [stdout] Output { [INFO] [stdout] rolls: [ [INFO] [stdout] 1, [INFO] [stdout] ], [INFO] [stdout] }, [INFO] [stdout] ) [INFO] [stdout] parsing 2d6 [INFO] [stdout] [src/parser.rs:233:9] call_depth = 0 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "2" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "6" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 1 [INFO] [stdout] ::: emitting op roll(num(2), num(6)) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 0 [INFO] [stdout] evaluating 2d6 [INFO] [stdout] evaluated 2d6 [INFO] [stdout] [src/interpret.rs:371:9] &result = Ok( [INFO] [stdout] Output { [INFO] [stdout] rolls: [ [INFO] [stdout] 6, [INFO] [stdout] 1, [INFO] [stdout] ], [INFO] [stdout] }, [INFO] [stdout] ) [INFO] [stdout] parsing ([1d5]+1)d6 [INFO] [stdout] [src/parser.rs:233:9] call_depth = 0 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "(" [INFO] [stdout] [src/parser.rs:236:9] &next.data = OpenParen [INFO] [stdout] -> eval content of open_paren [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "[" [INFO] [stdout] [src/parser.rs:236:9] &next.data = OpenSquare [INFO] [stdout] -> eval content of open_square [INFO] [stdout] [src/parser.rs:233:9] call_depth = 2 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "1" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 3 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "5" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = CloseSquare [INFO] [stdout] lhs num(5) [INFO] [stdout] <- close square 3 [INFO] [stdout] ::: emitting op roll(num(1), num(5)) [INFO] [stdout] target brace is Square Bracket [INFO] [stdout] current brace is Square Bracket [INFO] [stdout] <- breaking out due to matching brackets 2 [INFO] [stdout] [src/parser.rs:244:17] &lhs = roll( [INFO] [stdout] num( [INFO] [stdout] 1, [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 5, [INFO] [stdout] ), [INFO] [stdout] ) [INFO] [stdout] ::: emitting sum sum(roll(num(1), num(5))) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Add [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "+" [INFO] [stdout] -> eval rhs of op Add [INFO] [stdout] [src/parser.rs:233:9] call_depth = 2 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "1" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = CloseParen [INFO] [stdout] lhs num(1) [INFO] [stdout] <- close paren 2 [INFO] [stdout] ::: emitting op add(sum(roll(num(1), num(5))), num(1)) [INFO] [stdout] target brace is Parenthesis [INFO] [stdout] current brace is Parenthesis [INFO] [stdout] <- breaking out due to matching brackets 1 [INFO] [stdout] [src/parser.rs:244:17] &lhs = add( [INFO] [stdout] sum( [INFO] [stdout] roll( [INFO] [stdout] num( [INFO] [stdout] 1, [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 5, [INFO] [stdout] ), [INFO] [stdout] ), [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 1, [INFO] [stdout] ), [INFO] [stdout] ) [INFO] [stdout] ::: emitting parens expr paren(add(sum(roll(num(1), num(5))), num(1))) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "6" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 1 [INFO] [stdout] ::: emitting op roll(paren(add(sum(roll(num(1), num(5))), num(1))), num(6)) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 0 [INFO] [stdout] evaluating ([1d5]+1)d6 [INFO] [stdout] evaluated ([1d5]+1)d6 [INFO] [stdout] [src/interpret.rs:371:9] &result = Ok( [INFO] [stdout] Output { [INFO] [stdout] rolls: [ [INFO] [stdout] 3, [INFO] [stdout] 6, [INFO] [stdout] 5, [INFO] [stdout] ], [INFO] [stdout] }, [INFO] [stdout] ) [INFO] [stdout] parsing [1d5+=1]d6 [INFO] [stdout] [src/parser.rs:233:9] call_depth = 0 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "[" [INFO] [stdout] [src/parser.rs:236:9] &next.data = OpenSquare [INFO] [stdout] -> eval content of open_square [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "1" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 2 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "5" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = AddEq [INFO] [stdout] ::: emitting op roll(num(1), num(5)) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = AddEq [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "+=" [INFO] [stdout] -> eval rhs of op AddEq [INFO] [stdout] [src/parser.rs:233:9] call_depth = 2 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "1" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = CloseSquare [INFO] [stdout] lhs num(1) [INFO] [stdout] <- close square 2 [INFO] [stdout] ::: emitting op add_eq(roll(num(1), num(5)), num(1)) [INFO] [stdout] target brace is Square Bracket [INFO] [stdout] current brace is Square Bracket [INFO] [stdout] <- breaking out due to matching brackets 1 [INFO] [stdout] [src/parser.rs:244:17] &lhs = add_eq( [INFO] [stdout] roll( [INFO] [stdout] num( [INFO] [stdout] 1, [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 5, [INFO] [stdout] ), [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 1, [INFO] [stdout] ), [INFO] [stdout] ) [INFO] [stdout] ::: emitting sum sum(add_eq(roll(num(1), num(5)), num(1))) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "6" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 1 [INFO] [stdout] ::: emitting op roll(sum(add_eq(roll(num(1), num(5)), num(1))), num(6)) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 0 [INFO] [stdout] evaluating [1d5+=1]d6 [INFO] [stdout] evaluated [1d5+=1]d6 [INFO] [stdout] [src/interpret.rs:371:9] &result = Ok( [INFO] [stdout] Output { [INFO] [stdout] rolls: [ [INFO] [stdout] 1, [INFO] [stdout] 2, [INFO] [stdout] ], [INFO] [stdout] }, [INFO] [stdout] ) [INFO] [stdout] parsing ([2d2]+1)d6 [INFO] [stdout] [src/parser.rs:233:9] call_depth = 0 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "(" [INFO] [stdout] [src/parser.rs:236:9] &next.data = OpenParen [INFO] [stdout] -> eval content of open_paren [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "[" [INFO] [stdout] [src/parser.rs:236:9] &next.data = OpenSquare [INFO] [stdout] -> eval content of open_square [INFO] [stdout] [src/parser.rs:233:9] call_depth = 2 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "2" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 3 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "2" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = CloseSquare [INFO] [stdout] lhs num(2) [INFO] [stdout] <- close square 3 [INFO] [stdout] ::: emitting op roll(num(2), num(2)) [INFO] [stdout] target brace is Square Bracket [INFO] [stdout] current brace is Square Bracket [INFO] [stdout] <- breaking out due to matching brackets 2 [INFO] [stdout] [src/parser.rs:244:17] &lhs = roll( [INFO] [stdout] num( [INFO] [stdout] 2, [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 2, [INFO] [stdout] ), [INFO] [stdout] ) [INFO] [stdout] ::: emitting sum sum(roll(num(2), num(2))) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Add [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "+" [INFO] [stdout] -> eval rhs of op Add [INFO] [stdout] [src/parser.rs:233:9] call_depth = 2 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "1" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = CloseParen [INFO] [stdout] lhs num(1) [INFO] [stdout] <- close paren 2 [INFO] [stdout] ::: emitting op add(sum(roll(num(2), num(2))), num(1)) [INFO] [stdout] target brace is Parenthesis [INFO] [stdout] current brace is Parenthesis [INFO] [stdout] <- breaking out due to matching brackets 1 [INFO] [stdout] [src/parser.rs:244:17] &lhs = add( [INFO] [stdout] sum( [INFO] [stdout] roll( [INFO] [stdout] num( [INFO] [stdout] 2, [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 2, [INFO] [stdout] ), [INFO] [stdout] ), [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 1, [INFO] [stdout] ), [INFO] [stdout] ) [INFO] [stdout] ::: emitting parens expr paren(add(sum(roll(num(2), num(2))), num(1))) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "6" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 1 [INFO] [stdout] ::: emitting op roll(paren(add(sum(roll(num(2), num(2))), num(1))), num(6)) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 0 [INFO] [stdout] evaluating ([2d2]+1)d6 [INFO] [stdout] evaluated ([2d2]+1)d6 [INFO] [stdout] [src/interpret.rs:371:9] &result = Ok( [INFO] [stdout] Output { [INFO] [stdout] rolls: [ [INFO] [stdout] 6, [INFO] [stdout] 4, [INFO] [stdout] 1, [INFO] [stdout] 2, [INFO] [stdout] ], [INFO] [stdout] }, [INFO] [stdout] ) [INFO] [stdout] parsing [2d2+1]d6 [INFO] [stdout] [src/parser.rs:233:9] call_depth = 0 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "[" [INFO] [stdout] [src/parser.rs:236:9] &next.data = OpenSquare [INFO] [stdout] -> eval content of open_square [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "2" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 2 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "2" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Add [INFO] [stdout] ::: emitting op roll(num(2), num(2)) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Add [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "+" [INFO] [stdout] -> eval rhs of op Add [INFO] [stdout] [src/parser.rs:233:9] call_depth = 2 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "1" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = CloseSquare [INFO] [stdout] lhs num(1) [INFO] [stdout] <- close square 2 [INFO] [stdout] ::: emitting op add(roll(num(2), num(2)), num(1)) [INFO] [stdout] target brace is Square Bracket [INFO] [stdout] current brace is Square Bracket [INFO] [stdout] <- breaking out due to matching brackets 1 [INFO] [stdout] [src/parser.rs:244:17] &lhs = add( [INFO] [stdout] roll( [INFO] [stdout] num( [INFO] [stdout] 2, [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 2, [INFO] [stdout] ), [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 1, [INFO] [stdout] ), [INFO] [stdout] ) [INFO] [stdout] ::: emitting sum sum(add(roll(num(2), num(2)), num(1))) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "6" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 1 [INFO] [stdout] ::: emitting op roll(sum(add(roll(num(2), num(2)), num(1))), num(6)) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 0 [INFO] [stdout] evaluating [2d2+1]d6 [INFO] [stdout] evaluated [2d2+1]d6 [INFO] [stdout] [src/interpret.rs:371:9] &result = Ok( [INFO] [stdout] Output { [INFO] [stdout] rolls: [ [INFO] [stdout] 2, [INFO] [stdout] 4, [INFO] [stdout] 2, [INFO] [stdout] 2, [INFO] [stdout] 4, [INFO] [stdout] ], [INFO] [stdout] }, [INFO] [stdout] ) [INFO] [stdout] parsing [2d2+=1]d6 [INFO] [stdout] [src/parser.rs:233:9] call_depth = 0 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "[" [INFO] [stdout] [src/parser.rs:236:9] &next.data = OpenSquare [INFO] [stdout] -> eval content of open_square [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "2" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 2 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "2" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = AddEq [INFO] [stdout] ::: emitting op roll(num(2), num(2)) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = AddEq [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "+=" [INFO] [stdout] -> eval rhs of op AddEq [INFO] [stdout] [src/parser.rs:233:9] call_depth = 2 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "1" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = CloseSquare [INFO] [stdout] lhs num(1) [INFO] [stdout] <- close square 2 [INFO] [stdout] ::: emitting op add_eq(roll(num(2), num(2)), num(1)) [INFO] [stdout] target brace is Square Bracket [INFO] [stdout] current brace is Square Bracket [INFO] [stdout] <- breaking out due to matching brackets 1 [INFO] [stdout] [src/parser.rs:244:17] &lhs = add_eq( [INFO] [stdout] roll( [INFO] [stdout] num( [INFO] [stdout] 2, [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 2, [INFO] [stdout] ), [INFO] [stdout] ), [INFO] [stdout] num( [INFO] [stdout] 1, [INFO] [stdout] ), [INFO] [stdout] ) [INFO] [stdout] ::: emitting sum sum(add_eq(roll(num(2), num(2)), num(1))) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Roll [INFO] [stdout] [src/parser.rs:295:17] &self.tokens.slice() = "d" [INFO] [stdout] -> eval rhs of op Roll [INFO] [stdout] [src/parser.rs:233:9] call_depth = 1 [INFO] [stdout] [src/parser.rs:235:9] self.tokens.slice() = "6" [INFO] [stdout] [src/parser.rs:236:9] &next.data = Number [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 1 [INFO] [stdout] ::: emitting op roll(sum(add_eq(roll(num(2), num(2)), num(1))), num(6)) [INFO] [stdout] [src/parser.rs:250:17] &maybe_operator.data = Eof [INFO] [stdout] <- eof 0 [INFO] [stdout] evaluating [2d2+=1]d6 [INFO] [stdout] evaluated [2d2+=1]d6 [INFO] [stdout] [src/interpret.rs:371:9] &result = Ok( [INFO] [stdout] Output { [INFO] [stdout] rolls: [ [INFO] [stdout] 2, [INFO] [stdout] 1, [INFO] [stdout] 6, [INFO] [stdout] 3, [INFO] [stdout] 1, [INFO] [stdout] 2, [INFO] [stdout] ], [INFO] [stdout] }, [INFO] [stdout] ) [INFO] [stdout] [INFO] [stdout] thread 'interpret::test::test_expect_dice' (19) panicked at src/interpret.rs:308:13: [INFO] [stdout] output length is not in the expected range Output { rolls: [2, 1, 6, 3, 1, 2] }.len() != 3..=5 [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x5a8a12878412 - std::backtrace_rs::backtrace::libunwind::trace::h62f3c6bea0fedab3 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x5a8a12878412 - std::backtrace_rs::backtrace::trace_unsynchronized::hc41aaca6c0af0bde [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x5a8a12878412 - std::sys::backtrace::_print_fmt::h33ac2b97007106cc [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x5a8a12878412 - ::fmt::h4e0a3aeea0f9c085 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x5a8a1288950f - core::fmt::rt::Argument::fmt::h1edd6a3e00b22f10 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x5a8a1288950f - core::fmt::write::hecf68a131630c74d [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x5a8a12845851 - std::io::default_write_fmt::ha6b238eff7f0ef8a [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x5a8a12845851 - std::io::Write::write_fmt::h9846fe3d2a36c1ea [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x5a8a12851922 - std::sys::backtrace::BacktraceLock::print::h75160192768e5621 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x5a8a128564cf - std::panicking::default_hook::{{closure}}::h14d82797cfb1ddcb [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x5a8a12856361 - std::panicking::default_hook::h63f9bf8161c5d325 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x5a8a127de95e - as core::ops::function::Fn>::call::hb8126f8384f98101 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x5a8a127de95e - test::test_main_with_exit_callback::{{closure}}::hae96ae0cd2f2ce70 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x5a8a12856b8f - as core::ops::function::Fn>::call::ha703f6686c81d0c6 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x5a8a12856b8f - std::panicking::panic_with_hook::h3173740e06bd0752 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x5a8a128569ea - std::panicking::panic_handler::{{closure}}::hbac492c61eb56a87 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x5a8a12851a69 - std::sys::backtrace::__rust_end_short_backtrace::haa3eac3df9535320 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x5a8a12839e8d - __rustc[de0091b922c53d7e]::rust_begin_unwind [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x5a8a12891040 - core::panicking::panic_fmt::h5138da2ef87be35b [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x5a8a127ad0ce - shedron::interpret::test::::expect_len_in::h2d8e059f3bbc2639 [INFO] [stdout] at /opt/rustwide/workdir/src/interpret.rs:308:13 [INFO] [stdout] 20: 0x5a8a1279ef40 - shedron::interpret::test::test_expect_dice::h602fedeb93d020ac [INFO] [stdout] at /opt/rustwide/workdir/src/interpret.rs:416:14 [INFO] [stdout] 21: 0x5a8a1279fc67 - shedron::interpret::test::test_expect_dice::{{closure}}::h11ac59506c2eff66 [INFO] [stdout] at /opt/rustwide/workdir/src/interpret.rs:390:26 [INFO] [stdout] 22: 0x5a8a127921b6 - core::ops::function::FnOnce::call_once::hc7a7d31e95e64b07 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 23: 0x5a8a127de73b - core::ops::function::FnOnce::call_once::h8f50ae93d93b62b4 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x5a8a127de73b - test::__rust_begin_short_backtrace::h447963718d05a644 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/test/src/lib.rs:663:18 [INFO] [stdout] 25: 0x5a8a127f4375 - test::run_test_in_process::{{closure}}::hf890ba4755ca86c0 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/test/src/lib.rs:686:74 [INFO] [stdout] 26: 0x5a8a127f4375 - as core::ops::function::FnOnce<()>>::call_once::h31e4b2860e583faa [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 27: 0x5a8a127f4375 - std::panicking::catch_unwind::do_call::hec7cdbbe797e2cab [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 28: 0x5a8a127f4375 - std::panicking::catch_unwind::h24d3b93458b5ba67 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 29: 0x5a8a127f4375 - std::panic::catch_unwind::h46eeec7cf9c9336c [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panic.rs:359:14 [INFO] [stdout] 30: 0x5a8a127f4375 - test::run_test_in_process::h290de6e559006104 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/test/src/lib.rs:686:27 [INFO] [stdout] 31: 0x5a8a127f4375 - test::run_test::{{closure}}::h26eeb2c5f7e9a995 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/test/src/lib.rs:607:43 [INFO] [stdout] 32: 0x5a8a127cab74 - test::run_test::{{closure}}::h85af00882daabeaa [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/test/src/lib.rs:637:41 [INFO] [stdout] 33: 0x5a8a127cab74 - std::sys::backtrace::__rust_begin_short_backtrace::h9d9305dda51fa5f2 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 34: 0x5a8a127ce51a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hc6aada8b43f0527b [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 35: 0x5a8a127ce51a - as core::ops::function::FnOnce<()>>::call_once::ha89fe5505c1206f5 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 36: 0x5a8a127ce51a - std::panicking::catch_unwind::do_call::he3e0bef721d99583 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 37: 0x5a8a127ce51a - std::panicking::catch_unwind::ha8241964d3d773cd [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 38: 0x5a8a127ce51a - std::panic::catch_unwind::ha8554bc7696cae72 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/panic.rs:359:14 [INFO] [stdout] 39: 0x5a8a127ce51a - std::thread::Builder::spawn_unchecked_::{{closure}}::he06f1f62b4c90f8d [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 40: 0x5a8a127ce51a - core::ops::function::FnOnce::call_once{{vtable.shim}}::ha7fd20ecae19b9b9 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 41: 0x5a8a1284cc4f - as core::ops::function::FnOnce>::call_once::h43642ed9c40e0ab2 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 42: 0x5a8a1284cc4f - std::sys::thread::unix::Thread::new::thread_start::h38da0f633f090ce2 [INFO] [stdout] at /rustc/f8297e351a40c1439a467bbbb6879088047f50b3/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 43: 0x76f1746d3aa4 - [INFO] [stdout] 44: 0x76f174760a64 - clone [INFO] [stdout] 45: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] interpret::test::test_expect_dice [INFO] [stdout] [INFO] [stdout] test result: FAILED. 13 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] running `Command { std: "docker" "inspect" "df53d43e4f7eadf50661e2a278fe6dbea6ee08ffa0f431f2a427d32013d6685a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "df53d43e4f7eadf50661e2a278fe6dbea6ee08ffa0f431f2a427d32013d6685a", kill_on_drop: false }` [INFO] [stdout] df53d43e4f7eadf50661e2a278fe6dbea6ee08ffa0f431f2a427d32013d6685a