[INFO] cloning repository https://github.com/pseguin2011/dame_de_pique [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/pseguin2011/dame_de_pique" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpseguin2011%2Fdame_de_pique", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpseguin2011%2Fdame_de_pique'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 284976912efa636d4e785954861f133fe64b6b1f [INFO] checking pseguin2011/dame_de_pique against try#e58ab0492e70733577a2aa8f09aa11a81ccf8005 for pr-113457 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpseguin2011%2Fdame_de_pique" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/pseguin2011/dame_de_pique on toolchain e58ab0492e70733577a2aa8f09aa11a81ccf8005 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+e58ab0492e70733577a2aa8f09aa11a81ccf8005" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/pseguin2011/dame_de_pique [INFO] finished tweaking git repo https://github.com/pseguin2011/dame_de_pique [INFO] tweaked toml for git repo https://github.com/pseguin2011/dame_de_pique written to /workspace/builds/worker-7-tc2/source/Cargo.toml [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+e58ab0492e70733577a2aa8f09aa11a81ccf8005" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Updating git repository `https://github.com/pseguin2011/card_game_engine` [INFO] [stderr] Updating crates.io index [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+e58ab0492e70733577a2aa8f09aa11a81ccf8005" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded serde v1.0.174 [INFO] [stderr] Downloaded serde_derive v1.0.174 [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:5c16f4e6c37141f9fef0bc86f7a492d732943053e42aab8461035881e3f53823" "/opt/rustwide/cargo-home/bin/cargo" "+e58ab0492e70733577a2aa8f09aa11a81ccf8005" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 99b57b6475bf356b99fcb75f7bcbc341b62edb5ce8e7bb293b38ae34302fcada [INFO] running `Command { std: "docker" "start" "-a" "99b57b6475bf356b99fcb75f7bcbc341b62edb5ce8e7bb293b38ae34302fcada", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "99b57b6475bf356b99fcb75f7bcbc341b62edb5ce8e7bb293b38ae34302fcada", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "99b57b6475bf356b99fcb75f7bcbc341b62edb5ce8e7bb293b38ae34302fcada", kill_on_drop: false }` [INFO] [stdout] 99b57b6475bf356b99fcb75f7bcbc341b62edb5ce8e7bb293b38ae34302fcada [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:5c16f4e6c37141f9fef0bc86f7a492d732943053e42aab8461035881e3f53823" "/opt/rustwide/cargo-home/bin/cargo" "+e58ab0492e70733577a2aa8f09aa11a81ccf8005" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 34b74bd6759aebddac19b89eee43816be0cc30ba43adb8f49fe31c44859a922d [INFO] running `Command { std: "docker" "start" "-a" "34b74bd6759aebddac19b89eee43816be0cc30ba43adb8f49fe31c44859a922d", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.147 [INFO] [stderr] Compiling proc-macro2 v1.0.66 [INFO] [stderr] Compiling unicode-ident v1.0.11 [INFO] [stderr] Compiling memchr v2.5.0 [INFO] [stderr] Compiling getrandom v0.1.16 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Checking itoa v1.0.9 [INFO] [stderr] Checking pin-project-lite v0.2.10 [INFO] [stderr] Compiling unicase v2.6.0 [INFO] [stderr] Checking tinyvec_macros v0.1.1 [INFO] [stderr] Compiling serde v1.0.174 [INFO] [stderr] Checking futures-io v0.3.28 [INFO] [stderr] Checking cpufeatures v0.2.9 [INFO] [stderr] Compiling serde_derive v1.0.174 [INFO] [stderr] Checking percent-encoding v2.3.0 [INFO] [stderr] Checking pin-project-lite v0.1.12 [INFO] [stderr] Checking tinyvec v1.6.0 [INFO] [stderr] Checking unicode-bidi v0.3.13 [INFO] [stderr] Checking tracing-core v0.1.31 [INFO] [stderr] Compiling indexmap v1.9.3 [INFO] [stderr] Checking form_urlencoded v1.2.0 [INFO] [stderr] Compiling rustix v0.38.4 [INFO] [stderr] Checking http v0.2.9 [INFO] [stderr] Compiling pin-project-internal v0.4.30 [INFO] [stderr] Checking digest v0.9.0 [INFO] [stderr] Checking block-buffer v0.9.0 [INFO] [stderr] Checking hashbrown v0.12.3 [INFO] [stderr] Checking linux-raw-sys v0.4.3 [INFO] [stderr] Checking mime v0.3.17 [INFO] [stderr] Checking bitflags v2.3.3 [INFO] [stderr] Checking tracing v0.1.37 [INFO] [stderr] Checking sha-1 v0.9.8 [INFO] [stderr] Checking input_buffer v0.3.1 [INFO] [stderr] Compiling num-traits v0.2.16 [INFO] [stderr] Checking regex-syntax v0.7.4 [INFO] [stderr] Checking itoa v0.4.8 [INFO] [stderr] Checking fastrand v2.0.0 [INFO] [stderr] Checking safemem v0.3.3 [INFO] [stderr] Checking utf-8 v0.7.6 [INFO] [stderr] Compiling mime_guess v2.0.4 [INFO] [stderr] Compiling serde_json v1.0.103 [INFO] [stderr] Checking aho-corasick v1.0.2 [INFO] [stderr] Checking twoway v0.1.8 [INFO] [stderr] Checking buf_redux v0.8.4 [INFO] [stderr] Checking sha1 v0.10.5 [INFO] [stderr] Checking dtoa v0.4.8 [INFO] [stderr] Checking ryu v1.0.15 [INFO] [stderr] Checking iana-time-zone v0.1.57 [INFO] [stderr] Checking termcolor v1.2.0 [INFO] [stderr] Checking urlencoding v1.3.3 [INFO] [stderr] Checking http-body v0.3.1 [INFO] [stderr] Checking headers-core v0.2.0 [INFO] [stderr] Compiling quote v1.0.31 [INFO] [stderr] Checking headers v0.3.8 [INFO] [stderr] Compiling syn v2.0.27 [INFO] [stderr] Checking unicode-normalization v0.1.22 [INFO] [stderr] Checking idna v0.4.0 [INFO] [stderr] Checking net2 v0.2.39 [INFO] [stderr] Checking iovec v0.1.4 [INFO] [stderr] Checking signal-hook-registry v1.4.1 [INFO] [stderr] Checking num_cpus v1.16.0 [INFO] [stderr] Checking socket2 v0.3.19 [INFO] [stderr] Checking getrandom v0.2.10 [INFO] [stderr] Checking atty v0.2.14 [INFO] [stderr] Checking time v0.1.45 [INFO] [stderr] Checking regex-automata v0.3.3 [INFO] [stderr] Checking url v2.4.0 [INFO] [stderr] Checking mio v0.6.23 [INFO] [stderr] Checking rand_core v0.5.1 [INFO] [stderr] Checking rand_chacha v0.2.2 [INFO] [stderr] Checking tempfile v3.7.0 [INFO] [stderr] Checking rand v0.7.3 [INFO] [stderr] Checking mio-uds v0.6.8 [INFO] [stderr] Checking card_game_engine v0.1.2 (https://github.com/pseguin2011/card_game_engine#d2dc403d) [INFO] [stderr] Checking tungstenite v0.11.1 [INFO] [stderr] Checking multipart v0.17.1 [INFO] [stderr] Checking game v0.1.0 (/opt/rustwide/workdir/game) [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> game/src/gameplay/gameplay.rs:288:17 [INFO] [stdout] | [INFO] [stdout] 288 | for mut partner in game.partners.iter_mut() { [INFO] [stdout] | ----^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> game/src/gameplay/gameplay.rs:288:17 [INFO] [stdout] | [INFO] [stdout] 288 | for mut partner in game.partners.iter_mut() { [INFO] [stdout] | ----^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking serde_urlencoded v0.6.1 [INFO] [stderr] Checking uuid v0.8.2 [INFO] [stderr] Checking chrono v0.4.26 [INFO] [stdout] warning: unused imports: `DeckType`, `Deck` [INFO] [stdout] --> game/tests/game_integration_tests.rs:4:65 [INFO] [stdout] | [INFO] [stdout] 4 | use card_game_engine::models::deck::{Card, CardSuit, CardValue, Deck, DeckType}; [INFO] [stdout] | ^^^^ ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `card_game_engine::models::player::Player` [INFO] [stdout] --> game/tests/game_integration_tests.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use card_game_engine::models::player::Player; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `card_game_engine::state::GameState` [INFO] [stdout] --> game/tests/game_integration_tests.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use card_game_engine::state::GameState; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DDPState` [INFO] [stdout] --> game/tests/game_integration_tests.rs:8:22 [INFO] [stdout] | [INFO] [stdout] 8 | use game::gameplay::{DDPState, DameDePiqueGameBuilder, PlayerMove}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 4 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking regex v1.9.1 [INFO] [stderr] Checking env_logger v0.7.1 [INFO] [stderr] Compiling tokio-macros v0.2.6 [INFO] [stderr] Compiling futures-macro v0.3.28 [INFO] [stderr] Compiling pin-project-internal v1.1.2 [INFO] [stderr] Checking tokio v0.2.25 [INFO] [stderr] Checking pin-project v0.4.30 [INFO] [stderr] Checking futures-util v0.3.28 [INFO] [stderr] Checking pin-project v1.1.2 [INFO] [stderr] Checking tracing-futures v0.2.5 [INFO] [stderr] Checking tokio-util v0.3.1 [INFO] [stderr] Checking h2 v0.2.7 [INFO] [stderr] Checking futures-executor v0.3.28 [INFO] [stderr] Checking tokio-tungstenite v0.11.0 [INFO] [stderr] Checking futures v0.3.28 [INFO] [stderr] Checking hyper v0.13.10 [INFO] [stderr] Checking warp v0.2.5 [INFO] [stderr] Checking server v0.1.0 (/opt/rustwide/workdir/server) [INFO] [stdout] warning: unused import: `game::state::GameState` [INFO] [stdout] --> server/src/gameplay/handlers/gameplay_handlers.rs:10:5 [INFO] [stdout] | [INFO] [stdout] 10 | use game::state::GameState; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `game::state::GameState` [INFO] [stdout] --> server/src/gameplay/handlers/gameplay_handlers.rs:10:5 [INFO] [stdout] | [INFO] [stdout] 10 | use game::state::GameState; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GameSession`, `StartGameResponse`, `WebSocketResponse` [INFO] [stdout] --> server/src/ws.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | GameSession, GameSessions, Player, Players, StartGameResponse, WebSocketResponse, [INFO] [stdout] | ^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `game::Game` [INFO] [stdout] --> server/src/ws.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use game::Game; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde::Deserialize` [INFO] [stdout] --> server/src/ws.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use serde::Deserialize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde::Serialize` [INFO] [stdout] --> server/src/ws.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use serde::Serialize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::from_str` [INFO] [stdout] --> server/src/ws.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use serde_json::from_str; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GameSession`, `StartGameResponse`, `WebSocketResponse` [INFO] [stdout] --> server/src/ws.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | GameSession, GameSessions, Player, Players, StartGameResponse, WebSocketResponse, [INFO] [stdout] | ^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `game::Game` [INFO] [stdout] --> server/src/ws.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use game::Game; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde::Deserialize` [INFO] [stdout] --> server/src/ws.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use serde::Deserialize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde::Serialize` [INFO] [stdout] --> server/src/ws.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use serde::Serialize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::from_str` [INFO] [stdout] --> server/src/ws.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use serde_json::from_str; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> server/src/handler.rs:59:17 [INFO] [stdout] | [INFO] [stdout] 59 | if let Some(mut player) = players.write().await.get_mut(&player_username) { [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> server/src/handler.rs:59:17 [INFO] [stdout] | [INFO] [stdout] 59 | if let Some(mut player) = players.write().await.get_mut(&player_username) { [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> server/src/handler.rs:182:9 [INFO] [stdout] | [INFO] [stdout] 182 | let mut session = sessions.get_mut(&body.game_id).unwrap(); [INFO] [stdout] | ----^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> server/src/handler.rs:182:9 [INFO] [stdout] | [INFO] [stdout] 182 | let mut session = sessions.get_mut(&body.game_id).unwrap(); [INFO] [stdout] | ----^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `clients` [INFO] [stdout] --> server/src/ws.rs:70:45 [INFO] [stdout] | [INFO] [stdout] 70 | async fn client_msg(id: &str, msg: Message, clients: &Players) { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_clients` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `clients` [INFO] [stdout] --> server/src/ws.rs:70:45 [INFO] [stdout] | [INFO] [stdout] 70 | async fn client_msg(id: &str, msg: Message, clients: &Players) { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_clients` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 9 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 9 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 27.80s [INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: buf_redux v0.8.4, multipart v0.17.1 [INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1` [INFO] running `Command { std: "docker" "inspect" "34b74bd6759aebddac19b89eee43816be0cc30ba43adb8f49fe31c44859a922d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "34b74bd6759aebddac19b89eee43816be0cc30ba43adb8f49fe31c44859a922d", kill_on_drop: false }` [INFO] [stdout] 34b74bd6759aebddac19b89eee43816be0cc30ba43adb8f49fe31c44859a922d