Dec 18 01:43:27.627 INFO checking davbo/cryptopals against try#0b8c5828f68d7b2840b81fa51239346dc97fef5a for pr-54252 Dec 18 01:43:27.627 INFO running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-54252/worker-0/try#0b8c5828f68d7b2840b81fa51239346dc97fef5a:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/pr-54252/sources/try#0b8c5828f68d7b2840b81fa51239346dc97fef5a/gh/davbo/cryptopals:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+0b8c5828f68d7b2840b81fa51239346dc97fef5a-alt" "check" "--frozen" "--all" "--all-targets"` Dec 18 01:43:28.060 INFO [stdout] 9d0b83b89d84862629b6d1ad2d0d718951b3da59351d3f65bee939b406966d44 Dec 18 01:43:28.068 INFO running `"docker" "start" "-a" "9d0b83b89d84862629b6d1ad2d0d718951b3da59351d3f65bee939b406966d44"` Dec 18 01:43:29.608 INFO [stderr] Compiling pkg-config v0.3.11 Dec 18 01:43:29.608 INFO [stderr] Compiling openssl v0.10.8 Dec 18 01:43:29.608 INFO [stderr] Checking rand v0.5.0 Dec 18 01:43:32.842 INFO [stderr] Compiling openssl-sys v0.9.31 Dec 18 01:43:38.752 INFO [stderr] Checking matasano v0.0.1 (/opt/crater/workdir) Dec 18 01:43:39.123 INFO [stderr] warning: unused import: `set1::challenge8::score_ciphertext_for_ecb_mode` Dec 18 01:43:39.123 INFO [stderr] --> src/set2/challenge12.rs:5:5 Dec 18 01:43:39.123 INFO [stderr] | Dec 18 01:43:39.123 INFO [stderr] 5 | use set1::challenge8::score_ciphertext_for_ecb_mode; Dec 18 01:43:39.123 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.123 INFO [stderr] | Dec 18 01:43:39.123 INFO [stderr] = note: #[warn(unused_imports)] on by default Dec 18 01:43:39.123 INFO [stderr] Dec 18 01:43:39.220 INFO [stderr] warning: unnecessary parentheses around `while` condition Dec 18 01:43:39.220 INFO [stderr] --> src/set2/challenge13.rs:72:11 Dec 18 01:43:39.220 INFO [stderr] | Dec 18 01:43:39.220 INFO [stderr] 72 | while (test_len == len_enc) { Dec 18 01:43:39.220 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses Dec 18 01:43:39.220 INFO [stderr] | Dec 18 01:43:39.220 INFO [stderr] = note: #[warn(unused_parens)] on by default Dec 18 01:43:39.220 INFO [stderr] Dec 18 01:43:39.456 INFO [stderr] warning: value assigned to `sanitised_input` is never read Dec 18 01:43:39.456 INFO [stderr] --> src/set2/challenge13.rs:17:17 Dec 18 01:43:39.456 INFO [stderr] | Dec 18 01:43:39.456 INFO [stderr] 17 | let mut sanitised_input = String::new(); Dec 18 01:43:39.456 INFO [stderr] | ^^^^^^^^^^^^^^^ Dec 18 01:43:39.456 INFO [stderr] | Dec 18 01:43:39.456 INFO [stderr] = note: #[warn(unused_assignments)] on by default Dec 18 01:43:39.456 INFO [stderr] Dec 18 01:43:39.529 INFO [stderr] warning: value assigned to `sanitised_input` is never read Dec 18 01:43:39.529 INFO [stderr] --> src/set2/challenge13.rs:17:17 Dec 18 01:43:39.529 INFO [stderr] | Dec 18 01:43:39.529 INFO [stderr] 17 | let mut sanitised_input = String::new(); Dec 18 01:43:39.529 INFO [stderr] | ^^^^^^^^^^^^^^^ Dec 18 01:43:39.529 INFO [stderr] | Dec 18 01:43:39.529 INFO [stderr] = note: #[warn(unused_assignments)] on by default Dec 18 01:43:39.529 INFO [stderr] Dec 18 01:43:39.529 INFO [stderr] warning: constant item is never used: `KEY` Dec 18 01:43:39.529 INFO [stderr] --> src/set2/challenge13.rs:6:1 Dec 18 01:43:39.529 INFO [stderr] | Dec 18 01:43:39.529 INFO [stderr] 6 | const KEY: &'static [u8] = b"YELLOW SUBMARINE"; Dec 18 01:43:39.529 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.529 INFO [stderr] | Dec 18 01:43:39.529 INFO [stderr] = note: #[warn(dead_code)] on by default Dec 18 01:43:39.529 INFO [stderr] Dec 18 01:43:39.529 INFO [stderr] warning: struct is never constructed: `Profile` Dec 18 01:43:39.529 INFO [stderr] --> src/set2/challenge13.rs:8:1 Dec 18 01:43:39.529 INFO [stderr] | Dec 18 01:43:39.529 INFO [stderr] 8 | struct Profile { Dec 18 01:43:39.529 INFO [stderr] | ^^^^^^^^^^^^^^ Dec 18 01:43:39.529 INFO [stderr] Dec 18 01:43:39.529 INFO [stderr] warning: method is never used: `new` Dec 18 01:43:39.529 INFO [stderr] --> src/set2/challenge13.rs:16:5 Dec 18 01:43:39.529 INFO [stderr] | Dec 18 01:43:39.529 INFO [stderr] 16 | pub fn new(email: String) -> Profile { Dec 18 01:43:39.529 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.529 INFO [stderr] Dec 18 01:43:39.529 INFO [stderr] warning: function is never used: `encrypt` Dec 18 01:43:39.529 INFO [stderr] --> src/set2/challenge13.rs:35:1 Dec 18 01:43:39.529 INFO [stderr] | Dec 18 01:43:39.529 INFO [stderr] 35 | fn encrypt(plaintext: String) -> Vec { Dec 18 01:43:39.529 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.529 INFO [stderr] Dec 18 01:43:39.529 INFO [stderr] warning: function is never used: `decrypt` Dec 18 01:43:39.529 INFO [stderr] --> src/set2/challenge13.rs:40:1 Dec 18 01:43:39.529 INFO [stderr] | Dec 18 01:43:39.529 INFO [stderr] 40 | fn decrypt(ciphertext: Vec) -> String { Dec 18 01:43:39.529 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.529 INFO [stderr] Dec 18 01:43:39.529 INFO [stderr] warning: constant item is never used: `MESSAGE` Dec 18 01:43:39.529 INFO [stderr] --> src/set2/challenge14.rs:7:1 Dec 18 01:43:39.529 INFO [stderr] | Dec 18 01:43:39.529 INFO [stderr] 7 | / const MESSAGE: &'static [u8] = b"Um9sbGluJyBpbiBteSA1LjAKV2l0aCBteSByYWctdG9wIGRvd24gc28gbXkg Dec 18 01:43:39.529 INFO [stderr] 8 | | aGFpciBjYW4gYmxvdwpUaGUgZ2lybGllcyBvbiBzdGFuZGJ5IHdhdmluZyBq Dec 18 01:43:39.529 INFO [stderr] 9 | | dXN0IHRvIHNheSBoaQpEaWQgeW91IHN0b3A/IE5vLCBJIGp1c3QgZHJvdmUg Dec 18 01:43:39.529 INFO [stderr] 10 | | YnkK"; Dec 18 01:43:39.529 INFO [stderr] | |______^ Dec 18 01:43:39.529 INFO [stderr] Dec 18 01:43:39.529 INFO [stderr] warning: function is never used: `random_input` Dec 18 01:43:39.530 INFO [stderr] --> src/set2/challenge14.rs:12:1 Dec 18 01:43:39.530 INFO [stderr] | Dec 18 01:43:39.530 INFO [stderr] 12 | fn random_input() -> Vec { Dec 18 01:43:39.530 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.530 INFO [stderr] Dec 18 01:43:39.530 INFO [stderr] warning: function is never used: `encryption_oracle` Dec 18 01:43:39.530 INFO [stderr] --> src/set2/challenge14.rs:20:1 Dec 18 01:43:39.530 INFO [stderr] | Dec 18 01:43:39.530 INFO [stderr] 20 | fn encryption_oracle(attacker_input: &[u8]) -> Vec { Dec 18 01:43:39.530 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.530 INFO [stderr] Dec 18 01:43:39.530 INFO [stderr] warning: function is never used: `find_target_permutation` Dec 18 01:43:39.530 INFO [stderr] --> src/set2/challenge14.rs:27:1 Dec 18 01:43:39.530 INFO [stderr] | Dec 18 01:43:39.530 INFO [stderr] 27 | fn find_target_permutation(byte_index: usize, block_size: usize, marker_cipher: Vec, decrypted_bytes: &[u8]) -> Vec { Dec 18 01:43:39.530 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.530 INFO [stderr] Dec 18 01:43:39.530 INFO [stderr] warning: function is never used: `test_byte` Dec 18 01:43:39.530 INFO [stderr] --> src/set2/challenge14.rs:56:1 Dec 18 01:43:39.530 INFO [stderr] | Dec 18 01:43:39.530 INFO [stderr] 56 | fn test_byte(candidate: u8, byte_index: usize, block_size: usize, marker_cipher: Vec, target_permutation: Vec, decrypted_bytes: &[u8]) -> bool { Dec 18 01:43:39.530 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.530 INFO [stderr] Dec 18 01:43:39.530 INFO [stderr] warning: function is never used: `find_marker_block` Dec 18 01:43:39.530 INFO [stderr] --> src/set2/challenge14.rs:91:1 Dec 18 01:43:39.530 INFO [stderr] | Dec 18 01:43:39.530 INFO [stderr] 91 | fn find_marker_block(block_size: usize) -> Vec { Dec 18 01:43:39.530 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.530 INFO [stderr] Dec 18 01:43:39.530 INFO [stderr] warning: constant item is never used: `BLOCK_LENGTH` Dec 18 01:43:39.530 INFO [stderr] --> src/set3/challenge17.rs:7:1 Dec 18 01:43:39.530 INFO [stderr] | Dec 18 01:43:39.530 INFO [stderr] 7 | const BLOCK_LENGTH: usize = 16; Dec 18 01:43:39.530 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.530 INFO [stderr] Dec 18 01:43:39.530 INFO [stderr] warning: constant item is never used: `INPUT_STRINGS` Dec 18 01:43:39.530 INFO [stderr] --> src/set3/challenge17.rs:9:1 Dec 18 01:43:39.530 INFO [stderr] | Dec 18 01:43:39.530 INFO [stderr] 9 | / const INPUT_STRINGS: [&'static str; 10] = [ Dec 18 01:43:39.530 INFO [stderr] 10 | | "MDAwMDAwTm93IHRoYXQgdGhlIHBhcnR5IGlzIGp1bXBpbmc=", Dec 18 01:43:39.530 INFO [stderr] 11 | | "MDAwMDAxV2l0aCB0aGUgYmFzcyBraWNrZWQgaW4gYW5kIHRoZSBWZWdhJ3MgYXJlIHB1bXBpbic=", Dec 18 01:43:39.530 INFO [stderr] 12 | | "MDAwMDAyUXVpY2sgdG8gdGhlIHBvaW50LCB0byB0aGUgcG9pbnQsIG5vIGZha2luZw==", Dec 18 01:43:39.530 INFO [stderr] ... | Dec 18 01:43:39.530 INFO [stderr] 19 | | "MDAwMDA5aXRoIG15IHJhZy10b3AgZG93biBzbyBteSBoYWlyIGNhbiBibG93", Dec 18 01:43:39.530 INFO [stderr] 20 | | ]; Dec 18 01:43:39.530 INFO [stderr] | |__^ Dec 18 01:43:39.530 INFO [stderr] Dec 18 01:43:39.530 INFO [stderr] warning: function is never used: `pad` Dec 18 01:43:39.530 INFO [stderr] --> src/set3/challenge17.rs:22:1 Dec 18 01:43:39.530 INFO [stderr] | Dec 18 01:43:39.530 INFO [stderr] 22 | fn pad(mut input: Vec) -> Vec { Dec 18 01:43:39.530 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.530 INFO [stderr] Dec 18 01:43:39.530 INFO [stderr] warning: function is never used: `decrypt_and_check_padding` Dec 18 01:43:39.530 INFO [stderr] --> src/set3/challenge17.rs:34:1 Dec 18 01:43:39.530 INFO [stderr] | Dec 18 01:43:39.530 INFO [stderr] 34 | fn decrypt_and_check_padding(ciphertext: Vec, key: &[u8], iv: &[u8]) -> bool { Dec 18 01:43:39.530 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.530 INFO [stderr] Dec 18 01:43:39.530 INFO [stderr] warning: function is never used: `test_byte` Dec 18 01:43:39.530 INFO [stderr] --> src/set3/challenge17.rs:42:1 Dec 18 01:43:39.530 INFO [stderr] | Dec 18 01:43:39.530 INFO [stderr] 42 | fn test_byte(guess: u8, target_index: usize, attacking_block: Vec, discovered_bytes: &Vec, key: &[u8]) -> Result { Dec 18 01:43:39.530 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 18 01:43:39.530 INFO [stderr] Dec 18 01:43:39.628 INFO [stderr] warning: variable does not need to be mutable Dec 18 01:43:39.628 INFO [stderr] --> src/set2/challenge13.rs:70:9 Dec 18 01:43:39.628 INFO [stderr] | Dec 18 01:43:39.628 INFO [stderr] 70 | let mut len_enc = encrypt(Profile::new(test_email.clone()).to_string()).len(); Dec 18 01:43:39.628 INFO [stderr] | ----^^^^^^^ Dec 18 01:43:39.628 INFO [stderr] | | Dec 18 01:43:39.628 INFO [stderr] | help: remove this `mut` Dec 18 01:43:39.628 INFO [stderr] | Dec 18 01:43:39.628 INFO [stderr] = note: #[warn(unused_mut)] on by default Dec 18 01:43:39.628 INFO [stderr] Dec 18 01:43:39.694 INFO [stderr] Finished dev [unoptimized + debuginfo] target(s) in 10.16s Dec 18 01:43:40.254 INFO running `"docker" "inspect" "9d0b83b89d84862629b6d1ad2d0d718951b3da59351d3f65bee939b406966d44"` Dec 18 01:43:40.406 INFO running `"docker" "rm" "-f" "9d0b83b89d84862629b6d1ad2d0d718951b3da59351d3f65bee939b406966d44"` Dec 18 01:43:40.576 INFO [stdout] 9d0b83b89d84862629b6d1ad2d0d718951b3da59351d3f65bee939b406966d44