[INFO] cloning repository https://github.com/brken11/rusty_chess
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/brken11/rusty_chess" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbrken11%2Frusty_chess", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbrken11%2Frusty_chess'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] b44b06e45c69980552b371cebd31939bd5ed6e07
[INFO] testing brken11/rusty_chess against try#db823df02fd0c2cf67b43025ac3fef3f2d743245 for pr-150681
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbrken11%2Frusty_chess" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/brken11/rusty_chess
[INFO] finished tweaking git repo https://github.com/brken11/rusty_chess
[INFO] tweaked toml for git repo https://github.com/brken11/rusty_chess written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/brken11/rusty_chess on toolchain db823df02fd0c2cf67b43025ac3fef3f2d743245
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/brken11/rusty_chess 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" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 4bba6d2b83dba691785efd0976f9aa718cc42bddbb9be841cdc7e9c92bc52845
[INFO] running `Command { std: "docker" "start" "-a" "4bba6d2b83dba691785efd0976f9aa718cc42bddbb9be841cdc7e9c92bc52845", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4bba6d2b83dba691785efd0976f9aa718cc42bddbb9be841cdc7e9c92bc52845", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4bba6d2b83dba691785efd0976f9aa718cc42bddbb9be841cdc7e9c92bc52845", kill_on_drop: false }`
[INFO] [stdout] 4bba6d2b83dba691785efd0976f9aa718cc42bddbb9be841cdc7e9c92bc52845
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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=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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 91a7036f05ec3ca6773bfb19044ac91fb869a76625825f19aca891f002fdebc7
[INFO] running `Command { std: "docker" "start" "-a" "91a7036f05ec3ca6773bfb19044ac91fb869a76625825f19aca891f002fdebc7", kill_on_drop: false }`
[INFO] [stderr]    Compiling rusty_chess v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]  --> src/chess_bot.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::error::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::player_agent`
[INFO] [stdout]  --> src/game.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::player_agent;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]   --> src/game.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::thread;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ProtoMove`
[INFO] [stdout]  --> src/player_agent/player_actor.rs:3:61
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::move_parser::{chess_notation_parser, ParseError, ProtoMove};
[INFO] [stdout]   |                                                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Instant`
[INFO] [stdout]  --> src/rules.rs:1:27
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::time::{Duration, Instant};
[INFO] [stdout]   |                           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Config`
[INFO] [stdout]   --> src/main.rs:24:35
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::config::{parse_config, Config, ConfigResult};
[INFO] [stdout]    |                                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game_id`
[INFO] [stdout]   --> src/chess_bot.rs:42:35
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `move_notation`
[INFO] [stdout]   --> src/chess_bot.rs:42:50
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_move_notation`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game_id`
[INFO] [stdout]   --> src/chess_bot.rs:48:40
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stdout]    |                                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file`
[INFO] [stdout]    --> src/log.rs:273:29
[INFO] [stdout]     |
[INFO] [stdout] 273 |             LogOutput::File(file) => {
[INFO] [stdout]     |                             ^^^^ help: if this is intentional, prefix it with an underscore: `_file`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/ui.rs:81:12
[INFO] [stdout]    |
[INFO] [stdout] 81 |     fn run(mut self) -> UIManager {
[INFO] [stdout]    |            ----^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `log_handle`
[INFO] [stdout]   --> src/main.rs:67:10
[INFO] [stdout]    |
[INFO] [stdout] 67 |     let (log_handle, log_channel) = common_lib::init_logger(main_id, log_output);
[INFO] [stdout]    |          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_log_handle`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `can_castle`, `king_moved`, and `rook_moved` are never used
[INFO] [stdout]   --> src/board.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub trait CastlingRightsExt{
[INFO] [stdout]    |           ----------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 32 |     fn can_castle(self, color: Color, kingside: bool) -> bool;
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     fn king_moved(&mut self, king_color: Color);
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 38 |     fn rook_moved(&mut self, rook_color: Color, kingside: bool);
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `BitboardExt` is never used
[INFO] [stdout]   --> src/board.rs:97:11
[INFO] [stdout]    |
[INFO] [stdout] 97 | pub trait BitboardExt{
[INFO] [stdout]    |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BOARD_TEMPLATE` is never used
[INFO] [stdout]    --> src/board.rs:135:7
[INFO] [stdout]     |
[INFO] [stdout] 135 | const BOARD_TEMPLATE: &'static str =
[INFO] [stdout]     |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/board.rs:199:12
[INFO] [stdout]     |
[INFO] [stdout] 149 | impl Board {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn clone(&self) -> Board {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 239 |     pub fn get_piece_count(&self) -> u8 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     pub fn get_piece_color_at(&self, square: Square) -> Option<Color> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 338 |     pub fn find_piece_positions(&self, piece: Piece) -> Vec<Square> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 439 |     pub fn get_char_at(&self, square: Square) -> char {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 619 |     pub fn sees_down_file(&self, square:Square, ascending: bool) -> Bitboard {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 664 |     pub fn sees_down_diagonal(&self, square:Square, ascending_row: bool, ascending_col: bool) -> Bitboard {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 683 |     pub fn sees_like_knight(&self, square:Square) -> Bitboard {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 791 |     pub fn get_pieces_at_bitboard(&self, bitboard: Bitboard) -> Vec<(Piece, Square)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 801 |     pub fn get_piece_squares_from_bitboard(&self, piece: Piece, mut bitboard: Bitboard) -> Vec<Square> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 815 |     pub fn get_active_pieces(&self) -> Vec<(Piece, Square)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/board/pieces.rs:35:11
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl Piece {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  35 |     const PIECES_WITH_COLOR: [(Piece,Color); 12] = [
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  62 |     pub fn iter_with_color() -> impl Iterator<Item=(Piece, Color)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn is_rook(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn is_knight(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn is_bishop(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn is_queen(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub fn is_king(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 130 |     pub fn moves_diagonally(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 140 |     pub fn captures_diagonally(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub fn moves_n_captures_straight(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 164 |     pub fn is_promotion_candidate(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 171 |     pub fn to_index(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 175 |     pub fn from_index(index: usize) -> Option<Piece> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_pawn_row_offset`, `king_starting_square`, and `king_castle_target` are never used
[INFO] [stdout]    --> src/board/pieces.rs:234:18
[INFO] [stdout]     |
[INFO] [stdout] 212 | impl Color {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub const fn get_pawn_row_offset(&self) -> u8 {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 300 |     pub const fn king_starting_square(&self) -> Square {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 306 |     pub const fn king_castle_target(&self, castle_type: CastleType) -> Square {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/board/square.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout]  9 | ...trait SquareExt {
[INFO] [stdout]    |          --------- associated items in this trait
[INFO] [stdout] ...
[INFO] [stdout] 17 | ...const A1: Square; const A2: Square; const A3: Square; const A4: Square; const A5: Square; const A6: Square; const A7: Square; const A8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 18 | ...const B1: Square; const B2: Square; const B3: Square; const B4: Square; const B5: Square; const B6: Square; const B7: Square; const B8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 19 | ...const C1: Square; const C2: Square; const C3: Square; const C4: Square; const C5: Square; const C6: Square; const C7: Square; const C8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 20 | ...const D1: Square; const D2: Square; const D3: Square; const D4: Square; const D5: Square; const D6: Square; const D7: Square; const D8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 21 | ...const E1: Square; const E2: Square; const E3: Square; const E4: Square; const E5: Square; const E6: Square; const E7: Square; const E8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 22 | ...const F1: Square; const F2: Square; const F3: Square; const F4: Square; const F5: Square; const F6: Square; const F7: Square; const F8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 23 | ...const G1: Square; const G2: Square; const G3: Square; const G4: Square; const G5: Square; const G6: Square; const G7: Square; const G8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 24 | ...const H1: Square; const H2: Square; const H3: Square; const H4: Square; const H5: Square; const H6: Square; const H7: Square; const H8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 25 | .../// Array of square labels, from "a8","b8","c8" ... to ..., "f1", "g1", "h1".
[INFO] [stdout] 26 | ...const SQUARES: [&'static str; 64];
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 | ...fn get_rows(&self, ascending : bool) -> RowIterator;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 | ...fn get_cols(&self, ascending : bool) -> ColIterator;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 | ...fn get_pos_pair(&self) -> (Row, Col);
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 46 | .../// Returns the index of the square as a `usize`.
[INFO] [stdout] 47 | ...fn get_index(&self) -> usize;
[INFO] [stdout]    |       ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 | ...fn row_diff(&self, other_square: Square) -> u8;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] 58 | .../// Returns the absolute difference in columns between `Square`s
[INFO] [stdout] 59 | ...fn col_diff(&self, other_square: Square) -> u8;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] 60 | .../// Returns an iterator over the file letters.
[INFO] [stdout] 61 | ...fn iter_files() -> impl Iterator<Item = char>;
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 | ...fn iter_squares() -> impl Iterator<Item = Square>;
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 | ...fn to_square_str(&self) -> &str;
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `from_rank` and `to_rank` are never used
[INFO] [stdout]    --> src/board/square.rs:251:8
[INFO] [stdout]     |
[INFO] [stdout] 234 | pub trait RowExt {
[INFO] [stdout]     |           ------ associated items in this trait
[INFO] [stdout] ...
[INFO] [stdout] 251 |     fn from_rank(rank: u8) -> Self;
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 252 |     fn to_rank(&self) -> u8;
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `from_file` and `to_file` are never used
[INFO] [stdout]    --> src/board/square.rs:271:8
[INFO] [stdout]     |
[INFO] [stdout] 254 | pub trait ColExt {
[INFO] [stdout]     |           ------ associated items in this trait
[INFO] [stdout] ...
[INFO] [stdout] 271 |     fn from_file(file: char) -> Self;
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 272 |     fn to_file(&self) -> char;
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RowIterator` is never constructed
[INFO] [stdout]    --> src/board/square.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct RowIterator{
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ColIterator` is never constructed
[INFO] [stdout]    --> src/board/square.rs:344:12
[INFO] [stdout]     |
[INFO] [stdout] 344 | pub struct ColIterator{
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessApiConfig` is never constructed
[INFO] [stdout]  --> src/chess_bot.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ChessApiConfig {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ChessApiError` is never used
[INFO] [stdout]   --> src/chess_bot.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ChessApiError {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessApiClient` is never constructed
[INFO] [stdout]   --> src/chess_bot.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct ChessApiClient {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `authenticate`, `make_move`, and `get_game_state` are never used
[INFO] [stdout]   --> src/chess_bot.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 29 | impl ChessApiClient {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 30 |     /// Creates a new API client with the given configuration
[INFO] [stdout] 31 |     pub fn new(config: ChessApiConfig) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub async fn authenticate(&self) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/chess_moves.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub enum MoveData {
[INFO] [stdout]    |          -------- variants in this enum
[INFO] [stdout] 16 |     Normal = 0,
[INFO] [stdout] 17 |     NormalCheck = 1,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 18 |     NormalCheckmate = 2,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 19 |     NormalStalemate = 3,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 20 |     Castling = 4,
[INFO] [stdout] 21 |     CastlingCheck = 5,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 22 |     CastlingCheckmate = 6,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 23 |     CastlingStalemate = 7,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     Promotion = 8,
[INFO] [stdout] 25 |     PromotionCheck = 9,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 26 |     PromotionCheckmate = 10,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 27 |     PromotionStalemate = 11,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 28 |     EnPassant = 12,
[INFO] [stdout] 29 |     EnPassantCheck = 13,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 30 |     EnPassantCheckmate = 14,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 31 |     EnPassantStalemate = 15,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 32 |     EnableEnPassant = 16,
[INFO] [stdout] 33 |     EnableEnPassantCheck = 17,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 34 |     EnableEnPassantCheckmate = 18,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 35 |     EnableEnPassantStalemate = 19,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 36 |     Capture = 20,
[INFO] [stdout] 37 |     CaptureCheck = 21,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 38 |     CaptureCheckmate = 22,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 39 |     CaptureStalemate = 23,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 40 |     CapturePromotion = 24,
[INFO] [stdout] 41 |     CapturePromotionCheck = 25,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 42 |     CapturePromotionCheckmate = 26,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 43 |     CapturePromotionStalemate = 27,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 44 |     //Moves may be generated by the engine ahead of time, so they may need to be properly classified.
[INFO] [stdout] 45 |     GeneratedOnly,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SpecialMoveType` is never used
[INFO] [stdout]   --> src/chess_moves.rs:55:6
[INFO] [stdout]    |
[INFO] [stdout] 55 | enum SpecialMoveType {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/chess_moves.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub enum MoveError {
[INFO] [stdout]    |          --------- variants in this enum
[INFO] [stdout] 65 |     LeavesKingInCheck, //@TODO Return square of piece threatening King
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 66 |     PieceNotFound(Square),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 67 |     OriginNotFound(Piece),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 68 |     ObstructedMove,                 //@TODO Add blocking piece
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 69 |     DisambiguousMove(Disambiguity), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 70 |     IllegalMove, //@TODO remove any of these that aren't related to piece movement rules
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 71 |     CastleNotPermmited,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 72 |     KingCannotSeeRook, // @TODO ObscuredMove for Castle, should show blocking piece
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 73 |     PromotionRequired,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 74 |     IllegalPromotion,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `None`, `Rank`, `File`, and `Square` are never constructed
[INFO] [stdout]   --> src/chess_moves.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub enum Disambiguity {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] 79 |     None,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 80 |     Rank(Row),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 81 |     File(Col),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 82 |     Square(Square),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Disambiguity` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `WHITE_KINGSIDE_CASTLE` is never used
[INFO] [stdout]   --> src/chess_moves.rs:93:7
[INFO] [stdout]    |
[INFO] [stdout] 93 | const WHITE_KINGSIDE_CASTLE: ChessMove = ChessMove {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `WHITE_QUEENSIDE_CASTLE` is never used
[INFO] [stdout]   --> src/chess_moves.rs:99:7
[INFO] [stdout]    |
[INFO] [stdout] 99 | const WHITE_QUEENSIDE_CASTLE: ChessMove = ChessMove {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BLACK_KINGSIDE_CASTLE` is never used
[INFO] [stdout]    --> src/chess_moves.rs:105:7
[INFO] [stdout]     |
[INFO] [stdout] 105 | const BLACK_KINGSIDE_CASTLE: ChessMove = ChessMove {
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BLACK_QUEENSIDE_CASTLE` is never used
[INFO] [stdout]    --> src/chess_moves.rs:111:7
[INFO] [stdout]     |
[INFO] [stdout] 111 | const BLACK_QUEENSIDE_CASTLE: ChessMove = ChessMove {
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]     --> src/chess_moves.rs:158:12
[INFO] [stdout]      |
[INFO] [stdout]  130 | impl ChessMove {
[INFO] [stdout]      | -------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  158 |     pub fn valid_new( board: &mut Board, piece: Piece, origin: Square, target: Square, is_promotion: bool) -> Result<ChessMove, Mo...
[INFO] [stdout]      |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  170 |     pub fn new_castle(board: &mut Board, castle_type: CastleType) -> Result<ChessMove, MoveError> {
[INFO] [stdout]      |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  193 |     pub fn disambiguate_from_squares(possible_origins: &Vec<Square>) -> Disambiguity {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  228 |     pub fn new_with_disambiguation(
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  271 |     pub fn disambiguate_from_moves(possible_moves: &Vec<ChessMove>) -> Disambiguity {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  306 |     pub fn new_without_disambiguation(
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  442 |     pub fn new_from_squares(
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  455 |     fn assemble_special_move(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  517 |     pub fn to_simplified(&self) -> String {
[INFO] [stdout]      |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  594 |     pub fn make_move(&self, board: &mut Board) {
[INFO] [stdout]      |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  698 |     pub fn validate_move(&mut self, board: &mut Board) -> Result<(), MoveError> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  715 |     fn validate_movement(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  746 |     fn validate_capturable(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  757 |     fn validate_meta_data(&mut self, board: &mut Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  780 |     fn validate_pawn_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  873 |     fn validate_rook_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  892 |     fn validate_knight_move(&mut self) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  915 |     fn validate_bishop_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  933 |     fn validate_queen_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  963 |     fn validate_king_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1043 |     fn validate_promotion(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1093 |     fn validate_diagonal_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1119 |     fn validate_straight_move(&mut self, board: &Board, down_file: bool) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `special_move_builder` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1634:4
[INFO] [stdout]      |
[INFO] [stdout] 1634 | fn special_move_builder(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_none_or_promotion` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1655:4
[INFO] [stdout]      |
[INFO] [stdout] 1655 | fn build_none_or_promotion(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_move_type` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1694:4
[INFO] [stdout]      |
[INFO] [stdout] 1694 | fn build_move_type(base: MoveData, result: MoveResult) -> MoveData {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]     --> src/chess_moves.rs:1760:12
[INFO] [stdout]      |
[INFO] [stdout] 1704 | impl MoveData {
[INFO] [stdout]      | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1760 |     pub fn is_check(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1771 |     pub fn is_checkmate(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1782 |     pub fn is_stalemate(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1810 |     pub fn is_en_passant(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1885 |     pub fn add_result_data(&mut self, move_checks: bool, opp_has_move: bool) {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1903 |     fn add_check(self) -> MoveData {
[INFO] [stdout]      |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1914 |     fn add_checkmate(self) -> MoveData {
[INFO] [stdout]      |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1925 |     fn add_stalemate(self) -> MoveData {
[INFO] [stdout]      |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessClock` is never constructed
[INFO] [stdout]  --> src/clock.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct ChessClock{
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/clock.rs:16:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl ChessClock{
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 16 |     fn new() -> Self{
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Network`, `Game`, `Terminal`, `GUI`, and `Other` are never constructed
[INFO] [stdout]   --> src/common.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub enum ThreadIdentifier {
[INFO] [stdout]    |          ---------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 17 |     Network(ThreadIdHash),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 18 |     Game(ThreadIdHash),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 19 |     UI(ThreadIdHash),
[INFO] [stdout] 20 |     Terminal(ThreadIdHash),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 21 |     GUI(ThreadIdHash),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 22 |     Other(ThreadIdHash, &'static str),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ThreadIdentifier` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PlayerType` is never used
[INFO] [stdout]   --> src/game.rs:42:10
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub enum PlayerType{
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GameMetadata` is never constructed
[INFO] [stdout]   --> src/game.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub struct GameMetadata {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Game` is never constructed
[INFO] [stdout]   --> src/game.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct Game{
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `FullMoveNumber` is never used
[INFO] [stdout]   --> src/game.rs:70:10
[INFO] [stdout]    |
[INFO] [stdout] 70 | pub type FullMoveNumber = rules::FullMoveNumber;
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GameThread` is never constructed
[INFO] [stdout]   --> src/game.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub struct GameThread{
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameMessage` is never used
[INFO] [stdout]   --> src/game.rs:82:10
[INFO] [stdout]    |
[INFO] [stdout] 82 | pub enum GameMessage {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameResponse` is never used
[INFO] [stdout]   --> src/game.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum GameResponse {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameController` is never used
[INFO] [stdout]   --> src/game.rs:96:10
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub enum GameController {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `new_with_time_controls`, and `start_game` are never used
[INFO] [stdout]    --> src/game.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | impl Game{
[INFO] [stdout]     | --------- associated items in this implementation
[INFO] [stdout] 103 |     pub fn new(white: PlayerType, black: PlayerType) -> Game {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub fn new_with_time_controls(white: PlayerType, black: PlayerType, time_controls: TimeControls) -> Option<Game> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     fn start_game(&mut self) {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `start`, and `run` are never used
[INFO] [stdout]    --> src/game.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout] 135 | impl GameThread {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn new(game: Game) -> (GameThread, Sender<GameController>) {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 172 |     pub fn start(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     fn run(&mut self) {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlayerHandler` is never constructed
[INFO] [stdout]  --> src/handler.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct PlayerHandler{
[INFO] [stdout]   |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/handler.rs:13:13
[INFO] [stdout]    |
[INFO] [stdout] 12 |  impl PlayerHandler{
[INFO] [stdout]    |  ------------------ associated function in this implementation
[INFO] [stdout] 13 |      pub fn new(player_type: PlayerType, player_sender: mpsc::Sender<GameMessage>, player_receiver: mpsc::Receiver<GameResponse>) ->...
[INFO] [stdout]    |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `SetOutput`, `SetPrintTimestamp`, `SetTimestampDisplay`, `SetPrintThreadIdentifier`, `SetPrintLevel`, and `SetPrintMessage` are never constructed
[INFO] [stdout]   --> src/log.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub enum LogInstruction {
[INFO] [stdout]    |          -------------- variants in this enum
[INFO] [stdout] 38 |     SetLevel(LogLevel),
[INFO] [stdout] 39 |     SetOutput(LogOutput),
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 40 |     SetPrintTimestamp(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 41 |     SetTimestampDisplay(time_format::DisplayMode),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 42 |     SetPrintThreadIdentifier(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 43 |     SetPrintLevel(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 44 |     SetPrintMessage(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_id_channel_in_and_out` is never used
[INFO] [stdout]    --> src/log.rs:108:12
[INFO] [stdout]     |
[INFO] [stdout]  77 | impl LogThread {
[INFO] [stdout]     | -------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 108 |     pub fn from_id_channel_in_and_out( parent_thread: ThreadIdentifier, channel_in: Receiver<LogMessage>, out: LogOutput, ) -> (Log...
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PIECE_MAP` is never used
[INFO] [stdout]  --> src/move_parser.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub const PIECE_MAP: &[(&str, char)] = &[
[INFO] [stdout]   |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SORTED_PIECE_MAP` is never used
[INFO] [stdout]   --> src/move_parser.rs:37:11
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub const SORTED_PIECE_MAP: &[(char, char)] = &[('+', '+'), ('-', '-'), ('0', '0'), ('1', '1'), ('2', '2'), ('3', '3'), ('4', '4'), ...
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ParseError` is never used
[INFO] [stdout]   --> src/move_parser.rs:39:10
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub enum ParseError{
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Token` is never used
[INFO] [stdout]    --> src/move_parser.rs:113:10
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub enum Token {
[INFO] [stdout]     |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ProtoMove` is never constructed
[INFO] [stdout]    --> src/move_parser.rs:128:12
[INFO] [stdout]     |
[INFO] [stdout] 128 | pub struct ProtoMove {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `AlgebraicParseStage` is never used
[INFO] [stdout]    --> src/move_parser.rs:140:10
[INFO] [stdout]     |
[INFO] [stdout] 140 | pub enum AlgebraicParseStage{
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `finalize` is never used
[INFO] [stdout]    --> src/move_parser.rs:576:4
[INFO] [stdout]     |
[INFO] [stdout] 576 | fn finalize(proto_move: ProtoMove) -> Result<ProtoMove, ParseError>{
[INFO] [stdout]     |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tokenize_string` is never used
[INFO] [stdout]    --> src/move_parser.rs:665:4
[INFO] [stdout]     |
[INFO] [stdout] 665 | fn tokenize_string(string: &str, map:&[(char, char)], color: Color) -> Result<Vec<Token>, ParseError>{
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pre_process_tokens` is never used
[INFO] [stdout]    --> src/move_parser.rs:748:4
[INFO] [stdout]     |
[INFO] [stdout] 748 | fn pre_process_tokens(tokens: &Vec<Token>) -> Result<Vec<Token>, ParseError>{
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `from_simplified_algebraic_notation` is never used
[INFO] [stdout]    --> src/move_parser.rs:154:12
[INFO] [stdout]     |
[INFO] [stdout] 154 |     pub fn from_simplified_algebraic_notation(string: &str, active_player: Color) -> Result<ProtoMove, ParseError>{
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `from_long_algebraic_notation` is never used
[INFO] [stdout]    --> src/move_parser.rs:375:12
[INFO] [stdout]     |
[INFO] [stdout] 375 |     pub fn from_long_algebraic_notation(string: &str, active_player: Color) -> Result<ProtoMove, ParseError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_from_proto` is never used
[INFO] [stdout]    --> src/move_parser.rs:518:16
[INFO] [stdout]     |
[INFO] [stdout] 517 |     impl ChessMove {
[INFO] [stdout]     |     -------------- associated function in this implementation
[INFO] [stdout] 518 |         pub fn new_from_proto(board: &mut Board, proto_move: ProtoMove) -> Result<ChessMove, ParseError> {
[INFO] [stdout]     |                ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PlayerClient` is never used
[INFO] [stdout]  --> src/player_agent.rs:3:10
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub enum PlayerClient {
[INFO] [stdout]   |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `PlayerController` is never used
[INFO] [stdout]  --> src/player_agent.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub trait PlayerController {
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Player` is never used
[INFO] [stdout]  --> src/player_agent/player_actor.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub trait Player {
[INFO] [stdout]   |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `FullMoveNumber` is never used
[INFO] [stdout]   --> src/rules.rs:19:10
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub type FullMoveNumber = u8;
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameState` is never used
[INFO] [stdout]   --> src/rules.rs:22:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub enum GameState {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TimeControls` is never constructed
[INFO] [stdout]    --> src/rules.rs:102:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | pub struct TimeControls {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Timer` is never used
[INFO] [stdout]    --> src/rules.rs:116:11
[INFO] [stdout]     |
[INFO] [stdout] 116 | pub trait Timer {
[INFO] [stdout]     |           ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Simple` and `Debug` are never constructed
[INFO] [stdout]   --> src/time.rs:64:9
[INFO] [stdout]    |
[INFO] [stdout] 62 |     pub enum DisplayMode {
[INFO] [stdout]    |              ----------- variants in this enum
[INFO] [stdout] 63 |         ISO8601,
[INFO] [stdout] 64 |         Simple,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 65 |         Debug,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DisplayMode` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `CurrentBackend` is never used
[INFO] [stdout]   --> src/ui.rs:16:6
[INFO] [stdout]    |
[INFO] [stdout] 16 | type CurrentBackend = backend_x11::X11Backend;
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Web` is never constructed
[INFO] [stdout]   --> src/ui.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub enum UIType {
[INFO] [stdout]    |          ------ variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 23 |     Web,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Game` is never constructed
[INFO] [stdout]   --> src/ui.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub enum UIState {
[INFO] [stdout]    |          ------- variant in this enum
[INFO] [stdout] 27 |     Menu,
[INFO] [stdout] 28 |     Game,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UserInput` is never used
[INFO] [stdout]   --> src/ui.rs:31:10
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub enum UserInput {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `ui_state` and `log_channel` are never read
[INFO] [stdout]   --> src/ui.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct UIManager {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     ui_state: UIState,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 40 |     log_channel: Option<mpsc::Sender<LogMessage>>,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `GraphicsBackend` is never used
[INFO] [stdout]   --> src/ui.rs:43:7
[INFO] [stdout]    |
[INFO] [stdout] 43 | trait GraphicsBackend {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UiUpdate` is never used
[INFO] [stdout]   --> src/ui.rs:50:10
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub enum UiUpdate {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UiMessage` is never used
[INFO] [stdout]   --> src/ui.rs:55:10
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub enum UiMessage {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WIN32Backend` is never constructed
[INFO] [stdout]  --> src/ui/backend_win32.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct WIN32Backend {
[INFO] [stdout]   |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `X11Backend` is never constructed
[INFO] [stdout]  --> src/ui/backend_x11.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct X11Backend {
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]   --> src/clock.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]   --> src/clock.rs:34:40
[INFO] [stdout]    |
[INFO] [stdout] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1.18s
[INFO] running `Command { std: "docker" "inspect" "91a7036f05ec3ca6773bfb19044ac91fb869a76625825f19aca891f002fdebc7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "91a7036f05ec3ca6773bfb19044ac91fb869a76625825f19aca891f002fdebc7", kill_on_drop: false }`
[INFO] [stdout] 91a7036f05ec3ca6773bfb19044ac91fb869a76625825f19aca891f002fdebc7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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=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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 50c57872481e9cfe0b794b3a2797ea57827cd1331f3b208815d44b57f119cf91
[INFO] running `Command { std: "docker" "start" "-a" "50c57872481e9cfe0b794b3a2797ea57827cd1331f3b208815d44b57f119cf91", kill_on_drop: false }`
[INFO] [stderr]    Compiling rusty_chess v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]  --> src/chess_bot.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::error::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::player_agent`
[INFO] [stdout]  --> src/game.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::player_agent;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]   --> src/game.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::thread;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ProtoMove`
[INFO] [stdout]  --> src/player_agent/player_actor.rs:3:61
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::move_parser::{chess_notation_parser, ParseError, ProtoMove};
[INFO] [stdout]   |                                                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Instant`
[INFO] [stdout]  --> src/rules.rs:1:27
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::time::{Duration, Instant};
[INFO] [stdout]   |                           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Config`
[INFO] [stdout]   --> src/main.rs:24:35
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::config::{parse_config, Config, ConfigResult};
[INFO] [stdout]    |                                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game_id`
[INFO] [stdout]   --> src/chess_bot.rs:42:35
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `move_notation`
[INFO] [stdout]   --> src/chess_bot.rs:42:50
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_move_notation`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game_id`
[INFO] [stdout]   --> src/chess_bot.rs:48:40
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stdout]    |                                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file`
[INFO] [stdout]    --> src/log.rs:273:29
[INFO] [stdout]     |
[INFO] [stdout] 273 |             LogOutput::File(file) => {
[INFO] [stdout]     |                             ^^^^ help: if this is intentional, prefix it with an underscore: `_file`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/ui.rs:81:12
[INFO] [stdout]    |
[INFO] [stdout] 81 |     fn run(mut self) -> UIManager {
[INFO] [stdout]    |            ----^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `log_handle`
[INFO] [stdout]   --> src/main.rs:67:10
[INFO] [stdout]    |
[INFO] [stdout] 67 |     let (log_handle, log_channel) = common_lib::init_logger(main_id, log_output);
[INFO] [stdout]    |          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_log_handle`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `king_moved` and `rook_moved` are never used
[INFO] [stdout]   --> src/board.rs:37:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub trait CastlingRightsExt{
[INFO] [stdout]    |           ----------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 37 |     fn king_moved(&mut self, king_color: Color);
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 38 |     fn rook_moved(&mut self, rook_color: Color, kingside: bool);
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BOARD_TEMPLATE` is never used
[INFO] [stdout]    --> src/board.rs:135:7
[INFO] [stdout]     |
[INFO] [stdout] 135 | const BOARD_TEMPLATE: &'static str =
[INFO] [stdout]     |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/board.rs:199:12
[INFO] [stdout]     |
[INFO] [stdout] 149 | impl Board {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn clone(&self) -> Board {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 239 |     pub fn get_piece_count(&self) -> u8 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 338 |     pub fn find_piece_positions(&self, piece: Piece) -> Vec<Square> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 439 |     pub fn get_char_at(&self, square: Square) -> char {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 683 |     pub fn sees_like_knight(&self, square:Square) -> Bitboard {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 791 |     pub fn get_pieces_at_bitboard(&self, bitboard: Bitboard) -> Vec<(Piece, Square)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 815 |     pub fn get_active_pieces(&self) -> Vec<(Piece, Square)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/board/pieces.rs:35:11
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl Piece {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  35 |     const PIECES_WITH_COLOR: [(Piece,Color); 12] = [
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  62 |     pub fn iter_with_color() -> impl Iterator<Item=(Piece, Color)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn is_rook(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn is_knight(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn is_bishop(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn is_queen(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub fn is_king(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 130 |     pub fn moves_diagonally(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 171 |     pub fn to_index(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 175 |     pub fn from_index(index: usize) -> Option<Piece> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/board/square.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout]  9 | ...trait SquareExt {
[INFO] [stdout]    |          --------- associated items in this trait
[INFO] [stdout] ...
[INFO] [stdout] 17 | ...const A1: Square; const A2: Square; const A3: Square; const A4: Square; const A5: Square; const A6: Square; const A7: Square; const A8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 18 | ...const B1: Square; const B2: Square; const B3: Square; const B4: Square; const B5: Square; const B6: Square; const B7: Square; const B8: S...
[INFO] [stdout]    |                            ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 19 | ...const C1: Square; const C2: Square; const C3: Square; const C4: Square; const C5: Square; const C6: Square; const C7: Square; const C8: S...
[INFO] [stdout]    |                            ^^                                  ^^                ^^                ^^                ^^
[INFO] [stdout] 20 | ...const D1: Square; const D2: Square; const D3: Square; const D4: Square; const D5: Square; const D6: Square; const D7: Square; const D8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                                  ^^                                  ^^
[INFO] [stdout] 21 | ...const E1: Square; const E2: Square; const E3: Square; const E4: Square; const E5: Square; const E6: Square; const E7: Square; const E8: S...
[INFO] [stdout]    |                                              ^^                                  ^^                ^^                ^^
[INFO] [stdout] 22 | ...const F1: Square; const F2: Square; const F3: Square; const F4: Square; const F5: Square; const F6: Square; const F7: Square; const F8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                                  ^^                                  ^^
[INFO] [stdout] 23 | ...const G1: Square; const G2: Square; const G3: Square; const G4: Square; const G5: Square; const G6: Square; const G7: Square; const G8: S...
[INFO] [stdout]    |                            ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 24 | ...const H1: Square; const H2: Square; const H3: Square; const H4: Square; const H5: Square; const H6: Square; const H7: Square; const H8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 25 | .../// Array of square labels, from "a8","b8","c8" ... to ..., "f1", "g1", "h1".
[INFO] [stdout] 26 | ...const SQUARES: [&'static str; 64];
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 | ...fn get_rows(&self, ascending : bool) -> RowIterator;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 | ...fn get_cols(&self, ascending : bool) -> ColIterator;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 | ...fn get_pos_pair(&self) -> (Row, Col);
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 46 | .../// Returns the index of the square as a `usize`.
[INFO] [stdout] 47 | ...fn get_index(&self) -> usize;
[INFO] [stdout]    |       ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61 | ...fn iter_files() -> impl Iterator<Item = char>;
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 | ...fn iter_squares() -> impl Iterator<Item = Square>;
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 | ...fn to_square_str(&self) -> &str;
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_rank` is never used
[INFO] [stdout]    --> src/board/square.rs:252:8
[INFO] [stdout]     |
[INFO] [stdout] 234 | pub trait RowExt {
[INFO] [stdout]     |           ------ method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 252 |     fn to_rank(&self) -> u8;
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_file` is never used
[INFO] [stdout]    --> src/board/square.rs:272:8
[INFO] [stdout]     |
[INFO] [stdout] 254 | pub trait ColExt {
[INFO] [stdout]     |           ------ method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 272 |     fn to_file(&self) -> char;
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RowIterator` is never constructed
[INFO] [stdout]    --> src/board/square.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct RowIterator{
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ColIterator` is never constructed
[INFO] [stdout]    --> src/board/square.rs:344:12
[INFO] [stdout]     |
[INFO] [stdout] 344 | pub struct ColIterator{
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessApiConfig` is never constructed
[INFO] [stdout]  --> src/chess_bot.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ChessApiConfig {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ChessApiError` is never used
[INFO] [stdout]   --> src/chess_bot.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ChessApiError {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessApiClient` is never constructed
[INFO] [stdout]   --> src/chess_bot.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct ChessApiClient {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `authenticate`, `make_move`, and `get_game_state` are never used
[INFO] [stdout]   --> src/chess_bot.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 29 | impl ChessApiClient {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 30 |     /// Creates a new API client with the given configuration
[INFO] [stdout] 31 |     pub fn new(config: ChessApiConfig) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub async fn authenticate(&self) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `CaptureCheck`, `CaptureCheckmate`, `CaptureStalemate`, and `GeneratedOnly` are never constructed
[INFO] [stdout]   --> src/chess_moves.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub enum MoveData {
[INFO] [stdout]    |          -------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 37 |     CaptureCheck = 21,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 38 |     CaptureCheckmate = 22,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 39 |     CaptureStalemate = 23,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     GeneratedOnly,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SpecialMoveType` is never used
[INFO] [stdout]   --> src/chess_moves.rs:55:6
[INFO] [stdout]    |
[INFO] [stdout] 55 | enum SpecialMoveType {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/chess_moves.rs:66:19
[INFO] [stdout]    |
[INFO] [stdout] 66 |     PieceNotFound(Square),
[INFO] [stdout]    |     ------------- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 66 -     PieceNotFound(Square),
[INFO] [stdout] 66 +     PieceNotFound(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/chess_moves.rs:67:20
[INFO] [stdout]    |
[INFO] [stdout] 67 |     OriginNotFound(Piece),
[INFO] [stdout]    |     -------------- ^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 67 -     OriginNotFound(Piece),
[INFO] [stdout] 67 +     OriginNotFound(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/chess_moves.rs:69:22
[INFO] [stdout]    |
[INFO] [stdout] 69 |     DisambiguousMove(Disambiguity), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stdout]    |     ---------------- ^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 69 -     DisambiguousMove(Disambiguity), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stdout] 69 +     DisambiguousMove(()), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `assemble_special_move` and `to_simplified` are never used
[INFO] [stdout]    --> src/chess_moves.rs:455:8
[INFO] [stdout]     |
[INFO] [stdout] 130 | impl ChessMove {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 455 |     fn assemble_special_move(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 517 |     pub fn to_simplified(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `special_move_builder` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1634:4
[INFO] [stdout]      |
[INFO] [stdout] 1634 | fn special_move_builder(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_none_or_promotion` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1655:4
[INFO] [stdout]      |
[INFO] [stdout] 1655 | fn build_none_or_promotion(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_move_type` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1694:4
[INFO] [stdout]      |
[INFO] [stdout] 1694 | fn build_move_type(base: MoveData, result: MoveResult) -> MoveData {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `is_check`, `is_checkmate`, `is_stalemate`, and `is_en_passant` are never used
[INFO] [stdout]     --> src/chess_moves.rs:1760:12
[INFO] [stdout]      |
[INFO] [stdout] 1704 | impl MoveData {
[INFO] [stdout]      | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1760 |     pub fn is_check(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1771 |     pub fn is_checkmate(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1782 |     pub fn is_stalemate(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1810 |     pub fn is_en_passant(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessClock` is never constructed
[INFO] [stdout]  --> src/clock.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct ChessClock{
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/clock.rs:16:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl ChessClock{
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 16 |     fn new() -> Self{
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Network`, `Game`, `Terminal`, `GUI`, and `Other` are never constructed
[INFO] [stdout]   --> src/common.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub enum ThreadIdentifier {
[INFO] [stdout]    |          ---------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 17 |     Network(ThreadIdHash),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 18 |     Game(ThreadIdHash),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 19 |     UI(ThreadIdHash),
[INFO] [stdout] 20 |     Terminal(ThreadIdHash),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 21 |     GUI(ThreadIdHash),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 22 |     Other(ThreadIdHash, &'static str),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ThreadIdentifier` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PlayerType` is never used
[INFO] [stdout]   --> src/game.rs:42:10
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub enum PlayerType{
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GameMetadata` is never constructed
[INFO] [stdout]   --> src/game.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub struct GameMetadata {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Game` is never constructed
[INFO] [stdout]   --> src/game.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct Game{
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `FullMoveNumber` is never used
[INFO] [stdout]   --> src/game.rs:70:10
[INFO] [stdout]    |
[INFO] [stdout] 70 | pub type FullMoveNumber = rules::FullMoveNumber;
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GameThread` is never constructed
[INFO] [stdout]   --> src/game.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub struct GameThread{
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameMessage` is never used
[INFO] [stdout]   --> src/game.rs:82:10
[INFO] [stdout]    |
[INFO] [stdout] 82 | pub enum GameMessage {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameResponse` is never used
[INFO] [stdout]   --> src/game.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum GameResponse {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameController` is never used
[INFO] [stdout]   --> src/game.rs:96:10
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub enum GameController {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `new_with_time_controls`, and `start_game` are never used
[INFO] [stdout]    --> src/game.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | impl Game{
[INFO] [stdout]     | --------- associated items in this implementation
[INFO] [stdout] 103 |     pub fn new(white: PlayerType, black: PlayerType) -> Game {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub fn new_with_time_controls(white: PlayerType, black: PlayerType, time_controls: TimeControls) -> Option<Game> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     fn start_game(&mut self) {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `start`, and `run` are never used
[INFO] [stdout]    --> src/game.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout] 135 | impl GameThread {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn new(game: Game) -> (GameThread, Sender<GameController>) {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 172 |     pub fn start(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     fn run(&mut self) {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlayerHandler` is never constructed
[INFO] [stdout]  --> src/handler.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct PlayerHandler{
[INFO] [stdout]   |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/handler.rs:13:13
[INFO] [stdout]    |
[INFO] [stdout] 12 |  impl PlayerHandler{
[INFO] [stdout]    |  ------------------ associated function in this implementation
[INFO] [stdout] 13 |      pub fn new(player_type: PlayerType, player_sender: mpsc::Sender<GameMessage>, player_receiver: mpsc::Receiver<GameResponse>) ->...
[INFO] [stdout]    |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `SetOutput`, `SetPrintTimestamp`, `SetTimestampDisplay`, `SetPrintThreadIdentifier`, `SetPrintLevel`, and `SetPrintMessage` are never constructed
[INFO] [stdout]   --> src/log.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub enum LogInstruction {
[INFO] [stdout]    |          -------------- variants in this enum
[INFO] [stdout] 38 |     SetLevel(LogLevel),
[INFO] [stdout] 39 |     SetOutput(LogOutput),
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 40 |     SetPrintTimestamp(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 41 |     SetTimestampDisplay(time_format::DisplayMode),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 42 |     SetPrintThreadIdentifier(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 43 |     SetPrintLevel(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 44 |     SetPrintMessage(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_id_channel_in_and_out` is never used
[INFO] [stdout]    --> src/log.rs:108:12
[INFO] [stdout]     |
[INFO] [stdout]  77 | impl LogThread {
[INFO] [stdout]     | -------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 108 |     pub fn from_id_channel_in_and_out( parent_thread: ThreadIdentifier, channel_in: Receiver<LogMessage>, out: LogOutput, ) -> (Log...
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PIECE_MAP` is never used
[INFO] [stdout]  --> src/move_parser.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub const PIECE_MAP: &[(&str, char)] = &[
[INFO] [stdout]   |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/move_parser.rs:45:19
[INFO] [stdout]    |
[INFO] [stdout] 45 |     InvalidSquare(Square),
[INFO] [stdout]    |     ------------- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 45 -     InvalidSquare(Square),
[INFO] [stdout] 45 +     InvalidSquare(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/move_parser.rs:49:29
[INFO] [stdout]    |
[INFO] [stdout] 49 |     AlgebraicParseModeError(AlgebraicParseStage),
[INFO] [stdout]    |     ----------------------- ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 49 -     AlgebraicParseModeError(AlgebraicParseStage),
[INFO] [stdout] 49 +     AlgebraicParseModeError(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/move_parser.rs:51:22
[INFO] [stdout]    |
[INFO] [stdout] 51 |     IllegalMoveError(MoveError),
[INFO] [stdout]    |     ---------------- ^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 51 -     IllegalMoveError(MoveError),
[INFO] [stdout] 51 +     IllegalMoveError(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/move_parser.rs:53:25
[INFO] [stdout]    |
[INFO] [stdout] 53 |     MalformedExpression(Token),
[INFO] [stdout]    |     ------------------- ^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 53 -     MalformedExpression(Token),
[INFO] [stdout] 53 +     MalformedExpression(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `DisambiguousMoveError` and `Todo` are never constructed
[INFO] [stdout]   --> src/move_parser.rs:50:5
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub enum ParseError{
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 50 |     DisambiguousMoveError(Disambiguity),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     Todo,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[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] [stdout] warning: variant `Piece` is never constructed
[INFO] [stdout]    --> src/move_parser.rs:141:5
[INFO] [stdout]     |
[INFO] [stdout] 140 | pub enum AlgebraicParseStage{
[INFO] [stdout]     |          ------------------- variant in this enum
[INFO] [stdout] 141 |     Piece,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AlgebraicParseStage` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PlayerClient` is never used
[INFO] [stdout]  --> src/player_agent.rs:3:10
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub enum PlayerClient {
[INFO] [stdout]   |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `PlayerController` is never used
[INFO] [stdout]  --> src/player_agent.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub trait PlayerController {
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Player` is never used
[INFO] [stdout]  --> src/player_agent/player_actor.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub trait Player {
[INFO] [stdout]   |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `FullMoveNumber` is never used
[INFO] [stdout]   --> src/rules.rs:19:10
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub type FullMoveNumber = u8;
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameState` is never used
[INFO] [stdout]   --> src/rules.rs:22:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub enum GameState {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TimeControls` is never constructed
[INFO] [stdout]    --> src/rules.rs:102:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | pub struct TimeControls {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Timer` is never used
[INFO] [stdout]    --> src/rules.rs:116:11
[INFO] [stdout]     |
[INFO] [stdout] 116 | pub trait Timer {
[INFO] [stdout]     |           ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Simple` and `Debug` are never constructed
[INFO] [stdout]   --> src/time.rs:64:9
[INFO] [stdout]    |
[INFO] [stdout] 62 |     pub enum DisplayMode {
[INFO] [stdout]    |              ----------- variants in this enum
[INFO] [stdout] 63 |         ISO8601,
[INFO] [stdout] 64 |         Simple,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 65 |         Debug,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DisplayMode` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `CurrentBackend` is never used
[INFO] [stdout]   --> src/ui.rs:16:6
[INFO] [stdout]    |
[INFO] [stdout] 16 | type CurrentBackend = backend_x11::X11Backend;
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Web` is never constructed
[INFO] [stdout]   --> src/ui.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub enum UIType {
[INFO] [stdout]    |          ------ variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 23 |     Web,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Game` is never constructed
[INFO] [stdout]   --> src/ui.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub enum UIState {
[INFO] [stdout]    |          ------- variant in this enum
[INFO] [stdout] 27 |     Menu,
[INFO] [stdout] 28 |     Game,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UserInput` is never used
[INFO] [stdout]   --> src/ui.rs:31:10
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub enum UserInput {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `ui_state` and `log_channel` are never read
[INFO] [stdout]   --> src/ui.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct UIManager {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     ui_state: UIState,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 40 |     log_channel: Option<mpsc::Sender<LogMessage>>,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `GraphicsBackend` is never used
[INFO] [stdout]   --> src/ui.rs:43:7
[INFO] [stdout]    |
[INFO] [stdout] 43 | trait GraphicsBackend {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UiUpdate` is never used
[INFO] [stdout]   --> src/ui.rs:50:10
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub enum UiUpdate {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UiMessage` is never used
[INFO] [stdout]   --> src/ui.rs:55:10
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub enum UiMessage {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WIN32Backend` is never constructed
[INFO] [stdout]  --> src/ui/backend_win32.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct WIN32Backend {
[INFO] [stdout]   |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `X11Backend` is never constructed
[INFO] [stdout]  --> src/ui/backend_x11.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct X11Backend {
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]   --> src/clock.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]   --> src/clock.rs:34:40
[INFO] [stdout]    |
[INFO] [stdout] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.26s
[INFO] running `Command { std: "docker" "inspect" "50c57872481e9cfe0b794b3a2797ea57827cd1331f3b208815d44b57f119cf91", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "50c57872481e9cfe0b794b3a2797ea57827cd1331f3b208815d44b57f119cf91", kill_on_drop: false }`
[INFO] [stdout] 50c57872481e9cfe0b794b3a2797ea57827cd1331f3b208815d44b57f119cf91
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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=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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] e46da9516903bec042634f9dae6e38eccf38fd36802c7fa36d22ef9eb990618d
[INFO] running `Command { std: "docker" "start" "-a" "e46da9516903bec042634f9dae6e38eccf38fd36802c7fa36d22ef9eb990618d", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `std::error::Error`
[INFO] [stderr]  --> src/chess_bot.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use std::error::Error;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::player_agent`
[INFO] [stderr]  --> src/game.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use crate::player_agent;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::thread`
[INFO] [stderr]   --> src/game.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use std::thread;
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ProtoMove`
[INFO] [stderr]  --> src/player_agent/player_actor.rs:3:61
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::move_parser::{chess_notation_parser, ParseError, ProtoMove};
[INFO] [stderr]   |                                                             ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Instant`
[INFO] [stderr]  --> src/rules.rs:1:27
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::time::{Duration, Instant};
[INFO] [stderr]   |                           ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Config`
[INFO] [stderr]   --> src/main.rs:24:35
[INFO] [stderr]    |
[INFO] [stderr] 24 | use crate::config::{parse_config, Config, ConfigResult};
[INFO] [stderr]    |                                   ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `game_id`
[INFO] [stderr]   --> src/chess_bot.rs:42:35
[INFO] [stderr]    |
[INFO] [stderr] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stderr]    |                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `move_notation`
[INFO] [stderr]   --> src/chess_bot.rs:42:50
[INFO] [stderr]    |
[INFO] [stderr] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stderr]    |                                                  ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_move_notation`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `game_id`
[INFO] [stderr]   --> src/chess_bot.rs:48:40
[INFO] [stderr]    |
[INFO] [stderr] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stderr]    |                                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `file`
[INFO] [stderr]    --> src/log.rs:273:29
[INFO] [stderr]     |
[INFO] [stderr] 273 |             LogOutput::File(file) => {
[INFO] [stderr]     |                             ^^^^ help: if this is intentional, prefix it with an underscore: `_file`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/ui.rs:81:12
[INFO] [stderr]    |
[INFO] [stderr] 81 |     fn run(mut self) -> UIManager {
[INFO] [stderr]    |            ----^^^^
[INFO] [stderr]    |            |
[INFO] [stderr]    |            help: remove this `mut`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `log_handle`
[INFO] [stderr]   --> src/main.rs:67:10
[INFO] [stderr]    |
[INFO] [stderr] 67 |     let (log_handle, log_channel) = common_lib::init_logger(main_id, log_output);
[INFO] [stderr]    |          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_log_handle`
[INFO] [stderr] 
[INFO] [stderr] warning: methods `king_moved` and `rook_moved` are never used
[INFO] [stderr]   --> src/board.rs:37:8
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub trait CastlingRightsExt{
[INFO] [stderr]    |           ----------------- methods in this trait
[INFO] [stderr] ...
[INFO] [stderr] 37 |     fn king_moved(&mut self, king_color: Color);
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr] 38 |     fn rook_moved(&mut self, rook_color: Color, kingside: bool);
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `BOARD_TEMPLATE` is never used
[INFO] [stderr]    --> src/board.rs:135:7
[INFO] [stderr]     |
[INFO] [stderr] 135 | const BOARD_TEMPLATE: &'static str =
[INFO] [stderr]     |       ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/board.rs:199:12
[INFO] [stderr]     |
[INFO] [stderr] 149 | impl Board {
[INFO] [stderr]     | ---------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 199 |     pub fn clone(&self) -> Board {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 239 |     pub fn get_piece_count(&self) -> u8 {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 338 |     pub fn find_piece_positions(&self, piece: Piece) -> Vec<Square> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 439 |     pub fn get_char_at(&self, square: Square) -> char {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 683 |     pub fn sees_like_knight(&self, square:Square) -> Bitboard {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 791 |     pub fn get_pieces_at_bitboard(&self, bitboard: Bitboard) -> Vec<(Piece, Square)> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 815 |     pub fn get_active_pieces(&self) -> Vec<(Piece, Square)> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/board/pieces.rs:35:11
[INFO] [stderr]     |
[INFO] [stderr]  26 | impl Piece {
[INFO] [stderr]     | ---------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  35 |     const PIECES_WITH_COLOR: [(Piece,Color); 12] = [
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  62 |     pub fn iter_with_color() -> impl Iterator<Item=(Piece, Color)> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  99 |     pub fn is_rook(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 105 |     pub fn is_knight(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 111 |     pub fn is_bishop(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 117 |     pub fn is_queen(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 123 |     pub fn is_king(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 130 |     pub fn moves_diagonally(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 171 |     pub fn to_index(&self) -> usize {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 175 |     pub fn from_index(index: usize) -> Option<Piece> {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]   --> src/board/square.rs:17:11
[INFO] [stderr]    |
[INFO] [stderr]  9 | ...trait SquareExt {
[INFO] [stderr]    |          --------- associated items in this trait
[INFO] [stderr] ...
[INFO] [stderr] 17 | ...const A1: Square; const A2: Square; const A3: Square; const A4: Square; const A5: Square; const A6: Square; const A7: Square; const A8: S...
[INFO] [stderr]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stderr] 18 | ...const B1: Square; const B2: Square; const B3: Square; const B4: Square; const B5: Square; const B6: Square; const B7: Square; const B8: S...
[INFO] [stderr]    |                            ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stderr] 19 | ...const C1: Square; const C2: Square; const C3: Square; const C4: Square; const C5: Square; const C6: Square; const C7: Square; const C8: S...
[INFO] [stderr]    |                            ^^                                  ^^                ^^                ^^                ^^
[INFO] [stderr] 20 | ...const D1: Square; const D2: Square; const D3: Square; const D4: Square; const D5: Square; const D6: Square; const D7: Square; const D8: S...
[INFO] [stderr]    |          ^^                ^^                ^^                ^^                                  ^^                                  ^^
[INFO] [stderr] 21 | ...const E1: Square; const E2: Square; const E3: Square; const E4: Square; const E5: Square; const E6: Square; const E7: Square; const E8: S...
[INFO] [stderr]    |                                              ^^                                  ^^                ^^                ^^
[INFO] [stderr] 22 | ...const F1: Square; const F2: Square; const F3: Square; const F4: Square; const F5: Square; const F6: Square; const F7: Square; const F8: S...
[INFO] [stderr]    |          ^^                ^^                ^^                ^^                                  ^^                                  ^^
[INFO] [stderr] 23 | ...const G1: Square; const G2: Square; const G3: Square; const G4: Square; const G5: Square; const G6: Square; const G7: Square; const G8: S...
[INFO] [stderr]    |                            ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stderr] 24 | ...const H1: Square; const H2: Square; const H3: Square; const H4: Square; const H5: Square; const H6: Square; const H7: Square; const H8: S...
[INFO] [stderr]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stderr] 25 | .../// Array of square labels, from "a8","b8","c8" ... to ..., "f1", "g1", "h1".
[INFO] [stderr] 26 | ...const SQUARES: [&'static str; 64];
[INFO] [stderr]    |          ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 35 | ...fn get_rows(&self, ascending : bool) -> RowIterator;
[INFO] [stderr]    |       ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 41 | ...fn get_cols(&self, ascending : bool) -> ColIterator;
[INFO] [stderr]    |       ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 45 | ...fn get_pos_pair(&self) -> (Row, Col);
[INFO] [stderr]    |       ^^^^^^^^^^^^
[INFO] [stderr] 46 | .../// Returns the index of the square as a `usize`.
[INFO] [stderr] 47 | ...fn get_index(&self) -> usize;
[INFO] [stderr]    |       ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 61 | ...fn iter_files() -> impl Iterator<Item = char>;
[INFO] [stderr]    |       ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 65 | ...fn iter_squares() -> impl Iterator<Item = Square>;
[INFO] [stderr]    |       ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 70 | ...fn to_square_str(&self) -> &str;
[INFO] [stderr]    |       ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `to_rank` is never used
[INFO] [stderr]    --> src/board/square.rs:252:8
[INFO] [stderr]     |
[INFO] [stderr] 234 | pub trait RowExt {
[INFO] [stderr]     |           ------ method in this trait
[INFO] [stderr] ...
[INFO] [stderr] 252 |     fn to_rank(&self) -> u8;
[INFO] [stderr]     |        ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `to_file` is never used
[INFO] [stderr]    --> src/board/square.rs:272:8
[INFO] [stderr]     |
[INFO] [stderr] 254 | pub trait ColExt {
[INFO] [stderr]     |           ------ method in this trait
[INFO] [stderr] ...
[INFO] [stderr] 272 |     fn to_file(&self) -> char;
[INFO] [stderr]     |        ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `RowIterator` is never constructed
[INFO] [stderr]    --> src/board/square.rs:340:12
[INFO] [stderr]     |
[INFO] [stderr] 340 | pub struct RowIterator{
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ColIterator` is never constructed
[INFO] [stderr]    --> src/board/square.rs:344:12
[INFO] [stderr]     |
[INFO] [stderr] 344 | pub struct ColIterator{
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ChessApiConfig` is never constructed
[INFO] [stderr]  --> src/chess_bot.rs:9:12
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub struct ChessApiConfig {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `ChessApiError` is never used
[INFO] [stderr]   --> src/chess_bot.rs:17:10
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub enum ChessApiError {
[INFO] [stderr]    |          ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ChessApiClient` is never constructed
[INFO] [stderr]   --> src/chess_bot.rs:25:12
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub struct ChessApiClient {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `authenticate`, `make_move`, and `get_game_state` are never used
[INFO] [stderr]   --> src/chess_bot.rs:31:12
[INFO] [stderr]    |
[INFO] [stderr] 29 | impl ChessApiClient {
[INFO] [stderr]    | ------------------- associated items in this implementation
[INFO] [stderr] 30 |     /// Creates a new API client with the given configuration
[INFO] [stderr] 31 |     pub fn new(config: ChessApiConfig) -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 36 |     pub async fn authenticate(&self) -> Result<(), ChessApiError> {
[INFO] [stderr]    |                  ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stderr]    |                  ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `CaptureCheck`, `CaptureCheckmate`, `CaptureStalemate`, and `GeneratedOnly` are never constructed
[INFO] [stderr]   --> src/chess_moves.rs:37:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub enum MoveData {
[INFO] [stderr]    |          -------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 37 |     CaptureCheck = 21,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 38 |     CaptureCheckmate = 22,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 39 |     CaptureStalemate = 23,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 45 |     GeneratedOnly,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MoveData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: enum `SpecialMoveType` is never used
[INFO] [stderr]   --> src/chess_moves.rs:55:6
[INFO] [stderr]    |
[INFO] [stderr] 55 | enum SpecialMoveType {
[INFO] [stderr]    |      ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/chess_moves.rs:66:19
[INFO] [stderr]    |
[INFO] [stderr] 66 |     PieceNotFound(Square),
[INFO] [stderr]    |     ------------- ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 66 -     PieceNotFound(Square),
[INFO] [stderr] 66 +     PieceNotFound(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/chess_moves.rs:67:20
[INFO] [stderr]    |
[INFO] [stderr] 67 |     OriginNotFound(Piece),
[INFO] [stderr]    |     -------------- ^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 67 -     OriginNotFound(Piece),
[INFO] [stderr] 67 +     OriginNotFound(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/chess_moves.rs:69:22
[INFO] [stderr]    |
[INFO] [stderr] 69 |     DisambiguousMove(Disambiguity), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stderr]    |     ---------------- ^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 69 -     DisambiguousMove(Disambiguity), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stderr] 69 +     DisambiguousMove(()), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `assemble_special_move` and `to_simplified` are never used
[INFO] [stderr]    --> src/chess_moves.rs:455:8
[INFO] [stderr]     |
[INFO] [stderr] 130 | impl ChessMove {
[INFO] [stderr]     | -------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 455 |     fn assemble_special_move(
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 517 |     pub fn to_simplified(&self) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `special_move_builder` is never used
[INFO] [stderr]     --> src/chess_moves.rs:1634:4
[INFO] [stderr]      |
[INFO] [stderr] 1634 | fn special_move_builder(
[INFO] [stderr]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_none_or_promotion` is never used
[INFO] [stderr]     --> src/chess_moves.rs:1655:4
[INFO] [stderr]      |
[INFO] [stderr] 1655 | fn build_none_or_promotion(
[INFO] [stderr]      |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_move_type` is never used
[INFO] [stderr]     --> src/chess_moves.rs:1694:4
[INFO] [stderr]      |
[INFO] [stderr] 1694 | fn build_move_type(base: MoveData, result: MoveResult) -> MoveData {
[INFO] [stderr]      |    ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `is_check`, `is_checkmate`, `is_stalemate`, and `is_en_passant` are never used
[INFO] [stderr]     --> src/chess_moves.rs:1760:12
[INFO] [stderr]      |
[INFO] [stderr] 1704 | impl MoveData {
[INFO] [stderr]      | ------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 1760 |     pub fn is_check(&self) -> bool {
[INFO] [stderr]      |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1771 |     pub fn is_checkmate(&self) -> bool {
[INFO] [stderr]      |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1782 |     pub fn is_stalemate(&self) -> bool {
[INFO] [stderr]      |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1810 |     pub fn is_en_passant(&self) -> bool {
[INFO] [stderr]      |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ChessClock` is never constructed
[INFO] [stderr]  --> src/clock.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct ChessClock{
[INFO] [stderr]   |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/clock.rs:16:8
[INFO] [stderr]    |
[INFO] [stderr] 15 | impl ChessClock{
[INFO] [stderr]    | --------------- associated function in this implementation
[INFO] [stderr] 16 |     fn new() -> Self{
[INFO] [stderr]    |        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Network`, `Game`, `Terminal`, `GUI`, and `Other` are never constructed
[INFO] [stderr]   --> src/common.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub enum ThreadIdentifier {
[INFO] [stderr]    |          ---------------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 17 |     Network(ThreadIdHash),
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] 18 |     Game(ThreadIdHash),
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 19 |     UI(ThreadIdHash),
[INFO] [stderr] 20 |     Terminal(ThreadIdHash),
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 21 |     GUI(ThreadIdHash),
[INFO] [stderr]    |     ^^^
[INFO] [stderr] 22 |     Other(ThreadIdHash, &'static str),
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ThreadIdentifier` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: enum `PlayerType` is never used
[INFO] [stderr]   --> src/game.rs:42:10
[INFO] [stderr]    |
[INFO] [stderr] 42 | pub enum PlayerType{
[INFO] [stderr]    |          ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `GameMetadata` is never constructed
[INFO] [stderr]   --> src/game.rs:55:12
[INFO] [stderr]    |
[INFO] [stderr] 55 | pub struct GameMetadata {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Game` is never constructed
[INFO] [stderr]   --> src/game.rs:62:12
[INFO] [stderr]    |
[INFO] [stderr] 62 | pub struct Game{
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `FullMoveNumber` is never used
[INFO] [stderr]   --> src/game.rs:70:10
[INFO] [stderr]    |
[INFO] [stderr] 70 | pub type FullMoveNumber = rules::FullMoveNumber;
[INFO] [stderr]    |          ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `GameThread` is never constructed
[INFO] [stderr]   --> src/game.rs:72:12
[INFO] [stderr]    |
[INFO] [stderr] 72 | pub struct GameThread{
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `GameMessage` is never used
[INFO] [stderr]   --> src/game.rs:82:10
[INFO] [stderr]    |
[INFO] [stderr] 82 | pub enum GameMessage {
[INFO] [stderr]    |          ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `GameResponse` is never used
[INFO] [stderr]   --> src/game.rs:89:10
[INFO] [stderr]    |
[INFO] [stderr] 89 | pub enum GameResponse {
[INFO] [stderr]    |          ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `GameController` is never used
[INFO] [stderr]   --> src/game.rs:96:10
[INFO] [stderr]    |
[INFO] [stderr] 96 | pub enum GameController {
[INFO] [stderr]    |          ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `new_with_time_controls`, and `start_game` are never used
[INFO] [stderr]    --> src/game.rs:103:12
[INFO] [stderr]     |
[INFO] [stderr] 102 | impl Game{
[INFO] [stderr]     | --------- associated items in this implementation
[INFO] [stderr] 103 |     pub fn new(white: PlayerType, black: PlayerType) -> Game {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 112 |     pub fn new_with_time_controls(white: PlayerType, black: PlayerType, time_controls: TimeControls) -> Option<Game> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 125 |     fn start_game(&mut self) {
[INFO] [stderr]     |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `start`, and `run` are never used
[INFO] [stderr]    --> src/game.rs:142:12
[INFO] [stderr]     |
[INFO] [stderr] 135 | impl GameThread {
[INFO] [stderr]     | --------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 142 |     pub fn new(game: Game) -> (GameThread, Sender<GameController>) {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 172 |     pub fn start(mut self) -> Self {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 179 |     fn run(&mut self) {
[INFO] [stderr]     |        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PlayerHandler` is never constructed
[INFO] [stderr]  --> src/handler.rs:7:12
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub struct PlayerHandler{
[INFO] [stderr]   |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/handler.rs:13:13
[INFO] [stderr]    |
[INFO] [stderr] 12 |  impl PlayerHandler{
[INFO] [stderr]    |  ------------------ associated function in this implementation
[INFO] [stderr] 13 |      pub fn new(player_type: PlayerType, player_sender: mpsc::Sender<GameMessage>, player_receiver: mpsc::Receiver<GameResponse>) ->...
[INFO] [stderr]    |             ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `SetOutput`, `SetPrintTimestamp`, `SetTimestampDisplay`, `SetPrintThreadIdentifier`, `SetPrintLevel`, and `SetPrintMessage` are never constructed
[INFO] [stderr]   --> src/log.rs:39:5
[INFO] [stderr]    |
[INFO] [stderr] 37 | pub enum LogInstruction {
[INFO] [stderr]    |          -------------- variants in this enum
[INFO] [stderr] 38 |     SetLevel(LogLevel),
[INFO] [stderr] 39 |     SetOutput(LogOutput),
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 40 |     SetPrintTimestamp(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 41 |     SetTimestampDisplay(time_format::DisplayMode),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 42 |     SetPrintThreadIdentifier(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 43 |     SetPrintLevel(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 44 |     SetPrintMessage(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_id_channel_in_and_out` is never used
[INFO] [stderr]    --> src/log.rs:108:12
[INFO] [stderr]     |
[INFO] [stderr]  77 | impl LogThread {
[INFO] [stderr]     | -------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 108 |     pub fn from_id_channel_in_and_out( parent_thread: ThreadIdentifier, channel_in: Receiver<LogMessage>, out: LogOutput, ) -> (Log...
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `PIECE_MAP` is never used
[INFO] [stderr]  --> src/move_parser.rs:7:11
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub const PIECE_MAP: &[(&str, char)] = &[
[INFO] [stderr]   |           ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/move_parser.rs:45:19
[INFO] [stderr]    |
[INFO] [stderr] 45 |     InvalidSquare(Square),
[INFO] [stderr]    |     ------------- ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 45 -     InvalidSquare(Square),
[INFO] [stderr] 45 +     InvalidSquare(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/move_parser.rs:49:29
[INFO] [stderr]    |
[INFO] [stderr] 49 |     AlgebraicParseModeError(AlgebraicParseStage),
[INFO] [stderr]    |     ----------------------- ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 49 -     AlgebraicParseModeError(AlgebraicParseStage),
[INFO] [stderr] 49 +     AlgebraicParseModeError(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/move_parser.rs:51:22
[INFO] [stderr]    |
[INFO] [stderr] 51 |     IllegalMoveError(MoveError),
[INFO] [stderr]    |     ---------------- ^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 51 -     IllegalMoveError(MoveError),
[INFO] [stderr] 51 +     IllegalMoveError(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/move_parser.rs:53:25
[INFO] [stderr]    |
[INFO] [stderr] 53 |     MalformedExpression(Token),
[INFO] [stderr]    |     ------------------- ^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 53 -     MalformedExpression(Token),
[INFO] [stderr] 53 +     MalformedExpression(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: variants `DisambiguousMoveError` and `Todo` are never constructed
[INFO] [stderr]   --> src/move_parser.rs:50:5
[INFO] [stderr]    |
[INFO] [stderr] 39 | pub enum ParseError{
[INFO] [stderr]    |          ---------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 50 |     DisambiguousMoveError(Disambiguity),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 54 |     Todo,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr]    |
[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: variant `Piece` is never constructed
[INFO] [stderr]    --> src/move_parser.rs:141:5
[INFO] [stderr]     |
[INFO] [stderr] 140 | pub enum AlgebraicParseStage{
[INFO] [stderr]     |          ------------------- variant in this enum
[INFO] [stderr] 141 |     Piece,
[INFO] [stderr]     |     ^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `AlgebraicParseStage` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: enum `PlayerClient` is never used
[INFO] [stderr]  --> src/player_agent.rs:3:10
[INFO] [stderr]   |
[INFO] [stderr] 3 | pub enum PlayerClient {
[INFO] [stderr]   |          ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `PlayerController` is never used
[INFO] [stderr]  --> src/player_agent.rs:7:11
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub trait PlayerController {
[INFO] [stderr]   |           ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `Player` is never used
[INFO] [stderr]  --> src/player_agent/player_actor.rs:5:11
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub trait Player {
[INFO] [stderr]   |           ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `FullMoveNumber` is never used
[INFO] [stderr]   --> src/rules.rs:19:10
[INFO] [stderr]    |
[INFO] [stderr] 19 | pub type FullMoveNumber = u8;
[INFO] [stderr]    |          ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `GameState` is never used
[INFO] [stderr]   --> src/rules.rs:22:10
[INFO] [stderr]    |
[INFO] [stderr] 22 | pub enum GameState {
[INFO] [stderr]    |          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `TimeControls` is never constructed
[INFO] [stderr]    --> src/rules.rs:102:12
[INFO] [stderr]     |
[INFO] [stderr] 102 | pub struct TimeControls {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `Timer` is never used
[INFO] [stderr]    --> src/rules.rs:116:11
[INFO] [stderr]     |
[INFO] [stderr] 116 | pub trait Timer {
[INFO] [stderr]     |           ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Simple` and `Debug` are never constructed
[INFO] [stderr]   --> src/time.rs:64:9
[INFO] [stderr]    |
[INFO] [stderr] 62 |     pub enum DisplayMode {
[INFO] [stderr]    |              ----------- variants in this enum
[INFO] [stderr] 63 |         ISO8601,
[INFO] [stderr] 64 |         Simple,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 65 |         Debug,
[INFO] [stderr]    |         ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `DisplayMode` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `CurrentBackend` is never used
[INFO] [stderr]   --> src/ui.rs:16:6
[INFO] [stderr]    |
[INFO] [stderr] 16 | type CurrentBackend = backend_x11::X11Backend;
[INFO] [stderr]    |      ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Web` is never constructed
[INFO] [stderr]   --> src/ui.rs:23:5
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub enum UIType {
[INFO] [stderr]    |          ------ variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 23 |     Web,
[INFO] [stderr]    |     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Game` is never constructed
[INFO] [stderr]   --> src/ui.rs:28:5
[INFO] [stderr]    |
[INFO] [stderr] 26 | pub enum UIState {
[INFO] [stderr]    |          ------- variant in this enum
[INFO] [stderr] 27 |     Menu,
[INFO] [stderr] 28 |     Game,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `UserInput` is never used
[INFO] [stderr]   --> src/ui.rs:31:10
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub enum UserInput {
[INFO] [stderr]    |          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `ui_state` and `log_channel` are never read
[INFO] [stderr]   --> src/ui.rs:39:5
[INFO] [stderr]    |
[INFO] [stderr] 36 | pub struct UIManager {
[INFO] [stderr]    |            --------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 39 |     ui_state: UIState,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 40 |     log_channel: Option<mpsc::Sender<LogMessage>>,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `GraphicsBackend` is never used
[INFO] [stderr]   --> src/ui.rs:43:7
[INFO] [stderr]    |
[INFO] [stderr] 43 | trait GraphicsBackend {
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `UiUpdate` is never used
[INFO] [stderr]   --> src/ui.rs:50:10
[INFO] [stderr]    |
[INFO] [stderr] 50 | pub enum UiUpdate {
[INFO] [stderr]    |          ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `UiMessage` is never used
[INFO] [stderr]   --> src/ui.rs:55:10
[INFO] [stderr]    |
[INFO] [stderr] 55 | pub enum UiMessage {
[INFO] [stderr]    |          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `WIN32Backend` is never constructed
[INFO] [stderr]  --> src/ui/backend_win32.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct WIN32Backend {
[INFO] [stderr]   |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `X11Backend` is never constructed
[INFO] [stderr]  --> src/ui/backend_x11.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct X11Backend {
[INFO] [stderr]   |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: comparison is useless due to type limits
[INFO] [stderr]   --> src/clock.rs:34:12
[INFO] [stderr]    |
[INFO] [stderr] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: comparison is useless due to type limits
[INFO] [stderr]   --> src/clock.rs:34:40
[INFO] [stderr]    |
[INFO] [stderr] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stderr]    |                                        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `rusty_chess` (bin "rusty_chess" test) generated 79 warnings (run `cargo fix --bin "rusty_chess" -p rusty_chess --tests` to apply 12 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.07s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/rusty_chess-ab40282b0590ba38)
[INFO] [stdout] 
[INFO] [stdout] running 34 tests
[INFO] [stdout] test config::tests::parse_line_test_false_returns_error ... ok
[INFO] [stdout] test config::tests::parse_line_sets_terminal_true ... ok
[INFO] [stdout] test config::tests::update_result_accumulates_errors ... ok
[INFO] [stdout] test config::tests::parse_line_sets_log_file_path ... ok
[INFO] [stdout] test move_parser::tests::test_chess_move_pawn_two_step ... ok
[INFO] [stdout] test move_parser::tests::test_chess_move_knight_opening ... ok
[INFO] [stdout] test move_parser::tests::test_chess_move_disambiguate ... ok
[INFO] [stdout] test move_parser::tests::test_chess_move_illegal_rook_jump ... ok
[INFO] [stdout] test move_parser::tests::test_lan_promotion ... ok
[INFO] [stdout] test move_parser::tests::test_san_capture_with_check ... ok
[INFO] [stdout] test move_parser::tests::test_san_invalid_token ... ok
[INFO] [stdout] test move_parser::tests::test_san_kingside_castle ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_file_and_rank ... ok
[INFO] [stdout] test move_parser::tests::test_lan_missing_origin ... ok
[INFO] [stdout] test move_parser::tests::test_promotion_pre_processing ... ok
[INFO] [stdout] test move_parser::tests::test_mixed_tokens ... ok
[INFO] [stdout] test move_parser::tests::test_san_disambiguation_by_file ... ok
[INFO] [stdout] test move_parser::tests::test_proto_missing_target_square ... ok
[INFO] [stdout] test move_parser::tests::test_square_pre_processing ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_capture_and_check ... ok
[INFO] [stdout] test config::tests::parse_line_sets_log_mode_terminal ... ok
[INFO] [stdout] test config::tests::parse_config_invalid_utf8 ... FAILED
[INFO] [stdout] test config::tests::parse_config_no_file ... FAILED
[INFO] [stdout] test config::tests::parse_config_valid_file ... FAILED
[INFO] [stdout] test move_parser::tests::test_san_promotion ... ok
[INFO] [stdout] test move_parser::tests::test_lan_basic_move ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_queenside_castling_zero ... ok
[INFO] [stdout] test move_parser::tests::test_unrecognized_char ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_piece ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_promotion ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_kingside_castling_zero ... ok
[INFO] [stdout] test move_parser::tests::test_san_simple_knight_move ... ok
[INFO] [stderr] error: test failed, to rerun pass `--bin rusty_chess`
[INFO] [stdout] test move_parser::tests::test_tokenize_kingside_castling_o ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_queenside_castling_o ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- config::tests::parse_config_invalid_utf8 stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'config::tests::parse_config_invalid_utf8' (25) panicked at src/config.rs:232:50:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5586237c9dc2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5586237c9dc2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::trace_unsynchronized::<std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5586237c9dc2 - std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5586237c9dc2 - <<std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[585f66e14d78f9ba]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5586237de69a - <core[585f66e14d78f9ba]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5586237de69a - core[585f66e14d78f9ba]::fmt::write
[INFO] [stdout]    6:     0x5586237cebe6 - std[3f03f8b59f91bef1]::io::default_write_fmt::<alloc[15e7b27aba85d2e2]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5586237cebe6 - <alloc[15e7b27aba85d2e2]::vec::Vec<u8> as std[3f03f8b59f91bef1]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5586237a79bf - <std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5586237a79bf - std[3f03f8b59f91bef1]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5586237c1559 - std[3f03f8b59f91bef1]::panicking::default_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x55862375cede - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x55862375cede - test[30224e0cb089acd2]::test_main_with_exit_callback::<test[30224e0cb089acd2]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5586237c1712 - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5586237c1712 - std[3f03f8b59f91bef1]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5586237a7a78 - std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x55862379cbb9 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_end_short_backtrace::<std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5586237a88cd - __rustc[caa99d26c7bae192]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5586237ded6c - core[585f66e14d78f9ba]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5586237deae2 - core[585f66e14d78f9ba]::result::unwrap_failed
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/result.rs:1867:5
[INFO] [stdout]   20:     0x5586237312f1 - <core[585f66e14d78f9ba]::result::Result<std[3f03f8b59f91bef1]::fs::File, std[3f03f8b59f91bef1]::io::error::Error>>::unwrap
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/result.rs:1233:23
[INFO] [stdout]   21:     0x5586237312f1 - rusty_chess[2cfc966c7bece4ee]::config::tests::parse_config_invalid_utf8
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:232:50
[INFO] [stdout]   22:     0x55862372ec87 - rusty_chess[2cfc966c7bece4ee]::config::tests::parse_config_invalid_utf8::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:230:35
[INFO] [stdout]   23:     0x558623743a96 - <rusty_chess[2cfc966c7bece4ee]::config::tests::parse_config_invalid_utf8::{closure#0} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x55862375128b - <fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x55862375128b - test[30224e0cb089acd2]::__rust_begin_short_backtrace::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x55862375daea - test[30224e0cb089acd2]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x55862375daea - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x55862375daea - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   29:     0x55862375daea - std[3f03f8b59f91bef1]::panicking::catch_unwind::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   30:     0x55862375daea - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x55862375daea - test[30224e0cb089acd2]::run_test_in_process
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x55862375daea - test[30224e0cb089acd2]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x558623757fb4 - test[30224e0cb089acd2]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x558623757fb4 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_begin_short_backtrace::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   35:     0x5586237605e2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   36:     0x5586237605e2 - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x5586237605e2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   38:     0x5586237605e2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::<(), core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   39:     0x5586237605e2 - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x5586237605e2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   41:     0x5586237605e2 - <std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x5586237c95cf - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn core[585f66e14d78f9ba]::ops::function::FnOnce<(), Output = ()> + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   43:     0x5586237c95cf - <std[3f03f8b59f91bef1]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   44:     0x7aa33b7bfaa4 - <unknown>
[INFO] [stdout]   45:     0x7aa33b84ca64 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- config::tests::parse_config_no_file stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'config::tests::parse_config_no_file' (26) panicked at src/config.rs:223:38:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5586237c9dc2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5586237c9dc2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::trace_unsynchronized::<std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5586237c9dc2 - std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5586237c9dc2 - <<std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[585f66e14d78f9ba]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5586237de69a - <core[585f66e14d78f9ba]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5586237de69a - core[585f66e14d78f9ba]::fmt::write
[INFO] [stdout]    6:     0x5586237cebe6 - std[3f03f8b59f91bef1]::io::default_write_fmt::<alloc[15e7b27aba85d2e2]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5586237cebe6 - <alloc[15e7b27aba85d2e2]::vec::Vec<u8> as std[3f03f8b59f91bef1]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5586237a79bf - <std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5586237a79bf - std[3f03f8b59f91bef1]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5586237c1559 - std[3f03f8b59f91bef1]::panicking::default_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x55862375cede - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x55862375cede - test[30224e0cb089acd2]::test_main_with_exit_callback::<test[30224e0cb089acd2]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5586237c1712 - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5586237c1712 - std[3f03f8b59f91bef1]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5586237a7a78 - std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x55862379cbb9 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_end_short_backtrace::<std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5586237a88cd - __rustc[caa99d26c7bae192]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5586237ded6c - core[585f66e14d78f9ba]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5586237deae2 - core[585f66e14d78f9ba]::result::unwrap_failed
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/result.rs:1867:5
[INFO] [stdout]   20:     0x558623730e13 - <core[585f66e14d78f9ba]::result::Result<(), std[3f03f8b59f91bef1]::io::error::Error>>::unwrap
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/result.rs:1233:23
[INFO] [stdout]   21:     0x558623730e13 - rusty_chess[2cfc966c7bece4ee]::config::tests::parse_config_no_file
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:223:38
[INFO] [stdout]   22:     0x55862372ec27 - rusty_chess[2cfc966c7bece4ee]::config::tests::parse_config_no_file::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:221:30
[INFO] [stdout]   23:     0x558623743a16 - <rusty_chess[2cfc966c7bece4ee]::config::tests::parse_config_no_file::{closure#0} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x55862375128b - <fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x55862375128b - test[30224e0cb089acd2]::__rust_begin_short_backtrace::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x55862375daea - test[30224e0cb089acd2]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x55862375daea - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x55862375daea - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   29:     0x55862375daea - std[3f03f8b59f91bef1]::panicking::catch_unwind::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   30:     0x55862375daea - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x55862375daea - test[30224e0cb089acd2]::run_test_in_process
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x55862375daea - test[30224e0cb089acd2]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x558623757fb4 - test[30224e0cb089acd2]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x558623757fb4 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_begin_short_backtrace::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   35:     0x5586237605e2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   36:     0x5586237605e2 - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x5586237605e2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   38:     0x5586237605e2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::<(), core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   39:     0x5586237605e2 - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x5586237605e2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   41:     0x5586237605e2 - <std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x5586237c95cf - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn core[585f66e14d78f9ba]::ops::function::FnOnce<(), Output = ()> + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   43:     0x5586237c95cf - <std[3f03f8b59f91bef1]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   44:     0x7aa33b7bfaa4 - <unknown>
[INFO] [stdout]   45:     0x7aa33b84ca64 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- config::tests::parse_config_valid_file stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'config::tests::parse_config_valid_file' (27) panicked at src/config.rs:177:44:
[INFO] [stdout] Failed to create temp file: Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5586237c9dc2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5586237c9dc2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::trace_unsynchronized::<std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5586237c9dc2 - std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5586237c9dc2 - <<std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[585f66e14d78f9ba]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5586237de69a - <core[585f66e14d78f9ba]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5586237de69a - core[585f66e14d78f9ba]::fmt::write
[INFO] [stdout]    6:     0x5586237cebe6 - std[3f03f8b59f91bef1]::io::default_write_fmt::<alloc[15e7b27aba85d2e2]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5586237cebe6 - <alloc[15e7b27aba85d2e2]::vec::Vec<u8> as std[3f03f8b59f91bef1]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5586237a79bf - <std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5586237a79bf - std[3f03f8b59f91bef1]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5586237c1559 - std[3f03f8b59f91bef1]::panicking::default_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x55862375cede - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x55862375cede - test[30224e0cb089acd2]::test_main_with_exit_callback::<test[30224e0cb089acd2]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5586237c1712 - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5586237c1712 - std[3f03f8b59f91bef1]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5586237a7a78 - std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x55862379cbb9 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_end_short_backtrace::<std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5586237a88cd - __rustc[caa99d26c7bae192]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5586237ded6c - core[585f66e14d78f9ba]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5586237deae2 - core[585f66e14d78f9ba]::result::unwrap_failed
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/result.rs:1867:5
[INFO] [stdout]   20:     0x55862374445e - <core[585f66e14d78f9ba]::result::Result<std[3f03f8b59f91bef1]::fs::File, std[3f03f8b59f91bef1]::io::error::Error>>::expect
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/result.rs:1185:23
[INFO] [stdout]   21:     0x558623730c51 - rusty_chess[2cfc966c7bece4ee]::config::tests::temp_file
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:177:44
[INFO] [stdout]   22:     0x558623730ecf - rusty_chess[2cfc966c7bece4ee]::config::tests::parse_config_valid_file
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:243:20
[INFO] [stdout]   23:     0x55862372ec57 - rusty_chess[2cfc966c7bece4ee]::config::tests::parse_config_valid_file::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:242:33
[INFO] [stdout]   24:     0x558623743a56 - <rusty_chess[2cfc966c7bece4ee]::config::tests::parse_config_valid_file::{closure#0} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x55862375128b - <fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   26:     0x55862375128b - test[30224e0cb089acd2]::__rust_begin_short_backtrace::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:663:18
[INFO] [stdout]   27:     0x55862375daea - test[30224e0cb089acd2]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:74
[INFO] [stdout]   28:     0x55862375daea - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   29:     0x55862375daea - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   30:     0x55862375daea - std[3f03f8b59f91bef1]::panicking::catch_unwind::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   31:     0x55862375daea - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   32:     0x55862375daea - test[30224e0cb089acd2]::run_test_in_process
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:27
[INFO] [stdout]   33:     0x55862375daea - test[30224e0cb089acd2]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:607:43
[INFO] [stdout]   34:     0x558623757fb4 - test[30224e0cb089acd2]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:637:41
[INFO] [stdout]   35:     0x558623757fb4 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_begin_short_backtrace::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   36:     0x5586237605e2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   37:     0x5586237605e2 - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   38:     0x5586237605e2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   39:     0x5586237605e2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::<(), core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   40:     0x5586237605e2 - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   41:     0x5586237605e2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   42:     0x5586237605e2 - <std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   43:     0x5586237c95cf - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn core[585f66e14d78f9ba]::ops::function::FnOnce<(), Output = ()> + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   44:     0x5586237c95cf - <std[3f03f8b59f91bef1]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   45:     0x7aa33b7bfaa4 - <unknown>
[INFO] [stdout]   46:     0x7aa33b84ca64 - clone
[INFO] [stdout]   47:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     config::tests::parse_config_invalid_utf8
[INFO] [stdout]     config::tests::parse_config_no_file
[INFO] [stdout]     config::tests::parse_config_valid_file
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 31 passed; 3 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.24s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "e46da9516903bec042634f9dae6e38eccf38fd36802c7fa36d22ef9eb990618d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e46da9516903bec042634f9dae6e38eccf38fd36802c7fa36d22ef9eb990618d", kill_on_drop: false }`
[INFO] [stdout] e46da9516903bec042634f9dae6e38eccf38fd36802c7fa36d22ef9eb990618d
