[INFO] cloning repository https://github.com/caiotavares/emv [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/caiotavares/emv" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcaiotavares%2Femv", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcaiotavares%2Femv'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 1eb3441f48307eb9d5b6e05ac3bfd8d9f695fbd7 [INFO] testing caiotavares/emv against nightly-2025-01-18 for randomize-layout-3 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcaiotavares%2Femv" "/workspace/builds/worker-5-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc1/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/caiotavares/emv on toolchain nightly-2025-01-18 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+nightly-2025-01-18" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/caiotavares/emv [INFO] finished tweaking git repo https://github.com/caiotavares/emv [INFO] tweaked toml for git repo https://github.com/caiotavares/emv written to /workspace/builds/worker-5-tc1/source/Cargo.toml [INFO] crate git repo https://github.com/caiotavares/emv 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" "+nightly-2025-01-18" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Updating crates.io index [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded proc-macro-error v1.0.4 [INFO] [stderr] Downloaded version_check v0.9.2 [INFO] [stderr] Downloaded structopt v0.3.21 [INFO] [stderr] Downloaded hex v0.4.2 [INFO] [stderr] Downloaded pkg-config v0.3.17 [INFO] [stderr] Downloaded pcsc v2.4.0 [INFO] [stderr] Downloaded hermit-abi v0.1.18 [INFO] [stderr] Downloaded strsim v0.8.0 [INFO] [stderr] Downloaded textwrap v0.11.0 [INFO] [stderr] Downloaded unicode-width v0.1.8 [INFO] [stderr] Downloaded unicode-segmentation v1.7.1 [INFO] [stderr] Downloaded vec_map v0.8.2 [INFO] [stderr] Downloaded heck v0.3.2 [INFO] [stderr] Downloaded syn v1.0.60 [INFO] [stderr] Downloaded clap v2.33.3 [INFO] [stderr] Downloaded proc-macro-error-attr v1.0.4 [INFO] [stderr] Downloaded quote v1.0.9 [INFO] [stderr] Downloaded structopt-derive v0.4.14 [INFO] [stderr] Downloaded pcsc-sys v1.2.0 [INFO] [stderr] Downloaded ansi_term v0.11.0 [INFO] [stderr] Downloaded atty v0.2.14 [INFO] [stderr] Downloaded bitflags v1.2.1 [INFO] [stderr] Downloaded libc v0.2.86 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:819108c5571ea2e421544af4d832f968d213c87fbe3707a016657f43d2f853bc" "/opt/rustwide/cargo-home/bin/cargo" "+nightly-2025-01-18" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 6dd7a574bdcca047bc3a52313daa862065c143b9dbd8d20d25cbcead3174485d [INFO] running `Command { std: "docker" "start" "-a" "6dd7a574bdcca047bc3a52313daa862065c143b9dbd8d20d25cbcead3174485d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "6dd7a574bdcca047bc3a52313daa862065c143b9dbd8d20d25cbcead3174485d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6dd7a574bdcca047bc3a52313daa862065c143b9dbd8d20d25cbcead3174485d", kill_on_drop: false }` [INFO] [stdout] 6dd7a574bdcca047bc3a52313daa862065c143b9dbd8d20d25cbcead3174485d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:819108c5571ea2e421544af4d832f968d213c87fbe3707a016657f43d2f853bc" "/opt/rustwide/cargo-home/bin/cargo" "+nightly-2025-01-18" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 62967fdc453233b9cbd73f7f7403c947946a5210f4ddd1d84a37736fa3b10590 [INFO] running `Command { std: "docker" "start" "-a" "62967fdc453233b9cbd73f7f7403c947946a5210f4ddd1d84a37736fa3b10590", kill_on_drop: false }` [INFO] [stderr] Compiling version_check v0.9.2 [INFO] [stderr] Compiling proc-macro2 v1.0.24 [INFO] [stderr] Compiling syn v1.0.60 [INFO] [stderr] Compiling bitflags v1.2.1 [INFO] [stderr] Compiling libc v0.2.86 [INFO] [stderr] Compiling pkg-config v0.3.17 [INFO] [stderr] Compiling unicode-width v0.1.8 [INFO] [stderr] Compiling unicode-segmentation v1.7.1 [INFO] [stderr] Compiling strsim v0.8.0 [INFO] [stderr] Compiling ansi_term v0.11.0 [INFO] [stderr] Compiling vec_map v0.8.2 [INFO] [stderr] Compiling hex v0.4.2 [INFO] [stderr] Compiling textwrap v0.11.0 [INFO] [stderr] Compiling proc-macro-error-attr v1.0.4 [INFO] [stderr] Compiling proc-macro-error v1.0.4 [INFO] [stderr] Compiling pcsc-sys v1.2.0 [INFO] [stderr] Compiling heck v0.3.2 [INFO] [stderr] Compiling pcsc v2.4.0 [INFO] [stderr] Compiling quote v1.0.9 [INFO] [stderr] Compiling atty v0.2.14 [INFO] [stderr] Compiling clap v2.33.3 [INFO] [stderr] Compiling structopt-derive v0.4.14 [INFO] [stderr] Compiling structopt v0.3.21 [INFO] [stderr] Compiling emv v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused imports: `Read` and `Write` [INFO] [stdout] --> src/main.rs:2:30 [INFO] [stdout] | [INFO] [stdout] 2 | use std::io::{self, BufRead, Read, Write}; [INFO] [stdout] | ^^^^ ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/apdu/capdu.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `hex::FromHex` [INFO] [stdout] --> src/cli/interface.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use hex::FromHex; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `structopt::StructOpt` [INFO] [stdout] --> src/controller.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use structopt::StructOpt; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Command`, `Emv`, and `Mode` [INFO] [stdout] --> src/controller.rs:6:29 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::cli::interface::{Command, Emv, Mode}; [INFO] [stdout] | ^^^^^^^ ^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::tlv::parser::TLV` [INFO] [stdout] --> src/controller.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::tlv::parser::TLV; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `external_authenticate` is never used [INFO] [stdout] --> src/apdu/capdu.rs:92:8 [INFO] [stdout] | [INFO] [stdout] 92 | pub fn external_authenticate(issuer_authentication_data: Vec) -> APDU { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `offline_change_pin` is never used [INFO] [stdout] --> src/apdu/capdu.rs:115:8 [INFO] [stdout] | [INFO] [stdout] 115 | pub fn offline_change_pin(new_pin: Vec) -> APDU { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `application_block` is never used [INFO] [stdout] --> src/apdu/capdu.rs:129:8 [INFO] [stdout] | [INFO] [stdout] 129 | pub fn application_block(mac: Vec) -> APDU { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `application_unblock` is never used [INFO] [stdout] --> src/apdu/capdu.rs:133:8 [INFO] [stdout] | [INFO] [stdout] 133 | pub fn application_unblock(mac: Vec) -> APDU { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `application_block` is never used [INFO] [stdout] --> src/controller.rs:86:8 [INFO] [stdout] | [INFO] [stdout] 86 | pub fn application_block(card: &pcsc::Card, mac: Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `application_unblock` is never used [INFO] [stdout] --> src/controller.rs:92:8 [INFO] [stdout] | [INFO] [stdout] 92 | pub fn application_unblock(card: &pcsc::Card, mac: Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/cli/mod.rs:16:5 [INFO] [stdout] | [INFO] [stdout] 16 | io::stdout().flush(); [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)]` on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 16 | let _ = io::stdout().flush(); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/cli/mod.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | io::stdin().read_line(&mut buffer); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 17 | let _ = io::stdin().read_line(&mut buffer); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/cli/mod.rs:28:5 [INFO] [stdout] | [INFO] [stdout] 28 | io::stdout().flush(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 28 | let _ = io::stdout().flush(); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/cli/mod.rs:29:5 [INFO] [stdout] | [INFO] [stdout] 29 | io::stdin().read_line(&mut buffer); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 29 | let _ = io::stdin().read_line(&mut buffer); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/controller.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | / usb::transmit(card, &apdu) [INFO] [stdout] 12 | | .map(|response| { [INFO] [stdout] 13 | | match response { [INFO] [stdout] 14 | | RAPDU { status: Status::ResponseAvailable { length }, .. } => { [INFO] [stdout] ... | [INFO] [stdout] 24 | | }); [INFO] [stdout] | |__________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 11 | let _ = usb::transmit(card, &apdu) [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/controller.rs:18:21 [INFO] [stdout] | [INFO] [stdout] 18 | usb::transmit(card, &apdu.with_length(length)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 18 | let _ = usb::transmit(card, &apdu.with_length(length)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: path statement drops value [INFO] [stdout] --> src/controller.rs:21:21 [INFO] [stdout] | [INFO] [stdout] 21 | response; [INFO] [stdout] | ^^^^^^^^^ help: use `drop` to clarify the intent: `drop(response);` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(path_statements)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 12.75s [INFO] running `Command { std: "docker" "inspect" "62967fdc453233b9cbd73f7f7403c947946a5210f4ddd1d84a37736fa3b10590", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "62967fdc453233b9cbd73f7f7403c947946a5210f4ddd1d84a37736fa3b10590", kill_on_drop: false }` [INFO] [stdout] 62967fdc453233b9cbd73f7f7403c947946a5210f4ddd1d84a37736fa3b10590 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:819108c5571ea2e421544af4d832f968d213c87fbe3707a016657f43d2f853bc" "/opt/rustwide/cargo-home/bin/cargo" "+nightly-2025-01-18" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 30b9befc351a58ae848df0d9d26539cea85577231c971ed1ce30aabbfd9211e0 [INFO] running `Command { std: "docker" "start" "-a" "30b9befc351a58ae848df0d9d26539cea85577231c971ed1ce30aabbfd9211e0", kill_on_drop: false }` [INFO] [stderr] Compiling emv v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused imports: `Read` and `Write` [INFO] [stdout] --> src/main.rs:2:30 [INFO] [stdout] | [INFO] [stdout] 2 | use std::io::{self, BufRead, Read, Write}; [INFO] [stdout] | ^^^^ ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/apdu/capdu.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `hex::FromHex` [INFO] [stdout] --> src/cli/interface.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use hex::FromHex; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `structopt::StructOpt` [INFO] [stdout] --> src/controller.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use structopt::StructOpt; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Command`, `Emv`, and `Mode` [INFO] [stdout] --> src/controller.rs:6:29 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::cli::interface::{Command, Emv, Mode}; [INFO] [stdout] | ^^^^^^^ ^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::tlv::parser::TLV` [INFO] [stdout] --> src/controller.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::tlv::parser::TLV; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `external_authenticate` is never used [INFO] [stdout] --> src/apdu/capdu.rs:92:8 [INFO] [stdout] | [INFO] [stdout] 92 | pub fn external_authenticate(issuer_authentication_data: Vec) -> APDU { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `offline_change_pin` is never used [INFO] [stdout] --> src/apdu/capdu.rs:115:8 [INFO] [stdout] | [INFO] [stdout] 115 | pub fn offline_change_pin(new_pin: Vec) -> APDU { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `application_block` is never used [INFO] [stdout] --> src/apdu/capdu.rs:129:8 [INFO] [stdout] | [INFO] [stdout] 129 | pub fn application_block(mac: Vec) -> APDU { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `application_unblock` is never used [INFO] [stdout] --> src/apdu/capdu.rs:133:8 [INFO] [stdout] | [INFO] [stdout] 133 | pub fn application_unblock(mac: Vec) -> APDU { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `application_block` is never used [INFO] [stdout] --> src/controller.rs:86:8 [INFO] [stdout] | [INFO] [stdout] 86 | pub fn application_block(card: &pcsc::Card, mac: Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `application_unblock` is never used [INFO] [stdout] --> src/controller.rs:92:8 [INFO] [stdout] | [INFO] [stdout] 92 | pub fn application_unblock(card: &pcsc::Card, mac: Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/cli/mod.rs:16:5 [INFO] [stdout] | [INFO] [stdout] 16 | io::stdout().flush(); [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)]` on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 16 | let _ = io::stdout().flush(); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/cli/mod.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | io::stdin().read_line(&mut buffer); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 17 | let _ = io::stdin().read_line(&mut buffer); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/cli/mod.rs:28:5 [INFO] [stdout] | [INFO] [stdout] 28 | io::stdout().flush(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 28 | let _ = io::stdout().flush(); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/cli/mod.rs:29:5 [INFO] [stdout] | [INFO] [stdout] 29 | io::stdin().read_line(&mut buffer); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 29 | let _ = io::stdin().read_line(&mut buffer); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/controller.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | / usb::transmit(card, &apdu) [INFO] [stdout] 12 | | .map(|response| { [INFO] [stdout] 13 | | match response { [INFO] [stdout] 14 | | RAPDU { status: Status::ResponseAvailable { length }, .. } => { [INFO] [stdout] ... | [INFO] [stdout] 24 | | }); [INFO] [stdout] | |__________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 11 | let _ = usb::transmit(card, &apdu) [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/controller.rs:18:21 [INFO] [stdout] | [INFO] [stdout] 18 | usb::transmit(card, &apdu.with_length(length)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 18 | let _ = usb::transmit(card, &apdu.with_length(length)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: path statement drops value [INFO] [stdout] --> src/controller.rs:21:21 [INFO] [stdout] | [INFO] [stdout] 21 | response; [INFO] [stdout] | ^^^^^^^^^ help: use `drop` to clarify the intent: `drop(response);` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(path_statements)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.51s [INFO] running `Command { std: "docker" "inspect" "30b9befc351a58ae848df0d9d26539cea85577231c971ed1ce30aabbfd9211e0", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "30b9befc351a58ae848df0d9d26539cea85577231c971ed1ce30aabbfd9211e0", kill_on_drop: false }` [INFO] [stdout] 30b9befc351a58ae848df0d9d26539cea85577231c971ed1ce30aabbfd9211e0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:819108c5571ea2e421544af4d832f968d213c87fbe3707a016657f43d2f853bc" "/opt/rustwide/cargo-home/bin/cargo" "+nightly-2025-01-18" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] f77f51e7394f8a5d7b08a391eed264e16d8c0ea18761aa0b6efc2dfebc732418 [INFO] running `Command { std: "docker" "start" "-a" "f77f51e7394f8a5d7b08a391eed264e16d8c0ea18761aa0b6efc2dfebc732418", kill_on_drop: false }` [INFO] [stderr] warning: unused imports: `Read` and `Write` [INFO] [stderr] --> src/main.rs:2:30 [INFO] [stderr] | [INFO] [stderr] 2 | use std::io::{self, BufRead, Read, Write}; [INFO] [stderr] | ^^^^ ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::borrow::Borrow` [INFO] [stderr] --> src/apdu/capdu.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::borrow::Borrow; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `hex::FromHex` [INFO] [stderr] --> src/cli/interface.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use hex::FromHex; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `structopt::StructOpt` [INFO] [stderr] --> src/controller.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use structopt::StructOpt; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Command`, `Emv`, and `Mode` [INFO] [stderr] --> src/controller.rs:6:29 [INFO] [stderr] | [INFO] [stderr] 6 | use crate::cli::interface::{Command, Emv, Mode}; [INFO] [stderr] | ^^^^^^^ ^^^ ^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `crate::tlv::parser::TLV` [INFO] [stderr] --> src/controller.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | use crate::tlv::parser::TLV; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `external_authenticate` is never used [INFO] [stderr] --> src/apdu/capdu.rs:92:8 [INFO] [stderr] | [INFO] [stderr] 92 | pub fn external_authenticate(issuer_authentication_data: Vec) -> APDU { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: function `offline_change_pin` is never used [INFO] [stderr] --> src/apdu/capdu.rs:115:8 [INFO] [stderr] | [INFO] [stderr] 115 | pub fn offline_change_pin(new_pin: Vec) -> APDU { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `application_block` is never used [INFO] [stderr] --> src/apdu/capdu.rs:129:8 [INFO] [stderr] | [INFO] [stderr] 129 | pub fn application_block(mac: Vec) -> APDU { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `application_unblock` is never used [INFO] [stderr] --> src/apdu/capdu.rs:133:8 [INFO] [stderr] | [INFO] [stderr] 133 | pub fn application_unblock(mac: Vec) -> APDU { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `application_block` is never used [INFO] [stderr] --> src/controller.rs:86:8 [INFO] [stderr] | [INFO] [stderr] 86 | pub fn application_block(card: &pcsc::Card, mac: Vec) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `application_unblock` is never used [INFO] [stderr] --> src/controller.rs:92:8 [INFO] [stderr] | [INFO] [stderr] 92 | pub fn application_unblock(card: &pcsc::Card, mac: Vec) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/cli/mod.rs:16:5 [INFO] [stderr] | [INFO] [stderr] 16 | io::stdout().flush(); [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)]` on by default [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 16 | let _ = io::stdout().flush(); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/cli/mod.rs:17:5 [INFO] [stderr] | [INFO] [stderr] 17 | io::stdin().read_line(&mut buffer); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 17 | let _ = io::stdin().read_line(&mut buffer); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/cli/mod.rs:28:5 [INFO] [stderr] | [INFO] [stderr] 28 | io::stdout().flush(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 28 | let _ = io::stdout().flush(); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/cli/mod.rs:29:5 [INFO] [stderr] | [INFO] [stderr] 29 | io::stdin().read_line(&mut buffer); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 29 | let _ = io::stdin().read_line(&mut buffer); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/controller.rs:11:5 [INFO] [stderr] | [INFO] [stderr] 11 | / usb::transmit(card, &apdu) [INFO] [stderr] 12 | | .map(|response| { [INFO] [stderr] 13 | | match response { [INFO] [stderr] 14 | | RAPDU { status: Status::ResponseAvailable { length }, .. } => { [INFO] [stderr] ... | [INFO] [stderr] 24 | | }); [INFO] [stderr] | |__________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 11 | let _ = usb::transmit(card, &apdu) [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/controller.rs:18:21 [INFO] [stderr] | [INFO] [stderr] 18 | usb::transmit(card, &apdu.with_length(length)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 18 | let _ = usb::transmit(card, &apdu.with_length(length)); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: path statement drops value [INFO] [stderr] --> src/controller.rs:21:21 [INFO] [stderr] | [INFO] [stderr] 21 | response; [INFO] [stderr] | ^^^^^^^^^ help: use `drop` to clarify the intent: `drop(response);` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(path_statements)]` on by default [INFO] [stderr] [INFO] [stderr] warning: `emv` (bin "emv" test) generated 19 warnings (run `cargo fix --bin "emv" --tests` to apply 7 suggestions) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.09s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/emv-08eef8352170bde4) [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" "f77f51e7394f8a5d7b08a391eed264e16d8c0ea18761aa0b6efc2dfebc732418", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f77f51e7394f8a5d7b08a391eed264e16d8c0ea18761aa0b6efc2dfebc732418", kill_on_drop: false }` [INFO] [stdout] f77f51e7394f8a5d7b08a391eed264e16d8c0ea18761aa0b6efc2dfebc732418