[INFO] crate chunk_store 0.4.1 is already in cache [INFO] testing chunk_store-0.4.1 against 1.45.2 for beta-1.46-1 [INFO] extracting crate chunk_store 0.4.1 into /workspace/builds/worker-2/source [INFO] validating manifest of crates.io crate chunk_store 0.4.1 on toolchain 1.45.2 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.45.2" "read-manifest" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] started tweaking crates.io crate chunk_store 0.4.1 [INFO] finished tweaking crates.io crate chunk_store 0.4.1 [INFO] tweaked toml for crates.io crate chunk_store 0.4.1 written to /workspace/builds/worker-2/source/Cargo.toml [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.45.2" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }` [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.45.2" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "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_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+1.45.2" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] eac5baa81233c497325b0830fff8ee2499e6a398a6cbe0af7e47804ef373bc4d [INFO] running `Command { std: "docker" "start" "-a" "eac5baa81233c497325b0830fff8ee2499e6a398a6cbe0af7e47804ef373bc4d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "eac5baa81233c497325b0830fff8ee2499e6a398a6cbe0af7e47804ef373bc4d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "eac5baa81233c497325b0830fff8ee2499e6a398a6cbe0af7e47804ef373bc4d", kill_on_drop: false }` [INFO] [stdout] eac5baa81233c497325b0830fff8ee2499e6a398a6cbe0af7e47804ef373bc4d [INFO] running `Command { std: "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@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+1.45.2" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 40480484085f6fb15c4621a078627d002d5593f0df8ea2126ab83656b5b93337 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "40480484085f6fb15c4621a078627d002d5593f0df8ea2126ab83656b5b93337", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.74 [INFO] [stderr] Compiling winapi-build v0.1.1 [INFO] [stderr] Compiling winapi v0.2.8 [INFO] [stderr] Compiling log v0.4.11 [INFO] [stderr] Compiling autocfg v1.0.0 [INFO] [stderr] Compiling tinyvec v0.3.3 [INFO] [stderr] Compiling matches v0.1.8 [INFO] [stderr] Compiling byteorder v1.3.4 [INFO] [stderr] Compiling bitflags v0.4.0 [INFO] [stderr] Compiling rustc-serialize v0.3.24 [INFO] [stderr] Compiling httparse v1.3.4 [INFO] [stderr] Compiling slab v0.1.3 [INFO] [stderr] Compiling percent-encoding v1.0.1 [INFO] [stderr] Compiling bytes v0.3.0 [INFO] [stderr] Compiling regex-syntax v0.3.9 [INFO] [stderr] Compiling byteorder v0.5.3 [INFO] [stderr] Compiling utf8-ranges v0.1.3 [INFO] [stderr] Compiling serde v0.7.15 [INFO] [stderr] Compiling remove_dir_all v0.5.3 [INFO] [stderr] Compiling quick-error v1.2.3 [INFO] [stderr] Compiling unicode-bidi v0.3.4 [INFO] [stderr] Compiling kernel32-sys v0.2.2 [INFO] [stderr] Compiling ws2_32-sys v0.2.1 [INFO] [stderr] Compiling unicode-normalization v0.1.13 [INFO] [stderr] Compiling num-traits v0.2.12 [INFO] [stderr] Compiling log v0.3.9 [INFO] [stderr] Compiling sha1 v0.1.1 [INFO] [stderr] Compiling time v0.1.43 [INFO] [stderr] Compiling net2 v0.2.34 [INFO] [stderr] Compiling rand v0.4.6 [INFO] [stderr] Compiling memchr v0.1.11 [INFO] [stderr] Compiling nix v0.5.1 [INFO] [stderr] Compiling thread-id v2.0.0 [INFO] [stderr] Compiling thread_local v0.2.7 [INFO] [stderr] Compiling aho-corasick v0.5.3 [INFO] [stderr] Compiling idna v0.1.5 [INFO] [stderr] Compiling miow v0.1.5 [INFO] [stderr] Compiling regex v0.1.80 [INFO] [stderr] Compiling num-traits v0.1.43 [INFO] [stderr] Compiling rand v0.3.23 [INFO] [stderr] Compiling tempdir v0.3.7 [INFO] [stderr] Compiling url v1.7.2 [INFO] [stderr] Compiling toml v0.1.30 [INFO] [stderr] Compiling bincode v0.5.9 [INFO] [stderr] Compiling mio v0.5.1 [INFO] [stderr] Compiling log4rs v0.3.3 [INFO] [stderr] Compiling ws v0.4.8 [INFO] [stderr] Compiling maidsafe_utilities v0.6.0 [INFO] [stderr] Compiling chunk_store v0.4.1 (/opt/rustwide/workdir) [INFO] [stdout] warning: lint `exceeding_bitshifts` has been renamed to `arithmetic_overflow` [INFO] [stdout] --> src/lib.rs:28:22 [INFO] [stdout] | [INFO] [stdout] 28 | #![forbid(bad_style, exceeding_bitshifts, mutable_transmutes, no_mangle_const_items, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: use the new name: `arithmetic_overflow` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(renamed_and_removed_lints)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `drop_with_repr_extern` has been removed: `drop flags have been removed` [INFO] [stdout] --> src/lib.rs:30:21 [INFO] [stdout] | [INFO] [stdout] 30 | #![deny(deprecated, drop_with_repr_extern, improper_ctypes, missing_docs, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:29:32 [INFO] [stdout] | [INFO] [stdout] 29 | unknown_crate_types, warnings)] [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] = note: `#[warn(renamed_and_removed_lints)]` implied by `#[warn(warnings)]` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `plugin_as_library` has been removed: `plugins have been deprecated and retired` [INFO] [stdout] --> src/lib.rs:31:61 [INFO] [stdout] | [INFO] [stdout] 31 | non_shorthand_field_patterns, overflowing_literals, plugin_as_library, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `private_no_mangle_fns` has been removed: `no longer a warning, `#[no_mangle]` functions always exported` [INFO] [stdout] --> src/lib.rs:32:9 [INFO] [stdout] | [INFO] [stdout] 32 | private_no_mangle_fns, private_no_mangle_statics, stable_features, unconditional_recursion, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `private_no_mangle_statics` has been removed: `no longer a warning, `#[no_mangle]` statics always exported` [INFO] [stdout] --> src/lib.rs:32:32 [INFO] [stdout] | [INFO] [stdout] 32 | private_no_mangle_fns, private_no_mangle_statics, stable_features, unconditional_recursion, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `fat_ptr_transmutes` has been removed: `was accidentally removed back in 2014` [INFO] [stdout] --> src/lib.rs:37:24 [INFO] [stdout] | [INFO] [stdout] 37 | #![allow(box_pointers, fat_ptr_transmutes, missing_copy_implementations, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:114:32 [INFO] [stdout] | [INFO] [stdout] 114 | let serialised_value = try!(serialisation::serialise(value)); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:30:9 [INFO] [stdout] | [INFO] [stdout] 30 | #![deny(deprecated, drop_with_repr_extern, improper_ctypes, missing_docs, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:120:25 [INFO] [stdout] | [INFO] [stdout] 120 | let file_path = try!(self.file_path(key)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:141:25 [INFO] [stdout] | [INFO] [stdout] 141 | let file_path = try!(self.file_path(key)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:149:30 [INFO] [stdout] | [INFO] [stdout] 149 | match fs::File::open(try!(self.file_path(key))) { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:152:25 [INFO] [stdout] | [INFO] [stdout] 152 | let _ = try!(file.read_to_end(&mut contents)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:153:20 [INFO] [stdout] | [INFO] [stdout] 153 | Ok(try!(serialisation::deserialise::(&contents))) [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:208:24 [INFO] [stdout] | [INFO] [stdout] 208 | let filename = try!(serialisation::serialise(key)).to_hex(); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `#[macro_use]` import [INFO] [stdout] --> src/lib.rs:45:1 [INFO] [stdout] | [INFO] [stdout] 45 | #[macro_use] [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:33:37 [INFO] [stdout] | [INFO] [stdout] 33 | unknown_lints, unsafe_code, unused, unused_allocation, unused_attributes, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] = note: `#[warn(unused_imports)]` implied by `#[warn(unused)]` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused macro definition [INFO] [stdout] --> src/test.rs:18:1 [INFO] [stdout] | [INFO] [stdout] 18 | / macro_rules! assert_err { [INFO] [stdout] 19 | | ($cond : expr, $error : pat) => { [INFO] [stdout] 20 | | match $cond { [INFO] [stdout] 21 | | Err($error) => (), [INFO] [stdout] ... | [INFO] [stdout] 24 | | } [INFO] [stdout] 25 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:33:37 [INFO] [stdout] | [INFO] [stdout] 33 | unknown_lints, unsafe_code, unused, unused_allocation, unused_attributes, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] = note: `#[warn(unused_macros)]` implied by `#[warn(unused)]` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 15 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 46.38s [INFO] running `Command { std: "docker" "inspect" "40480484085f6fb15c4621a078627d002d5593f0df8ea2126ab83656b5b93337", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "40480484085f6fb15c4621a078627d002d5593f0df8ea2126ab83656b5b93337", kill_on_drop: false }` [INFO] [stdout] 40480484085f6fb15c4621a078627d002d5593f0df8ea2126ab83656b5b93337 [INFO] running `Command { std: "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@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+1.45.2" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] b577d2c56bb60c72812222bf8a43ee9ca2d3428f2fe6a7a59efb20fba9c36b75 [INFO] running `Command { std: "docker" "start" "-a" "b577d2c56bb60c72812222bf8a43ee9ca2d3428f2fe6a7a59efb20fba9c36b75", kill_on_drop: false }` [INFO] [stderr] Compiling chunk_store v0.4.1 (/opt/rustwide/workdir) [INFO] [stdout] warning: lint `exceeding_bitshifts` has been renamed to `arithmetic_overflow` [INFO] [stdout] --> src/lib.rs:28:22 [INFO] [stdout] | [INFO] [stdout] 28 | #![forbid(bad_style, exceeding_bitshifts, mutable_transmutes, no_mangle_const_items, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: use the new name: `arithmetic_overflow` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(renamed_and_removed_lints)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `drop_with_repr_extern` has been removed: `drop flags have been removed` [INFO] [stdout] --> src/lib.rs:30:21 [INFO] [stdout] | [INFO] [stdout] 30 | #![deny(deprecated, drop_with_repr_extern, improper_ctypes, missing_docs, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:29:32 [INFO] [stdout] | [INFO] [stdout] 29 | unknown_crate_types, warnings)] [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] = note: `#[warn(renamed_and_removed_lints)]` implied by `#[warn(warnings)]` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `plugin_as_library` has been removed: `plugins have been deprecated and retired` [INFO] [stdout] --> src/lib.rs:31:61 [INFO] [stdout] | [INFO] [stdout] 31 | non_shorthand_field_patterns, overflowing_literals, plugin_as_library, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `private_no_mangle_fns` has been removed: `no longer a warning, `#[no_mangle]` functions always exported` [INFO] [stdout] --> src/lib.rs:32:9 [INFO] [stdout] | [INFO] [stdout] 32 | private_no_mangle_fns, private_no_mangle_statics, stable_features, unconditional_recursion, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `private_no_mangle_statics` has been removed: `no longer a warning, `#[no_mangle]` statics always exported` [INFO] [stdout] --> src/lib.rs:32:32 [INFO] [stdout] | [INFO] [stdout] 32 | private_no_mangle_fns, private_no_mangle_statics, stable_features, unconditional_recursion, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `fat_ptr_transmutes` has been removed: `was accidentally removed back in 2014` [INFO] [stdout] --> src/lib.rs:37:24 [INFO] [stdout] | [INFO] [stdout] 37 | #![allow(box_pointers, fat_ptr_transmutes, missing_copy_implementations, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:114:32 [INFO] [stdout] | [INFO] [stdout] 114 | let serialised_value = try!(serialisation::serialise(value)); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:30:9 [INFO] [stdout] | [INFO] [stdout] 30 | #![deny(deprecated, drop_with_repr_extern, improper_ctypes, missing_docs, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:120:25 [INFO] [stdout] | [INFO] [stdout] 120 | let file_path = try!(self.file_path(key)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:141:25 [INFO] [stdout] | [INFO] [stdout] 141 | let file_path = try!(self.file_path(key)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:149:30 [INFO] [stdout] | [INFO] [stdout] 149 | match fs::File::open(try!(self.file_path(key))) { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:152:25 [INFO] [stdout] | [INFO] [stdout] 152 | let _ = try!(file.read_to_end(&mut contents)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:153:20 [INFO] [stdout] | [INFO] [stdout] 153 | Ok(try!(serialisation::deserialise::(&contents))) [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:208:24 [INFO] [stdout] | [INFO] [stdout] 208 | let filename = try!(serialisation::serialise(key)).to_hex(); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `#[macro_use]` import [INFO] [stdout] --> src/lib.rs:45:1 [INFO] [stdout] | [INFO] [stdout] 45 | #[macro_use] [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:33:37 [INFO] [stdout] | [INFO] [stdout] 33 | unknown_lints, unsafe_code, unused, unused_allocation, unused_attributes, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] = note: `#[warn(unused_imports)]` implied by `#[warn(unused)]` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused macro definition [INFO] [stdout] --> src/test.rs:18:1 [INFO] [stdout] | [INFO] [stdout] 18 | / macro_rules! assert_err { [INFO] [stdout] 19 | | ($cond : expr, $error : pat) => { [INFO] [stdout] 20 | | match $cond { [INFO] [stdout] 21 | | Err($error) => (), [INFO] [stdout] ... | [INFO] [stdout] 24 | | } [INFO] [stdout] 25 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:33:37 [INFO] [stdout] | [INFO] [stdout] 33 | unknown_lints, unsafe_code, unused, unused_allocation, unused_attributes, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] = note: `#[warn(unused_macros)]` implied by `#[warn(unused)]` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 15 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `exceeding_bitshifts` has been renamed to `arithmetic_overflow` [INFO] [stdout] --> src/lib.rs:28:22 [INFO] [stdout] | [INFO] [stdout] 28 | #![forbid(bad_style, exceeding_bitshifts, mutable_transmutes, no_mangle_const_items, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: use the new name: `arithmetic_overflow` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(renamed_and_removed_lints)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `drop_with_repr_extern` has been removed: `drop flags have been removed` [INFO] [stdout] --> src/lib.rs:30:21 [INFO] [stdout] | [INFO] [stdout] 30 | #![deny(deprecated, drop_with_repr_extern, improper_ctypes, missing_docs, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:29:32 [INFO] [stdout] | [INFO] [stdout] 29 | unknown_crate_types, warnings)] [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] = note: `#[warn(renamed_and_removed_lints)]` implied by `#[warn(warnings)]` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `plugin_as_library` has been removed: `plugins have been deprecated and retired` [INFO] [stdout] --> src/lib.rs:31:61 [INFO] [stdout] | [INFO] [stdout] 31 | non_shorthand_field_patterns, overflowing_literals, plugin_as_library, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `private_no_mangle_fns` has been removed: `no longer a warning, `#[no_mangle]` functions always exported` [INFO] [stdout] --> src/lib.rs:32:9 [INFO] [stdout] | [INFO] [stdout] 32 | private_no_mangle_fns, private_no_mangle_statics, stable_features, unconditional_recursion, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `private_no_mangle_statics` has been removed: `no longer a warning, `#[no_mangle]` statics always exported` [INFO] [stdout] --> src/lib.rs:32:32 [INFO] [stdout] | [INFO] [stdout] 32 | private_no_mangle_fns, private_no_mangle_statics, stable_features, unconditional_recursion, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lint `fat_ptr_transmutes` has been removed: `was accidentally removed back in 2014` [INFO] [stdout] --> src/lib.rs:37:24 [INFO] [stdout] | [INFO] [stdout] 37 | #![allow(box_pointers, fat_ptr_transmutes, missing_copy_implementations, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:114:32 [INFO] [stdout] | [INFO] [stdout] 114 | let serialised_value = try!(serialisation::serialise(value)); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/lib.rs:30:9 [INFO] [stdout] | [INFO] [stdout] 30 | #![deny(deprecated, drop_with_repr_extern, improper_ctypes, missing_docs, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:120:25 [INFO] [stdout] | [INFO] [stdout] 120 | let file_path = try!(self.file_path(key)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:141:25 [INFO] [stdout] | [INFO] [stdout] 141 | let file_path = try!(self.file_path(key)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:149:30 [INFO] [stdout] | [INFO] [stdout] 149 | match fs::File::open(try!(self.file_path(key))) { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:152:25 [INFO] [stdout] | [INFO] [stdout] 152 | let _ = try!(file.read_to_end(&mut contents)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:153:20 [INFO] [stdout] | [INFO] [stdout] 153 | Ok(try!(serialisation::deserialise::(&contents))) [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stdout] --> src/chunk_store.rs:208:24 [INFO] [stdout] | [INFO] [stdout] 208 | let filename = try!(serialisation::serialise(key)).to_hex(); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 13 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 3.33s [INFO] running `Command { std: "docker" "inspect" "b577d2c56bb60c72812222bf8a43ee9ca2d3428f2fe6a7a59efb20fba9c36b75", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "b577d2c56bb60c72812222bf8a43ee9ca2d3428f2fe6a7a59efb20fba9c36b75", kill_on_drop: false }` [INFO] [stdout] b577d2c56bb60c72812222bf8a43ee9ca2d3428f2fe6a7a59efb20fba9c36b75 [INFO] running `Command { std: "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@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+1.45.2" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] e40e376595325677d744ea106570aa38296ad5481a41400e5eb0fd0c2082a5bb [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "e40e376595325677d744ea106570aa38296ad5481a41400e5eb0fd0c2082a5bb", kill_on_drop: false }` [INFO] [stderr] warning: lint `exceeding_bitshifts` has been renamed to `arithmetic_overflow` [INFO] [stderr] --> src/lib.rs:28:22 [INFO] [stderr] | [INFO] [stderr] 28 | #![forbid(bad_style, exceeding_bitshifts, mutable_transmutes, no_mangle_const_items, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ help: use the new name: `arithmetic_overflow` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(renamed_and_removed_lints)]` on by default [INFO] [stderr] [INFO] [stderr] warning: lint `drop_with_repr_extern` has been removed: `drop flags have been removed` [INFO] [stderr] --> src/lib.rs:30:21 [INFO] [stderr] | [INFO] [stderr] 30 | #![deny(deprecated, drop_with_repr_extern, improper_ctypes, missing_docs, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] note: the lint level is defined here [INFO] [stderr] --> src/lib.rs:29:32 [INFO] [stderr] | [INFO] [stderr] 29 | unknown_crate_types, warnings)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] = note: `#[warn(renamed_and_removed_lints)]` implied by `#[warn(warnings)]` [INFO] [stderr] [INFO] [stderr] warning: lint `plugin_as_library` has been removed: `plugins have been deprecated and retired` [INFO] [stderr] --> src/lib.rs:31:61 [INFO] [stderr] | [INFO] [stderr] 31 | non_shorthand_field_patterns, overflowing_literals, plugin_as_library, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: lint `private_no_mangle_fns` has been removed: `no longer a warning, `#[no_mangle]` functions always exported` [INFO] [stderr] --> src/lib.rs:32:9 [INFO] [stderr] | [INFO] [stderr] 32 | private_no_mangle_fns, private_no_mangle_statics, stable_features, unconditional_recursion, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: lint `private_no_mangle_statics` has been removed: `no longer a warning, `#[no_mangle]` statics always exported` [INFO] [stderr] --> src/lib.rs:32:32 [INFO] [stderr] | [INFO] [stderr] 32 | private_no_mangle_fns, private_no_mangle_statics, stable_features, unconditional_recursion, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: lint `fat_ptr_transmutes` has been removed: `was accidentally removed back in 2014` [INFO] [stderr] --> src/lib.rs:37:24 [INFO] [stderr] | [INFO] [stderr] 37 | #![allow(box_pointers, fat_ptr_transmutes, missing_copy_implementations, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:114:32 [INFO] [stderr] | [INFO] [stderr] 114 | let serialised_value = try!(serialisation::serialise(value)); [INFO] [stderr] | ^^^ [INFO] [stderr] | [INFO] [stderr] note: the lint level is defined here [INFO] [stderr] --> src/lib.rs:30:9 [INFO] [stderr] | [INFO] [stderr] 30 | #![deny(deprecated, drop_with_repr_extern, improper_ctypes, missing_docs, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: lint `exceeding_bitshifts` has been renamed to `arithmetic_overflow` [INFO] [stderr] --> src/lib.rs:28:22 [INFO] [stderr] | [INFO] [stderr] 28 | #![forbid(bad_style, exceeding_bitshifts, mutable_transmutes, no_mangle_const_items, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ help: use the new name: `arithmetic_overflow` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(renamed_and_removed_lints)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:120:25 [INFO] [stderr] | [INFO] [stderr] 120 | let file_path = try!(self.file_path(key)); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:141:25 [INFO] [stderr] | [INFO] [stderr] 141 | let file_path = try!(self.file_path(key)); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:149:30 [INFO] [stderr] | [INFO] [stderr] 149 | match fs::File::open(try!(self.file_path(key))) { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: lint `drop_with_repr_extern` has been removed: `drop flags have been removed` [INFO] [stderr] --> src/lib.rs:30:21 [INFO] [stderr] | [INFO] [stderr] 30 | #![deny(deprecated, drop_with_repr_extern, improper_ctypes, missing_docs, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] note: the lint level is defined here [INFO] [stderr] --> src/lib.rs:29:32 [INFO] [stderr] | [INFO] [stderr] 29 | unknown_crate_types, warnings)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] = note: `#[warn(renamed_and_removed_lints)]` implied by `#[warn(warnings)]` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:152:25 [INFO] [stderr] | [INFO] [stderr] 152 | let _ = try!(file.read_to_end(&mut contents)); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: lint `plugin_as_library` has been removed: `plugins have been deprecated and retired` [INFO] [stderr] --> src/lib.rs:31:61 [INFO] [stderr] | [INFO] [stderr] 31 | non_shorthand_field_patterns, overflowing_literals, plugin_as_library, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:153:20 [INFO] [stderr] | [INFO] [stderr] 153 | Ok(try!(serialisation::deserialise::(&contents))) [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: lint `private_no_mangle_fns` has been removed: `no longer a warning, `#[no_mangle]` functions always exported` [INFO] [stderr] --> src/lib.rs:32:9 [INFO] [stderr] | [INFO] [stderr] 32 | private_no_mangle_fns, private_no_mangle_statics, stable_features, unconditional_recursion, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:208:24 [INFO] [stderr] | [INFO] [stderr] 208 | let filename = try!(serialisation::serialise(key)).to_hex(); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: lint `private_no_mangle_statics` has been removed: `no longer a warning, `#[no_mangle]` statics always exported` [INFO] [stderr] --> src/lib.rs:32:32 [INFO] [stderr] | [INFO] [stderr] 32 | private_no_mangle_fns, private_no_mangle_statics, stable_features, unconditional_recursion, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: 13 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: lint `fat_ptr_transmutes` has been removed: `was accidentally removed back in 2014` [INFO] [stderr] --> src/lib.rs:37:24 [INFO] [stderr] | [INFO] [stderr] 37 | #![allow(box_pointers, fat_ptr_transmutes, missing_copy_implementations, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:114:32 [INFO] [stderr] | [INFO] [stderr] 114 | let serialised_value = try!(serialisation::serialise(value)); [INFO] [stderr] | ^^^ [INFO] [stderr] | [INFO] [stderr] note: the lint level is defined here [INFO] [stderr] --> src/lib.rs:30:9 [INFO] [stderr] | [INFO] [stderr] 30 | #![deny(deprecated, drop_with_repr_extern, improper_ctypes, missing_docs, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:120:25 [INFO] [stderr] | [INFO] [stderr] 120 | let file_path = try!(self.file_path(key)); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:141:25 [INFO] [stderr] | [INFO] [stderr] 141 | let file_path = try!(self.file_path(key)); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:149:30 [INFO] [stderr] | [INFO] [stderr] 149 | match fs::File::open(try!(self.file_path(key))) { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:152:25 [INFO] [stderr] | [INFO] [stderr] 152 | let _ = try!(file.read_to_end(&mut contents)); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:153:20 [INFO] [stderr] | [INFO] [stderr] 153 | Ok(try!(serialisation::deserialise::(&contents))) [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead [INFO] [stderr] --> src/chunk_store.rs:208:24 [INFO] [stderr] | [INFO] [stderr] 208 | let filename = try!(serialisation::serialise(key)).to_hex(); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused `#[macro_use]` import [INFO] [stderr] --> src/lib.rs:45:1 [INFO] [stderr] | [INFO] [stderr] 45 | #[macro_use] [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] note: the lint level is defined here [INFO] [stderr] --> src/lib.rs:33:37 [INFO] [stderr] | [INFO] [stderr] 33 | unknown_lints, unsafe_code, unused, unused_allocation, unused_attributes, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] = note: `#[warn(unused_imports)]` implied by `#[warn(unused)]` [INFO] [stderr] [INFO] [stderr] warning: unused macro definition [INFO] [stderr] --> src/test.rs:18:1 [INFO] [stderr] | [INFO] [stderr] 18 | / macro_rules! assert_err { [INFO] [stderr] 19 | | ($cond : expr, $error : pat) => { [INFO] [stderr] 20 | | match $cond { [INFO] [stderr] 21 | | Err($error) => (), [INFO] [stderr] ... | [INFO] [stderr] 24 | | } [INFO] [stderr] 25 | | } [INFO] [stderr] | |_^ [INFO] [stderr] | [INFO] [stderr] note: the lint level is defined here [INFO] [stderr] --> src/lib.rs:33:37 [INFO] [stderr] | [INFO] [stderr] 33 | unknown_lints, unsafe_code, unused, unused_allocation, unused_attributes, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] = note: `#[warn(unused_macros)]` implied by `#[warn(unused)]` [INFO] [stderr] [INFO] [stderr] warning: 15 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.14s [INFO] [stderr] Running /opt/rustwide/target/debug/deps/chunk_store-83ac8e4349b1875a [INFO] [stdout] [INFO] [stdout] running 9 tests [INFO] [stdout] test test::test::failed_put_when_not_enough_space ... ok [INFO] [stdout] test test::test::tempdir_cleanup ... ok [INFO] [stdout] test test::test::get_fails_when_key_does_not_exist ... ok [INFO] [stdout] test test::test::create_multiple_instances_in_the_same_root ... ok [INFO] [stdout] test test::test::put_and_get_value_should_be_same ... ok [INFO] [stdout] test test::test::overwrite_value ... ok [INFO] [stdout] test test::test::delete ... ok [INFO] [stdout] test test::test::keys ... ok [INFO] [stdout] test test::test::successful_put ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 9 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] [stderr] Doc-tests chunk_store [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 `Command { std: "docker" "inspect" "e40e376595325677d744ea106570aa38296ad5481a41400e5eb0fd0c2082a5bb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e40e376595325677d744ea106570aa38296ad5481a41400e5eb0fd0c2082a5bb", kill_on_drop: false }` [INFO] [stdout] e40e376595325677d744ea106570aa38296ad5481a41400e5eb0fd0c2082a5bb