[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-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Faxmz%2Fcryptopals" "/workspace/builds/worker-2-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-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-2-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-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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] 49647cc5bbccc40347da961d8caf5693f07485a55fc3ba0754078ccdbc15c0dd
[INFO] running `Command { std: "docker" "start" "-a" "49647cc5bbccc40347da961d8caf5693f07485a55fc3ba0754078ccdbc15c0dd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "49647cc5bbccc40347da961d8caf5693f07485a55fc3ba0754078ccdbc15c0dd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "49647cc5bbccc40347da961d8caf5693f07485a55fc3ba0754078ccdbc15c0dd", kill_on_drop: false }`
[INFO] [stdout] 49647cc5bbccc40347da961d8caf5693f07485a55fc3ba0754078ccdbc15c0dd
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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] da27b27af75a598418110dae5199d18fab1ca4a4a4ce5b393a5298cb6f891622
[INFO] running `Command { std: "docker" "start" "-a" "da27b27af75a598418110dae5199d18fab1ca4a4a4ce5b393a5298cb6f891622", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.180
[INFO] [stderr]    Compiling zerocopy v0.8.33
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling num-integer v0.1.46
[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 openssl-macros v0.1.1
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling num-bigint v0.4.6
[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 19.15s
[INFO] running `Command { std: "docker" "inspect" "da27b27af75a598418110dae5199d18fab1ca4a4a4ce5b393a5298cb6f891622", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "da27b27af75a598418110dae5199d18fab1ca4a4a4ce5b393a5298cb6f891622", kill_on_drop: false }`
[INFO] [stdout] da27b27af75a598418110dae5199d18fab1ca4a4a4ce5b393a5298cb6f891622
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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] 4900b8543fa4222f3c4b6e1381545d9c3bc53a99258b7ff28f63e8a9d826098b
[INFO] running `Command { std: "docker" "start" "-a" "4900b8543fa4222f3c4b6e1381545d9c3bc53a99258b7ff28f63e8a9d826098b", 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<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 2.57s
[INFO] running `Command { std: "docker" "inspect" "4900b8543fa4222f3c4b6e1381545d9c3bc53a99258b7ff28f63e8a9d826098b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4900b8543fa4222f3c4b6e1381545d9c3bc53a99258b7ff28f63e8a9d826098b", kill_on_drop: false }`
[INFO] [stdout] 4900b8543fa4222f3c4b6e1381545d9c3bc53a99258b7ff28f63e8a9d826098b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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] 9cf10d18e99ce34f68aa2a0719dab19a6c08e93145661576e7e1a037141afc2e
[INFO] running `Command { std: "docker" "start" "-a" "9cf10d18e99ce34f68aa2a0719dab19a6c08e93145661576e7e1a037141afc2e", 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<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 30 warnings
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.12s
[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::challenge1::tests::test_challenge1 ... ok
[INFO] [stdout] test set1::challenge2::tests::test_challenge2_all_ffs ... ok
[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_basic ... 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::challenge5::tests::test_repeating_key_xor ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_plaintext_decryption ... ok
[INFO] [stdout] test set1::challenge8::tests::test_challenge8_detect_ecb ... ok
[INFO] [stdout] test set1::challenge8::tests::test_has_duplicate_blocks ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_friedman ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_hamming ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_kasiski ... 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::challenge7::tests::test_challenge7_decrypt ... ok
[INFO] [stdout] test set2::challenge10::tests::test_ecb_encrypt_decrypt ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case1_repeated_16byte_blocks_should_not_detect ... ok
[INFO] [stdout] test set2::challenge10::tests::test_cbc_encrypt_decrypt ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case6_text_repetition_expect_failures ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case5_two_distinct_patterns_should_detect ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case6_text_repetition_should_detect ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case4_repeated_16byte_blocks_expect_failures ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case3_repeated_16byte_blocks_expect_failures ... 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::challenge13::tests::challenge13_profile_for ... ok
[INFO] [stdout] test set2::challenge13::tests::challenge13_ecb_cut_and_paste_attack ... ok
[INFO] [stdout] test set2::challenge12::tests::challenge12_step1_detect_block_size ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case7_mixed_character_patterns_should_detect ... 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 set2::challenge9::tests::test_pkcs7_unpad ... ok
[INFO] [stdout] test set2::challenge16::tests::challenge16 ... 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 set3::challenge18::tests::test_challenge18 ... 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 set2::challenge9::tests::test_pkcs7_pad ... ok
[INFO] [stdout] test set3::challenge21::tests::test_mt19937_known_outputs ... 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 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 set3::challenge23::tests::test_untemper ... ok
[INFO] [stdout] test set3::challenge19::tests::test_decipher_with_space_xor ... ok
[INFO] [stdout] test set3::challenge24::tests::test_mt19937_stream_cipher ... ok
[INFO] [stdout] test set3::challenge17::tests::test_padding_oracle_attack ... ok
[INFO] [stdout] test set4::challenge25::tests::print_pt ... ignored
[INFO] [stdout] test set4::challenge25::tests::test_edit_all ... ok
[INFO] [stdout] test set4::challenge25::tests::test_edit_partial ... ignored
[INFO] [stdout] test set4::challenge26::tests::ctr_bitflipping ... ok
[INFO] [stdout] test set4::challenge27::tests::recover_key_cbc_iv_key ... 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::challenge30::tests::test_length_extension_attack ... ok
[INFO] [stdout] test set4::challenge30::tests::test_md4 ... ok
[INFO] [stdout] test set4::challenge30::tests::test_md4_padding_len ... 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 set1::challenge6::tests::test_challenge6_key_recovery ... ok
[INFO] [stdout] test set5::challenge33::tests_dh_simple::diffie_hellman ... ok
[INFO] [stdout] test set1::challenge4::tests::test_detect_single_char_xor ... ok
[INFO] [stdout] test set5::challenge33::tests_dh::diffie_hellman ... ok
[INFO] [stdout] test set5::challenge34::tests::normal_echo ... ok
[INFO] [stdout] test set2::challenge14::tests::test_byte_at_a_time_decrypt ... ok
[INFO] [stdout] test set2::challenge12::tests::challenge12_step3_byte_at_a_time_decrypt ... ok
[INFO] [stdout] test set5::challenge36::tests::srp ... ok
[INFO] [stdout] test set5::challenge34::tests::mitm_attack ... ok
[INFO] [stdout] test set5::challenge35::tests::mitm_attack ... ok
[INFO] [stdout] test set5::challenge38::tests::srp ... 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 utils::encoding::tests::test_bytes_to_base64 ... ok
[INFO] [stdout] test set6::challenge41::tests::test_challenge41 ... ok
[INFO] [stdout] test utils::encoding::tests::test_hex_to_base64_roundtrip ... ok
[INFO] [stdout] test utils::hmac::tests::test_hmac_sha1 ... ok
[INFO] [stdout] test utils::encoding::tests::test_hex_to_bytes ... ok
[INFO] [stdout] test set5::challenge40::tests::test_rsa_broadcast ... 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 set5::challenge37::tests::srp ... ok
[INFO] [stdout] test utils::rsa::tests::test_miller_rabin ... ok
[INFO] [stdout] test set5::challenge39::tests::test_rsa_short ... ok
[INFO] [stdout] test set5::challenge39::tests::test_rsa_long ... ok
[INFO] [stdout] test set3::challenge24::tests::test_mt19937_stream_cipher_hack ... ok
[INFO] [stdout] test set5::challenge39::tests::test_rsa_crt ... ok
[INFO] [stdout] test utils::rsa::tests::test_gen_prime ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 95 passed; 0 failed; 18 ignored; 0 measured; 0 filtered out; finished in 38.80s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "9cf10d18e99ce34f68aa2a0719dab19a6c08e93145661576e7e1a037141afc2e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9cf10d18e99ce34f68aa2a0719dab19a6c08e93145661576e7e1a037141afc2e", kill_on_drop: false }`
[INFO] [stdout] 9cf10d18e99ce34f68aa2a0719dab19a6c08e93145661576e7e1a037141afc2e
