[INFO] fetching crate shedron 0.1.4... [INFO] testing shedron-0.1.4 against beta-2025-09-21 for beta-1.91-3 [INFO] extracting crate shedron 0.1.4 into /workspace/builds/worker-4-tc2/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-4-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate shedron 0.1.4 on toolchain beta-2025-09-21 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "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" "+beta-2025-09-21" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [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" "+beta-2025-09-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] e04ed8adb20b08d17a1c67dbd52a2dfe32a7e4687f18ab75adebe205b2387974 [INFO] running `Command { std: "docker" "start" "-a" "e04ed8adb20b08d17a1c67dbd52a2dfe32a7e4687f18ab75adebe205b2387974", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "e04ed8adb20b08d17a1c67dbd52a2dfe32a7e4687f18ab75adebe205b2387974", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e04ed8adb20b08d17a1c67dbd52a2dfe32a7e4687f18ab75adebe205b2387974", kill_on_drop: false }` [INFO] [stdout] e04ed8adb20b08d17a1c67dbd52a2dfe32a7e4687f18ab75adebe205b2387974 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 4ec4e2f7af8428b4eaa891c2944393b494ab0998a920d5c2b97c8dc629b0591f [INFO] running `Command { std: "docker" "start" "-a" "4ec4e2f7af8428b4eaa891c2944393b494ab0998a920d5c2b97c8dc629b0591f", kill_on_drop: false }` [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling beef v0.5.2 [INFO] [stderr] Compiling fnv v1.0.7 [INFO] [stderr] Compiling paste v1.0.15 [INFO] [stderr] Compiling regex-syntax v0.6.29 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling rand v0.8.5 [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.27s [INFO] running `Command { std: "docker" "inspect" "4ec4e2f7af8428b4eaa891c2944393b494ab0998a920d5c2b97c8dc629b0591f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4ec4e2f7af8428b4eaa891c2944393b494ab0998a920d5c2b97c8dc629b0591f", kill_on_drop: false }` [INFO] [stdout] 4ec4e2f7af8428b4eaa891c2944393b494ab0998a920d5c2b97c8dc629b0591f [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 2a39b9ea4da458ff639ff528f28e8ff02eb24b9dc35fdef4e8fd05061d9b0390 [INFO] running `Command { std: "docker" "start" "-a" "2a39b9ea4da458ff639ff528f28e8ff02eb24b9dc35fdef4e8fd05061d9b0390", 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.23s [INFO] running `Command { std: "docker" "inspect" "2a39b9ea4da458ff639ff528f28e8ff02eb24b9dc35fdef4e8fd05061d9b0390", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2a39b9ea4da458ff639ff528f28e8ff02eb24b9dc35fdef4e8fd05061d9b0390", kill_on_drop: false }` [INFO] [stdout] 2a39b9ea4da458ff639ff528f28e8ff02eb24b9dc35fdef4e8fd05061d9b0390 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] ae417c5c4c87eb153396912596025d4cd04c77b0dfeea3bcbf4894c37c32fc9e [INFO] running `Command { std: "docker" "start" "-a" "ae417c5c4c87eb153396912596025d4cd04c77b0dfeea3bcbf4894c37c32fc9e", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.03s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/shedron-f13a3e3722c51368) [INFO] [stdout] [INFO] [stdout] running 14 tests [INFO] [stdout] test interpret::test::test_append ... ok [INFO] [stdout] test interpret::test::test_drop ... ok [INFO] [stdout] test parser::test::display ... ok [INFO] [stdout] test parser::test::parse_parenthesis ... ok [INFO] [stdout] test interpret::test::test_negative ... ok [INFO] [stdout] test interpret::test::test_run_blind ... ok [INFO] [stdout] test parser::test::parse_complicated_syntax ... ok [INFO] [stdout] test parser::test::parse_brackets ... ok [INFO] [stdout] test parser::test::parse_invalid_syntax ... ok [INFO] [stdout] test parser::test::parse_things ... ok [INFO] [stdout] test interpret::test::test_fail_index_out_of_bounds - should panic ... ok [INFO] [stdout] test interpret::test::test_expect_dice ... FAILED [INFO] [stdout] test interpret::test::test_fail_len - should panic ... ok [INFO] [stdout] test interpret::test::test_fail_range - should panic ... 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] 4, [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] 1, [INFO] [stdout] 2, [INFO] [stdout] 2, [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] 3, [INFO] [stdout] 1, [INFO] [stdout] 3, [INFO] [stdout] 1, [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] 5, [INFO] [stdout] 1, [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 = 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] 3, [INFO] [stdout] 1, [INFO] [stdout] 5, [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] 3, [INFO] [stdout] 3, [INFO] [stdout] 4, [INFO] [stdout] 3, [INFO] [stdout] 1, [INFO] [stdout] 1, [INFO] [stdout] ], [INFO] [stdout] }, [INFO] [stdout] ) [INFO] [stdout] [INFO] [stdout] thread 'interpret::test::test_expect_dice' (27) panicked at src/interpret.rs:308:13: [INFO] [stdout] output length is not in the expected range Output { rolls: [3, 3, 4, 3, 1, 1] }.len() != 3..=5 [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x6129fab3b562 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x6129fab3b562 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x6129fab3b562 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x6129fab3b562 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x6129fab4c65f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x6129fab4c65f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x6129fab089c1 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x6129fab089c1 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x6129fab14a22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x6129fab195cf - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x6129fab19461 - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6129faaa193e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x6129faaa193e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x6129fab19c8f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x6129fab19c8f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x6129fab19aea - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x6129fab14b59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x6129faafce9d - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x6129fab54190 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x6129faa700ae - shedron::interpret::test::::expect_len_in::hde4767b0c02d02c9 [INFO] [stdout] at /opt/rustwide/workdir/src/interpret.rs:308:13 [INFO] [stdout] 20: 0x6129faa61ec0 - shedron::interpret::test::test_expect_dice::hfb1447e92d3bbd6c [INFO] [stdout] at /opt/rustwide/workdir/src/interpret.rs:416:14 [INFO] [stdout] 21: 0x6129faa62be7 - shedron::interpret::test::test_expect_dice::{{closure}}::hfe4844e13d89d759 [INFO] [stdout] at /opt/rustwide/workdir/src/interpret.rs:390:26 [INFO] [stdout] 22: 0x6129faa551c6 - core::ops::function::FnOnce::call_once::hc1fb319bd91b0093 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 23: 0x6129faaa16fb - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6129faaa16fb - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 25: 0x6129faab7365 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 26: 0x6129faab7365 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 27: 0x6129faab7365 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 28: 0x6129faab7365 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 29: 0x6129faab7365 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 30: 0x6129faab7365 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 31: 0x6129faab7365 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 32: 0x6129faa8db54 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 33: 0x6129faa8db54 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 34: 0x6129faa9141a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 35: 0x6129faa9141a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 36: 0x6129faa9141a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 37: 0x6129faa9141a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 38: 0x6129faa9141a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 39: 0x6129faa9141a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 40: 0x6129faa9141a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 41: 0x6129fab0fcbf - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 42: 0x6129fab0fcbf - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 43: 0x73ea51071aa4 - [INFO] [stdout] 44: 0x73ea510fea34 - 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" "ae417c5c4c87eb153396912596025d4cd04c77b0dfeea3bcbf4894c37c32fc9e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ae417c5c4c87eb153396912596025d4cd04c77b0dfeea3bcbf4894c37c32fc9e", kill_on_drop: false }` [INFO] [stdout] ae417c5c4c87eb153396912596025d4cd04c77b0dfeea3bcbf4894c37c32fc9e