[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 1.94.0 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Faxmz%2Fcryptopals" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-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-2-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/axmz/cryptopals on toolchain 1.94.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.94.0" "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" "+1.94.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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" "+1.94.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 8d69a1eb88685c368178cbc39d386aa04c4183404fe163bd60cd61109a46e927
[INFO] running `Command { std: "docker" "start" "-a" "8d69a1eb88685c368178cbc39d386aa04c4183404fe163bd60cd61109a46e927", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "8d69a1eb88685c368178cbc39d386aa04c4183404fe163bd60cd61109a46e927", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8d69a1eb88685c368178cbc39d386aa04c4183404fe163bd60cd61109a46e927", kill_on_drop: false }`
[INFO] [stdout] 8d69a1eb88685c368178cbc39d386aa04c4183404fe163bd60cd61109a46e927
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=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" "+1.94.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c4a9a3bd1a5c06ede9d5bda0d9676e44d89e1320ebcaa811b9250e7155c87931
[INFO] running `Command { std: "docker" "start" "-a" "c4a9a3bd1a5c06ede9d5bda0d9676e44d89e1320ebcaa811b9250e7155c87931", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.105
[INFO] [stderr]    Compiling zerocopy v0.8.33
[INFO] [stderr]    Compiling find-msvc-tools v0.1.7
[INFO] [stderr]    Compiling quote v1.0.43
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling cc v1.2.52
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[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 14.10s
[INFO] running `Command { std: "docker" "inspect" "c4a9a3bd1a5c06ede9d5bda0d9676e44d89e1320ebcaa811b9250e7155c87931", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c4a9a3bd1a5c06ede9d5bda0d9676e44d89e1320ebcaa811b9250e7155c87931", kill_on_drop: false }`
[INFO] [stdout] c4a9a3bd1a5c06ede9d5bda0d9676e44d89e1320ebcaa811b9250e7155c87931
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=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" "+1.94.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 3de2e47ccd1265a24cd02bb88ec4f6790d5007db8a21e86d665ceea31813b814
[INFO] running `Command { std: "docker" "start" "-a" "3de2e47ccd1265a24cd02bb88ec4f6790d5007db8a21e86d665ceea31813b814", 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.44s
[INFO] running `Command { std: "docker" "inspect" "3de2e47ccd1265a24cd02bb88ec4f6790d5007db8a21e86d665ceea31813b814", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3de2e47ccd1265a24cd02bb88ec4f6790d5007db8a21e86d665ceea31813b814", kill_on_drop: false }`
[INFO] [stdout] 3de2e47ccd1265a24cd02bb88ec4f6790d5007db8a21e86d665ceea31813b814
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=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" "+1.94.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 0c36816e311c3c7ac495b1cbd6c097c5824e0e5180ce9f6f423fc14b7976d979
[INFO] running `Command { std: "docker" "start" "-a" "0c36816e311c3c7ac495b1cbd6c097c5824e0e5180ce9f6f423fc14b7976d979", 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.08s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/cryptopals-5666befd738ac9b4)
[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_basic ... ok
[INFO] [stdout] test set1::challenge2::tests::test_challenge2_different_lengths ... ok
[INFO] [stdout] test set1::challenge2::tests::test_challenge2_all_zeros ... 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::challenge6::tests::test_challenge6_keysize_detection_hamming ... ok
[INFO] [stdout] test set1::challenge5::tests::test_repeating_key_xor ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_kasiski ... ok
[INFO] [stdout] test set1::challenge8::tests::test_has_duplicate_blocks ... ok
[INFO] [stdout] test set1::challenge8::tests::test_challenge8_detect_ecb ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_plaintext_decryption ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_friedman ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case3_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::challenge12::tests::challenge12_step1_detect_block_size ... ok
[INFO] [stdout] test set2::challenge10::tests::test_ecb_encrypt_decrypt ... 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 set2::challenge13::tests::challenge13_ecb_cut_and_paste_attack ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case6_text_repetition_expect_failures ... ok
[INFO] [stdout] test set2::challenge15::tests::challenge15_pkcs7_padding_validation ... ok
[INFO] [stdout] test set2::challenge9::tests::test_pkcs7_pad ... ok
[INFO] [stdout] test set2::challenge9::tests::test_pkcs7_unpad ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case6_text_repetition_should_detect ... ok
[INFO] [stdout] test set2::challenge10::tests::test_cbc_encrypt_decrypt ... ok
[INFO] [stdout] test set2::challenge16::tests::challenge16 ... ok
[INFO] [stdout] test set2::challenge14::tests::test_detect_random_bytes_length ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case5_two_distinct_patterns_should_detect ... 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::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 set2::challenge11::tests::test_case4_repeated_16byte_blocks_expect_failures ... ok
[INFO] [stdout] test set2::challenge13::tests::challenge13_ecb_cut_and_paste ... ok
[INFO] [stdout] test set3::challenge18::tests::test_challenge18 ... ok
[INFO] [stdout] test set3::challenge24::tests::test_mt19937_stream_cipher ... ok
[INFO] [stdout] test set4::challenge25::tests::print_pt ... ignored
[INFO] [stdout] test set3::challenge21::tests::test_mt19937_known_outputs ... 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 set3::challenge19::tests::test_decipher_with_space_xor ... ok
[INFO] [stdout] test set4::challenge28::tests::test_sha1_mac ... ok
[INFO] [stdout] test set4::challenge25::tests::test_edit_all ... 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::challenge28::tests::test_sha1 ... ok
[INFO] [stdout] test set4::challenge30::tests::test_md4 ... ok
[INFO] [stdout] test set4::challenge29::tests::test_length_extension_attack ... ok
[INFO] [stdout] test set3::challenge23::tests::test_untemper ... ok
[INFO] [stdout] test set3::challenge23::tests::test_clone_mt19937_rng ... 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 set5::challenge33::tests_dh_simple::diffie_hellman ... ok
[INFO] [stdout] test set1::challenge4::tests::test_detect_single_char_xor ... ok
[INFO] [stdout] test set2::challenge13::tests::challenge13_profile_for ... ok
[INFO] [stdout] test set2::challenge12::tests::challenge12_step2_detect_ecb ... ok
[INFO] [stdout] test set2::challenge11::tests::test_case7_mixed_character_patterns_should_detect ... ok
[INFO] [stdout] test set3::challenge17::tests::test_padding_oracle_attack ... ok
[INFO] [stdout] test set1::challenge6::tests::test_challenge6_key_recovery ... ok
[INFO] [stdout] test set5::challenge40::tests::test_rsa_broadcast ... ok
[INFO] [stdout] test set6::challenge41::tests::test_challenge41 ... ok
[INFO] [stdout] test utils::encoding::tests::test_bytes_to_base64 ... ok
[INFO] [stdout] test utils::encoding::tests::test_hex_to_base64_roundtrip ... ok
[INFO] [stdout] test utils::encoding::tests::test_hex_to_bytes ... ok
[INFO] [stdout] test utils::hmac::tests::test_hmac_sha1 ... ok
[INFO] [stdout] test set5::challenge38::tests::srp ... ok
[INFO] [stdout] test set5::challenge36::tests::srp ... ok
[INFO] [stdout] test utils::rsa_toy::tests::test_egcd ... ok
[INFO] [stdout] test utils::rsa_toy::tests::test_gen_prime ... ok
[INFO] [stdout] test utils::rsa_toy::tests::test_invmod ... ok
[INFO] [stdout] test utils::rsa_toy::tests::test_miller_rabin ... ok
[INFO] [stdout] test utils::rsa_toy::tests::test_mod_exp ... ok
[INFO] [stdout] test set5::challenge34::tests::normal_echo ... 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_toy::tests::test_toy_rsa ... FAILED
[INFO] [stdout] test set5::challenge34::tests::mitm_attack ... ok
[INFO] [stdout] test set5::challenge33::tests_dh::diffie_hellman ... ok
[INFO] [stdout] test set5::challenge35::tests::mitm_attack ... ok
[INFO] [stdout] test set2::challenge14::tests::test_byte_at_a_time_decrypt ... ok
[INFO] [stdout] test set5::challenge37::tests::srp ... ok
[INFO] [stdout] test set2::challenge12::tests::challenge12_step3_byte_at_a_time_decrypt ... ok
[INFO] [stdout] test utils::rsa::tests::test_miller_rabin ... ok
[INFO] [stdout] test set3::challenge24::tests::test_mt19937_password_token_generator ... ok
[INFO] [stdout] test set3::challenge22::tests::test_crack_mt19937_seed ... 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 set5::challenge39::tests::test_rsa_long ... ok
[INFO] [stdout] test set5::challenge39::tests::test_rsa_short ... ok
[INFO] [stdout] test utils::rsa::tests::test_gen_prime ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- utils::rsa_toy::tests::test_toy_rsa stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'utils::rsa_toy::tests::test_toy_rsa' (108) panicked at src/utils/rsa_toy.rs:62:9:
[INFO] [stdout] Inverse does not exist
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x58175db7a3c2 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x58175db7a3c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x58175db7a3c2 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x58175db7a3c2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x58175db8b53a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x58175db8b53a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x58175db49036 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x58175db49036 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x58175db598a9 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x58175db598a9 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x58175db59741 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x58175daaface - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x58175daaface - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x58175db59b22 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x58175db59b22 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x58175db5999a - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x58175db54e29 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x58175db3de6d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x58175db929dc - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x58175da3a383 - cryptopals::utils::rsa_toy::invmod::hf6f86284cf111ee1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/utils/rsa_toy.rs:62:9
[INFO] [stdout]   20:     0x58175da3a694 - cryptopals::utils::rsa_toy::toy_rsa::h00fe51191e3d5091
[INFO] [stdout]                                at /opt/rustwide/workdir/src/utils/rsa_toy.rs:99:13
[INFO] [stdout]   21:     0x58175da6f296 - cryptopals::utils::rsa_toy::tests::test_toy_rsa::h24dd6d9b657abe66
[INFO] [stdout]                                at /opt/rustwide/workdir/src/utils/rsa_toy.rs:153:25
[INFO] [stdout]   22:     0x58175da6f637 - cryptopals::utils::rsa_toy::tests::test_toy_rsa::{{closure}}::hd5e3cd0fd79a8b13
[INFO] [stdout]                                at /opt/rustwide/workdir/src/utils/rsa_toy.rs:152:22
[INFO] [stdout]   23:     0x58175da472d6 - core::ops::function::FnOnce::call_once::h9c12151974ec4a14
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x58175daaf88b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x58175daaf88b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x58175dac329a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x58175dac329a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x58175dac329a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   29:     0x58175dac329a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   30:     0x58175dac329a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x58175dac329a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x58175dac329a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x58175da9d6f4 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x58175da9d6f4 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   35:     0x58175daa1092 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   36:     0x58175daa1092 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x58175daa1092 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   38:     0x58175daa1092 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   39:     0x58175daa1092 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x58175daa1092 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   41:     0x58175daa1092 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x58175db500bf - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   43:     0x58175db500bf - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   44:     0x7fd6e28fdaa4 - <unknown>
[INFO] [stdout]   45:     0x7fd6e298aa64 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     utils::rsa_toy::tests::test_toy_rsa
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 94 passed; 1 failed; 18 ignored; 0 measured; 0 filtered out; finished in 12.55s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin cryptopals`
[INFO] running `Command { std: "docker" "inspect" "0c36816e311c3c7ac495b1cbd6c097c5824e0e5180ce9f6f423fc14b7976d979", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0c36816e311c3c7ac495b1cbd6c097c5824e0e5180ce9f6f423fc14b7976d979", kill_on_drop: false }`
[INFO] [stdout] 0c36816e311c3c7ac495b1cbd6c097c5824e0e5180ce9f6f423fc14b7976d979
