[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.95.0 for beta-1.96-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Faxmz%2Fcryptopals" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-6-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-6-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/axmz/cryptopals on toolchain 1.95.0 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.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.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 1636aa285f8665a4e80d24ee1fb09432a90a55dd476fe265d41b99142f31004e [INFO] running `Command { std: "docker" "start" "-a" "1636aa285f8665a4e80d24ee1fb09432a90a55dd476fe265d41b99142f31004e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "1636aa285f8665a4e80d24ee1fb09432a90a55dd476fe265d41b99142f31004e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1636aa285f8665a4e80d24ee1fb09432a90a55dd476fe265d41b99142f31004e", kill_on_drop: false }` [INFO] [stdout] 1636aa285f8665a4e80d24ee1fb09432a90a55dd476fe265d41b99142f31004e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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.95.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 9caf580ac0f4905423489c5a9b105919ee65f6f2cc21b783a8dbfb95e3b7b165 [INFO] running `Command { std: "docker" "start" "-a" "9caf580ac0f4905423489c5a9b105919ee65f6f2cc21b783a8dbfb95e3b7b165", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.180 [INFO] [stderr] Compiling zerocopy v0.8.33 [INFO] [stderr] Compiling proc-macro2 v1.0.105 [INFO] [stderr] Compiling find-msvc-tools v0.1.7 [INFO] [stderr] Compiling unicode-ident v1.0.22 [INFO] [stderr] Compiling quote v1.0.43 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling num-integer v0.1.46 [INFO] [stderr] Compiling cc v1.2.52 [INFO] [stderr] Compiling syn v2.0.114 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling rand_core v0.6.4 [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 openssl-macros v0.1.1 [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 { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:59:61 [INFO] [stdout] | [INFO] [stdout] 59 | pub fn compute_shared_simplified(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:82:34 [INFO] [stdout] | [INFO] [stdout] 82 | pub fn compute_shared(&self, A: BigUint, v: BigUint, b: BigUint, u: BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `S` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:85:13 [INFO] [stdout] | [INFO] [stdout] 85 | let S = base.modpow(&b, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:90:34 [INFO] [stdout] | [INFO] [stdout] 90 | pub fn offline_attack(&self, A: BigUint, b: BigUint, u: BigUint, password: &str) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `S` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:96:13 [INFO] [stdout] | [INFO] [stdout] 96 | let S = base.modpow(&b, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:104:9 [INFO] [stdout] | [INFO] [stdout] 104 | ... A: BigUint, // Client's ephemeral public key A = g**a % N. Maybe it doesn't reflect in my code but it is supposed to be a ses... [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:113:13 [INFO] [stdout] | [INFO] [stdout] 113 | let B = (&self.k * &v + generate_public_value(&b, &self.g, &self.p)) % &self.p; [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:116:13 [INFO] [stdout] | [INFO] [stdout] 116 | let K = self.compute_shared(A, v, b, u); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:124:9 [INFO] [stdout] | [INFO] [stdout] 124 | A: BigUint, [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:128:13 [INFO] [stdout] | [INFO] [stdout] 128 | let B = generate_public_value(&b, &self.g, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:130:13 [INFO] [stdout] | [INFO] [stdout] 130 | let K = self.compute_shared(A, v, b.clone(), u.clone()); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:134:48 [INFO] [stdout] | [INFO] [stdout] 134 | pub fn validate(&self, client_hmac: &[u8], K: &[u8]) -> bool { [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:153:33 [INFO] [stdout] | [INFO] [stdout] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:153:46 [INFO] [stdout] | [INFO] [stdout] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `uH` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:163:9 [INFO] [stdout] | [INFO] [stdout] 163 | let uH = sha256(&[A.to_bytes_be(), B.to_bytes_be()].concat()); [INFO] [stdout] | ^^ help: convert the identifier to snake case: `u_h` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 18.64s [INFO] running `Command { std: "docker" "inspect" "9caf580ac0f4905423489c5a9b105919ee65f6f2cc21b783a8dbfb95e3b7b165", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "9caf580ac0f4905423489c5a9b105919ee65f6f2cc21b783a8dbfb95e3b7b165", kill_on_drop: false }` [INFO] [stdout] 9caf580ac0f4905423489c5a9b105919ee65f6f2cc21b783a8dbfb95e3b7b165 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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.95.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 06626cf9cb470a6d46c200ab9d529a9357b9c400c7ef3a3d1bf782f5adc87352 [INFO] running `Command { std: "docker" "start" "-a" "06626cf9cb470a6d46c200ab9d529a9357b9c400c7ef3a3d1bf782f5adc87352", kill_on_drop: false }` [INFO] [stderr] Compiling cryptopals v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge36.rs:42:34 [INFO] [stdout] | [INFO] [stdout] 42 | let (username, password, A) = client.get_credentials(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/set5/challenge36.rs:44:20 [INFO] [stdout] | [INFO] [stdout] 44 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:43:34 [INFO] [stdout] | [INFO] [stdout] 43 | let (username, password, A) = attacker.get_credentials(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:44:13 [INFO] [stdout] | [INFO] [stdout] 44 | let A = 0u32.into(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:45:20 [INFO] [stdout] | [INFO] [stdout] 45 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:49:34 [INFO] [stdout] | [INFO] [stdout] 49 | let (username, password, A) = attacker.get_credentials(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:50:13 [INFO] [stdout] | [INFO] [stdout] 50 | let A = p.clone(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:51:20 [INFO] [stdout] | [INFO] [stdout] 51 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:55:34 [INFO] [stdout] | [INFO] [stdout] 55 | let (username, password, A) = attacker.get_credentials(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:56:13 [INFO] [stdout] | [INFO] [stdout] 56 | let A = &p * 2u32; [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/set5/challenge37.rs:57:20 [INFO] [stdout] | [INFO] [stdout] 57 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/set5/challenge38.rs:37:34 [INFO] [stdout] | [INFO] [stdout] 37 | let (username, password, A) = client.get_credentials(); [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/set5/challenge38.rs:39:20 [INFO] [stdout] | [INFO] [stdout] 39 | let (salt, B, ks, u, b) = rogue_server.register_simplified(username, password, A.clone()); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `N_012` should have a snake case name [INFO] [stdout] --> src/set5/challenge40.rs:54:17 [INFO] [stdout] | [INFO] [stdout] 54 | let N_012 = &n0 * &n1 * &n2; [INFO] [stdout] | ^^^^^ help: convert the identifier to snake case: `n_012` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:41:50 [INFO] [stdout] | [INFO] [stdout] 41 | pub fn compute_shared(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:59:61 [INFO] [stdout] | [INFO] [stdout] 59 | pub fn compute_shared_simplified(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:82:34 [INFO] [stdout] | [INFO] [stdout] 82 | pub fn compute_shared(&self, A: BigUint, v: BigUint, b: BigUint, u: BigUint) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `S` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:85:13 [INFO] [stdout] | [INFO] [stdout] 85 | let S = base.modpow(&b, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:90:34 [INFO] [stdout] | [INFO] [stdout] 90 | pub fn offline_attack(&self, A: BigUint, b: BigUint, u: BigUint, password: &str) -> Vec { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `S` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:96:13 [INFO] [stdout] | [INFO] [stdout] 96 | let S = base.modpow(&b, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:104:9 [INFO] [stdout] | [INFO] [stdout] 104 | ... A: BigUint, // Client's ephemeral public key A = g**a % N. Maybe it doesn't reflect in my code but it is supposed to be a ses... [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:113:13 [INFO] [stdout] | [INFO] [stdout] 113 | let B = (&self.k * &v + generate_public_value(&b, &self.g, &self.p)) % &self.p; [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:116:13 [INFO] [stdout] | [INFO] [stdout] 116 | let K = self.compute_shared(A, v, b, u); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:124:9 [INFO] [stdout] | [INFO] [stdout] 124 | A: BigUint, [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:128:13 [INFO] [stdout] | [INFO] [stdout] 128 | let B = generate_public_value(&b, &self.g, &self.p); [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:130:13 [INFO] [stdout] | [INFO] [stdout] 130 | let K = self.compute_shared(A, v, b.clone(), u.clone()); [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:134:48 [INFO] [stdout] | [INFO] [stdout] 134 | pub fn validate(&self, client_hmac: &[u8], K: &[u8]) -> bool { [INFO] [stdout] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `A` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:153:33 [INFO] [stdout] | [INFO] [stdout] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stdout] | ^ help: convert the identifier to snake case: `a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `B` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:153:46 [INFO] [stdout] | [INFO] [stdout] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stdout] | ^ help: convert the identifier to snake case: `b` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `uH` should have a snake case name [INFO] [stdout] --> src/utils/srp.rs:163:9 [INFO] [stdout] | [INFO] [stdout] 163 | let uH = sha256(&[A.to_bytes_be(), B.to_bytes_be()].concat()); [INFO] [stdout] | ^^ help: convert the identifier to snake case: `u_h` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 3.11s [INFO] running `Command { std: "docker" "inspect" "06626cf9cb470a6d46c200ab9d529a9357b9c400c7ef3a3d1bf782f5adc87352", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "06626cf9cb470a6d46c200ab9d529a9357b9c400c7ef3a3d1bf782f5adc87352", kill_on_drop: false }` [INFO] [stdout] 06626cf9cb470a6d46c200ab9d529a9357b9c400c7ef3a3d1bf782f5adc87352 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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.95.0" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 494cf9aaed3146d024765699afdffdbee662885bbc1493403018742d9b977d32 [INFO] running `Command { std: "docker" "start" "-a" "494cf9aaed3146d024765699afdffdbee662885bbc1493403018742d9b977d32", kill_on_drop: false }` [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge36.rs:42:34 [INFO] [stderr] | [INFO] [stderr] 42 | let (username, password, A) = client.get_credentials(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/set5/challenge36.rs:44:20 [INFO] [stderr] | [INFO] [stderr] 44 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:43:34 [INFO] [stderr] | [INFO] [stderr] 43 | let (username, password, A) = attacker.get_credentials(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:44:13 [INFO] [stderr] | [INFO] [stderr] 44 | let A = 0u32.into(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:45:20 [INFO] [stderr] | [INFO] [stderr] 45 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:49:34 [INFO] [stderr] | [INFO] [stderr] 49 | let (username, password, A) = attacker.get_credentials(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:50:13 [INFO] [stderr] | [INFO] [stderr] 50 | let A = p.clone(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:51:20 [INFO] [stderr] | [INFO] [stderr] 51 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:55:34 [INFO] [stderr] | [INFO] [stderr] 55 | let (username, password, A) = attacker.get_credentials(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:56:13 [INFO] [stderr] | [INFO] [stderr] 56 | let A = &p * 2u32; [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/set5/challenge37.rs:57:20 [INFO] [stderr] | [INFO] [stderr] 57 | let (salt, B, ks) = server.register(username, password, A); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/set5/challenge38.rs:37:34 [INFO] [stderr] | [INFO] [stderr] 37 | let (username, password, A) = client.get_credentials(); [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/set5/challenge38.rs:39:20 [INFO] [stderr] | [INFO] [stderr] 39 | let (salt, B, ks, u, b) = rogue_server.register_simplified(username, password, A.clone()); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `N_012` should have a snake case name [INFO] [stderr] --> src/set5/challenge40.rs:54:17 [INFO] [stderr] | [INFO] [stderr] 54 | let N_012 = &n0 * &n1 * &n2; [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `n_012` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:41:50 [INFO] [stderr] | [INFO] [stderr] 41 | pub fn compute_shared(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:59:61 [INFO] [stderr] | [INFO] [stderr] 59 | pub fn compute_shared_simplified(&self, salt: [u8; 16], B: &BigUint) -> Vec { [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:82:34 [INFO] [stderr] | [INFO] [stderr] 82 | pub fn compute_shared(&self, A: BigUint, v: BigUint, b: BigUint, u: BigUint) -> Vec { [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `S` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:85:13 [INFO] [stderr] | [INFO] [stderr] 85 | let S = base.modpow(&b, &self.p); [INFO] [stderr] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:90:34 [INFO] [stderr] | [INFO] [stderr] 90 | pub fn offline_attack(&self, A: BigUint, b: BigUint, u: BigUint, password: &str) -> Vec { [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `S` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:96:13 [INFO] [stderr] | [INFO] [stderr] 96 | let S = base.modpow(&b, &self.p); [INFO] [stderr] | ^ help: convert the identifier to snake case (notice the capitalization): `s` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:104:9 [INFO] [stderr] | [INFO] [stderr] 104 | ... A: BigUint, // Client's ephemeral public key A = g**a % N. Maybe it doesn't reflect in my code but it is supposed to be a ses... [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:113:13 [INFO] [stderr] | [INFO] [stderr] 113 | let B = (&self.k * &v + generate_public_value(&b, &self.g, &self.p)) % &self.p; [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `K` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:116:13 [INFO] [stderr] | [INFO] [stderr] 116 | let K = self.compute_shared(A, v, b, u); [INFO] [stderr] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:124:9 [INFO] [stderr] | [INFO] [stderr] 124 | A: BigUint, [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:128:13 [INFO] [stderr] | [INFO] [stderr] 128 | let B = generate_public_value(&b, &self.g, &self.p); [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `K` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:130:13 [INFO] [stderr] | [INFO] [stderr] 130 | let K = self.compute_shared(A, v, b.clone(), u.clone()); [INFO] [stderr] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stderr] [INFO] [stderr] warning: variable `K` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:134:48 [INFO] [stderr] | [INFO] [stderr] 134 | pub fn validate(&self, client_hmac: &[u8], K: &[u8]) -> bool { [INFO] [stderr] | ^ help: convert the identifier to snake case (notice the capitalization): `k` [INFO] [stderr] [INFO] [stderr] warning: variable `A` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:153:33 [INFO] [stderr] | [INFO] [stderr] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stderr] | ^ help: convert the identifier to snake case: `a` [INFO] [stderr] [INFO] [stderr] warning: variable `B` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:153:46 [INFO] [stderr] | [INFO] [stderr] 153 | fn compute_scrambling_parameter(A: &BigUint, B: &BigUint) -> BigUint { [INFO] [stderr] | ^ help: convert the identifier to snake case: `b` [INFO] [stderr] [INFO] [stderr] warning: variable `uH` should have a snake case name [INFO] [stderr] --> src/utils/srp.rs:163:9 [INFO] [stderr] | [INFO] [stderr] 163 | let uH = sha256(&[A.to_bytes_be(), B.to_bytes_be()].concat()); [INFO] [stderr] | ^^ help: convert the identifier to snake case: `u_h` [INFO] [stderr] [INFO] [stderr] warning: `cryptopals` (bin "cryptopals" test) generated 30 warnings [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.06s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/cryptopals-a065ba97b29d4c53) [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_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::challenge2::tests::test_challenge2_all_ffs ... ok [INFO] [stdout] test set1::challenge5::tests::test_repeating_key_xor ... ok [INFO] [stdout] test set1::challenge2::tests::test_challenge2_different_lengths ... ok [INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_hamming ... ok [INFO] [stdout] test set1::challenge2::tests::test_challenge2_basic ... ok [INFO] [stdout] test set1::challenge8::tests::test_has_duplicate_blocks ... ok [INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_kasiski ... 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 set2::challenge11::tests::test_case6_text_repetition_expect_failures ... ok [INFO] [stdout] test set2::challenge11::tests::test_case2_repeated_16byte_blocks_expect_failures ... 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_cbc_encrypt_decrypt ... ok [INFO] [stdout] test set2::challenge12::tests::challenge12_step2_detect_ecb ... ok [INFO] [stdout] test set2::challenge13::tests::challenge13_ecb_cut_and_paste_attack ... ok [INFO] [stdout] test set2::challenge13::tests::challenge13_ecb_cut_and_paste ... ok [INFO] [stdout] test set2::challenge11::tests::test_case5_two_distinct_patterns_should_detect ... ok [INFO] [stdout] test set2::challenge13::tests::challenge13_profile_for ... ok [INFO] [stdout] test set2::challenge10::tests::test_challenge10_decrypt ... ok [INFO] [stdout] test set2::challenge11::tests::test_case3_repeated_16byte_blocks_expect_failures ... ok [INFO] [stdout] test set2::challenge14::tests::test_detect_random_bytes_length ... ok [INFO] [stdout] test set2::challenge11::tests::test_case1_repeated_16byte_blocks_should_not_detect ... ok [INFO] [stdout] test set2::challenge11::tests::test_case4_repeated_16byte_blocks_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 set1::challenge7::tests::test_challenge7_decrypt ... 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 set2::challenge9::tests::test_pkcs7_unpad ... ok [INFO] [stdout] test set2::challenge16::tests::challenge16 ... ok [INFO] [stdout] test set3::challenge19::tests::test_decipher_with_chi_squared ... ignored [INFO] [stdout] test set3::challenge19::tests::test_decipher_with_score_english ... ignored [INFO] [stdout] test set3::challenge19::tests::word_frequency ... ignored [INFO] [stdout] test set3::challenge20::tests::test_decipher_with_score_english ... ignored [INFO] [stdout] test set2::challenge11::tests::test_case7_mixed_character_patterns_should_detect ... 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::challenge18::tests::test_challenge18 ... ok [INFO] [stdout] test set4::challenge25::tests::print_pt ... ignored [INFO] [stdout] test set3::challenge23::tests::test_untemper ... ok [INFO] [stdout] test set2::challenge11::tests::test_case6_text_repetition_should_detect ... ok [INFO] [stdout] test set3::challenge21::tests::test_mt19937_known_outputs ... ok [INFO] [stdout] test set3::challenge23::tests::test_clone_mt19937_rng ... ok [INFO] [stdout] test set3::challenge24::tests::test_mt19937_stream_cipher ... ok [INFO] [stdout] test set4::challenge25::tests::test_edit_partial ... ignored [INFO] [stdout] test set4::challenge28::tests::test_sha1_mac ... ok [INFO] [stdout] test set4::challenge27::tests::recover_key_cbc_iv_key ... ok [INFO] [stdout] test set4::challenge30::tests::test_length_extension_attack ... ok [INFO] [stdout] test set4::challenge30::tests::test_md4 ... ok [INFO] [stdout] test set1::challenge6::tests::test_challenge6_keysize_detection_friedman ... 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 set4::challenge28::tests::test_sha1 ... ok [INFO] [stdout] test set4::challenge29::tests::test_length_extension_attack ... ok [INFO] [stdout] test set5::challenge33::tests_dh_simple::diffie_hellman ... ok [INFO] [stdout] test set4::challenge29::tests::test_padding_len_0 ... ok [INFO] [stdout] test set4::challenge25::tests::test_edit_all ... ok [INFO] [stdout] test set4::challenge26::tests::ctr_bitflipping ... ok [INFO] [stdout] test set3::challenge19::tests::test_decipher_with_space_xor ... ok [INFO] [stdout] test set1::challenge6::tests::test_challenge6_key_recovery ... ok [INFO] [stdout] test set3::challenge17::tests::test_padding_oracle_attack ... ok [INFO] [stdout] test set1::challenge4::tests::test_detect_single_char_xor ... ok [INFO] [stdout] test set5::challenge36::tests::srp ... 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::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::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::challenge33::tests_dh::diffie_hellman ... ok [INFO] [stdout] test set5::challenge35::tests::mitm_attack ... ok [INFO] [stdout] test utils::rsa::tests::test_miller_rabin ... ok [INFO] [stdout] test set5::challenge37::tests::srp ... ok [INFO] [stdout] test set5::challenge34::tests::mitm_attack ... 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 set5::challenge39::tests::test_rsa_crt ... ok [INFO] [stdout] test set3::challenge24::tests::test_mt19937_stream_cipher_hack ... ok [INFO] [stdout] test set5::challenge39::tests::test_rsa_short ... ok [INFO] [stdout] test set5::challenge39::tests::test_rsa_long ... 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 20.01s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "494cf9aaed3146d024765699afdffdbee662885bbc1493403018742d9b977d32", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "494cf9aaed3146d024765699afdffdbee662885bbc1493403018742d9b977d32", kill_on_drop: false }` [INFO] [stdout] 494cf9aaed3146d024765699afdffdbee662885bbc1493403018742d9b977d32