[INFO] cloning repository https://github.com/ccagnin/spotify-jukebox-cli
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/ccagnin/spotify-jukebox-cli" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fccagnin%2Fspotify-jukebox-cli", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fccagnin%2Fspotify-jukebox-cli'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] b511413c75be1bbe6266ff86db0202596e624dd2
[INFO] testing ccagnin/spotify-jukebox-cli against try#33835004928d3bf65db4d4712e1330766263b0bd for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fccagnin%2Fspotify-jukebox-cli" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/ccagnin/spotify-jukebox-cli
[INFO] finished tweaking git repo https://github.com/ccagnin/spotify-jukebox-cli
[INFO] tweaked toml for git repo https://github.com/ccagnin/spotify-jukebox-cli written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/ccagnin/spotify-jukebox-cli on toolchain 33835004928d3bf65db4d4712e1330766263b0bd
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/ccagnin/spotify-jukebox-cli 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" "+33835004928d3bf65db4d4712e1330766263b0bd" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 0fba997432da2c35505173c26276550b6ebaafd19729a52d8aa66b4bd9e3a088
[INFO] running `Command { std: "docker" "start" "-a" "0fba997432da2c35505173c26276550b6ebaafd19729a52d8aa66b4bd9e3a088", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "0fba997432da2c35505173c26276550b6ebaafd19729a52d8aa66b4bd9e3a088", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0fba997432da2c35505173c26276550b6ebaafd19729a52d8aa66b4bd9e3a088", kill_on_drop: false }`
[INFO] [stdout] 0fba997432da2c35505173c26276550b6ebaafd19729a52d8aa66b4bd9e3a088
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 79a9d33e14123161ab75eda2943a7a3ad506f0f960a7f055640f4b7e8f418a1e
[INFO] running `Command { std: "docker" "start" "-a" "79a9d33e14123161ab75eda2943a7a3ad506f0f960a7f055640f4b7e8f418a1e", kill_on_drop: false }`
[INFO] [stderr]    Compiling bitflags v2.9.1
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling hashbrown v0.15.4
[INFO] [stderr]    Compiling signal-hook-registry v1.4.5
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling equator-macro v0.4.2
[INFO] [stderr]    Compiling rustversion v1.0.21
[INFO] [stderr]    Compiling anyhow v1.0.99
[INFO] [stderr]    Compiling zerovec v0.11.4
[INFO] [stderr]    Compiling built v0.7.7
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling profiling-procmacros v1.0.17
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling profiling v1.0.17
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling maybe-rayon v0.1.1
[INFO] [stderr]    Compiling equator v0.4.2
[INFO] [stderr]    Compiling flate2 v1.1.2
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]    Compiling rav1e v0.7.1
[INFO] [stderr]    Compiling signal-hook-mio v0.2.4
[INFO] [stderr]    Compiling fax_derive v0.2.0
[INFO] [stderr]    Compiling aligned-vec v0.6.4
[INFO] [stderr]    Compiling arg_enum_proc_macro v0.3.4
[INFO] [stderr]    Compiling itertools v0.12.1
[INFO] [stderr]    Compiling v_frame v0.3.9
[INFO] [stderr]    Compiling simd_helpers v0.1.0
[INFO] [stderr]    Compiling half v2.6.0
[INFO] [stderr]    Compiling indexmap v2.10.0
[INFO] [stderr]    Compiling rustix v1.0.8
[INFO] [stderr]    Compiling bitstream-io v2.6.0
[INFO] [stderr]    Compiling weezl v0.1.10
[INFO] [stderr]    Compiling serde_json v1.0.143
[INFO] [stderr]    Compiling anstyle-query v1.1.3
[INFO] [stderr]    Compiling tinystr v0.8.1
[INFO] [stderr]    Compiling potential_utf v0.1.3
[INFO] [stderr]    Compiling imgref v1.11.0
[INFO] [stderr]    Compiling anstyle v1.0.11
[INFO] [stderr]    Compiling icu_collections v2.0.0
[INFO] [stderr]    Compiling fax v0.2.6
[INFO] [stderr]    Compiling anstream v0.6.19
[INFO] [stderr]    Compiling loop9 v0.1.5
[INFO] [stderr]    Compiling icu_locale_core v2.0.0
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling derive_more-impl v2.0.1
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling av1-grain v0.2.4
[INFO] [stderr]    Compiling pxfm v0.1.23
[INFO] [stderr]    Compiling fdeflate v0.3.7
[INFO] [stderr]    Compiling toml_write v0.1.2
[INFO] [stderr]    Compiling winnow v0.7.12
[INFO] [stderr]    Compiling bytemuck v1.23.2
[INFO] [stderr]    Compiling linux-raw-sys v0.9.4
[INFO] [stderr]    Compiling gif v0.13.3
[INFO] [stderr]    Compiling qoi v0.4.1
[INFO] [stderr]    Compiling png v0.18.0
[INFO] [stderr]    Compiling exr v1.73.0
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling icu_provider v2.0.0
[INFO] [stderr]    Compiling crossterm v0.28.1
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling derive_more v2.0.1
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]    Compiling compact_str v0.8.1
[INFO] [stderr]    Compiling icu_properties v2.0.1
[INFO] [stderr]    Compiling icu_normalizer v2.0.0
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling clap_builder v4.5.42
[INFO] [stderr]    Compiling tiff v0.10.3
[INFO] [stderr]    Compiling lru v0.12.5
[INFO] [stderr]    Compiling clap_derive v4.5.41
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling moxcms v0.7.5
[INFO] [stderr]    Compiling ratatui v0.29.0
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling url v2.5.7
[INFO] [stderr]    Compiling clap v4.5.42
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling tokio-util v0.7.16
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling ravif v0.11.20
[INFO] [stderr]    Compiling image v0.25.8
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling hyper-tls v0.5.0
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling jukebox-cli v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: field `access_token` is never read
[INFO] [stdout]   --> src/jukebox_state.rs:41:9
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub struct JukeboxState {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub access_token: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/jukebox_state.rs:60:12
[INFO] [stdout]     |
[INFO] [stdout]  47 | impl JukeboxState {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  60 |     pub fn set_access_token(&mut self, token: String) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub fn play(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn pause(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub fn handle_song_end(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn add_volume(&mut self, _amount: u8) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 165 |     pub fn sub_volume(&mut self, _amount: u8) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 169 |     pub fn has_access_token(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn get_access_token(&self) -> Option<&String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `currently_playing` is never read
[INFO] [stdout]   --> src/spotify_types.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct QueueResponse {
[INFO] [stdout]    |            ------------- field in this struct
[INFO] [stdout] 19 |     pub currently_playing: Option<SpotifyTrack>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `QueueResponse` 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: fields `id` and `name` are never read
[INFO] [stdout]   --> src/spotify_api.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct SpotifyDevice {
[INFO] [stdout]    |            ------------- fields in this struct
[INFO] [stdout] 15 |     pub id: String,
[INFO] [stdout]    |         ^^
[INFO] [stdout] 16 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SpotifyDevice` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `token_type`, `expires_in`, and `refresh_token` are never read
[INFO] [stdout]   --> src/spotify_auth.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub struct TokenResponse {
[INFO] [stdout]    |            ------------- fields in this struct
[INFO] [stdout]  8 |     pub access_token: String,
[INFO] [stdout]  9 |     pub token_type: String,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 10 |     pub expires_in: u64,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 11 |     pub refresh_token: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/screen/playlist_side.rs:26:37
[INFO] [stdout]    |
[INFO] [stdout] 26 | fn get_combined_list(jukebox_state: &JukeboxState) -> Vec<ListItem> {
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^         ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                     |
[INFO] [stdout]    |                                     the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 26 | fn get_combined_list(jukebox_state: &JukeboxState) -> Vec<ListItem<'_>> {
[INFO] [stdout]    |                                                                   ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 44s
[INFO] running `Command { std: "docker" "inspect" "79a9d33e14123161ab75eda2943a7a3ad506f0f960a7f055640f4b7e8f418a1e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "79a9d33e14123161ab75eda2943a7a3ad506f0f960a7f055640f4b7e8f418a1e", kill_on_drop: false }`
[INFO] [stdout] 79a9d33e14123161ab75eda2943a7a3ad506f0f960a7f055640f4b7e8f418a1e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 4d2f2436be7de6806cffbca3b9aea27703f65ec6361804cf043ae285430af310
[INFO] running `Command { std: "docker" "start" "-a" "4d2f2436be7de6806cffbca3b9aea27703f65ec6361804cf043ae285430af310", kill_on_drop: false }`
[INFO] [stderr]    Compiling jukebox-cli v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: field `access_token` is never read
[INFO] [stdout]   --> src/jukebox_state.rs:41:9
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub struct JukeboxState {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub access_token: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/jukebox_state.rs:60:12
[INFO] [stdout]     |
[INFO] [stdout]  47 | impl JukeboxState {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  60 |     pub fn set_access_token(&mut self, token: String) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub fn play(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn pause(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub fn handle_song_end(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn add_volume(&mut self, _amount: u8) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 165 |     pub fn sub_volume(&mut self, _amount: u8) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 169 |     pub fn has_access_token(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn get_access_token(&self) -> Option<&String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `currently_playing` is never read
[INFO] [stdout]   --> src/spotify_types.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct QueueResponse {
[INFO] [stdout]    |            ------------- field in this struct
[INFO] [stdout] 19 |     pub currently_playing: Option<SpotifyTrack>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `QueueResponse` 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: fields `id` and `name` are never read
[INFO] [stdout]   --> src/spotify_api.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct SpotifyDevice {
[INFO] [stdout]    |            ------------- fields in this struct
[INFO] [stdout] 15 |     pub id: String,
[INFO] [stdout]    |         ^^
[INFO] [stdout] 16 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SpotifyDevice` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `token_type`, `expires_in`, and `refresh_token` are never read
[INFO] [stdout]   --> src/spotify_auth.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub struct TokenResponse {
[INFO] [stdout]    |            ------------- fields in this struct
[INFO] [stdout]  8 |     pub access_token: String,
[INFO] [stdout]  9 |     pub token_type: String,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 10 |     pub expires_in: u64,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 11 |     pub refresh_token: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/screen/playlist_side.rs:26:37
[INFO] [stdout]    |
[INFO] [stdout] 26 | fn get_combined_list(jukebox_state: &JukeboxState) -> Vec<ListItem> {
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^         ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                     |
[INFO] [stdout]    |                                     the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 26 | fn get_combined_list(jukebox_state: &JukeboxState) -> Vec<ListItem<'_>> {
[INFO] [stdout]    |                                                                   ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 2.02s
[INFO] running `Command { std: "docker" "inspect" "4d2f2436be7de6806cffbca3b9aea27703f65ec6361804cf043ae285430af310", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4d2f2436be7de6806cffbca3b9aea27703f65ec6361804cf043ae285430af310", kill_on_drop: false }`
[INFO] [stdout] 4d2f2436be7de6806cffbca3b9aea27703f65ec6361804cf043ae285430af310
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] f5aa44334977a44f91e5651d3416b74fcbc1307c00bc30ecf3660f524c8528b1
[INFO] running `Command { std: "docker" "start" "-a" "f5aa44334977a44f91e5651d3416b74fcbc1307c00bc30ecf3660f524c8528b1", kill_on_drop: false }`
[INFO] [stderr] warning: field `access_token` is never read
[INFO] [stderr]   --> src/jukebox_state.rs:41:9
[INFO] [stderr]    |
[INFO] [stderr] 37 | pub struct JukeboxState {
[INFO] [stderr]    |            ------------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 41 |     pub access_token: Option<String>,
[INFO] [stderr]    |         ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/jukebox_state.rs:60:12
[INFO] [stderr]     |
[INFO] [stderr]  47 | impl JukeboxState {
[INFO] [stderr]     | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  60 |     pub fn set_access_token(&mut self, token: String) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 149 |     pub fn play(&mut self) {
[INFO] [stderr]     |            ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 153 |     pub fn pause(&mut self) {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 157 |     pub fn handle_song_end(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 161 |     pub fn add_volume(&mut self, _amount: u8) {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 165 |     pub fn sub_volume(&mut self, _amount: u8) {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 169 |     pub fn has_access_token(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 173 |     pub fn get_access_token(&self) -> Option<&String> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `currently_playing` is never read
[INFO] [stderr]   --> src/spotify_types.rs:19:9
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub struct QueueResponse {
[INFO] [stderr]    |            ------------- field in this struct
[INFO] [stderr] 19 |     pub currently_playing: Option<SpotifyTrack>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `QueueResponse` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `id` and `name` are never read
[INFO] [stderr]   --> src/spotify_api.rs:15:9
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub struct SpotifyDevice {
[INFO] [stderr]    |            ------------- fields in this struct
[INFO] [stderr] 15 |     pub id: String,
[INFO] [stderr]    |         ^^
[INFO] [stderr] 16 |     pub name: String,
[INFO] [stderr]    |         ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `SpotifyDevice` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `token_type`, `expires_in`, and `refresh_token` are never read
[INFO] [stderr]   --> src/spotify_auth.rs:9:9
[INFO] [stderr]    |
[INFO] [stderr]  7 | pub struct TokenResponse {
[INFO] [stderr]    |            ------------- fields in this struct
[INFO] [stderr]  8 |     pub access_token: String,
[INFO] [stderr]  9 |     pub token_type: String,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr] 10 |     pub expires_in: u64,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr] 11 |     pub refresh_token: Option<String>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/screen/playlist_side.rs:26:37
[INFO] [stderr]    |
[INFO] [stderr] 26 | fn get_combined_list(jukebox_state: &JukeboxState) -> Vec<ListItem> {
[INFO] [stderr]    |                                     ^^^^^^^^^^^^^         ^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                                     |
[INFO] [stderr]    |                                     the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 26 | fn get_combined_list(jukebox_state: &JukeboxState) -> Vec<ListItem<'_>> {
[INFO] [stderr]    |                                                                   ++++
[INFO] [stderr] 
[INFO] [stderr] warning: `jukebox-cli` (bin "jukebox-cli" test) generated 6 warnings (run `cargo fix --bin "jukebox-cli" -p jukebox-cli --tests` to apply 1 suggestion)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.45s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/jukebox_cli-72ea0396a9b8874b)
[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" "f5aa44334977a44f91e5651d3416b74fcbc1307c00bc30ecf3660f524c8528b1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f5aa44334977a44f91e5651d3416b74fcbc1307c00bc30ecf3660f524c8528b1", kill_on_drop: false }`
[INFO] [stdout] f5aa44334977a44f91e5651d3416b74fcbc1307c00bc30ecf3660f524c8528b1
