[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] 6522b3ea5f447c8851a813b82effd1f6713a35d8
[INFO] testing axmz/cryptopals/6522b3ea5f447c8851a813b82effd1f6713a35d8 against master#ec6f9a5b4413f74386267ef8efc93712c2ce6db6 for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Faxmz%2Fcryptopals" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/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-4-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/axmz/cryptopals on toolchain ec6f9a5b4413f74386267ef8efc93712c2ce6db6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "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 rand_core v0.6.4
[INFO] [stderr]   Downloaded getrandom v0.2.17
[INFO] [stderr]   Downloaded wasi v0.11.1+wasi-snapshot-preview1
[INFO] [stderr]   Downloaded foreign-types v0.3.2
[INFO] [stderr]   Downloaded rand_chacha v0.3.1
[INFO] [stderr]   Downloaded rand v0.8.5
[INFO] [stderr]   Downloaded foreign-types-shared v0.1.1
[INFO] [stderr]   Downloaded cfg-if v1.0.4
[INFO] [stderr]   Downloaded openssl-macros v0.1.1
[INFO] [stderr]   Downloaded ppv-lite86 v0.2.21
[INFO] [stderr]   Downloaded pkg-config v0.3.32
[INFO] [stderr]   Downloaded shlex v1.3.0
[INFO] [stderr]   Downloaded quote v1.0.43
[INFO] [stderr]   Downloaded num-integer v0.1.46
[INFO] [stderr]   Downloaded autocfg v1.5.0
[INFO] [stderr]   Downloaded find-msvc-tools v0.1.7
[INFO] [stderr]   Downloaded hex v0.4.3
[INFO] [stderr]   Downloaded unicode-ident v1.0.22
[INFO] [stderr]   Downloaded once_cell v1.21.3
[INFO] [stderr]   Downloaded proc-macro2 v1.0.105
[INFO] [stderr]   Downloaded num-traits v0.2.19
[INFO] [stderr]   Downloaded bitflags v2.10.0
[INFO] [stderr]   Downloaded cc v1.2.52
[INFO] [stderr]   Downloaded openssl-sys v0.9.111
[INFO] [stderr]   Downloaded base64 v0.21.7
[INFO] [stderr]   Downloaded zerocopy-derive v0.8.33
[INFO] [stderr]   Downloaded num-bigint v0.4.6
[INFO] [stderr]   Downloaded vcpkg v0.2.15
[INFO] [stderr]   Downloaded zerocopy v0.8.33
[INFO] [stderr]   Downloaded syn v2.0.114
[INFO] [stderr]   Downloaded openssl v0.10.75
[INFO] [stderr]   Downloaded libc v0.2.180
[INFO] [stderr]   Downloaded openssl-src v300.5.5+3.5.5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 949e6c5a7f9d0973376264ffaab59eb764c34377f895c31977fc8d574846a847
[INFO] running `Command { std: "docker" "start" "-a" "949e6c5a7f9d0973376264ffaab59eb764c34377f895c31977fc8d574846a847", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "949e6c5a7f9d0973376264ffaab59eb764c34377f895c31977fc8d574846a847", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "949e6c5a7f9d0973376264ffaab59eb764c34377f895c31977fc8d574846a847", kill_on_drop: false }`
[INFO] [stdout] 949e6c5a7f9d0973376264ffaab59eb764c34377f895c31977fc8d574846a847
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 450c09cb3ae8b759a4e44e2ff626d45879cf1e4fd9c6925c38a8909158364f86
[INFO] running `Command { std: "docker" "start" "-a" "450c09cb3ae8b759a4e44e2ff626d45879cf1e4fd9c6925c38a8909158364f86", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.180
[INFO] [stderr]    Compiling find-msvc-tools v0.1.7
[INFO] [stderr]    Compiling shlex v1.3.0
[INFO] [stderr]    Compiling cfg-if v1.0.4
[INFO] [stderr]    Compiling proc-macro2 v1.0.105
[INFO] [stderr]    Compiling zerocopy v0.8.33
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling quote v1.0.43
[INFO] [stderr]    Compiling pkg-config v0.3.32
[INFO] [stderr]    Compiling vcpkg v0.2.15
[INFO] [stderr]    Compiling unicode-ident v1.0.22
[INFO] [stderr]    Compiling foreign-types-shared v0.1.1
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling base64 v0.21.7
[INFO] [stderr]    Compiling hex v0.4.3
[INFO] [stderr]    Compiling foreign-types v0.3.2
[INFO] [stderr]    Compiling cc v1.2.52
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling openssl-src v300.5.5+3.5.5
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling getrandom v0.2.17
[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<u8> {
[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<u8> {
[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<u8> {
[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<u8> {
[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 3m 31s
[INFO] running `Command { std: "docker" "inspect" "450c09cb3ae8b759a4e44e2ff626d45879cf1e4fd9c6925c38a8909158364f86", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "450c09cb3ae8b759a4e44e2ff626d45879cf1e4fd9c6925c38a8909158364f86", kill_on_drop: false }`
[INFO] [stdout] 450c09cb3ae8b759a4e44e2ff626d45879cf1e4fd9c6925c38a8909158364f86
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 80bdb09ba30bc1d26c5be3a3b0b7e786e0b1c385abe75d0b5390d02afb168b23
[INFO] running `Command { std: "docker" "start" "-a" "80bdb09ba30bc1d26c5be3a3b0b7e786e0b1c385abe75d0b5390d02afb168b23", 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/set6/challenge48.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 |         B: &BigUint,
[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/set6/challenge48.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 81 |         let B = BigUint::from(2u32).pow((8 * (k - 2)) as u32);
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `M` should have a snake case name
[INFO] [stdout]   --> src/set6/challenge48.rs:93:17
[INFO] [stdout]    |
[INFO] [stdout] 93 |         let mut M = vec![(2u32 * &B, 3u32 * &B - 1u32)];
[INFO] [stdout]    |                 ^ help: convert the identifier to snake case: `m`
[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<u8> {
[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<u8> {
[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<u8> {
[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<u8> {
[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 3.56s
[INFO] running `Command { std: "docker" "inspect" "80bdb09ba30bc1d26c5be3a3b0b7e786e0b1c385abe75d0b5390d02afb168b23", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "80bdb09ba30bc1d26c5be3a3b0b7e786e0b1c385abe75d0b5390d02afb168b23", kill_on_drop: false }`
[INFO] [stdout] 80bdb09ba30bc1d26c5be3a3b0b7e786e0b1c385abe75d0b5390d02afb168b23
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 3bd3762b817e5fbcb5da1c8a8a245b5c1f5abce9d7c497c956a53d17564702be
[INFO] running `Command { std: "docker" "start" "-a" "3bd3762b817e5fbcb5da1c8a8a245b5c1f5abce9d7c497c956a53d17564702be", kill_on_drop: false }`
[INFO] [stdout] 
[INFO] [stderr] warning: variable `A` should have a snake case name
[INFO] [stdout] running 129 tests
[INFO] [stderr]   --> src/set5/challenge36.rs:42:34
[INFO] [stdout] test set1::challenge1::tests::test_challenge1 ... ok
[INFO] [stderr]    |
[INFO] [stdout] test set1::challenge2::tests::test_challenge2_basic ... ok
[INFO] [stderr] 42 |         let (username, password, A) = client.get_credentials();
[INFO] [stdout] test set1::challenge2::tests::test_challenge2_empty_strings ... ok
[INFO] [stderr]    |                                  ^ help: convert the identifier to snake case: `a`
[INFO] [stdout] test set1::challenge2::tests::test_challenge2_different_lengths ... ok
[INFO] [stderr]    |
[INFO] [stdout] test set1::challenge2::tests::test_challenge2_all_zeros ... ok
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] test set1::challenge3::tests::test_challenge3 ... ok
[INFO] [stderr] 
[INFO] [stdout] test set1::challenge2::tests::test_challenge2_all_ffs ... ok
[INFO] [stderr] warning: variable `B` should have a snake case name
[INFO] [stdout] test set1::challenge5::tests::test_repeating_key_xor ... ok
[INFO] [stderr]   --> src/set5/challenge36.rs:44:20
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_plaintext_decryption ... ok
[INFO] [stderr]    |
[INFO] [stdout] test set1::challenge8::tests::test_has_duplicate_blocks ... ok
[INFO] [stderr] 44 |         let (salt, B, ks) = server.register(username, password, A);
[INFO] [stdout] test set2::challenge10::tests::test_cbc_encrypt_decrypt ... ok
[INFO] [stderr]    |                    ^ help: convert the identifier to snake case: `b`
[INFO] [stdout] test set2::challenge10::tests::test_ecb_encrypt_decrypt ... ok
[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/set6/challenge48.rs:23:9
[INFO] [stderr]    |
[INFO] [stderr] 23 |         B: &BigUint,
[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/set6/challenge48.rs:81:13
[INFO] [stderr]    |
[INFO] [stderr] 81 |         let B = BigUint::from(2u32).pow((8 * (k - 2)) as u32);
[INFO] [stderr]    |             ^ help: convert the identifier to snake case: `b`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `M` should have a snake case name
[INFO] [stderr]   --> src/set6/challenge48.rs:93:17
[INFO] [stderr]    |
[INFO] [stderr] 93 |         let mut M = vec![(2u32 * &B, 3u32 * &B - 1u32)];
[INFO] [stderr]    |                 ^ help: convert the identifier to snake case: `m`
[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<u8> {
[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<u8> {
[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<u8> {
[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<u8> {
[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 33 warnings
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.09s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/cryptopals-163a79dac7d55ccd)
[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 set2::challenge11::tests::test_case6_text_repetition_should_detect ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case2_repeated_16byte_blocks_expect_failures ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case5_two_distinct_patterns_should_detect ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_friedman ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case4_repeated_16byte_blocks_expect_failures ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case1_repeated_16byte_blocks_should_not_detect ... ok
[INFO] [stdout] test set1::challenge7::tests::test_challenge7_decrypt ... ok
[INFO] [stdout] test set2::challenge10::tests::test_challenge10_decrypt ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case7_mixed_character_patterns_should_detect ... ok
[INFO] [stdout] test set2::challenge12::tests::challenge12_step1_detect_block_size ... 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::challenge9::tests::test_pkcs7_unpad ... 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 set2::challenge13::tests::challenge13_profile_for ... ok
[INFO] [stdout] test set3::challenge19::tests::test_crib_dragging ... ignored
[INFO] [stdout] test set2::challenge9::tests::test_pkcs7_pad ... ok
[INFO] [stdout] test set2::challenge13::tests::challenge13_ecb_cut_and_paste_attack ... ok
[INFO] [stdout] test set2::challenge14::tests::test_detect_random_bytes_length ... ok
[INFO] [stdout] test set2::challenge15::tests::challenge15_pkcs7_padding_validation ... ok
[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 set3::challenge19::tests::word_frequency ... ignored
[INFO] [stdout] test set3::challenge20::tests::test_decipher_with_score_english ... ignored
[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 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_untemper ... ok
[INFO] [stdout] test set3::challenge21::tests::test_mt19937_known_outputs ... ok
[INFO] [stdout] test set1::challenge8::tests::test_challenge8_detect_ecb ... ok
[INFO] [stdout] test set3::challenge23::tests::test_clone_mt19937_rng ... ok
[INFO] [stdout] test set3::challenge18::tests::test_challenge18 ... ok
[INFO] [stdout] test set4::challenge25::tests::print_pt ... ignored
[INFO] [stdout] test set3::challenge24::tests::test_mt19937_stream_cipher ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_hamming ... ok
[INFO] [stdout] test set4::challenge25::tests::test_edit_partial ... ignored
[INFO] [stdout] test set4::challenge27::tests::recover_key_cbc_iv_key ... ok
[INFO] [stdout] test set4::challenge26::tests::ctr_bitflipping ... ok
[INFO] [stdout] test set4::challenge28::tests::test_sha1 ... ok
[INFO] [stdout] test set4::challenge29::tests::test_padding_len_0 ... ok
[INFO] [stdout] test set4::challenge25::tests::test_edit_all ... ok
[INFO] [stdout] test set4::challenge29::tests::test_length_extension_attack ... ok
[INFO] [stdout] test set4::challenge30::tests::test_length_extension_attack ... ok
[INFO] [stdout] test set4::challenge28::tests::test_sha1_mac ... 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_padding_len ... ok
[INFO] [stdout] test set4::challenge30::tests::test_md4 ... ok
[INFO] [stdout] test set5::challenge33::tests_dh_simple::diffie_hellman ... ok
[INFO] [stdout] test set2::challenge16::tests::challenge16 ... ok
[INFO] [stdout] test set3::challenge19::tests::test_decipher_with_space_xor ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_kasiski ... ok
[INFO] [stdout] test set3::challenge17::tests::test_padding_oracle_attack ... ok
[INFO] [stdout] test set1::challenge4::tests::test_detect_single_char_xor ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_key_recovery ... ok
[INFO] [stdout] test set5::challenge36::tests::srp ... ok
[INFO] [stdout] test set5::challenge35::tests::mitm_attack ... ok
[INFO] [stdout] test set5::challenge38::tests::srp ... ok
[INFO] [stdout] test set5::challenge40::tests::test_rsa_broadcast ... ok
[INFO] [stdout] test set5::challenge33::tests_dh::diffie_hellman ... ok
[INFO] [stdout] test set2::challenge14::tests::test_byte_at_a_time_decrypt ... ok
[INFO] [stdout] test set6::challenge44::tests::test_repeated_nonce_key_recovery ... ok
[INFO] [stdout] test set2::challenge12::tests::challenge12_step3_byte_at_a_time_decrypt ... ok
[INFO] [stdout] test set6::challenge45::tests::test_g_p_plus_one_magic_signature ... ok
[INFO] [stdout] test set6::challenge45::tests::test_dsa_parameter_tampering ... ok
[INFO] [stdout] test set5::challenge37::tests::srp ... ok
[INFO] [stdout] test set5::challenge34::tests::normal_echo ... 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 set5::challenge34::tests::mitm_attack ... ok
[INFO] [stdout] test set6::challenge41::tests::test_unpadded_message_recovery_oracle ... ok
[INFO] [stdout] test utils::dsa_toy::tests::test_dsa_sign_verify ... ok
[INFO] [stdout] test utils::dsa_toy::tests::test_nonce_reuse_key_recovery ... 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 set6::challenge47::tests::test_bleichenbachers_pkcs_1_5_padding ... ok
[INFO] [stdout] test set6::challenge43::tests::test_dsa_nonce_reuse_attack_with_params ... 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 utils::rsa_toy::tests::test_toy_rsa ... 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 utils::xor::tests::test_xor_hex_empty_strings ... ok
[INFO] [stdout] test utils::xor::tests::test_xor_with_byte ... ok
[INFO] [stdout] test utils::rsa::tests::test_miller_rabin ... ok
[INFO] [stdout] test set3::challenge24::tests::test_mt19937_stream_cipher_hack ... ok
[INFO] [stdout] test set6::challenge42::tests::test_correct_verifier_rejects_forgery ... ok
[INFO] [stdout] test utils::dsa::tests::test_verify_rejects_tampered_message ... ok
[INFO] [stdout] test utils::dsa::tests::test_sign_verify_roundtrip ... ok
[INFO] [stdout] test set5::challenge39::tests::test_rsa_crt ... ok
[INFO] [stdout] test set6::challenge42::tests::test_bleichenbachers_e3_rsa_attack ... ok
[INFO] [stdout] test set5::challenge39::tests::test_rsa_long has been running for over 60 seconds
[INFO] [stdout] test set5::challenge39::tests::test_rsa_short has been running for over 60 seconds
[INFO] [stdout] test set6::challenge43::tests::test_dsa_nonce_reuse_attack has been running for over 60 seconds
[INFO] [stdout] test set6::challenge46::tests::test_rsa_parity_oracle has been running for over 60 seconds
[INFO] [stdout] test set6::challenge47::tests::test_bleichenbachers_attack has been running for over 60 seconds
[INFO] [stdout] test set6::challenge48::tests::test_bleichenbachers_attack has been running for over 60 seconds
[INFO] [stdout] test utils::dsa::tests::test_verify_rejects_wrong_pubkey has been running for over 60 seconds
[INFO] [stdout] test utils::rsa::tests::test_gen_prime has been running for over 60 seconds
[INFO] [stdout] test set5::challenge39::tests::test_rsa_short ... ok
[INFO] [stdout] test set5::challenge39::tests::test_rsa_long ... ok
[INFO] [stdout] test set6::challenge43::tests::test_dsa_nonce_reuse_attack ... ok
[INFO] [stdout] test utils::rsa::tests::test_gen_prime ... ok
[INFO] [stdout] test utils::dsa::tests::test_verify_rejects_wrong_pubkey ... ok
[INFO] [stdout] test set6::challenge46::tests::test_rsa_parity_oracle ... ok
[ERROR] error running command: no output for 300 seconds
[INFO] running `Command { std: "docker" "inspect" "3bd3762b817e5fbcb5da1c8a8a245b5c1f5abce9d7c497c956a53d17564702be", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3bd3762b817e5fbcb5da1c8a8a245b5c1f5abce9d7c497c956a53d17564702be", kill_on_drop: false }`
[INFO] [stdout] 3bd3762b817e5fbcb5da1c8a8a245b5c1f5abce9d7c497c956a53d17564702be
