[INFO] fetching crate opensimplex 0.2.0... [INFO] testing opensimplex-0.2.0 against beta-2022-04-10 for beta-1.61-1 [INFO] extracting crate opensimplex 0.2.0 into /workspace/builds/worker-6/source [INFO] validating manifest of crates.io crate opensimplex 0.2.0 on toolchain beta-2022-04-10 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+beta-2022-04-10" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking crates.io crate opensimplex 0.2.0 [INFO] finished tweaking crates.io crate opensimplex 0.2.0 [INFO] tweaked toml for crates.io crate opensimplex 0.2.0 written to /workspace/builds/worker-6/source/Cargo.toml [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+beta-2022-04-10" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }` [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+beta-2022-04-10" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:b0c94ce3c1162fcb8e57cac5b65ec2f72eabb1eebea4fcc35e269e823f681646" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2022-04-10" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 2270938bb21b06505a59933ad0e6604a1b773bba0eeb6062fcc1dff958be0d34 [INFO] running `Command { std: "docker" "start" "-a" "2270938bb21b06505a59933ad0e6604a1b773bba0eeb6062fcc1dff958be0d34", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "2270938bb21b06505a59933ad0e6604a1b773bba0eeb6062fcc1dff958be0d34", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2270938bb21b06505a59933ad0e6604a1b773bba0eeb6062fcc1dff958be0d34", kill_on_drop: false }` [INFO] [stdout] 2270938bb21b06505a59933ad0e6604a1b773bba0eeb6062fcc1dff958be0d34 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:b0c94ce3c1162fcb8e57cac5b65ec2f72eabb1eebea4fcc35e269e823f681646" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2022-04-10" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 7ea9a483d515adac445ee4cb9b592bb990d1fdb200fb398eefff9b29ce568977 [INFO] running `Command { std: "docker" "start" "-a" "7ea9a483d515adac445ee4cb9b592bb990d1fdb200fb398eefff9b29ce568977", kill_on_drop: false }` [INFO] [stderr] Compiling opensimplex v0.2.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: use of deprecated function `gcc::compile_library`: crate has been renamed to `cc`, the `gcc` name is not maintained [INFO] [stdout] --> build.rs:4:10 [INFO] [stdout] | [INFO] [stdout] 4 | gcc::compile_library("libopensimplex.a", &["src/opensimplex.c"]); [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:5:30 [INFO] [stdout] | [INFO] [stdout] 5 | use libc::{ c_int, c_double, int64_t, int16_t, c_void }; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int16_t`: Use i16 instead. [INFO] [stdout] --> src/lib.rs:5:39 [INFO] [stdout] | [INFO] [stdout] 5 | use libc::{ c_int, c_double, int64_t, int16_t, c_void }; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:9:18 [INFO] [stdout] | [INFO] [stdout] 9 | perm: *const int64_t, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:10:29 [INFO] [stdout] | [INFO] [stdout] 10 | permGradIndex3D: *const int64_t, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead [INFO] [stdout] --> src/lib.rs:35:57 [INFO] [stdout] | [INFO] [stdout] 35 | let mut ctx: *mut RawOsnContext = unsafe { mem::uninitialized() }; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:15:33 [INFO] [stdout] | [INFO] [stdout] 15 | fn open_simplex_noise(seed: int64_t, ctx: *mut *mut RawOsnContext) -> c_int; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int16_t`: Use i16 instead. [INFO] [stdout] --> src/lib.rs:17:72 [INFO] [stdout] | [INFO] [stdout] 17 | fn open_simplex_noise_init_perm(ctx: *mut RawOsnContext, p: *const int16_t, nelements: c_int) -> c_int; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 7 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1.53s [INFO] running `Command { std: "docker" "inspect" "7ea9a483d515adac445ee4cb9b592bb990d1fdb200fb398eefff9b29ce568977", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7ea9a483d515adac445ee4cb9b592bb990d1fdb200fb398eefff9b29ce568977", kill_on_drop: false }` [INFO] [stdout] 7ea9a483d515adac445ee4cb9b592bb990d1fdb200fb398eefff9b29ce568977 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:b0c94ce3c1162fcb8e57cac5b65ec2f72eabb1eebea4fcc35e269e823f681646" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2022-04-10" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 072a77506ec04f20d507fd444bb286c4939ce54e8be96faec3dfc4d5ef03bb79 [INFO] running `Command { std: "docker" "start" "-a" "072a77506ec04f20d507fd444bb286c4939ce54e8be96faec3dfc4d5ef03bb79", kill_on_drop: false }` [INFO] [stderr] Compiling opensimplex v0.2.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: use of deprecated function `gcc::compile_library`: crate has been renamed to `cc`, the `gcc` name is not maintained [INFO] [stdout] --> build.rs:4:10 [INFO] [stdout] | [INFO] [stdout] 4 | gcc::compile_library("libopensimplex.a", &["src/opensimplex.c"]); [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:5:30 [INFO] [stdout] | [INFO] [stdout] 5 | use libc::{ c_int, c_double, int64_t, int16_t, c_void }; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int16_t`: Use i16 instead. [INFO] [stdout] --> src/lib.rs:5:39 [INFO] [stdout] | [INFO] [stdout] 5 | use libc::{ c_int, c_double, int64_t, int16_t, c_void }; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:9:18 [INFO] [stdout] | [INFO] [stdout] 9 | perm: *const int64_t, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:10:29 [INFO] [stdout] | [INFO] [stdout] 10 | permGradIndex3D: *const int64_t, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead [INFO] [stdout] --> src/lib.rs:35:57 [INFO] [stdout] | [INFO] [stdout] 35 | let mut ctx: *mut RawOsnContext = unsafe { mem::uninitialized() }; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:15:33 [INFO] [stdout] | [INFO] [stdout] 15 | fn open_simplex_noise(seed: int64_t, ctx: *mut *mut RawOsnContext) -> c_int; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int16_t`: Use i16 instead. [INFO] [stdout] --> src/lib.rs:17:72 [INFO] [stdout] | [INFO] [stdout] 17 | fn open_simplex_noise_init_perm(ctx: *mut RawOsnContext, p: *const int16_t, nelements: c_int) -> c_int; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 7 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:5:30 [INFO] [stdout] | [INFO] [stdout] 5 | use libc::{ c_int, c_double, int64_t, int16_t, c_void }; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int16_t`: Use i16 instead. [INFO] [stdout] --> src/lib.rs:5:39 [INFO] [stdout] | [INFO] [stdout] 5 | use libc::{ c_int, c_double, int64_t, int16_t, c_void }; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:9:18 [INFO] [stdout] | [INFO] [stdout] 9 | perm: *const int64_t, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:10:29 [INFO] [stdout] | [INFO] [stdout] 10 | permGradIndex3D: *const int64_t, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead [INFO] [stdout] --> src/lib.rs:35:57 [INFO] [stdout] | [INFO] [stdout] 35 | let mut ctx: *mut RawOsnContext = unsafe { mem::uninitialized() }; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stdout] --> src/lib.rs:15:33 [INFO] [stdout] | [INFO] [stdout] 15 | fn open_simplex_noise(seed: int64_t, ctx: *mut *mut RawOsnContext) -> c_int; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated type alias `libc::int16_t`: Use i16 instead. [INFO] [stdout] --> src/lib.rs:17:72 [INFO] [stdout] | [INFO] [stdout] 17 | fn open_simplex_noise_init_perm(ctx: *mut RawOsnContext, p: *const int16_t, nelements: c_int) -> c_int; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 7 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.67s [INFO] [stderr] Executable unittests src/lib.rs (/opt/rustwide/target/debug/deps/opensimplex-2f9306b107a7925a) [INFO] running `Command { std: "docker" "inspect" "072a77506ec04f20d507fd444bb286c4939ce54e8be96faec3dfc4d5ef03bb79", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "072a77506ec04f20d507fd444bb286c4939ce54e8be96faec3dfc4d5ef03bb79", kill_on_drop: false }` [INFO] [stdout] 072a77506ec04f20d507fd444bb286c4939ce54e8be96faec3dfc4d5ef03bb79 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:b0c94ce3c1162fcb8e57cac5b65ec2f72eabb1eebea4fcc35e269e823f681646" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2022-04-10" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 8581643d779674b1cdd799db1293c1249e92a69b79594796aead97c9de52d82e [INFO] running `Command { std: "docker" "start" "-a" "8581643d779674b1cdd799db1293c1249e92a69b79594796aead97c9de52d82e", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] warning: use of deprecated function `gcc::compile_library`: crate has been renamed to `cc`, the `gcc` name is not maintained [INFO] [stderr] --> build.rs:4:10 [INFO] [stderr] | [INFO] [stderr] 4 | gcc::compile_library("libopensimplex.a", &["src/opensimplex.c"]); [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: `opensimplex` (build script) generated 1 warning [INFO] [stderr] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stderr] --> src/lib.rs:5:30 [INFO] [stderr] | [INFO] [stderr] 5 | use libc::{ c_int, c_double, int64_t, int16_t, c_void }; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated type alias `libc::int16_t`: Use i16 instead. [INFO] [stderr] --> src/lib.rs:5:39 [INFO] [stderr] | [INFO] [stderr] 5 | use libc::{ c_int, c_double, int64_t, int16_t, c_void }; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stderr] --> src/lib.rs:9:18 [INFO] [stderr] | [INFO] [stderr] 9 | perm: *const int64_t, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stderr] --> src/lib.rs:10:29 [INFO] [stderr] | [INFO] [stderr] 10 | permGradIndex3D: *const int64_t, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead [INFO] [stderr] --> src/lib.rs:35:57 [INFO] [stderr] | [INFO] [stderr] 35 | let mut ctx: *mut RawOsnContext = unsafe { mem::uninitialized() }; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated type alias `libc::int64_t`: Use i64 instead. [INFO] [stderr] --> src/lib.rs:15:33 [INFO] [stderr] | [INFO] [stderr] 15 | fn open_simplex_noise(seed: int64_t, ctx: *mut *mut RawOsnContext) -> c_int; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated type alias `libc::int16_t`: Use i16 instead. [INFO] [stderr] --> src/lib.rs:17:72 [INFO] [stderr] | [INFO] [stderr] 17 | fn open_simplex_noise_init_perm(ctx: *mut RawOsnContext, p: *const int16_t, nelements: c_int) -> c_int; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `opensimplex` (lib) generated 7 warnings [INFO] [stderr] warning: `opensimplex` (lib test) generated 7 warnings (7 duplicates) [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.24s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/opensimplex-2f9306b107a7925a) [INFO] [stderr] Doc-tests opensimplex [INFO] [stdout] [INFO] [stdout] running 1 test [INFO] [stdout] test test_basics ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [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; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "8581643d779674b1cdd799db1293c1249e92a69b79594796aead97c9de52d82e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8581643d779674b1cdd799db1293c1249e92a69b79594796aead97c9de52d82e", kill_on_drop: false }` [INFO] [stdout] 8581643d779674b1cdd799db1293c1249e92a69b79594796aead97c9de52d82e