[INFO] fetching crate chessly 0.1.3... [INFO] testing chessly-0.1.3 against master#cdb45c87e2cd43495379f7e867e3cc15dcee9f93 for pr-145838-1 [INFO] extracting crate chessly 0.1.3 into /workspace/builds/worker-3-tc1/source [INFO] started tweaking crates.io crate chessly 0.1.3 [INFO] finished tweaking crates.io crate chessly 0.1.3 [INFO] tweaked toml for crates.io crate chessly 0.1.3 written to /workspace/builds/worker-3-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate chessly 0.1.3 on toolchain cdb45c87e2cd43495379f7e867e3cc15dcee9f93 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate chessly 0.1.3 already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 8c439564875cd96a65c93668c8c2ed7ae10532f9b4ed02253c3a691339d10a0f [INFO] running `Command { std: "docker" "start" "-a" "8c439564875cd96a65c93668c8c2ed7ae10532f9b4ed02253c3a691339d10a0f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "8c439564875cd96a65c93668c8c2ed7ae10532f9b4ed02253c3a691339d10a0f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8c439564875cd96a65c93668c8c2ed7ae10532f9b4ed02253c3a691339d10a0f", kill_on_drop: false }` [INFO] [stdout] 8c439564875cd96a65c93668c8c2ed7ae10532f9b4ed02253c3a691339d10a0f [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] b3d4d38340ef3095d90ac079afaf9311f8bf5acaf27912f9dd5cbc03664f1b70 [INFO] running `Command { std: "docker" "start" "-a" "b3d4d38340ef3095d90ac079afaf9311f8bf5acaf27912f9dd5cbc03664f1b70", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.152 [INFO] [stderr] Compiling log v0.4.20 [INFO] [stderr] Compiling getrandom v0.2.12 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling chessly v0.1.3 (/opt/rustwide/workdir) [INFO] [stdout] warning: field `0` is never read [INFO] [stdout] --> src/board/board.rs:39:29 [INFO] [stdout] | [INFO] [stdout] 39 | pub struct IllegalMoveError(&'static str); [INFO] [stdout] | ---------------- ^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this struct [INFO] [stdout] | [INFO] [stdout] = help: consider removing this field [INFO] [stdout] = note: `IllegalMoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `0` is never read [INFO] [stdout] --> src/board/square_coordinates.rs:6:23 [INFO] [stdout] | [INFO] [stdout] 6 | pub struct ParseError(&'static str); [INFO] [stdout] | ---------- ^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this struct [INFO] [stdout] | [INFO] [stdout] = help: consider removing this field [INFO] [stdout] = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 4.89s [INFO] running `Command { std: "docker" "inspect" "b3d4d38340ef3095d90ac079afaf9311f8bf5acaf27912f9dd5cbc03664f1b70", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "b3d4d38340ef3095d90ac079afaf9311f8bf5acaf27912f9dd5cbc03664f1b70", kill_on_drop: false }` [INFO] [stdout] b3d4d38340ef3095d90ac079afaf9311f8bf5acaf27912f9dd5cbc03664f1b70 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 52e933fbcb14b4deb44cad4a37fe7bfe424123460136d85bc97602d4907eb17e [INFO] running `Command { std: "docker" "start" "-a" "52e933fbcb14b4deb44cad4a37fe7bfe424123460136d85bc97602d4907eb17e", kill_on_drop: false }` [INFO] [stderr] Compiling yansi v0.5.1 [INFO] [stderr] Compiling diff v0.1.13 [INFO] [stdout] warning: field `0` is never read [INFO] [stdout] --> src/board/board.rs:39:29 [INFO] [stdout] | [INFO] [stdout] 39 | pub struct IllegalMoveError(&'static str); [INFO] [stdout] | ---------------- ^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this struct [INFO] [stdout] | [INFO] [stdout] = help: consider removing this field [INFO] [stdout] = note: `IllegalMoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `0` is never read [INFO] [stdout] --> src/board/square_coordinates.rs:6:23 [INFO] [stdout] | [INFO] [stdout] 6 | pub struct ParseError(&'static str); [INFO] [stdout] | ---------- ^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this struct [INFO] [stdout] | [INFO] [stdout] = help: consider removing this field [INFO] [stdout] = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling colored v2.1.0 [INFO] [stderr] Compiling pretty_assertions v1.4.0 [INFO] [stderr] Compiling chessly v0.1.3 (/opt/rustwide/workdir) [INFO] [stdout] warning: field `0` is never read [INFO] [stdout] --> src/board/board.rs:39:29 [INFO] [stdout] | [INFO] [stdout] 39 | pub struct IllegalMoveError(&'static str); [INFO] [stdout] | ---------------- ^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this struct [INFO] [stdout] | [INFO] [stdout] = help: consider removing this field [INFO] [stdout] = note: `IllegalMoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 3.40s [INFO] running `Command { std: "docker" "inspect" "52e933fbcb14b4deb44cad4a37fe7bfe424123460136d85bc97602d4907eb17e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "52e933fbcb14b4deb44cad4a37fe7bfe424123460136d85bc97602d4907eb17e", kill_on_drop: false }` [INFO] [stdout] 52e933fbcb14b4deb44cad4a37fe7bfe424123460136d85bc97602d4907eb17e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 19bb53adbe6a8c748fc0227d146c739a9cb495808dfc0db8c70f849936b5c5fd [INFO] running `Command { std: "docker" "start" "-a" "19bb53adbe6a8c748fc0227d146c739a9cb495808dfc0db8c70f849936b5c5fd", kill_on_drop: false }` [INFO] [stderr] warning: field `0` is never read [INFO] [stderr] --> src/board/board.rs:39:29 [INFO] [stderr] | [INFO] [stderr] 39 | pub struct IllegalMoveError(&'static str); [INFO] [stderr] | ---------------- ^^^^^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | field in this struct [INFO] [stderr] | [INFO] [stderr] = help: consider removing this field [INFO] [stderr] = note: `IllegalMoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: field `0` is never read [INFO] [stderr] --> src/board/square_coordinates.rs:6:23 [INFO] [stderr] | [INFO] [stderr] 6 | pub struct ParseError(&'static str); [INFO] [stderr] | ---------- ^^^^^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | field in this struct [INFO] [stderr] | [INFO] [stderr] = help: consider removing this field [INFO] [stderr] = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: `chessly` (lib) generated 2 warnings [INFO] [stderr] warning: `chessly` (lib test) generated 1 warning (1 duplicate) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.06s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/chessly-77929f1357bb894f) [INFO] [stdout] [INFO] [stdout] running 41 tests [INFO] [stdout] test board::attack::tests::test_is_square_attacked_by_pawns ... ok [INFO] [stdout] test board::attack::tests::test_is_square_attacked_by_rooks ... ok [INFO] [stdout] test board::attack::tests::test_is_square_attacked_by_bishops ... ok [INFO] [stdout] test board::fen::tests::test_initial_position ... ok [INFO] [stdout] test board::attack::tests::test_is_square_attacked_by_knights ... ok [INFO] [stdout] test board::attack::tests::test_is_square_attacked_by_kings ... ok [INFO] [stdout] test board::move_generator::tests::test_black_bishop_moves ... ok [INFO] [stdout] test board::move_generator::tests::test_black_pawn_moves ... ok [INFO] [stdout] test board::move_generator::tests::test_black_queen_moves ... ok [INFO] [stdout] test board::move_generator::tests::test_black_non_sliding_piece_moves ... ok [INFO] [stdout] test board::move_generator::tests::test_black_rook_moves ... ok [INFO] [stdout] test board::move_generator::tests::test_black_castling ... ok [INFO] [stdout] test board::move_generator::tests::test_white_bishop_moves ... ok [INFO] [stdout] test board::move_generator::tests::test_white_queen_moves ... ok [INFO] [stdout] test board::move_generator::tests::test_move_generation ... ok [INFO] [stdout] test board::move_generator::tests::test_white_non_sliding_piece_moves ... ok [INFO] [stdout] test board::move_generator::tests::test_white_rook_moves ... ok [INFO] [stdout] test board::square_coordinates::tests::test_constructor ... ok [INFO] [stdout] test board::movement::tests::test_make_undo ... ok [INFO] [stdout] test board::square_coordinates::tests::test_display ... ok [INFO] [stdout] test board::square_coordinates::tests::test_try_from ... ok [INFO] [stdout] test board::attack::tests::test_is_square_attacked_by_queens ... ok [INFO] [stdout] test board::move_generator::tests::test_white_pawn_moves ... ok [INFO] [stdout] test board::fen::tests::test_to_string ... ok [INFO] [stdout] test uci::command::tests::parse_isready ... ok [INFO] [stdout] test uci::command::tests::parse_ponder_hit ... ok [INFO] [stdout] test uci::command::tests::parse_debug ... ok [INFO] [stdout] test uci::command::tests::parse_debug_invalid ... ok [INFO] [stdout] test uci::command::tests::parse_go ... ok [INFO] [stdout] test uci::command::tests::parse_go_invalid ... ok [INFO] [stdout] test board::move_generator::tests::test_white_castling ... ok [INFO] [stdout] test board::square_coordinates::tests::test_constructor_invalid_rank - should panic ... ok [INFO] [stdout] test board::square_coordinates::tests::test_constructor_invalid_file - should panic ... ok [INFO] [stdout] test uci::command::tests::parse_position ... ok [INFO] [stdout] test uci::command::tests::parse_position_invalid ... ok [INFO] [stdout] test uci::command::tests::parse_quit ... ok [INFO] [stdout] test uci::command::tests::parse_set_option_invalid ... ok [INFO] [stdout] test uci::command::tests::parse_set_option ... ok [INFO] [stdout] test uci::command::tests::parse_stop ... ok [INFO] [stdout] test uci::command::tests::parse_uci ... ok [INFO] [stdout] test uci::command::tests::parse_uci_new_game ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 41 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/chessly-63dc3ed6e323766c) [INFO] [stdout] [INFO] [stderr] Running tests/perf_test.rs (/opt/rustwide/target/debug/deps/perf_test-ede8d3d2ff62b3c5) [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 1 test [INFO] [stdout] test test_positions ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 33.78s [INFO] [stdout] [INFO] [stderr] Doc-tests chessly [INFO] [stdout] [INFO] [stdout] running 31 tests [INFO] [stdout] test src/board/board.rs - board::board::Board::is_fifty_move_rule (line 449) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::get_pseudo_legal_moves (line 252) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::get_legal_moves_for_square (line 220) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::get_piece (line 310) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::get_legal_moves (line 187) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::get_pseudo_legal_moves_for_square (line 282) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board (line 53) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::is_in_checkmate (line 352) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::from_fen (line 121) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::to_fen (line 153) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::is_in_check (line 333) ... ok [INFO] [stdout] test src/board/piece.rs - board::piece::Color (line 7) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::make_move (line 508) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::is_threefold_repetition (line 407) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::is_in_stalemate (line 385) ... ok [INFO] [stdout] test src/board/piece.rs - board::piece::Piece::new (line 106) ... ok [INFO] [stdout] test src/board/piece.rs - board::piece::Piece::to_symbol (line 123) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::undo_move (line 534) ... ok [INFO] [stdout] test src/board/board.rs - board::board::Board::side_to_move (line 486) ... ok [INFO] [stdout] test src/board/piece.rs - board::piece::Piece::to_unicode_symbol (line 145) ... ok [INFO] [stdout] test src/board/piece_move.rs - board::piece_move::PieceMove (line 16) ... ok [INFO] [stdout] test src/board/piece.rs - board::piece::Piece (line 86) ... ok [INFO] [stdout] test src/board/piece.rs - board::piece::Kind (line 34) ... ok [INFO] [stdout] test src/board/square_coordinates.rs - board::square_coordinates::SquareCoordinates (line 14) ... ok [INFO] [stdout] test src/board/square_coordinates.rs - board::square_coordinates::SquareCoordinates::board_index (line 94) ... ok [INFO] [stdout] test src/board/square_coordinates.rs - board::square_coordinates::SquareCoordinates::new (line 40) ... ok [INFO] [stdout] test src/board/piece_move.rs - board::piece_move::PieceMove::to_long_algebraic_notation (line 57) ... ok [INFO] [stdout] test src/board/square_coordinates.rs - board::square_coordinates::SquareCoordinates::file (line 64) ... ok [INFO] [stdout] test src/board/square_coordinates.rs - board::square_coordinates::SquareCoordinates::rank (line 79) ... ok [INFO] [stdout] test src/testing/perft_test_case.rs - testing::perft_test_case::PerftTestCase::run (line 52) ... ok [INFO] [stdout] test src/testing/perft_test_case.rs - testing::perft_test_case::PerftTestCase (line 11) ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 31 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 3.42s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "19bb53adbe6a8c748fc0227d146c739a9cb495808dfc0db8c70f849936b5c5fd", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "19bb53adbe6a8c748fc0227d146c739a9cb495808dfc0db8c70f849936b5c5fd", kill_on_drop: false }` [INFO] [stdout] 19bb53adbe6a8c748fc0227d146c739a9cb495808dfc0db8c70f849936b5c5fd