[INFO] cloning repository https://github.com/axmz/cryptopals [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/axmz/cryptopals" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Faxmz%2Fcryptopals", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Faxmz%2Fcryptopals'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 3f949bbe1997b211a47865392a102059629f744c [INFO] testing axmz/cryptopals against beta-2026-04-21 for beta-1.96-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Faxmz%2Fcryptopals" "/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/axmz/cryptopals [INFO] finished tweaking git repo https://github.com/axmz/cryptopals [INFO] tweaked toml for git repo https://github.com/axmz/cryptopals written to /workspace/builds/worker-6-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/axmz/cryptopals on toolchain beta-2026-04-21 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/axmz/cryptopals 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" "+beta-2026-04-21" "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" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 2a7313a9de90a19b626dfe73b39ee2b5c1e9f9ad9f56f90b9f8f33109b90b44f [INFO] running `Command { std: "docker" "start" "-a" "2a7313a9de90a19b626dfe73b39ee2b5c1e9f9ad9f56f90b9f8f33109b90b44f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "2a7313a9de90a19b626dfe73b39ee2b5c1e9f9ad9f56f90b9f8f33109b90b44f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2a7313a9de90a19b626dfe73b39ee2b5c1e9f9ad9f56f90b9f8f33109b90b44f", kill_on_drop: false }` [INFO] [stdout] 2a7313a9de90a19b626dfe73b39ee2b5c1e9f9ad9f56f90b9f8f33109b90b44f [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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 26ce513113605118a5f93f82ea713838a6ba8188aee250abf32d26448616f6c8 [INFO] running `Command { std: "docker" "start" "-a" "26ce513113605118a5f93f82ea713838a6ba8188aee250abf32d26448616f6c8", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.180 [INFO] [stderr] Compiling find-msvc-tools v0.1.7 [INFO] [stderr] Compiling zerocopy v0.8.33 [INFO] [stderr] Compiling proc-macro2 v1.0.105 [INFO] [stderr] Compiling quote v1.0.43 [INFO] [stderr] Compiling unicode-ident v1.0.22 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling num-integer v0.1.46 [INFO] [stderr] Compiling cc v1.2.52 [INFO] [stderr] Compiling syn v2.0.114 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling num-bigint v0.4.6 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling cryptopals v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:41:50 [INFO] [stdout] | [INFO] [stdout] 41 | pub fn compute_shared(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:59:61 [INFO] [stdout] | [INFO] [stdout] 59 | pub fn compute_shared_simplified(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:82:34 [INFO] [stdout] | [INFO] [stdout] 82 | pub fn compute_shared(&self, A: BigUint, v: BigUint, b: BigUint, u: BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `S` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:85:13 [INFO] [stdout] | [INFO] [stdout] 85 | let S = base.modpow(&b, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:90:34 [INFO] [stdout] | [INFO] [stdout] 90 | pub fn offline_attack(&self, A: BigUint, b: BigUint, u: BigUint, password: &str) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `S` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:96:13 [INFO] [stdout] | [INFO] [stdout] 96 | let S = base.modpow(&b, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:104:9 [INFO] [stdout] | [INFO] [stdout] 104 | ... A: BigUint, // Client's ephemeral public key A = g**a % N. Maybe it doesn't reflect in my code but it is supposed to be a ses... [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:113:13 [INFO] [stdout] | [INFO] [stdout] 113 | let B = (&self.k * &v + generate_public_value(&b, &self.g, &self.p)) % &self.p; [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:116:13 [INFO] [stdout] | [INFO] [stdout] 116 | let K = self.compute_shared(A, v, b, u); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:124:9 [INFO] [stdout] | [INFO] [stdout] 124 | A: BigUint, [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:128:13 [INFO] [stdout] | [INFO] [stdout] 128 | let B = generate_public_value(&b, &self.g, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:130:13 [INFO] [stdout] | [INFO] [stdout] 130 | let K = self.compute_shared(A, v, b.clone(), u.clone()); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:134:48 [INFO] [stdout] | [INFO] [stdout] 134 | pub fn validate(&self, client_hmac: &[u8], K: &[u8]) -> bool { [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:153:33 [INFO] [stdout] | [INFO] [stdout] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:153:46 [INFO] [stdout] | [INFO] [stdout] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `uH` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:163:9 [INFO] [stdout] | [INFO] [stdout] 163 | let uH = sha256(&[A.to_bytes_be(), B.to_bytes_be()].concat()); [INFO] [stdout] | ^^ help: convert the identifier to snake case: `u_h` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 17.44s [INFO] running `Command { std: "docker" "inspect" "26ce513113605118a5f93f82ea713838a6ba8188aee250abf32d26448616f6c8", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "26ce513113605118a5f93f82ea713838a6ba8188aee250abf32d26448616f6c8", kill_on_drop: false }` [INFO] [stdout] 26ce513113605118a5f93f82ea713838a6ba8188aee250abf32d26448616f6c8 [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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 92fab934ad722167c8865429a6b2acfce80ffa84dc4f699032673d982e483177 [INFO] running `Command { std: "docker" "start" "-a" "92fab934ad722167c8865429a6b2acfce80ffa84dc4f699032673d982e483177", kill_on_drop: false }` [INFO] [stderr] Compiling cryptopals v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge36.rs:42:34 [INFO] [stdout] | [INFO] [stdout] 42 | let (username, password, A) = client.get_credentials(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/set5/challenge36.rs:44:20 [INFO] [stdout] | [INFO] [stdout] 44 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:43:34 [INFO] [stdout] | [INFO] [stdout] 43 | let (username, password, A) = attacker.get_credentials(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:44:13 [INFO] [stdout] | [INFO] [stdout] 44 | let A = 0u32.into(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:45:20 [INFO] [stdout] | [INFO] [stdout] 45 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:49:34 [INFO] [stdout] | [INFO] [stdout] 49 | let (username, password, A) = attacker.get_credentials(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:50:13 [INFO] [stdout] | [INFO] [stdout] 50 | let A = p.clone(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:51:20 [INFO] [stdout] | [INFO] [stdout] 51 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:55:34 [INFO] [stdout] | [INFO] [stdout] 55 | let (username, password, A) = attacker.get_credentials(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:56:13 [INFO] [stdout] | [INFO] [stdout] 56 | let A = &p * 2u32; [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:57:20 [INFO] [stdout] | [INFO] [stdout] 57 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge38.rs:37:34 [INFO] [stdout] | [INFO] [stdout] 37 | let (username, password, A) = client.get_credentials(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/set5/challenge38.rs:39:20 [INFO] [stdout] | [INFO] [stdout] 39 | let (salt, B, ks, u, b) = rogue_server.register_simplified(username, password, A.clone()); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `N_012` should have a snake case name [INFO] [stdout] --> src/set5/challenge40.rs:54:17 [INFO] [stdout] | [INFO] [stdout] 54 | let N_012 = &n0 * &n1 * &n2; [INFO] [stdout] | ^^^^^ help: convert the identifier to snake case: `n_012` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:41:50 [INFO] [stdout] | [INFO] [stdout] 41 | pub fn compute_shared(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:59:61 [INFO] [stdout] | [INFO] [stdout] 59 | pub fn compute_shared_simplified(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:82:34 [INFO] [stdout] | [INFO] [stdout] 82 | pub fn compute_shared(&self, A: BigUint, v: BigUint, b: BigUint, u: BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `S` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:85:13 [INFO] [stdout] | [INFO] [stdout] 85 | let S = base.modpow(&b, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:90:34 [INFO] [stdout] | [INFO] [stdout] 90 | pub fn offline_attack(&self, A: BigUint, b: BigUint, u: BigUint, password: &str) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `S` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:96:13 [INFO] [stdout] | [INFO] [stdout] 96 | let S = base.modpow(&b, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:104:9 [INFO] [stdout] | [INFO] [stdout] 104 | ... A: BigUint, // Client's ephemeral public key A = g**a % N. Maybe it doesn't reflect in my code but it is supposed to be a ses... [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:113:13 [INFO] [stdout] | [INFO] [stdout] 113 | let B = (&self.k * &v + generate_public_value(&b, &self.g, &self.p)) % &self.p; [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:116:13 [INFO] [stdout] | [INFO] [stdout] 116 | let K = self.compute_shared(A, v, b, u); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:124:9 [INFO] [stdout] | [INFO] [stdout] 124 | A: BigUint, [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:128:13 [INFO] [stdout] | [INFO] [stdout] 128 | let B = generate_public_value(&b, &self.g, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:130:13 [INFO] [stdout] | [INFO] [stdout] 130 | let K = self.compute_shared(A, v, b.clone(), u.clone()); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:134:48 [INFO] [stdout] | [INFO] [stdout] 134 | pub fn validate(&self, client_hmac: &[u8], K: &[u8]) -> bool { [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:153:33 [INFO] [stdout] | [INFO] [stdout] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:153:46 [INFO] [stdout] | [INFO] [stdout] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `uH` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:163:9 [INFO] [stdout] | [INFO] [stdout] 163 | let uH = sha256(&[A.to_bytes_be(), B.to_bytes_be()].concat()); [INFO] [stdout] | ^^ help: convert the identifier to snake case: `u_h` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 2.96s [INFO] running `Command { std: "docker" "inspect" "92fab934ad722167c8865429a6b2acfce80ffa84dc4f699032673d982e483177", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "92fab934ad722167c8865429a6b2acfce80ffa84dc4f699032673d982e483177", kill_on_drop: false }` [INFO] [stdout] 92fab934ad722167c8865429a6b2acfce80ffa84dc4f699032673d982e483177 [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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-04-21" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 8160e246696a568db8fbfb69a7f9f1c1364b24b9eece7b18c2befdd8e933f387 [INFO] running `Command { std: "docker" "start" "-a" "8160e246696a568db8fbfb69a7f9f1c1364b24b9eece7b18c2befdd8e933f387", kill_on_drop: false }` [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge36.rs:42:34 [INFO] [stderr] | [INFO] [stderr] 42 | let (username, password, A) = client.get_credentials(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/set5/challenge36.rs:44:20 [INFO] [stderr] | [INFO] [stderr] 44 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:43:34 [INFO] [stderr] | [INFO] [stderr] 43 | let (username, password, A) = attacker.get_credentials(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:44:13 [INFO] [stderr] | [INFO] [stderr] 44 | let A = 0u32.into(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:45:20 [INFO] [stderr] | [INFO] [stderr] 45 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:49:34 [INFO] [stderr] | [INFO] [stderr] 49 | let (username, password, A) = attacker.get_credentials(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:50:13 [INFO] [stderr] | [INFO] [stderr] 50 | let A = p.clone(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:51:20 [INFO] [stderr] | [INFO] [stderr] 51 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:55:34 [INFO] [stderr] | [INFO] [stderr] 55 | let (username, password, A) = attacker.get_credentials(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:56:13 [INFO] [stderr] | [INFO] [stderr] 56 | let A = &p * 2u32; [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:57:20 [INFO] [stderr] | [INFO] [stderr] 57 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge38.rs:37:34 [INFO] [stderr] | [INFO] [stderr] 37 | let (username, password, A) = client.get_credentials(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/set5/challenge38.rs:39:20 [INFO] [stderr] | [INFO] [stderr] 39 | let (salt, B, ks, u, b) = rogue_server.register_simplified(username, password, A.clone()); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `N_012` should have a snake case name [INFO] [stderr] --> src/set5/challenge40.rs:54:17 [INFO] [stderr] | [INFO] [stderr] 54 | let N_012 = &n0 * &n1 * &n2; [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `n_012` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:41:50 [INFO] [stderr] | [INFO] [stderr] 41 | pub fn compute_shared(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:59:61 [INFO] [stderr] | [INFO] [stderr] 59 | pub fn compute_shared_simplified(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:82:34 [INFO] [stderr] | [INFO] [stderr] 82 | pub fn compute_shared(&self, A: BigUint, v: BigUint, b: BigUint, u: BigUint) -> Vec { [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `S` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:85:13 [INFO] [stderr] | [INFO] [stderr] 85 | let S = base.modpow(&b, &self.p); [INFO] [stderr] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:90:34 [INFO] [stderr] | [INFO] [stderr] 90 | pub fn offline_attack(&self, A: BigUint, b: BigUint, u: BigUint, password: &str) -> Vec { [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `S` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:96:13 [INFO] [stderr] | [INFO] [stderr] 96 | let S = base.modpow(&b, &self.p); [INFO] [stderr] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:104:9 [INFO] [stderr] | [INFO] [stderr] 104 | ... A: BigUint, // Client's ephemeral public key A = g**a % N. Maybe it doesn't reflect in my code but it is supposed to be a ses... [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:113:13 [INFO] [stderr] | [INFO] [stderr] 113 | let B = (&self.k * &v + generate_public_value(&b, &self.g, &self.p)) % &self.p; [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `K` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:116:13 [INFO] [stderr] | [INFO] [stderr] 116 | let K = self.compute_shared(A, v, b, u); [INFO] [stderr] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:124:9 [INFO] [stderr] | [INFO] [stderr] 124 | A: BigUint, [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:128:13 [INFO] [stderr] | [INFO] [stderr] 128 | let B = generate_public_value(&b, &self.g, &self.p); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `K` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:130:13 [INFO] [stderr] | [INFO] [stderr] 130 | let K = self.compute_shared(A, v, b.clone(), u.clone()); [INFO] [stderr] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stderr] [INFO] [stderr] warning: variable `K` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:134:48 [INFO] [stderr] | [INFO] [stderr] 134 | pub fn validate(&self, client_hmac: &[u8], K: &[u8]) -> bool { [INFO] [stderr] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:153:33 [INFO] [stderr] | [INFO] [stderr] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:153:46 [INFO] [stderr] | [INFO] [stderr] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `uH` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:163:9 [INFO] [stderr] | [INFO] [stderr] 163 | let uH = sha256(&[A.to_bytes_be(), B.to_bytes_be()].concat()); [INFO] [stderr] | ^^ help: convert the identifier to snake case: `u_h` [INFO] [stderr] [INFO] [stderr] warning: `cryptopals` (bin "cryptopals" test) generated 30 warnings [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.10s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/cryptopals-8cca95b82c66c85d) [INFO] [stdout] [INFO] [stdout] running 113 tests [INFO] [stdout] test set1::challenge2::tests::test_challenge2_all_zeros ... ok [INFO] [stdout] test set1::challenge2::tests::test_challenge2_different_lengths ... ok [INFO] [stdout] test set1::challenge2::tests::test_challenge2_empty_strings ... ok [INFO] [stdout] test set1::challenge3::tests::test_challenge3 ... ok [INFO] [stdout] test set1::challenge2::tests::test_challenge2_basic ... ok [INFO] [stdout] test set1::challenge5::tests::test_repeating_key_xor ... ok [INFO] [stdout] test set1::challenge1::tests::test_challenge1 ... ok [INFO] [stdout] test set1::challenge2::tests::test_challenge2_all_ffs ... ok [INFO] [stdout] test set1::challenge6::tests::test_challenge6_plaintext_decryption ... ok [INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_kasiski ... ok [INFO] [stdout] test set1::challenge7::tests::test_challenge7_decrypt ... ok [INFO] [stdout] test set2::challenge10::tests::test_ecb_encrypt_decrypt ... ok [INFO] [stdout] test set2::challenge10::tests::test_cbc_encrypt_decrypt ... ok [INFO] [stdout] test set2::challenge11::tests::test_case4_repeated_16byte_blocks_expect_failures ... ok [INFO] [stdout] test set2::challenge10::tests::test_challenge10_decrypt ... ok [INFO] [stdout] test set2::challenge11::tests::test_case2_repeated_16byte_blocks_expect_failures ... ok [INFO] [stdout] test set1::challenge8::tests::test_has_duplicate_blocks ... ok [INFO] [stdout] test set2::challenge11::tests::test_case5_two_distinct_patterns_should_detect ... ok [INFO] [stdout] test set2::challenge11::tests::test_case3_repeated_16byte_blocks_expect_failures ... ok [INFO] [stdout] test set2::challenge11::tests::test_case6_text_repetition_expect_failures ... ok [INFO] [stdout] test set1::challenge8::tests::test_challenge8_detect_ecb ... ok [INFO] [stdout] test set2::challenge12::tests::challenge12_step2_detect_ecb ... ok [INFO] [stdout] test set2::challenge13::tests::challenge13_ecb_cut_and_paste ... ok [INFO] [stdout] test set2::challenge14::tests::test_detect_random_bytes_length ... ok [INFO] [stdout] test set2::challenge9::tests::test_pkcs7_pad ... ok [INFO] [stdout] test set2::challenge9::tests::test_pkcs7_unpad ... ok [INFO] [stdout] test set3::challenge18::tests::test_challenge18 ... ok [INFO] [stdout] test set3::challenge19::tests::demo_print_xor_space ... ignored [INFO] [stdout] test set3::challenge19::tests::print_big_columnar_xor_table ... ignored [INFO] [stdout] test set3::challenge19::tests::print_ct_and_pt ... ignored [INFO] [stdout] test set3::challenge19::tests::test_crib_dragging ... ignored [INFO] [stdout] test set3::challenge19::tests::test_decipher_with_chi_squared ... ignored [INFO] [stdout] test set3::challenge19::tests::test_decipher_with_score_english ... ignored [INFO] [stdout] test set2::challenge13::tests::challenge13_ecb_cut_and_paste_attack ... ok [INFO] [stdout] test set3::challenge19::tests::word_frequency ... ignored [INFO] [stdout] test set3::challenge20::tests::test_decipher_with_score_english ... ignored [INFO] [stdout] test set3::challenge21::tests::test_mt19937_known_outputs ... ok [INFO] [stdout] test set2::challenge11::tests::test_case6_text_repetition_should_detect ... ok [INFO] [stdout] test set2::challenge12::tests::challenge12_step1_detect_block_size ... ok [INFO] [stdout] test set2::challenge13::tests::challenge13_profile_for ... ok [INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_friedman ... ok [INFO] [stdout] test set3::challenge23::demos::test_demo_rshift8 ... ignored [INFO] [stdout] test set3::challenge23::demos::test_undo_step1_rshift18 ... ignored [INFO] [stdout] test set3::challenge23::demos::test_undo_step2_lshift15 ... ignored [INFO] [stdout] test set3::challenge23::demos::test_undo_step2_lshift15_mask ... ignored [INFO] [stdout] test set2::challenge16::tests::challenge16 ... ok [INFO] [stdout] test set3::challenge23::demos::test_undo_step3_lshift7_mask ... ignored [INFO] [stdout] test set3::challenge23::demos::test_undo_step4_rshift11 ... ignored [INFO] [stdout] test set3::challenge23::tests::test_clone_mt19937_rng ... ok [INFO] [stdout] test set4::challenge25::tests::print_pt ... ignored [INFO] [stdout] test set3::challenge23::tests::test_untemper ... ok [INFO] [stdout] test set4::challenge25::tests::test_edit_partial ... ignored [INFO] [stdout] test set3::challenge24::tests::test_mt19937_stream_cipher ... ok [INFO] [stdout] test set4::challenge25::tests::test_edit_all ... ok [INFO] [stdout] test set4::challenge26::tests::ctr_bitflipping ... ok [INFO] [stdout] test set4::challenge27::tests::recover_key_cbc_iv_key ... ok [INFO] [stdout] test set2::challenge15::tests::challenge15_pkcs7_padding_validation ... ok [INFO] [stdout] test set2::challenge11::tests::test_case7_mixed_character_patterns_should_detect ... ok [INFO] [stdout] test set2::challenge11::tests::test_case1_repeated_16byte_blocks_should_not_detect ... ok [INFO] [stdout] test set4::challenge28::tests::test_sha1 ... ok [INFO] [stdout] test set4::challenge28::tests::test_sha1_mac ... ok [INFO] [stdout] test set4::challenge29::tests::test_length_extension_attack ... ok [INFO] [stdout] test set4::challenge29::tests::test_padding_len_0 ... ok [INFO] [stdout] test set4::challenge31::tests::side_channel_timing_attack ... ignored [INFO] [stdout] test set4::challenge32::tests::side_channel_timing_attack ... ignored [INFO] [stdout] test set4::challenge30::tests::test_md4 ... ok [INFO] [stdout] test set5::challenge33::tests_dh_simple::diffie_hellman ... ok [INFO] [stdout] test set3::challenge17::tests::test_padding_oracle_attack ... ok [INFO] [stdout] test set4::challenge30::tests::test_length_extension_attack ... ok [INFO] [stdout] test set4::challenge30::tests::test_md4_padding_len ... ok [INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_hamming ... ok [INFO] [stdout] test set3::challenge19::tests::test_decipher_with_space_xor ... ok [INFO] [stdout] test set1::challenge6::tests::test_challenge6_key_recovery ... ok [INFO] [stdout] test set1::challenge4::tests::test_detect_single_char_xor ... ok [INFO] [stdout] test set5::challenge40::tests::test_rsa_broadcast ... ok [INFO] [stdout] test set6::challenge41::tests::test_challenge41 ... ok [INFO] [stdout] test utils::encoding::tests::test_bytes_to_base64 ... ok [INFO] [stdout] test utils::encoding::tests::test_hex_to_base64_roundtrip ... ok [INFO] [stdout] test utils::encoding::tests::test_hex_to_bytes ... ok [INFO] [stdout] test utils::hmac::tests::test_hmac_sha1 ... ok [INFO] [stdout] test set5::challenge36::tests::srp ... ok [INFO] [stdout] test set5::challenge33::tests_dh::diffie_hellman ... ok [INFO] [stdout] test utils::rsa_toy::tests::test_egcd ... ok [INFO] [stdout] test utils::rsa_toy::tests::test_gen_prime ... ok [INFO] [stdout] test utils::rsa_toy::tests::test_invmod ... ok [INFO] [stdout] test utils::rsa_toy::tests::test_miller_rabin ... ok [INFO] [stdout] test utils::rsa_toy::tests::test_mod_exp ... ok [INFO] [stdout] test set5::challenge38::tests::srp ... ok [INFO] [stdout] test utils::scoring::tests::test_calculate_ic_long_english_text ... ok [INFO] [stdout] test utils::scoring::tests::test_chi_squared ... ok [INFO] [stdout] test utils::scoring::tests::test_chi_squared_partial_english ... ok [INFO] [stdout] test utils::scoring::tests::test_chi_squared_with_high_byte ... ok [INFO] [stdout] test utils::scoring::tests::test_hamming_distance ... ok [INFO] [stdout] test utils::scoring::tests::test_score_english ... ok [INFO] [stdout] test utils::xor::tests::test_xor_hex_basic ... ok [INFO] [stdout] test utils::xor::tests::test_xor_hex_different_lengths ... ok [INFO] [stdout] test set5::challenge34::tests::normal_echo ... ok [INFO] [stdout] test utils::xor::tests::test_xor_hex_empty_strings ... ok [INFO] [stdout] test utils::xor::tests::test_xor_with_byte ... ok [INFO] [stdout] test set5::challenge35::tests::mitm_attack ... ok [INFO] [stdout] test set2::challenge12::tests::challenge12_step3_byte_at_a_time_decrypt ... ok [INFO] [stdout] test set2::challenge14::tests::test_byte_at_a_time_decrypt ... ok [INFO] [stdout] test utils::rsa_toy::tests::test_toy_rsa ... FAILED [INFO] [stdout] test set5::challenge37::tests::srp ... ok [INFO] [stdout] test utils::rsa::tests::test_miller_rabin ... ok [INFO] [stdout] test set5::challenge34::tests::mitm_attack ... ok [INFO] [stdout] test set5::challenge39::tests::test_rsa_short ... ok [INFO] [stdout] test set3::challenge22::tests::test_crack_mt19937_seed ... ok [INFO] [stdout] test set3::challenge24::tests::test_mt19937_password_token_generator ... ok [INFO] [stdout] test set3::challenge24::tests::test_mt19937_stream_cipher_hack ... ok [INFO] [stdout] test set5::challenge39::tests::test_rsa_long ... ok [INFO] [stdout] test utils::rsa::tests::test_gen_prime ... ok [INFO] [stderr] error: test failed, to rerun pass `--bin cryptopals` [INFO] [stdout] test set5::challenge39::tests::test_rsa_crt ... ok [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- utils::rsa_toy::tests::test_toy_rsa stdout ---- [INFO] [stdout] [INFO] [stdout] thread 'utils::rsa_toy::tests::test_toy_rsa' (101) panicked at src/utils/rsa_toy.rs:62:9: [INFO] [stdout] Inverse does not exist [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x567a0b8bf58a - std[128c3efe2914e152]::backtrace_rs::backtrace::libunwind::trace [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x567a0b8bf58a - std[128c3efe2914e152]::backtrace_rs::backtrace::trace_unsynchronized:: [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x567a0b8bf58a - std[128c3efe2914e152]::sys::backtrace::_print_fmt [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:74:9 [INFO] [stdout] 3: 0x567a0b8bf58a - <::print::DisplayBacktrace as core[6771d259883166e6]::fmt::Display>::fmt [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:44:26 [INFO] [stdout] 4: 0x567a0b8d407a - ::fmt [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/fmt/rt.rs:152:76 [INFO] [stdout] 5: 0x567a0b8d407a - core[6771d259883166e6]::fmt::write [INFO] [stdout] 6: 0x567a0b8c3e02 - std[128c3efe2914e152]::io::default_write_fmt::> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/io/mod.rs:621:11 [INFO] [stdout] 7: 0x567a0b8c3e02 - as std[128c3efe2914e152]::io::Write>::write_fmt [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/io/mod.rs:1976:13 [INFO] [stdout] 8: 0x567a0b89e65f - ::print [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:47:9 [INFO] [stdout] 9: 0x567a0b89e65f - std[128c3efe2914e152]::panicking::default_hook::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:292:27 [INFO] [stdout] 10: 0x567a0b8b7929 - std[128c3efe2914e152]::panicking::default_hook [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:316:9 [INFO] [stdout] 11: 0x567a0b7e67ec - core[6771d259883166e6]::ops::function::Fn<(&'a std[128c3efe2914e152]::panic::PanicHookInfo<'b>,), Output = ()> + core[6771d259883166e6]::marker::Sync + core[6771d259883166e6]::marker::Send> as core[6771d259883166e6]::ops::function::Fn<(&std[128c3efe2914e152]::panic::PanicHookInfo,)>>::call [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/alloc/src/boxed.rs:2263:9 [INFO] [stdout] 12: 0x567a0b7e67ec - test[b137923399915ecf]::test_main_with_exit_callback::::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x567a0b8b7ae2 - core[6771d259883166e6]::ops::function::Fn<(&'a std[128c3efe2914e152]::panic::PanicHookInfo<'b>,), Output = ()> + core[6771d259883166e6]::marker::Sync + core[6771d259883166e6]::marker::Send> as core[6771d259883166e6]::ops::function::Fn<(&std[128c3efe2914e152]::panic::PanicHookInfo,)>>::call [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/alloc/src/boxed.rs:2263:9 [INFO] [stdout] 14: 0x567a0b8b7ae2 - std[128c3efe2914e152]::panicking::panic_with_hook [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:833:13 [INFO] [stdout] 15: 0x567a0b89e74a - std[128c3efe2914e152]::panicking::panic_handler::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:691:13 [INFO] [stdout] 16: 0x567a0b893929 - std[128c3efe2914e152]::sys::backtrace::__rust_end_short_backtrace:: [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:182:18 [INFO] [stdout] 17: 0x567a0b89f42d - __rustc[752cc74e29381ccc]::rust_begin_unwind [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:689:5 [INFO] [stdout] 18: 0x567a0b8d47cc - core[6771d259883166e6]::panicking::panic_fmt [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x567a0b7b3e03 - cryptopals::utils::rsa_toy::invmod::he8e07af7f9ca14b9 [INFO] [stdout] at /opt/rustwide/workdir/src/utils/rsa_toy.rs:62:9 [INFO] [stdout] 20: 0x567a0b7b4114 - cryptopals::utils::rsa_toy::toy_rsa::h27b5a56b91879224 [INFO] [stdout] at /opt/rustwide/workdir/src/utils/rsa_toy.rs:99:13 [INFO] [stdout] 21: 0x567a0b77c586 - cryptopals::utils::rsa_toy::tests::test_toy_rsa::h26db2f8bb464073e [INFO] [stdout] at /opt/rustwide/workdir/src/utils/rsa_toy.rs:153:25 [INFO] [stdout] 22: 0x567a0b77c927 - cryptopals::utils::rsa_toy::tests::test_toy_rsa::{{closure}}::h23ec83161894ac35 [INFO] [stdout] at /opt/rustwide/workdir/src/utils/rsa_toy.rs:152:22 [INFO] [stdout] 23: 0x567a0b7d6d76 - core::ops::function::FnOnce::call_once::hf94da41345782c5a [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x567a0b7da8eb - core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String> as core[6771d259883166e6]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x567a0b7da8eb - test[b137923399915ecf]::__rust_begin_short_backtrace::, fn() -> core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x567a0b7e72bb - test[b137923399915ecf]::run_test_in_process::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x567a0b7e72bb - as core[6771d259883166e6]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/panic/unwind_safe.rs:275:9 [INFO] [stdout] 28: 0x567a0b7e72bb - std[128c3efe2914e152]::panicking::catch_unwind::do_call::, core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:581:40 [INFO] [stdout] 29: 0x567a0b7e72bb - std[128c3efe2914e152]::panicking::catch_unwind::, core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:544:19 [INFO] [stdout] 30: 0x567a0b7e72bb - std[128c3efe2914e152]::panic::catch_unwind::, core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x567a0b7e72bb - test[b137923399915ecf]::run_test_in_process [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x567a0b7e72bb - test[b137923399915ecf]::run_test::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x567a0b7e1714 - test[b137923399915ecf]::run_test::{closure#1} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x567a0b7e1714 - std[128c3efe2914e152]::sys::backtrace::__rust_begin_short_backtrace:: [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:166:18 [INFO] [stdout] 35: 0x567a0b7e9ec2 - std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked::::{closure#1}::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/thread/lifecycle.rs:91:13 [INFO] [stdout] 36: 0x567a0b7e9ec2 - ::{closure#1}::{closure#0}> as core[6771d259883166e6]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/panic/unwind_safe.rs:275:9 [INFO] [stdout] 37: 0x567a0b7e9ec2 - std[128c3efe2914e152]::panicking::catch_unwind::do_call::::{closure#1}::{closure#0}>, ()> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:581:40 [INFO] [stdout] 38: 0x567a0b7e9ec2 - std[128c3efe2914e152]::panicking::catch_unwind::<(), core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe::{closure#1}::{closure#0}>> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:544:19 [INFO] [stdout] 39: 0x567a0b7e9ec2 - std[128c3efe2914e152]::panic::catch_unwind::::{closure#1}::{closure#0}>, ()> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x567a0b7e9ec2 - std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked::::{closure#1} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/thread/lifecycle.rs:89:26 [INFO] [stdout] 41: 0x567a0b7e9ec2 - ::{closure#1} as core[6771d259883166e6]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x567a0b8bee9f - + core[6771d259883166e6]::marker::Send> as core[6771d259883166e6]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/alloc/src/boxed.rs:2249:9 [INFO] [stdout] 43: 0x567a0b8bee9f - ::new::thread_start [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/thread/unix.rs:118:17 [INFO] [stdout] 44: 0x7550ecbc7aa4 - [INFO] [stdout] 45: 0x7550ecc54a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] utils::rsa_toy::tests::test_toy_rsa [INFO] [stdout] [INFO] [stdout] test result: FAILED. 94 passed; 1 failed; 18 ignored; 0 measured; 0 filtered out; finished in 16.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "8160e246696a568db8fbfb69a7f9f1c1364b24b9eece7b18c2befdd8e933f387", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8160e246696a568db8fbfb69a7f9f1c1364b24b9eece7b18c2befdd8e933f387", kill_on_drop: false }` [INFO] [stdout] 8160e246696a568db8fbfb69a7f9f1c1364b24b9eece7b18c2befdd8e933f387