[INFO] fetching crate gt7_server 1.1.1...
[INFO] testing gt7_server-1.1.1 against master#c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38 for pr-146098-7
[INFO] extracting crate gt7_server 1.1.1 into /workspace/builds/worker-6-tc1/source
[INFO] started tweaking crates.io crate gt7_server 1.1.1
[INFO] finished tweaking crates.io crate gt7_server 1.1.1
[INFO] tweaked toml for crates.io crate gt7_server 1.1.1 written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate gt7_server 1.1.1 on toolchain c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate gt7_server 1.1.1 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" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded unicase v2.8.0
[INFO] [stderr]   Downloaded thiserror-impl v1.0.65
[INFO] [stderr]   Downloaded thiserror v1.0.65
[INFO] [stderr]   Downloaded pin-project-internal v1.1.6
[INFO] [stderr]   Downloaded pin-project v1.1.6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 9178df8260a9d04c9dd8a164af10f9f6e811cfb7f3fc73591efaaaf63585437e
[INFO] running `Command { std: "docker" "start" "-a" "9178df8260a9d04c9dd8a164af10f9f6e811cfb7f3fc73591efaaaf63585437e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "9178df8260a9d04c9dd8a164af10f9f6e811cfb7f3fc73591efaaaf63585437e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9178df8260a9d04c9dd8a164af10f9f6e811cfb7f3fc73591efaaaf63585437e", kill_on_drop: false }`
[INFO] [stdout] 9178df8260a9d04c9dd8a164af10f9f6e811cfb7f3fc73591efaaaf63585437e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0d4fc12bd5e410ef29a2ab2d3943b76415e928583d130730705bcd34c9ad56ba
[INFO] running `Command { std: "docker" "start" "-a" "0d4fc12bd5e410ef29a2ab2d3943b76415e928583d130730705bcd34c9ad56ba", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.89
[INFO] [stderr]    Compiling libc v0.2.161
[INFO] [stderr]    Compiling bytes v1.8.0
[INFO] [stderr]    Compiling unicode-bidi v0.3.17
[INFO] [stderr]    Compiling thiserror v1.0.65
[INFO] [stderr]    Compiling serde v1.0.213
[INFO] [stderr]    Compiling tracing-core v0.1.32
[INFO] [stderr]    Compiling unicase v2.8.0
[INFO] [stderr]    Compiling unicode-normalization v0.1.24
[INFO] [stderr]    Compiling hashbrown v0.15.0
[INFO] [stderr]    Compiling multer v2.1.0
[INFO] [stderr]    Compiling serde_json v1.0.132
[INFO] [stderr]    Compiling utf-8 v0.7.6
[INFO] [stderr]    Compiling data-encoding v2.6.0
[INFO] [stderr]    Compiling inout v0.1.3
[INFO] [stderr]    Compiling encoding_rs v0.8.34
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling cipher v0.4.4
[INFO] [stderr]    Compiling indexmap v2.6.0
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling salsa20 v0.10.2
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling http v1.1.0
[INFO] [stderr]    Compiling mio v1.0.2
[INFO] [stderr]    Compiling socket2 v0.5.7
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling quote v1.0.37
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling syn v2.0.82
[INFO] [stderr]    Compiling tracing v0.1.40
[INFO] [stderr]    Compiling idna v0.5.0
[INFO] [stderr]    Compiling url v2.5.2
[INFO] [stderr]    Compiling http-body v0.4.6
[INFO] [stderr]    Compiling headers-core v0.2.0
[INFO] [stderr]    Compiling headers v0.3.9
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling tokio-macros v2.4.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.65
[INFO] [stderr]    Compiling serde_derive v1.0.213
[INFO] [stderr]    Compiling pin-project-internal v1.1.6
[INFO] [stderr]    Compiling tokio v1.41.0
[INFO] [stderr]    Compiling zerocopy v0.7.35
[INFO] [stderr]    Compiling pin-project v1.1.6
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling ppv-lite86 v0.2.20
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling tungstenite v0.21.0
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling tokio-util v0.7.12
[INFO] [stderr]    Compiling tokio-tungstenite v0.21.0
[INFO] [stderr]    Compiling h2 v0.3.26
[INFO] [stderr]    Compiling tokio-stream v0.1.16
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling hyper v0.14.31
[INFO] [stderr]    Compiling warp v0.3.7
[INFO] [stderr]    Compiling gt7_server v1.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/gt_data/gt_data.rs:87:29
[INFO] [stdout]    |
[INFO] [stdout] 87 |         data.current_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111);
[INFO] [stdout]    |                             ^                                                       ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 87 -         data.current_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111);
[INFO] [stdout] 87 +         data.current_gear = LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/gt_data/gt_data.rs:88:31
[INFO] [stdout]    |
[INFO] [stdout] 88 |         data.suggested_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4);
[INFO] [stdout]    |                               ^                                               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 88 -         data.suggested_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4);
[INFO] [stdout] 88 +         data.suggested_gear = LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `StreamCipherSeek`
[INFO] [stdout]  --> src/socket_server/helper.rs:1:48
[INFO] [stdout]   |
[INFO] [stdout] 1 | use salsa20::cipher::{KeyIvInit, StreamCipher, StreamCipherSeek};
[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: `TryStreamExt`
[INFO] [stdout]  --> src/server/ws.rs:3:37
[INFO] [stdout]   |
[INFO] [stdout] 3 | use futures::{StreamExt, FutureExt, TryStreamExt};
[INFO] [stdout]   |                                     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `reply::json` and `ws::Message`
[INFO] [stdout]  --> src/server/handler.rs:4:30
[INFO] [stdout]   |
[INFO] [stdout] 4 | use warp::{http::StatusCode, reply::json, ws::Message, Reply, Rejection};
[INFO] [stdout]   |                              ^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::convert::Infallible`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::convert::Infallible;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `FutureExt`
[INFO] [stdout]  --> src/server/ws.rs:3:26
[INFO] [stdout]   |
[INFO] [stdout] 3 | use futures::{StreamExt, FutureExt, TryStreamExt};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `r_size`
[INFO] [stdout]    --> src/socket_server/socket_server.rs:118:16
[INFO] [stdout]     |
[INFO] [stdout] 118 |             Ok(r_size) => {
[INFO] [stdout]     |                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_r_size`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `client_ws_rcv`
[INFO] [stdout]   --> src/server/ws.rs:10:28
[INFO] [stdout]    |
[INFO] [stdout] 10 |     let (client_ws_sender, client_ws_rcv) = ws.split();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_client_ws_rcv`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 |     let mut playstation_ip: String;
[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: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let mut ws_port: u16;
[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]   --> src/main.rs:36:14
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let (tx, mut rx) = broadcast::channel::<GTData>(100);
[INFO] [stdout]    |              ----^^
[INFO] [stdout]    |              |
[INFO] [stdout]    |              help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rx`
[INFO] [stdout]   --> src/main.rs:36:14
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let (tx, mut rx) = broadcast::channel::<GTData>(100);
[INFO] [stdout]    |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_rx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     tyre_diameter_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_fl`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     tyre_diameter_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     tyre_diameter_RL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     tyre_diameter_RR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     type_speed_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     type_speed_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     type_speed_RL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_speed_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     tyre_speed_RR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_speed_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     tyre_slip_ratio_FL: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     tyre_slip_ratio_FR: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     tyre_slip_ratio_RL: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     tyre_slip_ratio_RR: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_temp_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     tyre_temp_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_temp_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_temp_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     tyre_temp_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_temp_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/server/ws.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | /     bs.map(|data| {
[INFO] [stdout] 14 | |         Ok(Message::text(serde_json::to_string(&data.unwrap()).unwrap()))
[INFO] [stdout] 15 | |     }).forward(client_ws_sender).await;
[INFO] [stdout]    | |______________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 13 |     let _ = bs.map(|data| {
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 42.87s
[INFO] running `Command { std: "docker" "inspect" "0d4fc12bd5e410ef29a2ab2d3943b76415e928583d130730705bcd34c9ad56ba", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0d4fc12bd5e410ef29a2ab2d3943b76415e928583d130730705bcd34c9ad56ba", kill_on_drop: false }`
[INFO] [stdout] 0d4fc12bd5e410ef29a2ab2d3943b76415e928583d130730705bcd34c9ad56ba
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7189b22675b4b1ca00a5f711557fb3e9a2d9d45902a484290baf36dabfcd0598
[INFO] running `Command { std: "docker" "start" "-a" "7189b22675b4b1ca00a5f711557fb3e9a2d9d45902a484290baf36dabfcd0598", kill_on_drop: false }`
[INFO] [stderr]    Compiling gt7_server v1.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/gt_data/gt_data.rs:87:29
[INFO] [stdout]    |
[INFO] [stdout] 87 |         data.current_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111);
[INFO] [stdout]    |                             ^                                                       ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 87 -         data.current_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111);
[INFO] [stdout] 87 +         data.current_gear = LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/gt_data/gt_data.rs:88:31
[INFO] [stdout]    |
[INFO] [stdout] 88 |         data.suggested_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4);
[INFO] [stdout]    |                               ^                                               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 88 -         data.suggested_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4);
[INFO] [stdout] 88 +         data.suggested_gear = LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `StreamCipherSeek`
[INFO] [stdout]  --> src/socket_server/helper.rs:1:48
[INFO] [stdout]   |
[INFO] [stdout] 1 | use salsa20::cipher::{KeyIvInit, StreamCipher, StreamCipherSeek};
[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: `TryStreamExt`
[INFO] [stdout]  --> src/server/ws.rs:3:37
[INFO] [stdout]   |
[INFO] [stdout] 3 | use futures::{StreamExt, FutureExt, TryStreamExt};
[INFO] [stdout]   |                                     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `reply::json` and `ws::Message`
[INFO] [stdout]  --> src/server/handler.rs:4:30
[INFO] [stdout]   |
[INFO] [stdout] 4 | use warp::{http::StatusCode, reply::json, ws::Message, Reply, Rejection};
[INFO] [stdout]   |                              ^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::convert::Infallible`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::convert::Infallible;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `FutureExt`
[INFO] [stdout]  --> src/server/ws.rs:3:26
[INFO] [stdout]   |
[INFO] [stdout] 3 | use futures::{StreamExt, FutureExt, TryStreamExt};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `r_size`
[INFO] [stdout]    --> src/socket_server/socket_server.rs:118:16
[INFO] [stdout]     |
[INFO] [stdout] 118 |             Ok(r_size) => {
[INFO] [stdout]     |                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_r_size`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `client_ws_rcv`
[INFO] [stdout]   --> src/server/ws.rs:10:28
[INFO] [stdout]    |
[INFO] [stdout] 10 |     let (client_ws_sender, client_ws_rcv) = ws.split();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_client_ws_rcv`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 |     let mut playstation_ip: String;
[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: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let mut ws_port: u16;
[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]   --> src/main.rs:36:14
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let (tx, mut rx) = broadcast::channel::<GTData>(100);
[INFO] [stdout]    |              ----^^
[INFO] [stdout]    |              |
[INFO] [stdout]    |              help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rx`
[INFO] [stdout]   --> src/main.rs:36:14
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let (tx, mut rx) = broadcast::channel::<GTData>(100);
[INFO] [stdout]    |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_rx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     tyre_diameter_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_fl`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     tyre_diameter_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     tyre_diameter_RL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     tyre_diameter_RR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     type_speed_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     type_speed_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     type_speed_RL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_speed_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     tyre_speed_RR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_speed_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     tyre_slip_ratio_FL: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     tyre_slip_ratio_FR: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     tyre_slip_ratio_RL: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     tyre_slip_ratio_RR: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_temp_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     tyre_temp_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_temp_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_temp_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     tyre_temp_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_temp_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/server/ws.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | /     bs.map(|data| {
[INFO] [stdout] 14 | |         Ok(Message::text(serde_json::to_string(&data.unwrap()).unwrap()))
[INFO] [stdout] 15 | |     }).forward(client_ws_sender).await;
[INFO] [stdout]    | |______________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 13 |     let _ = bs.map(|data| {
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.26s
[INFO] running `Command { std: "docker" "inspect" "7189b22675b4b1ca00a5f711557fb3e9a2d9d45902a484290baf36dabfcd0598", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7189b22675b4b1ca00a5f711557fb3e9a2d9d45902a484290baf36dabfcd0598", kill_on_drop: false }`
[INFO] [stdout] 7189b22675b4b1ca00a5f711557fb3e9a2d9d45902a484290baf36dabfcd0598
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 4d287b5e36a4db61cefcd600f15213ab5cbc8c71a87ebba1a6a44ac173bbdd67
[INFO] running `Command { std: "docker" "start" "-a" "4d287b5e36a4db61cefcd600f15213ab5cbc8c71a87ebba1a6a44ac173bbdd67", kill_on_drop: false }`
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]   --> src/gt_data/gt_data.rs:87:29
[INFO] [stderr]    |
[INFO] [stderr] 87 |         data.current_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111);
[INFO] [stderr]    |                             ^                                                       ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 87 -         data.current_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111);
[INFO] [stderr] 87 +         data.current_gear = LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111 ;
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]   --> src/gt_data/gt_data.rs:88:31
[INFO] [stderr]    |
[INFO] [stderr] 88 |         data.suggested_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4);
[INFO] [stderr]    |                               ^                                               ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 88 -         data.suggested_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4);
[INFO] [stderr] 88 +         data.suggested_gear = LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4 ;
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `StreamCipherSeek`
[INFO] [stderr]  --> src/socket_server/helper.rs:1:48
[INFO] [stderr]   |
[INFO] [stderr] 1 | use salsa20::cipher::{KeyIvInit, StreamCipher, StreamCipherSeek};
[INFO] [stderr]   |                                                ^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `TryStreamExt`
[INFO] [stderr]  --> src/server/ws.rs:3:37
[INFO] [stderr]   |
[INFO] [stderr] 3 | use futures::{StreamExt, FutureExt, TryStreamExt};
[INFO] [stderr]   |                                     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `reply::json` and `ws::Message`
[INFO] [stderr]  --> src/server/handler.rs:4:30
[INFO] [stderr]   |
[INFO] [stderr] 4 | use warp::{http::StatusCode, reply::json, ws::Message, Reply, Rejection};
[INFO] [stderr]   |                              ^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::convert::Infallible`
[INFO] [stderr]   --> src/main.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use std::convert::Infallible;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `FutureExt`
[INFO] [stderr]  --> src/server/ws.rs:3:26
[INFO] [stderr]   |
[INFO] [stderr] 3 | use futures::{StreamExt, FutureExt, TryStreamExt};
[INFO] [stderr]   |                          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `r_size`
[INFO] [stderr]    --> src/socket_server/socket_server.rs:118:16
[INFO] [stderr]     |
[INFO] [stderr] 118 |             Ok(r_size) => {
[INFO] [stderr]     |                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_r_size`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `client_ws_rcv`
[INFO] [stderr]   --> src/server/ws.rs:10:28
[INFO] [stderr]    |
[INFO] [stderr] 10 |     let (client_ws_sender, client_ws_rcv) = ws.split();
[INFO] [stderr]    |                            ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_client_ws_rcv`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/main.rs:19:9
[INFO] [stderr]    |
[INFO] [stderr] 19 |     let mut playstation_ip: String;
[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: variable does not need to be mutable
[INFO] [stderr]   --> src/main.rs:20:9
[INFO] [stderr]    |
[INFO] [stderr] 20 |     let mut ws_port: u16;
[INFO] [stderr]    |         ----^^^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/main.rs:36:14
[INFO] [stderr]    |
[INFO] [stderr] 36 |     let (tx, mut rx) = broadcast::channel::<GTData>(100);
[INFO] [stderr]    |              ----^^
[INFO] [stderr]    |              |
[INFO] [stderr]    |              help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rx`
[INFO] [stderr]   --> src/main.rs:36:14
[INFO] [stderr]    |
[INFO] [stderr] 36 |     let (tx, mut rx) = broadcast::channel::<GTData>(100);
[INFO] [stderr]    |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_rx`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_diameter_FL` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 16 |     tyre_diameter_FL: f32,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_fl`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_diameter_FR` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr] 17 |     tyre_diameter_FR: f32,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_fr`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_diameter_RL` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 |     tyre_diameter_RL: f32,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_rl`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_diameter_RR` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:19:5
[INFO] [stderr]    |
[INFO] [stderr] 19 |     tyre_diameter_RR: f32,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_rr`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `type_speed_FL` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 20 |     type_speed_FL: f32,
[INFO] [stderr]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_fl`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `type_speed_FR` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 21 |     type_speed_FR: f32,
[INFO] [stderr]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_fr`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `type_speed_RL` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:22:5
[INFO] [stderr]    |
[INFO] [stderr] 22 |     type_speed_RL: f32,
[INFO] [stderr]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_rl`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_speed_RR` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:23:5
[INFO] [stderr]    |
[INFO] [stderr] 23 |     tyre_speed_RR: f32,
[INFO] [stderr]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_speed_rr`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_slip_ratio_FL` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 |     tyre_slip_ratio_FL: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_fl`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_slip_ratio_FR` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:26:5
[INFO] [stderr]    |
[INFO] [stderr] 26 |     tyre_slip_ratio_FR: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_fr`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_slip_ratio_RL` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:27:5
[INFO] [stderr]    |
[INFO] [stderr] 27 |     tyre_slip_ratio_RL: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_rl`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_slip_ratio_RR` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:28:5
[INFO] [stderr]    |
[INFO] [stderr] 28 |     tyre_slip_ratio_RR: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_rr`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_temp_FL` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:47:5
[INFO] [stderr]    |
[INFO] [stderr] 47 |     tyre_temp_FL: f32,
[INFO] [stderr]    |     ^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_temp_fl`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tyre_temp_FR` should have a snake case name
[INFO] [stderr]   --> src/gt_data/gt_data.rs:48:5
[INFO] [stderr]    |
[INFO] [stderr] 48 |     tyre_temp_FR: f32,
[INFO] [stderr]    |     ^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_temp_fr`
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]   --> src/server/ws.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | /     bs.map(|data| {
[INFO] [stderr] 14 | |         Ok(Message::text(serde_json::to_string(&data.unwrap()).unwrap()))
[INFO] [stderr] 15 | |     }).forward(client_ws_sender).await;
[INFO] [stderr]    | |______________________________________^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]    |
[INFO] [stderr] 13 |     let _ = bs.map(|data| {
[INFO] [stderr]    |     +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `gt7_server` (bin "gt7_server" test) generated 28 warnings (run `cargo fix --bin "gt7_server" -p gt7_server --tests` to apply 12 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.10s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/gt7_server-c9a71d18602f100a)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "4d287b5e36a4db61cefcd600f15213ab5cbc8c71a87ebba1a6a44ac173bbdd67", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4d287b5e36a4db61cefcd600f15213ab5cbc8c71a87ebba1a6a44ac173bbdd67", kill_on_drop: false }`
[INFO] [stdout] 4d287b5e36a4db61cefcd600f15213ab5cbc8c71a87ebba1a6a44ac173bbdd67
