[INFO] updating cached repository https://github.com/jordanstephens/cryptopals [INFO] running `"git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune"` [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 235dbdedf6fdf1df3d7d0250ac38d6cb636d0720 [INFO] testing jordanstephens/cryptopals against beta-2020-06-03 for beta-1.45-1 [INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjordanstephens%2Fcryptopals" "/workspace/builds/worker-2/source"` [INFO] [stderr] Cloning into '/workspace/builds/worker-2/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/jordanstephens/cryptopals on toolchain beta-2020-06-03 [INFO] running `"/workspace/cargo-home/bin/cargo" "+beta-2020-06-03" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started tweaking git repo https://github.com/jordanstephens/cryptopals [INFO] finished tweaking git repo https://github.com/jordanstephens/cryptopals [INFO] tweaked toml for git repo https://github.com/jordanstephens/cryptopals written to /workspace/builds/worker-2/source/Cargo.toml [INFO] crate git repo https://github.com/jordanstephens/cryptopals already has a lockfile, it will not be regenerated [INFO] running `"/workspace/cargo-home/bin/cargo" "+beta-2020-06-03" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-06-03" "build" "--frozen"` [INFO] [stdout] ce82929483d743f81d3e9796ab611dd6f35a3a06a3cc3894303327e58f5907fd [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `"docker" "start" "-a" "ce82929483d743f81d3e9796ab611dd6f35a3a06a3cc3894303327e58f5907fd"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] Compiling ordered-float v1.0.2 [INFO] [stderr] Compiling rayon-core v1.7.0 [INFO] [stderr] Compiling rayon v1.3.0 [INFO] [stderr] Compiling cryptopals v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: cannot borrow `distribution.table` as mutable because it is also borrowed as immutable [INFO] [stderr] --> src/distribution.rs:94:7 [INFO] [stderr] | [INFO] [stderr] 93 | let curr = distribution.table.get(key).unwrap(); [INFO] [stderr] | ------------------ immutable borrow occurs here [INFO] [stderr] 94 | distribution.table.insert(*key, curr + (1.0 / len)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ ---- immutable borrow later used here [INFO] [stderr] | | [INFO] [stderr] | mutable borrow occurs here [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(mutable_borrow_reservation_conflict)]` on by default [INFO] [stderr] = warning: this borrowing pattern was not meant to be accepted, and may become a hard error in the future [INFO] [stderr] = note: for more information, see issue #59159 [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Buffer` [INFO] [stderr] --> src/buffer.rs:5:12 [INFO] [stderr] | [INFO] [stderr] 5 | pub struct Buffer { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/buffer.rs:10:10 [INFO] [stderr] | [INFO] [stderr] 10 | pub fn new(bytes: Vec) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `from_hex` [INFO] [stderr] --> src/buffer.rs:14:10 [INFO] [stderr] | [INFO] [stderr] 14 | pub fn from_hex(hex_str: &str) -> Result { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `to_base64` [INFO] [stderr] --> src/buffer.rs:19:10 [INFO] [stderr] | [INFO] [stderr] 19 | pub fn to_base64(&self) -> String { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `to_hex` [INFO] [stderr] --> src/buffer.rs:23:10 [INFO] [stderr] | [INFO] [stderr] 23 | pub fn to_hex(&self) -> String { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `xor` [INFO] [stderr] --> src/buffer.rs:27:10 [INFO] [stderr] | [INFO] [stderr] 27 | pub fn xor(&self, other: &Buffer) -> Result { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `from_hex` [INFO] [stderr] --> src/decoder.rs:3:8 [INFO] [stderr] | [INFO] [stderr] 3 | pub fn from_hex(input: &str) -> Result, Error> { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `hex_val` [INFO] [stderr] --> src/decoder.rs:17:4 [INFO] [stderr] | [INFO] [stderr] 17 | fn hex_val(c: u8) -> Result { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `A` [INFO] [stderr] --> src/distribution.rs:5:3 [INFO] [stderr] | [INFO] [stderr] 5 | A, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `B` [INFO] [stderr] --> src/distribution.rs:6:3 [INFO] [stderr] | [INFO] [stderr] 6 | B, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `C` [INFO] [stderr] --> src/distribution.rs:7:3 [INFO] [stderr] | [INFO] [stderr] 7 | C, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `D` [INFO] [stderr] --> src/distribution.rs:8:3 [INFO] [stderr] | [INFO] [stderr] 8 | D, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `E` [INFO] [stderr] --> src/distribution.rs:9:3 [INFO] [stderr] | [INFO] [stderr] 9 | E, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `F` [INFO] [stderr] --> src/distribution.rs:10:3 [INFO] [stderr] | [INFO] [stderr] 10 | F, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `G` [INFO] [stderr] --> src/distribution.rs:11:3 [INFO] [stderr] | [INFO] [stderr] 11 | G, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `H` [INFO] [stderr] --> src/distribution.rs:12:3 [INFO] [stderr] | [INFO] [stderr] 12 | H, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `I` [INFO] [stderr] --> src/distribution.rs:13:3 [INFO] [stderr] | [INFO] [stderr] 13 | I, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `J` [INFO] [stderr] --> src/distribution.rs:14:3 [INFO] [stderr] | [INFO] [stderr] 14 | J, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `K` [INFO] [stderr] --> src/distribution.rs:15:3 [INFO] [stderr] | [INFO] [stderr] 15 | K, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `L` [INFO] [stderr] --> src/distribution.rs:16:3 [INFO] [stderr] | [INFO] [stderr] 16 | L, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `M` [INFO] [stderr] --> src/distribution.rs:17:3 [INFO] [stderr] | [INFO] [stderr] 17 | M, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `N` [INFO] [stderr] --> src/distribution.rs:18:3 [INFO] [stderr] | [INFO] [stderr] 18 | N, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `O` [INFO] [stderr] --> src/distribution.rs:19:3 [INFO] [stderr] | [INFO] [stderr] 19 | O, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `P` [INFO] [stderr] --> src/distribution.rs:20:3 [INFO] [stderr] | [INFO] [stderr] 20 | P, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Q` [INFO] [stderr] --> src/distribution.rs:21:3 [INFO] [stderr] | [INFO] [stderr] 21 | Q, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `R` [INFO] [stderr] --> src/distribution.rs:22:3 [INFO] [stderr] | [INFO] [stderr] 22 | R, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `S` [INFO] [stderr] --> src/distribution.rs:23:3 [INFO] [stderr] | [INFO] [stderr] 23 | S, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `T` [INFO] [stderr] --> src/distribution.rs:24:3 [INFO] [stderr] | [INFO] [stderr] 24 | T, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `U` [INFO] [stderr] --> src/distribution.rs:25:3 [INFO] [stderr] | [INFO] [stderr] 25 | U, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `V` [INFO] [stderr] --> src/distribution.rs:26:3 [INFO] [stderr] | [INFO] [stderr] 26 | V, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `W` [INFO] [stderr] --> src/distribution.rs:27:3 [INFO] [stderr] | [INFO] [stderr] 27 | W, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `X` [INFO] [stderr] --> src/distribution.rs:28:3 [INFO] [stderr] | [INFO] [stderr] 28 | X, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Y` [INFO] [stderr] --> src/distribution.rs:29:3 [INFO] [stderr] | [INFO] [stderr] 29 | Y, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Z` [INFO] [stderr] --> src/distribution.rs:30:3 [INFO] [stderr] | [INFO] [stderr] 30 | Z, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `WHITESPACE` [INFO] [stderr] --> src/distribution.rs:31:3 [INFO] [stderr] | [INFO] [stderr] 31 | WHITESPACE, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `OTHER` [INFO] [stderr] --> src/distribution.rs:32:3 [INFO] [stderr] | [INFO] [stderr] 32 | OTHER, [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `UNKNOWN` [INFO] [stderr] --> src/distribution.rs:33:3 [INFO] [stderr] | [INFO] [stderr] 33 | UNKNOWN, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: constant is never used: `ENGLISH` [INFO] [stderr] --> src/distribution.rs:36:1 [INFO] [stderr] | [INFO] [stderr] 36 | / const ENGLISH: [(Key, f32, &str); 29] = [ [INFO] [stderr] 37 | | (Key::A, 0.05213904, "a"), [INFO] [stderr] 38 | | (Key::B, 0.00993984, "b"), [INFO] [stderr] 39 | | (Key::C, 0.01738712, "c"), [INFO] [stderr] ... | [INFO] [stderr] 69 | | (Key::UNKNOWN, 0.0, ""), [INFO] [stderr] 70 | | ]; [INFO] [stderr] | |__^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Distribution` [INFO] [stderr] --> src/distribution.rs:72:12 [INFO] [stderr] | [INFO] [stderr] 72 | pub struct Distribution { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/distribution.rs:78:10 [INFO] [stderr] | [INFO] [stderr] 78 | pub fn new() -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `from` [INFO] [stderr] --> src/distribution.rs:84:10 [INFO] [stderr] | [INFO] [stderr] 84 | pub fn from(input: &[u8]) -> Self { [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `empty` [INFO] [stderr] --> src/distribution.rs:99:10 [INFO] [stderr] | [INFO] [stderr] 99 | pub fn empty() -> Self { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `english` [INFO] [stderr] --> src/distribution.rs:110:10 [INFO] [stderr] | [INFO] [stderr] 110 | pub fn english() -> Self { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `scale` [INFO] [stderr] --> src/distribution.rs:121:10 [INFO] [stderr] | [INFO] [stderr] 121 | pub fn scale(&mut self, n: f32) -> &Self { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `score` [INFO] [stderr] --> src/distribution.rs:127:8 [INFO] [stderr] | [INFO] [stderr] 127 | pub fn score(sample: &[u8]) -> f32 { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `distance` [INFO] [stderr] --> src/distribution.rs:134:8 [INFO] [stderr] | [INFO] [stderr] 134 | pub fn distance(observed: &Distribution, expected: &Distribution) -> f32 { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `chi_squared_i` [INFO] [stderr] --> src/distribution.rs:142:4 [INFO] [stderr] | [INFO] [stderr] 142 | fn chi_squared_i(observed: f32, expected: f32) -> f32 { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `chi_squared` [INFO] [stderr] --> src/distribution.rs:152:4 [INFO] [stderr] | [INFO] [stderr] 152 | fn chi_squared(observed: &Vec, expected: &Vec) -> f32 { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `to_hex` [INFO] [stderr] --> src/encoder.rs:1:8 [INFO] [stderr] | [INFO] [stderr] 1 | pub fn to_hex(bytes: &[u8]) -> String { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `to_base64` [INFO] [stderr] --> src/encoder.rs:15:8 [INFO] [stderr] | [INFO] [stderr] 15 | pub fn to_base64(bytes: &[u8]) -> String { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `convert_chunk` [INFO] [stderr] --> src/encoder.rs:46:4 [INFO] [stderr] | [INFO] [stderr] 46 | fn convert_chunk(chunk: &[u8], charset: &Charset) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Charset` [INFO] [stderr] --> src/encoder.rs:62:8 [INFO] [stderr] | [INFO] [stderr] 62 | struct Charset { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/encoder.rs:67:6 [INFO] [stderr] | [INFO] [stderr] 67 | fn new(chars: &str) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `base64` [INFO] [stderr] --> src/encoder.rs:73:6 [INFO] [stderr] | [INFO] [stderr] 73 | fn base64() -> Self { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `hex` [INFO] [stderr] --> src/encoder.rs:77:6 [INFO] [stderr] | [INFO] [stderr] 77 | fn hex() -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `DecodeHexError` [INFO] [stderr] --> src/error.rs:4:3 [INFO] [stderr] | [INFO] [stderr] 4 | DecodeHexError, [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `XorError` [INFO] [stderr] --> src/error.rs:5:3 [INFO] [stderr] | [INFO] [stderr] 5 | XorError [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `encrypt` [INFO] [stderr] --> src/xor_cipher.rs:5:8 [INFO] [stderr] | [INFO] [stderr] 5 | pub fn encrypt(bytes: &[u8], key: &[u8]) -> Vec { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `decrypt` [INFO] [stderr] --> src/xor_cipher.rs:9:8 [INFO] [stderr] | [INFO] [stderr] 9 | pub fn decrypt(bytes: &[u8], key: &[u8]) -> Vec { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `xor` [INFO] [stderr] --> src/xor_cipher.rs:13:4 [INFO] [stderr] | [INFO] [stderr] 13 | fn xor(bytes: &[u8], key: &[u8]) -> Vec { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `find_candidate_keys` [INFO] [stderr] --> src/xor_cipher.rs:28:8 [INFO] [stderr] | [INFO] [stderr] 28 | pub fn find_candidate_keys(ciphertext: &[u8]) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `find_best_key` [INFO] [stderr] --> src/xor_cipher.rs:43:8 [INFO] [stderr] | [INFO] [stderr] 43 | pub fn find_best_key(bytes: &[u8]) -> KeyCandidate { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused `std::iter::Map` that must be used [INFO] [stderr] --> src/distribution.rs:122:5 [INFO] [stderr] | [INFO] [stderr] 122 | self.table.iter_mut().map(|(_, value)| *value * n); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: iterators are lazy and do nothing unless consumed [INFO] [stderr] [INFO] [stderr] warning: 64 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 7.58s [INFO] running `"docker" "inspect" "ce82929483d743f81d3e9796ab611dd6f35a3a06a3cc3894303327e58f5907fd"` [INFO] running `"docker" "rm" "-f" "ce82929483d743f81d3e9796ab611dd6f35a3a06a3cc3894303327e58f5907fd"` [INFO] [stdout] ce82929483d743f81d3e9796ab611dd6f35a3a06a3cc3894303327e58f5907fd [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-06-03" "test" "--frozen" "--no-run"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 6291504cf9181cb0b2d3377692bdcb5f7425bbb9187c95c6493410ecb29ffc40 [INFO] running `"docker" "start" "-a" "6291504cf9181cb0b2d3377692bdcb5f7425bbb9187c95c6493410ecb29ffc40"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] Compiling cryptopals v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: cannot borrow `distribution.table` as mutable because it is also borrowed as immutable [INFO] [stderr] --> src/distribution.rs:94:7 [INFO] [stderr] | [INFO] [stderr] 93 | let curr = distribution.table.get(key).unwrap(); [INFO] [stderr] | ------------------ immutable borrow occurs here [INFO] [stderr] 94 | distribution.table.insert(*key, curr + (1.0 / len)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ ---- immutable borrow later used here [INFO] [stderr] | | [INFO] [stderr] | mutable borrow occurs here [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(mutable_borrow_reservation_conflict)]` on by default [INFO] [stderr] = warning: this borrowing pattern was not meant to be accepted, and may become a hard error in the future [INFO] [stderr] = note: for more information, see issue #59159 [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Buffer` [INFO] [stderr] --> src/buffer.rs:5:12 [INFO] [stderr] | [INFO] [stderr] 5 | pub struct Buffer { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/buffer.rs:10:10 [INFO] [stderr] | [INFO] [stderr] 10 | pub fn new(bytes: Vec) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `from_hex` [INFO] [stderr] --> src/buffer.rs:14:10 [INFO] [stderr] | [INFO] [stderr] 14 | pub fn from_hex(hex_str: &str) -> Result { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `to_base64` [INFO] [stderr] --> src/buffer.rs:19:10 [INFO] [stderr] | [INFO] [stderr] 19 | pub fn to_base64(&self) -> String { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `to_hex` [INFO] [stderr] --> src/buffer.rs:23:10 [INFO] [stderr] | [INFO] [stderr] 23 | pub fn to_hex(&self) -> String { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `xor` [INFO] [stderr] --> src/buffer.rs:27:10 [INFO] [stderr] | [INFO] [stderr] 27 | pub fn xor(&self, other: &Buffer) -> Result { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `from_hex` [INFO] [stderr] --> src/decoder.rs:3:8 [INFO] [stderr] | [INFO] [stderr] 3 | pub fn from_hex(input: &str) -> Result, Error> { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `hex_val` [INFO] [stderr] --> src/decoder.rs:17:4 [INFO] [stderr] | [INFO] [stderr] 17 | fn hex_val(c: u8) -> Result { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `A` [INFO] [stderr] --> src/distribution.rs:5:3 [INFO] [stderr] | [INFO] [stderr] 5 | A, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `B` [INFO] [stderr] --> src/distribution.rs:6:3 [INFO] [stderr] | [INFO] [stderr] 6 | B, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `C` [INFO] [stderr] --> src/distribution.rs:7:3 [INFO] [stderr] | [INFO] [stderr] 7 | C, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `D` [INFO] [stderr] --> src/distribution.rs:8:3 [INFO] [stderr] | [INFO] [stderr] 8 | D, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `E` [INFO] [stderr] --> src/distribution.rs:9:3 [INFO] [stderr] | [INFO] [stderr] 9 | E, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `F` [INFO] [stderr] --> src/distribution.rs:10:3 [INFO] [stderr] | [INFO] [stderr] 10 | F, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `G` [INFO] [stderr] --> src/distribution.rs:11:3 [INFO] [stderr] | [INFO] [stderr] 11 | G, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `H` [INFO] [stderr] --> src/distribution.rs:12:3 [INFO] [stderr] | [INFO] [stderr] 12 | H, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `I` [INFO] [stderr] --> src/distribution.rs:13:3 [INFO] [stderr] | [INFO] [stderr] 13 | I, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `J` [INFO] [stderr] --> src/distribution.rs:14:3 [INFO] [stderr] | [INFO] [stderr] 14 | J, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `K` [INFO] [stderr] --> src/distribution.rs:15:3 [INFO] [stderr] | [INFO] [stderr] 15 | K, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `L` [INFO] [stderr] --> src/distribution.rs:16:3 [INFO] [stderr] | [INFO] [stderr] 16 | L, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `M` [INFO] [stderr] --> src/distribution.rs:17:3 [INFO] [stderr] | [INFO] [stderr] 17 | M, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `N` [INFO] [stderr] --> src/distribution.rs:18:3 [INFO] [stderr] | [INFO] [stderr] 18 | N, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `O` [INFO] [stderr] --> src/distribution.rs:19:3 [INFO] [stderr] | [INFO] [stderr] 19 | O, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `P` [INFO] [stderr] --> src/distribution.rs:20:3 [INFO] [stderr] | [INFO] [stderr] 20 | P, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Q` [INFO] [stderr] --> src/distribution.rs:21:3 [INFO] [stderr] | [INFO] [stderr] 21 | Q, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `R` [INFO] [stderr] --> src/distribution.rs:22:3 [INFO] [stderr] | [INFO] [stderr] 22 | R, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `S` [INFO] [stderr] --> src/distribution.rs:23:3 [INFO] [stderr] | [INFO] [stderr] 23 | S, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `T` [INFO] [stderr] --> src/distribution.rs:24:3 [INFO] [stderr] | [INFO] [stderr] 24 | T, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `U` [INFO] [stderr] --> src/distribution.rs:25:3 [INFO] [stderr] | [INFO] [stderr] 25 | U, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `V` [INFO] [stderr] --> src/distribution.rs:26:3 [INFO] [stderr] | [INFO] [stderr] 26 | V, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `W` [INFO] [stderr] --> src/distribution.rs:27:3 [INFO] [stderr] | [INFO] [stderr] 27 | W, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `X` [INFO] [stderr] --> src/distribution.rs:28:3 [INFO] [stderr] | [INFO] [stderr] 28 | X, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Y` [INFO] [stderr] --> src/distribution.rs:29:3 [INFO] [stderr] | [INFO] [stderr] 29 | Y, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Z` [INFO] [stderr] --> src/distribution.rs:30:3 [INFO] [stderr] | [INFO] [stderr] 30 | Z, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `WHITESPACE` [INFO] [stderr] --> src/distribution.rs:31:3 [INFO] [stderr] | [INFO] [stderr] 31 | WHITESPACE, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `OTHER` [INFO] [stderr] --> src/distribution.rs:32:3 [INFO] [stderr] | [INFO] [stderr] 32 | OTHER, [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `UNKNOWN` [INFO] [stderr] --> src/distribution.rs:33:3 [INFO] [stderr] | [INFO] [stderr] 33 | UNKNOWN, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: constant is never used: `ENGLISH` [INFO] [stderr] --> src/distribution.rs:36:1 [INFO] [stderr] | [INFO] [stderr] 36 | / const ENGLISH: [(Key, f32, &str); 29] = [ [INFO] [stderr] 37 | | (Key::A, 0.05213904, "a"), [INFO] [stderr] 38 | | (Key::B, 0.00993984, "b"), [INFO] [stderr] 39 | | (Key::C, 0.01738712, "c"), [INFO] [stderr] ... | [INFO] [stderr] 69 | | (Key::UNKNOWN, 0.0, ""), [INFO] [stderr] 70 | | ]; [INFO] [stderr] | |__^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Distribution` [INFO] [stderr] --> src/distribution.rs:72:12 [INFO] [stderr] | [INFO] [stderr] 72 | pub struct Distribution { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/distribution.rs:78:10 [INFO] [stderr] | [INFO] [stderr] 78 | pub fn new() -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `from` [INFO] [stderr] --> src/distribution.rs:84:10 [INFO] [stderr] | [INFO] [stderr] 84 | pub fn from(input: &[u8]) -> Self { [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `empty` [INFO] [stderr] --> src/distribution.rs:99:10 [INFO] [stderr] | [INFO] [stderr] 99 | pub fn empty() -> Self { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `english` [INFO] [stderr] --> src/distribution.rs:110:10 [INFO] [stderr] | [INFO] [stderr] 110 | pub fn english() -> Self { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `scale` [INFO] [stderr] --> src/distribution.rs:121:10 [INFO] [stderr] | [INFO] [stderr] 121 | pub fn scale(&mut self, n: f32) -> &Self { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `score` [INFO] [stderr] --> src/distribution.rs:127:8 [INFO] [stderr] | [INFO] [stderr] 127 | pub fn score(sample: &[u8]) -> f32 { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `distance` [INFO] [stderr] --> src/distribution.rs:134:8 [INFO] [stderr] | [INFO] [stderr] 134 | pub fn distance(observed: &Distribution, expected: &Distribution) -> f32 { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `chi_squared_i` [INFO] [stderr] --> src/distribution.rs:142:4 [INFO] [stderr] | [INFO] [stderr] 142 | fn chi_squared_i(observed: f32, expected: f32) -> f32 { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `chi_squared` [INFO] [stderr] --> src/distribution.rs:152:4 [INFO] [stderr] | [INFO] [stderr] 152 | fn chi_squared(observed: &Vec, expected: &Vec) -> f32 { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `to_hex` [INFO] [stderr] --> src/encoder.rs:1:8 [INFO] [stderr] | [INFO] [stderr] 1 | pub fn to_hex(bytes: &[u8]) -> String { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `to_base64` [INFO] [stderr] --> src/encoder.rs:15:8 [INFO] [stderr] | [INFO] [stderr] 15 | pub fn to_base64(bytes: &[u8]) -> String { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `convert_chunk` [INFO] [stderr] --> src/encoder.rs:46:4 [INFO] [stderr] | [INFO] [stderr] 46 | fn convert_chunk(chunk: &[u8], charset: &Charset) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Charset` [INFO] [stderr] --> src/encoder.rs:62:8 [INFO] [stderr] | [INFO] [stderr] 62 | struct Charset { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/encoder.rs:67:6 [INFO] [stderr] | [INFO] [stderr] 67 | fn new(chars: &str) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `base64` [INFO] [stderr] --> src/encoder.rs:73:6 [INFO] [stderr] | [INFO] [stderr] 73 | fn base64() -> Self { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `hex` [INFO] [stderr] --> src/encoder.rs:77:6 [INFO] [stderr] | [INFO] [stderr] 77 | fn hex() -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `DecodeHexError` [INFO] [stderr] --> src/error.rs:4:3 [INFO] [stderr] | [INFO] [stderr] 4 | DecodeHexError, [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `XorError` [INFO] [stderr] --> src/error.rs:5:3 [INFO] [stderr] | [INFO] [stderr] 5 | XorError [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `encrypt` [INFO] [stderr] --> src/xor_cipher.rs:5:8 [INFO] [stderr] | [INFO] [stderr] 5 | pub fn encrypt(bytes: &[u8], key: &[u8]) -> Vec { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `decrypt` [INFO] [stderr] --> src/xor_cipher.rs:9:8 [INFO] [stderr] | [INFO] [stderr] 9 | pub fn decrypt(bytes: &[u8], key: &[u8]) -> Vec { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `xor` [INFO] [stderr] --> src/xor_cipher.rs:13:4 [INFO] [stderr] | [INFO] [stderr] 13 | fn xor(bytes: &[u8], key: &[u8]) -> Vec { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `find_candidate_keys` [INFO] [stderr] --> src/xor_cipher.rs:28:8 [INFO] [stderr] | [INFO] [stderr] 28 | pub fn find_candidate_keys(ciphertext: &[u8]) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `find_best_key` [INFO] [stderr] --> src/xor_cipher.rs:43:8 [INFO] [stderr] | [INFO] [stderr] 43 | pub fn find_best_key(bytes: &[u8]) -> KeyCandidate { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused `std::iter::Map` that must be used [INFO] [stderr] --> src/distribution.rs:122:5 [INFO] [stderr] | [INFO] [stderr] 122 | self.table.iter_mut().map(|(_, value)| *value * n); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: iterators are lazy and do nothing unless consumed [INFO] [stderr] [INFO] [stderr] warning: 64 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: cannot borrow `distribution.table` as mutable because it is also borrowed as immutable [INFO] [stderr] --> src/distribution.rs:94:7 [INFO] [stderr] | [INFO] [stderr] 93 | let curr = distribution.table.get(key).unwrap(); [INFO] [stderr] | ------------------ immutable borrow occurs here [INFO] [stderr] 94 | distribution.table.insert(*key, curr + (1.0 / len)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ ---- immutable borrow later used here [INFO] [stderr] | | [INFO] [stderr] | mutable borrow occurs here [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(mutable_borrow_reservation_conflict)]` on by default [INFO] [stderr] = warning: this borrowing pattern was not meant to be accepted, and may become a hard error in the future [INFO] [stderr] = note: for more information, see issue #59159 [INFO] [stderr] [INFO] [stderr] warning: unused `std::iter::Map` that must be used [INFO] [stderr] --> src/distribution.rs:122:5 [INFO] [stderr] | [INFO] [stderr] 122 | self.table.iter_mut().map(|(_, value)| *value * n); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: iterators are lazy and do nothing unless consumed [INFO] [stderr] [INFO] [stderr] warning: 2 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 2.28s [INFO] running `"docker" "inspect" "6291504cf9181cb0b2d3377692bdcb5f7425bbb9187c95c6493410ecb29ffc40"` [INFO] running `"docker" "rm" "-f" "6291504cf9181cb0b2d3377692bdcb5f7425bbb9187c95c6493410ecb29ffc40"` [INFO] [stdout] 6291504cf9181cb0b2d3377692bdcb5f7425bbb9187c95c6493410ecb29ffc40 [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-06-03" "test" "--frozen"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 54cc6366a53767d225bd7ab090dc24b4f7924476df820138c7698e7ceb4a5cdd [INFO] running `"docker" "start" "-a" "54cc6366a53767d225bd7ab090dc24b4f7924476df820138c7698e7ceb4a5cdd"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] warning: cannot borrow `distribution.table` as mutable because it is also borrowed as immutable [INFO] [stderr] --> src/distribution.rs:94:7 [INFO] [stderr] | [INFO] [stderr] 93 | let curr = distribution.table.get(key).unwrap(); [INFO] [stderr] | ------------------ immutable borrow occurs here [INFO] [stderr] 94 | distribution.table.insert(*key, curr + (1.0 / len)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ ---- immutable borrow later used here [INFO] [stderr] | | [INFO] [stderr] | mutable borrow occurs here [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(mutable_borrow_reservation_conflict)]` on by default [INFO] [stderr] = warning: this borrowing pattern was not meant to be accepted, and may become a hard error in the future [INFO] [stderr] = note: for more information, see issue #59159 [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Buffer` [INFO] [stderr] --> src/buffer.rs:5:12 [INFO] [stderr] | [INFO] [stderr] 5 | pub struct Buffer { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/buffer.rs:10:10 [INFO] [stderr] | [INFO] [stderr] 10 | pub fn new(bytes: Vec) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `from_hex` [INFO] [stderr] --> src/buffer.rs:14:10 [INFO] [stderr] | [INFO] [stderr] 14 | pub fn from_hex(hex_str: &str) -> Result { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `to_base64` [INFO] [stderr] --> src/buffer.rs:19:10 [INFO] [stderr] | [INFO] [stderr] 19 | pub fn to_base64(&self) -> String { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `to_hex` [INFO] [stderr] --> src/buffer.rs:23:10 [INFO] [stderr] | [INFO] [stderr] 23 | pub fn to_hex(&self) -> String { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `xor` [INFO] [stderr] --> src/buffer.rs:27:10 [INFO] [stderr] | [INFO] [stderr] 27 | pub fn xor(&self, other: &Buffer) -> Result { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `from_hex` [INFO] [stderr] --> src/decoder.rs:3:8 [INFO] [stderr] | [INFO] [stderr] 3 | pub fn from_hex(input: &str) -> Result, Error> { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `hex_val` [INFO] [stderr] --> src/decoder.rs:17:4 [INFO] [stderr] | [INFO] [stderr] 17 | fn hex_val(c: u8) -> Result { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `A` [INFO] [stderr] --> src/distribution.rs:5:3 [INFO] [stderr] | [INFO] [stderr] 5 | A, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `B` [INFO] [stderr] --> src/distribution.rs:6:3 [INFO] [stderr] | [INFO] [stderr] 6 | B, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `C` [INFO] [stderr] --> src/distribution.rs:7:3 [INFO] [stderr] | [INFO] [stderr] 7 | C, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `D` [INFO] [stderr] --> src/distribution.rs:8:3 [INFO] [stderr] | [INFO] [stderr] 8 | D, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `E` [INFO] [stderr] --> src/distribution.rs:9:3 [INFO] [stderr] | [INFO] [stderr] 9 | E, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `F` [INFO] [stderr] --> src/distribution.rs:10:3 [INFO] [stderr] | [INFO] [stderr] 10 | F, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `G` [INFO] [stderr] --> src/distribution.rs:11:3 [INFO] [stderr] | [INFO] [stderr] 11 | G, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `H` [INFO] [stderr] --> src/distribution.rs:12:3 [INFO] [stderr] | [INFO] [stderr] 12 | H, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `I` [INFO] [stderr] --> src/distribution.rs:13:3 [INFO] [stderr] | [INFO] [stderr] 13 | I, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `J` [INFO] [stderr] --> src/distribution.rs:14:3 [INFO] [stderr] | [INFO] [stderr] 14 | J, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `K` [INFO] [stderr] --> src/distribution.rs:15:3 [INFO] [stderr] | [INFO] [stderr] 15 | K, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `L` [INFO] [stderr] --> src/distribution.rs:16:3 [INFO] [stderr] | [INFO] [stderr] 16 | L, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `M` [INFO] [stderr] --> src/distribution.rs:17:3 [INFO] [stderr] | [INFO] [stderr] 17 | M, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `N` [INFO] [stderr] --> src/distribution.rs:18:3 [INFO] [stderr] | [INFO] [stderr] 18 | N, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `O` [INFO] [stderr] --> src/distribution.rs:19:3 [INFO] [stderr] | [INFO] [stderr] 19 | O, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `P` [INFO] [stderr] --> src/distribution.rs:20:3 [INFO] [stderr] | [INFO] [stderr] 20 | P, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Q` [INFO] [stderr] --> src/distribution.rs:21:3 [INFO] [stderr] | [INFO] [stderr] 21 | Q, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `R` [INFO] [stderr] --> src/distribution.rs:22:3 [INFO] [stderr] | [INFO] [stderr] 22 | R, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `S` [INFO] [stderr] --> src/distribution.rs:23:3 [INFO] [stderr] | [INFO] [stderr] 23 | S, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `T` [INFO] [stderr] --> src/distribution.rs:24:3 [INFO] [stderr] | [INFO] [stderr] 24 | T, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `U` [INFO] [stderr] --> src/distribution.rs:25:3 [INFO] [stderr] | [INFO] [stderr] 25 | U, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `V` [INFO] [stderr] --> src/distribution.rs:26:3 [INFO] [stderr] | [INFO] [stderr] 26 | V, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `W` [INFO] [stderr] --> src/distribution.rs:27:3 [INFO] [stderr] | [INFO] [stderr] 27 | W, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `X` [INFO] [stderr] --> src/distribution.rs:28:3 [INFO] [stderr] | [INFO] [stderr] 28 | X, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Y` [INFO] [stderr] --> src/distribution.rs:29:3 [INFO] [stderr] | [INFO] [stderr] 29 | Y, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Z` [INFO] [stderr] --> src/distribution.rs:30:3 [INFO] [stderr] | [INFO] [stderr] 30 | Z, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `WHITESPACE` [INFO] [stderr] --> src/distribution.rs:31:3 [INFO] [stderr] | [INFO] [stderr] 31 | WHITESPACE, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `OTHER` [INFO] [stderr] --> src/distribution.rs:32:3 [INFO] [stderr] | [INFO] [stderr] 32 | OTHER, [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `UNKNOWN` [INFO] [stderr] --> src/distribution.rs:33:3 [INFO] [stderr] | [INFO] [stderr] 33 | UNKNOWN, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: constant is never used: `ENGLISH` [INFO] [stderr] --> src/distribution.rs:36:1 [INFO] [stderr] | [INFO] [stderr] 36 | / const ENGLISH: [(Key, f32, &str); 29] = [ [INFO] [stderr] 37 | | (Key::A, 0.05213904, "a"), [INFO] [stderr] 38 | | (Key::B, 0.00993984, "b"), [INFO] [stderr] 39 | | (Key::C, 0.01738712, "c"), [INFO] [stderr] ... | [INFO] [stderr] 69 | | (Key::UNKNOWN, 0.0, ""), [INFO] [stderr] 70 | | ]; [INFO] [stderr] | |__^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Distribution` [INFO] [stderr] --> src/distribution.rs:72:12 [INFO] [stderr] | [INFO] [stderr] 72 | pub struct Distribution { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/distribution.rs:78:10 [INFO] [stderr] | [INFO] [stderr] 78 | pub fn new() -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `from` [INFO] [stderr] --> src/distribution.rs:84:10 [INFO] [stderr] | [INFO] [stderr] 84 | pub fn from(input: &[u8]) -> Self { [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `empty` [INFO] [stderr] --> src/distribution.rs:99:10 [INFO] [stderr] | [INFO] [stderr] 99 | pub fn empty() -> Self { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `english` [INFO] [stderr] --> src/distribution.rs:110:10 [INFO] [stderr] | [INFO] [stderr] 110 | pub fn english() -> Self { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `scale` [INFO] [stderr] --> src/distribution.rs:121:10 [INFO] [stderr] | [INFO] [stderr] 121 | pub fn scale(&mut self, n: f32) -> &Self { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `score` [INFO] [stderr] --> src/distribution.rs:127:8 [INFO] [stderr] | [INFO] [stderr] 127 | pub fn score(sample: &[u8]) -> f32 { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `distance` [INFO] [stderr] --> src/distribution.rs:134:8 [INFO] [stderr] | [INFO] [stderr] 134 | pub fn distance(observed: &Distribution, expected: &Distribution) -> f32 { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `chi_squared_i` [INFO] [stderr] --> src/distribution.rs:142:4 [INFO] [stderr] | [INFO] [stderr] 142 | fn chi_squared_i(observed: f32, expected: f32) -> f32 { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `chi_squared` [INFO] [stderr] --> src/distribution.rs:152:4 [INFO] [stderr] | [INFO] [stderr] 152 | fn chi_squared(observed: &Vec, expected: &Vec) -> f32 { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `to_hex` [INFO] [stderr] --> src/encoder.rs:1:8 [INFO] [stderr] | [INFO] [stderr] 1 | pub fn to_hex(bytes: &[u8]) -> String { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `to_base64` [INFO] [stderr] --> src/encoder.rs:15:8 [INFO] [stderr] | [INFO] [stderr] 15 | pub fn to_base64(bytes: &[u8]) -> String { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `convert_chunk` [INFO] [stderr] --> src/encoder.rs:46:4 [INFO] [stderr] | [INFO] [stderr] 46 | fn convert_chunk(chunk: &[u8], charset: &Charset) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Charset` [INFO] [stderr] --> src/encoder.rs:62:8 [INFO] [stderr] | [INFO] [stderr] 62 | struct Charset { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/encoder.rs:67:6 [INFO] [stderr] | [INFO] [stderr] 67 | fn new(chars: &str) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `base64` [INFO] [stderr] --> src/encoder.rs:73:6 [INFO] [stderr] | [INFO] [stderr] 73 | fn base64() -> Self { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `hex` [INFO] [stderr] --> src/encoder.rs:77:6 [INFO] [stderr] | [INFO] [stderr] 77 | fn hex() -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `DecodeHexError` [INFO] [stderr] --> src/error.rs:4:3 [INFO] [stderr] | [INFO] [stderr] 4 | DecodeHexError, [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `XorError` [INFO] [stderr] --> src/error.rs:5:3 [INFO] [stderr] | [INFO] [stderr] 5 | XorError [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `encrypt` [INFO] [stderr] --> src/xor_cipher.rs:5:8 [INFO] [stderr] | [INFO] [stderr] 5 | pub fn encrypt(bytes: &[u8], key: &[u8]) -> Vec { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `decrypt` [INFO] [stderr] --> src/xor_cipher.rs:9:8 [INFO] [stderr] | [INFO] [stderr] 9 | pub fn decrypt(bytes: &[u8], key: &[u8]) -> Vec { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `xor` [INFO] [stderr] --> src/xor_cipher.rs:13:4 [INFO] [stderr] | [INFO] [stderr] 13 | fn xor(bytes: &[u8], key: &[u8]) -> Vec { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `find_candidate_keys` [INFO] [stderr] --> src/xor_cipher.rs:28:8 [INFO] [stderr] | [INFO] [stderr] 28 | pub fn find_candidate_keys(ciphertext: &[u8]) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `find_best_key` [INFO] [stderr] --> src/xor_cipher.rs:43:8 [INFO] [stderr] | [INFO] [stderr] 43 | pub fn find_best_key(bytes: &[u8]) -> KeyCandidate { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused `std::iter::Map` that must be used [INFO] [stderr] --> src/distribution.rs:122:5 [INFO] [stderr] | [INFO] [stderr] 122 | self.table.iter_mut().map(|(_, value)| *value * n); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: iterators are lazy and do nothing unless consumed [INFO] [stderr] [INFO] [stderr] warning: 64 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: cannot borrow `distribution.table` as mutable because it is also borrowed as immutable [INFO] [stderr] --> src/distribution.rs:94:7 [INFO] [stderr] | [INFO] [stderr] 93 | let curr = distribution.table.get(key).unwrap(); [INFO] [stderr] | ------------------ immutable borrow occurs here [INFO] [stderr] 94 | distribution.table.insert(*key, curr + (1.0 / len)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ ---- immutable borrow later used here [INFO] [stderr] | | [INFO] [stderr] | mutable borrow occurs here [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(mutable_borrow_reservation_conflict)]` on by default [INFO] [stderr] = warning: this borrowing pattern was not meant to be accepted, and may become a hard error in the future [INFO] [stderr] = note: for more information, see issue #59159 [INFO] [stderr] [INFO] [stderr] warning: unused `std::iter::Map` that must be used [INFO] [stderr] --> src/distribution.rs:122:5 [INFO] [stderr] | [INFO] [stderr] 122 | self.table.iter_mut().map(|(_, value)| *value * n); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: iterators are lazy and do nothing unless consumed [INFO] [stderr] [INFO] [stderr] warning: 2 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.08s [INFO] [stderr] Running /opt/rustwide/target/debug/deps/cryptopals-77d57023b9f14570 [INFO] [stdout] [INFO] [stdout] running 15 tests [INFO] [stdout] test buffer::test_fixed_xor ... ok [INFO] [stdout] test distribution::test_chi_squared_eq ... ok [INFO] [stdout] test distribution::test_chi_squared_zero_expected ... ok [INFO] [stdout] test buffer::test_hex_to_b64 ... ok [INFO] [stdout] test buffer::test_empty ... ok [INFO] [stdout] test buffer::test_padding1 ... ok [INFO] [stdout] test distribution::test_chi_squared_ne ... ok [INFO] [stdout] test buffer::test_simple ... ok [INFO] [stdout] test buffer::test_padding2 ... ok [INFO] [stdout] test distribution::test_chi_squared_inverted ... ok [INFO] [stdout] test distribution::test_score ... ok [INFO] [stdout] test xor_cipher::tests::test_encrypt_repeating_key_xor ... ok [INFO] [stdout] test xor_cipher::tests::test_decrypt ... ok [INFO] [stdout] test xor_cipher::tests::test_find_best_key ... ok [INFO] [stdout] test xor_cipher::tests::test_find_key_from_file ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 15 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] [stderr] Doc-tests cryptopals [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] running `"docker" "inspect" "54cc6366a53767d225bd7ab090dc24b4f7924476df820138c7698e7ceb4a5cdd"` [INFO] running `"docker" "rm" "-f" "54cc6366a53767d225bd7ab090dc24b4f7924476df820138c7698e7ceb4a5cdd"` [INFO] [stdout] 54cc6366a53767d225bd7ab090dc24b4f7924476df820138c7698e7ceb4a5cdd