[INFO] updating cached repository https://github.com/ferran1/ex-rust [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] 66e7ef7ee59767150348ab69a2da5eff0feccda9 [INFO] testing ferran1/ex-rust against 1.44.0 for beta-1.45-1 [INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fferran1%2Fex-rust" "/workspace/builds/worker-5/source"` [INFO] [stderr] Cloning into '/workspace/builds/worker-5/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/ferran1/ex-rust on toolchain 1.44.0 [INFO] running `"/workspace/cargo-home/bin/cargo" "+1.44.0" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started tweaking git repo https://github.com/ferran1/ex-rust [INFO] finished tweaking git repo https://github.com/ferran1/ex-rust [INFO] tweaked toml for git repo https://github.com/ferran1/ex-rust written to /workspace/builds/worker-5/source/Cargo.toml [INFO] crate git repo https://github.com/ferran1/ex-rust already has a lockfile, it will not be regenerated [INFO] running `"/workspace/cargo-home/bin/cargo" "+1.44.0" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5/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" "+1.44.0" "build" "--frozen"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 9c3fb8241557965bc96575b8154cacc42733c34bfa20d0c851e1191c5e939b6d [INFO] running `"docker" "start" "-a" "9c3fb8241557965bc96575b8154cacc42733c34bfa20d0c851e1191c5e939b6d"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] Compiling ex-rust v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/bin/match.rs:9:10 [INFO] [stderr] | [INFO] [stderr] 9 | 1...5 => println!("It's one from 1 to 5"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: multiple patterns covering the same range [INFO] [stderr] --> src/bin/match.rs:9:9 [INFO] [stderr] | [INFO] [stderr] 7 | 1 => println!("It's number one!"), [INFO] [stderr] | - this range overlaps on `1i32` [INFO] [stderr] 8 | 2 => println!("It's number two!"), [INFO] [stderr] 9 | 1...5 => println!("It's one from 1 to 5"), [INFO] [stderr] | ^^^^^ overlapping patterns [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(overlapping_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: irrefutable if-let pattern [INFO] [stderr] --> src/bin/match.rs:24:5 [INFO] [stderr] | [INFO] [stderr] 24 | / if let number = 1 { [INFO] [stderr] 25 | | println!("The number is 1!"); [INFO] [stderr] 26 | | } else { [INFO] [stderr] 27 | | println!("The number isn't 1..") [INFO] [stderr] 28 | | } [INFO] [stderr] | |_____^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(irrefutable_let_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `number` [INFO] [stderr] --> src/bin/match.rs:24:12 [INFO] [stderr] | [INFO] [stderr] 24 | if let number = 1 { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_number` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `third_value` [INFO] [stderr] --> src/bin/vectors.rs:13:14 [INFO] [stderr] | [INFO] [stderr] 13 | Some(third_value) => println!("It's purple!"), [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_third_value` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `home_address` [INFO] [stderr] --> src/bin/enums.rs:3:9 [INFO] [stderr] | [INFO] [stderr] 3 | let home_address = IPAddressKind::V4(127, 0, 0, 1); [INFO] [stderr] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_home_address` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `loopback` [INFO] [stderr] --> src/bin/enums.rs:4:9 [INFO] [stderr] | [INFO] [stderr] 4 | let loopback = IPAddr::V6(String::from("::1")); // Call the type alias "IPAddr" of the [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_loopback` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `x` [INFO] [stderr] --> src/bin/shadowing.rs:7:13 [INFO] [stderr] | [INFO] [stderr] 7 | let x = x + 5; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_x` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: method is never used: `call` [INFO] [stderr] --> src/bin/enums.rs:33:5 [INFO] [stderr] | [INFO] [stderr] 33 | fn call(&self) { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `a` [INFO] [stderr] --> src/bin/references_borrowing.rs:5:9 [INFO] [stderr] | [INFO] [stderr] 5 | let a = y; /* Ownership is being "moved" to the variable a because the value [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `d` [INFO] [stderr] --> src/bin/references_borrowing.rs:17:9 [INFO] [stderr] | [INFO] [stderr] 17 | let d = &c; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_d` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/bin/references_borrowing.rs:18:9 [INFO] [stderr] | [INFO] [stderr] 18 | let e = &c; // variables d and e borrow from the variable c, [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/bin/references_borrowing.rs:16:9 [INFO] [stderr] | [INFO] [stderr] 16 | let mut c = String::from("Hello world!"); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `a` [INFO] [stderr] --> src/bin/primitives_constants.rs:14:9 [INFO] [stderr] | [INFO] [stderr] 14 | let a = 30; // i = signed integer [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `b` [INFO] [stderr] --> src/bin/primitives_constants.rs:15:9 [INFO] [stderr] | [INFO] [stderr] 15 | let mut b : u32 = 35; // u = unsigned integer, mut = mutable [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_b` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `c` [INFO] [stderr] --> src/bin/primitives_constants.rs:33:9 [INFO] [stderr] | [INFO] [stderr] 33 | let c = 2.0; // Default type = f64 [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_c` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `d` [INFO] [stderr] --> src/bin/primitives_constants.rs:34:9 [INFO] [stderr] | [INFO] [stderr] 34 | let d: f32 = 20.5; // Variables can always be type annotated [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_d` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/bin/primitives_constants.rs:37:9 [INFO] [stderr] | [INFO] [stderr] 37 | let e = true; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `f` [INFO] [stderr] --> src/bin/primitives_constants.rs:40:9 [INFO] [stderr] | [INFO] [stderr] 40 | let f = 'F'; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_f` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `my_str` [INFO] [stderr] --> src/bin/primitives_constants.rs:43:9 [INFO] [stderr] | [INFO] [stderr] 43 | let my_str = "This is a &str"; [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_my_str` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `my_string` [INFO] [stderr] --> src/bin/primitives_constants.rs:46:9 [INFO] [stderr] | [INFO] [stderr] 46 | let my_string = String::from("This is a String"); [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_my_string` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `sum` [INFO] [stderr] --> src/bin/primitives_constants.rs:50:9 [INFO] [stderr] | [INFO] [stderr] 50 | let sum = 5 + 10; [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_sum` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `difference` [INFO] [stderr] --> src/bin/primitives_constants.rs:52:9 [INFO] [stderr] | [INFO] [stderr] 52 | let difference = 95.5 - 4.3; [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_difference` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `product` [INFO] [stderr] --> src/bin/primitives_constants.rs:54:9 [INFO] [stderr] | [INFO] [stderr] 54 | let product = 4 * 30; [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_product` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `quotient` [INFO] [stderr] --> src/bin/primitives_constants.rs:56:9 [INFO] [stderr] | [INFO] [stderr] 56 | let quotient = 56.7 / 32.2; [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_quotient` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `remainder` [INFO] [stderr] --> src/bin/primitives_constants.rs:58:9 [INFO] [stderr] | [INFO] [stderr] 58 | let remainder = 43 % 5; [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_remainder` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `y` [INFO] [stderr] --> src/bin/primitives_constants.rs:84:13 [INFO] [stderr] | [INFO] [stderr] 84 | let (x, y, z) = tup; // Deconstruct tuple to create bindings [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_y` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `z` [INFO] [stderr] --> src/bin/primitives_constants.rs:84:16 [INFO] [stderr] | [INFO] [stderr] 84 | let (x, y, z) = tup; // Deconstruct tuple to create bindings [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_z` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/bin/primitives_constants.rs:15:9 [INFO] [stderr] | [INFO] [stderr] 15 | let mut b : u32 = 35; // u = unsigned integer, mut = mutable [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 4 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] warning: 3 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] warning: 4 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: 16 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 2.80s [INFO] running `"docker" "inspect" "9c3fb8241557965bc96575b8154cacc42733c34bfa20d0c851e1191c5e939b6d"` [INFO] running `"docker" "rm" "-f" "9c3fb8241557965bc96575b8154cacc42733c34bfa20d0c851e1191c5e939b6d"` [INFO] [stdout] 9c3fb8241557965bc96575b8154cacc42733c34bfa20d0c851e1191c5e939b6d [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5/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" "+1.44.0" "test" "--frozen" "--no-run"` [INFO] [stdout] 05a94d3604bbf24fa180cc1d6b424f1a678b20e4e1c9f612b46632b38e4ce59f [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" "05a94d3604bbf24fa180cc1d6b424f1a678b20e4e1c9f612b46632b38e4ce59f"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] Compiling ex-rust v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: unused variable: `a` [INFO] [stderr] --> src/bin/references_borrowing.rs:5:9 [INFO] [stderr] | [INFO] [stderr] 5 | let a = y; /* Ownership is being "moved" to the variable a because the value [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `d` [INFO] [stderr] --> src/bin/references_borrowing.rs:17:9 [INFO] [stderr] | [INFO] [stderr] 17 | let d = &c; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_d` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/bin/references_borrowing.rs:18:9 [INFO] [stderr] | [INFO] [stderr] 18 | let e = &c; // variables d and e borrow from the variable c, [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/bin/references_borrowing.rs:16:9 [INFO] [stderr] | [INFO] [stderr] 16 | let mut c = String::from("Hello world!"); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/bin/match.rs:9:10 [INFO] [stderr] | [INFO] [stderr] 9 | 1...5 => println!("It's one from 1 to 5"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: multiple patterns covering the same range [INFO] [stderr] --> src/bin/match.rs:9:9 [INFO] [stderr] | [INFO] [stderr] 7 | 1 => println!("It's number one!"), [INFO] [stderr] | - this range overlaps on `1i32` [INFO] [stderr] 8 | 2 => println!("It's number two!"), [INFO] [stderr] 9 | 1...5 => println!("It's one from 1 to 5"), [INFO] [stderr] | ^^^^^ overlapping patterns [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(overlapping_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: irrefutable if-let pattern [INFO] [stderr] --> src/bin/match.rs:24:5 [INFO] [stderr] | [INFO] [stderr] 24 | / if let number = 1 { [INFO] [stderr] 25 | | println!("The number is 1!"); [INFO] [stderr] 26 | | } else { [INFO] [stderr] 27 | | println!("The number isn't 1..") [INFO] [stderr] 28 | | } [INFO] [stderr] | |_____^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(irrefutable_let_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `number` [INFO] [stderr] --> src/bin/match.rs:24:12 [INFO] [stderr] | [INFO] [stderr] 24 | if let number = 1 { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_number` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `x` [INFO] [stderr] --> src/bin/shadowing.rs:7:13 [INFO] [stderr] | [INFO] [stderr] 7 | let x = x + 5; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_x` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `a` [INFO] [stderr] --> src/bin/primitives_constants.rs:14:9 [INFO] [stderr] | [INFO] [stderr] 14 | let a = 30; // i = signed integer [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `b` [INFO] [stderr] --> src/bin/primitives_constants.rs:15:9 [INFO] [stderr] | [INFO] [stderr] 15 | let mut b : u32 = 35; // u = unsigned integer, mut = mutable [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_b` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `c` [INFO] [stderr] --> src/bin/primitives_constants.rs:33:9 [INFO] [stderr] | [INFO] [stderr] 33 | let c = 2.0; // Default type = f64 [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_c` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `d` [INFO] [stderr] --> src/bin/primitives_constants.rs:34:9 [INFO] [stderr] | [INFO] [stderr] 34 | let d: f32 = 20.5; // Variables can always be type annotated [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_d` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/bin/primitives_constants.rs:37:9 [INFO] [stderr] | [INFO] [stderr] 37 | let e = true; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `f` [INFO] [stderr] --> src/bin/primitives_constants.rs:40:9 [INFO] [stderr] | [INFO] [stderr] 40 | let f = 'F'; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_f` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `my_str` [INFO] [stderr] --> src/bin/primitives_constants.rs:43:9 [INFO] [stderr] | [INFO] [stderr] 43 | let my_str = "This is a &str"; [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_my_str` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `my_string` [INFO] [stderr] --> src/bin/primitives_constants.rs:46:9 [INFO] [stderr] | [INFO] [stderr] 46 | let my_string = String::from("This is a String"); [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_my_string` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `sum` [INFO] [stderr] --> src/bin/primitives_constants.rs:50:9 [INFO] [stderr] | [INFO] [stderr] 50 | let sum = 5 + 10; [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_sum` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `difference` [INFO] [stderr] --> src/bin/primitives_constants.rs:52:9 [INFO] [stderr] | [INFO] [stderr] 52 | let difference = 95.5 - 4.3; [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_difference` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `product` [INFO] [stderr] --> src/bin/primitives_constants.rs:54:9 [INFO] [stderr] | [INFO] [stderr] 54 | let product = 4 * 30; [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_product` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `quotient` [INFO] [stderr] --> src/bin/primitives_constants.rs:56:9 [INFO] [stderr] | [INFO] [stderr] 56 | let quotient = 56.7 / 32.2; [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_quotient` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `remainder` [INFO] [stderr] --> src/bin/primitives_constants.rs:58:9 [INFO] [stderr] | [INFO] [stderr] 58 | let remainder = 43 % 5; [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_remainder` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `y` [INFO] [stderr] --> src/bin/primitives_constants.rs:84:13 [INFO] [stderr] | [INFO] [stderr] 84 | let (x, y, z) = tup; // Deconstruct tuple to create bindings [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_y` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `z` [INFO] [stderr] --> src/bin/primitives_constants.rs:84:16 [INFO] [stderr] | [INFO] [stderr] 84 | let (x, y, z) = tup; // Deconstruct tuple to create bindings [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_z` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `third_value` [INFO] [stderr] --> src/bin/vectors.rs:13:14 [INFO] [stderr] | [INFO] [stderr] 13 | Some(third_value) => println!("It's purple!"), [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_third_value` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/bin/primitives_constants.rs:15:9 [INFO] [stderr] | [INFO] [stderr] 15 | let mut b : u32 = 35; // u = unsigned integer, mut = mutable [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `home_address` [INFO] [stderr] --> src/bin/enums.rs:3:9 [INFO] [stderr] | [INFO] [stderr] 3 | let home_address = IPAddressKind::V4(127, 0, 0, 1); [INFO] [stderr] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_home_address` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `loopback` [INFO] [stderr] --> src/bin/enums.rs:4:9 [INFO] [stderr] | [INFO] [stderr] 4 | let loopback = IPAddr::V6(String::from("::1")); // Call the type alias "IPAddr" of the [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_loopback` [INFO] [stderr] [INFO] [stderr] warning: method is never used: `call` [INFO] [stderr] --> src/bin/enums.rs:33:5 [INFO] [stderr] | [INFO] [stderr] 33 | fn call(&self) { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 4 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: 4 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] warning: 16 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: 3 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 3.02s [INFO] running `"docker" "inspect" "05a94d3604bbf24fa180cc1d6b424f1a678b20e4e1c9f612b46632b38e4ce59f"` [INFO] running `"docker" "rm" "-f" "05a94d3604bbf24fa180cc1d6b424f1a678b20e4e1c9f612b46632b38e4ce59f"` [INFO] [stdout] 05a94d3604bbf24fa180cc1d6b424f1a678b20e4e1c9f612b46632b38e4ce59f [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5/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" "+1.44.0" "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] 7af16f0758399f0a61b399db48dc13b40ba9e7fcdd041e4c73c4151fbed6e846 [INFO] running `"docker" "start" "-a" "7af16f0758399f0a61b399db48dc13b40ba9e7fcdd041e4c73c4151fbed6e846"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] warning: unused variable: `a` [INFO] [stderr] --> src/bin/references_borrowing.rs:5:9 [INFO] [stderr] | [INFO] [stderr] 5 | let a = y; /* Ownership is being "moved" to the variable a because the value [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `d` [INFO] [stderr] --> src/bin/references_borrowing.rs:17:9 [INFO] [stderr] | [INFO] [stderr] 17 | let d = &c; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_d` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/bin/references_borrowing.rs:18:9 [INFO] [stderr] | [INFO] [stderr] 18 | let e = &c; // variables d and e borrow from the variable c, [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/bin/references_borrowing.rs:16:9 [INFO] [stderr] | [INFO] [stderr] 16 | let mut c = String::from("Hello world!"); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 4 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: unused variable: `x` [INFO] [stderr] --> src/bin/shadowing.rs:7:13 [INFO] [stderr] | [INFO] [stderr] 7 | let x = x + 5; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_x` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] warning: unused variable: `a` [INFO] [stderr] --> src/bin/primitives_constants.rs:14:9 [INFO] [stderr] | [INFO] [stderr] 14 | let a = 30; // i = signed integer [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `b` [INFO] [stderr] --> src/bin/primitives_constants.rs:15:9 [INFO] [stderr] | [INFO] [stderr] 15 | let mut b : u32 = 35; // u = unsigned integer, mut = mutable [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_b` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `c` [INFO] [stderr] --> src/bin/primitives_constants.rs:33:9 [INFO] [stderr] | [INFO] [stderr] 33 | let c = 2.0; // Default type = f64 [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_c` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `d` [INFO] [stderr] --> src/bin/primitives_constants.rs:34:9 [INFO] [stderr] | [INFO] [stderr] 34 | let d: f32 = 20.5; // Variables can always be type annotated [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_d` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/bin/primitives_constants.rs:37:9 [INFO] [stderr] | [INFO] [stderr] 37 | let e = true; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `f` [INFO] [stderr] --> src/bin/primitives_constants.rs:40:9 [INFO] [stderr] | [INFO] [stderr] 40 | let f = 'F'; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_f` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `my_str` [INFO] [stderr] --> src/bin/primitives_constants.rs:43:9 [INFO] [stderr] | [INFO] [stderr] 43 | let my_str = "This is a &str"; [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_my_str` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `my_string` [INFO] [stderr] --> src/bin/primitives_constants.rs:46:9 [INFO] [stderr] | [INFO] [stderr] 46 | let my_string = String::from("This is a String"); [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_my_string` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `sum` [INFO] [stderr] --> src/bin/primitives_constants.rs:50:9 [INFO] [stderr] | [INFO] [stderr] 50 | let sum = 5 + 10; [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_sum` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `difference` [INFO] [stderr] --> src/bin/primitives_constants.rs:52:9 [INFO] [stderr] | [INFO] [stderr] 52 | let difference = 95.5 - 4.3; [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_difference` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `product` [INFO] [stderr] --> src/bin/primitives_constants.rs:54:9 [INFO] [stderr] | [INFO] [stderr] 54 | let product = 4 * 30; [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_product` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `quotient` [INFO] [stderr] --> src/bin/primitives_constants.rs:56:9 [INFO] [stderr] | [INFO] [stderr] 56 | let quotient = 56.7 / 32.2; [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_quotient` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `remainder` [INFO] [stderr] --> src/bin/primitives_constants.rs:58:9 [INFO] [stderr] | [INFO] [stderr] 58 | let remainder = 43 % 5; [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_remainder` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `y` [INFO] [stderr] --> src/bin/primitives_constants.rs:84:13 [INFO] [stderr] | [INFO] [stderr] 84 | let (x, y, z) = tup; // Deconstruct tuple to create bindings [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_y` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `z` [INFO] [stderr] --> src/bin/primitives_constants.rs:84:16 [INFO] [stderr] | [INFO] [stderr] 84 | let (x, y, z) = tup; // Deconstruct tuple to create bindings [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_z` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/bin/primitives_constants.rs:15:9 [INFO] [stderr] | [INFO] [stderr] 15 | let mut b : u32 = 35; // u = unsigned integer, mut = mutable [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 16 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: unused variable: `third_value` [INFO] [stderr] --> src/bin/vectors.rs:13:14 [INFO] [stderr] | [INFO] [stderr] 13 | Some(third_value) => println!("It's purple!"), [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_third_value` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] warning: unused variable: `home_address` [INFO] [stderr] --> src/bin/enums.rs:3:9 [INFO] [stderr] | [INFO] [stderr] 3 | let home_address = IPAddressKind::V4(127, 0, 0, 1); [INFO] [stderr] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_home_address` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/bin/match.rs:9:10 [INFO] [stderr] | [INFO] [stderr] 9 | 1...5 => println!("It's one from 1 to 5"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `loopback` [INFO] [stderr] --> src/bin/enums.rs:4:9 [INFO] [stderr] | [INFO] [stderr] 4 | let loopback = IPAddr::V6(String::from("::1")); // Call the type alias "IPAddr" of the [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_loopback` [INFO] [stderr] [INFO] [stderr] warning: method is never used: `call` [INFO] [stderr] --> src/bin/enums.rs:33:5 [INFO] [stderr] | [INFO] [stderr] 33 | fn call(&self) { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 3 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: multiple patterns covering the same range [INFO] [stderr] --> src/bin/match.rs:9:9 [INFO] [stderr] | [INFO] [stderr] 7 | 1 => println!("It's number one!"), [INFO] [stderr] | - this range overlaps on `1i32` [INFO] [stderr] 8 | 2 => println!("It's number two!"), [INFO] [stderr] 9 | 1...5 => println!("It's one from 1 to 5"), [INFO] [stderr] | ^^^^^ overlapping patterns [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(overlapping_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: irrefutable if-let pattern [INFO] [stderr] --> src/bin/match.rs:24:5 [INFO] [stderr] | [INFO] [stderr] 24 | / if let number = 1 { [INFO] [stderr] 25 | | println!("The number is 1!"); [INFO] [stderr] 26 | | } else { [INFO] [stderr] 27 | | println!("The number isn't 1..") [INFO] [stderr] 28 | | } [INFO] [stderr] | |_____^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(irrefutable_let_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `number` [INFO] [stderr] --> src/bin/match.rs:24:12 [INFO] [stderr] | [INFO] [stderr] 24 | if let number = 1 { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_number` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 4 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.04s [INFO] [stderr] Running /opt/rustwide/target/debug/deps/enums-f8a0a236818c2ac4 [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] [stderr] Running /opt/rustwide/target/debug/deps/ex_rust-b267d9ef3f9f0588 [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] [stderr] Running /opt/rustwide/target/debug/deps/functions_methods-c2b198d0e63be1fe [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] [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] [stderr] Running /opt/rustwide/target/debug/deps/if_statements-f0d7722e57df92c2 [INFO] [stderr] Running /opt/rustwide/target/debug/deps/loops-2079b2de988d6fb0 [INFO] [stderr] Running /opt/rustwide/target/debug/deps/match-d69bf497f676daaa [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] [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] [stderr] Running /opt/rustwide/target/debug/deps/primitives_constants-d8dcf3b01216a561 [INFO] [stderr] Running /opt/rustwide/target/debug/deps/references_borrowing-981e48ded20fd1aa [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] [stdout] [INFO] [stderr] Running /opt/rustwide/target/debug/deps/shadowing-41b3453359c57008 [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] [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] [stderr] Running /opt/rustwide/target/debug/deps/slices-4c72c059bbee83a1 [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] [stderr] Running /opt/rustwide/target/debug/deps/structs-64c5d0ddde43e9ab [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] [stderr] Running /opt/rustwide/target/debug/deps/vectors-81b74c0372594f12 [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" "7af16f0758399f0a61b399db48dc13b40ba9e7fcdd041e4c73c4151fbed6e846"` [INFO] running `"docker" "rm" "-f" "7af16f0758399f0a61b399db48dc13b40ba9e7fcdd041e4c73c4151fbed6e846"` [INFO] [stdout] 7af16f0758399f0a61b399db48dc13b40ba9e7fcdd041e4c73c4151fbed6e846