[INFO] fetching crate riffy 0.1.1...
[INFO] testing riffy-0.1.1 against 1.95.0 for beta-1.96-2
[INFO] extracting crate riffy 0.1.1 into /workspace/builds/worker-7-tc1/source
[INFO] started tweaking crates.io crate riffy 0.1.1
[INFO] finished tweaking crates.io crate riffy 0.1.1
[INFO] tweaked toml for crates.io crate riffy 0.1.1 written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate riffy 0.1.1 on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 71 packages to latest compatible versions
[INFO] [stderr]       Adding criterion v0.3.6 (available: v0.8.2)
[INFO] [stderr]       Adding rand v0.8.6 (available: v0.10.1)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded criterion-plot v0.4.5
[INFO] [stderr]   Downloaded criterion v0.3.6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] bbb25bc821f08f2a5c8d0d8ec2053915c0936b8932e4ae2d2d6e7bb9c53ea32e
[INFO] running `Command { std: "docker" "start" "-a" "bbb25bc821f08f2a5c8d0d8ec2053915c0936b8932e4ae2d2d6e7bb9c53ea32e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "bbb25bc821f08f2a5c8d0d8ec2053915c0936b8932e4ae2d2d6e7bb9c53ea32e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "bbb25bc821f08f2a5c8d0d8ec2053915c0936b8932e4ae2d2d6e7bb9c53ea32e", kill_on_drop: false }`
[INFO] [stdout] bbb25bc821f08f2a5c8d0d8ec2053915c0936b8932e4ae2d2d6e7bb9c53ea32e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/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" "RUSTDOCFLAGS=--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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5d6a9642bcad0770109a44f1975c40c51305f2170ef6c7120971fca4d1923c40
[INFO] running `Command { std: "docker" "start" "-a" "5d6a9642bcad0770109a44f1975c40c51305f2170ef6c7120971fca4d1923c40", kill_on_drop: false }`
[INFO] [stderr]    Compiling riffy v0.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::AtomicPtr::<T>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/lib.rs:246:40
[INFO] [stdout]     |
[INFO] [stdout] 246 |                     self.tail_of_queue.compare_and_swap(
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 0.27s
[INFO] running `Command { std: "docker" "inspect" "5d6a9642bcad0770109a44f1975c40c51305f2170ef6c7120971fca4d1923c40", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5d6a9642bcad0770109a44f1975c40c51305f2170ef6c7120971fca4d1923c40", kill_on_drop: false }`
[INFO] [stdout] 5d6a9642bcad0770109a44f1975c40c51305f2170ef6c7120971fca4d1923c40
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/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" "RUSTDOCFLAGS=--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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cc1fde4f0f0addd87e91f3d016440cc589ccfc5f7860ed89feb0d5497a788c16
[INFO] running `Command { std: "docker" "start" "-a" "cc1fde4f0f0addd87e91f3d016440cc589ccfc5f7860ed89feb0d5497a788c16", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling regex-syntax v0.8.10
[INFO] [stderr]    Compiling plotters-backend v0.3.7
[INFO] [stderr]    Compiling textwrap v0.11.0
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling plotters-svg v0.3.7
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling csv-core v0.1.13
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]    Compiling cast v0.3.0
[INFO] [stderr]    Compiling half v1.8.3
[INFO] [stderr]    Compiling walkdir v2.5.0
[INFO] [stderr]    Compiling clap v2.34.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rayon v1.12.0
[INFO] [stderr]    Compiling atty v0.2.14
[INFO] [stderr]    Compiling oorandom v11.1.5
[INFO] [stderr]    Compiling plotters v0.3.7
[INFO] [stderr]    Compiling rand v0.8.6
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling criterion-plot v0.4.5
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::AtomicPtr::<T>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/lib.rs:246:40
[INFO] [stdout]     |
[INFO] [stdout] 246 |                     self.tail_of_queue.compare_and_swap(
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling csv v1.4.0
[INFO] [stderr]    Compiling serde_cbor v0.11.2
[INFO] [stderr]    Compiling tinytemplate v1.2.1
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling criterion v0.3.6
[INFO] [stderr]    Compiling riffy v0.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: use of deprecated method `std::sync::atomic::AtomicPtr::<T>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stdout]    --> src/lib.rs:246:40
[INFO] [stdout]     |
[INFO] [stdout] 246 |                     self.tail_of_queue.compare_and_swap(
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stdout]    --> src/lib.rs:590:38
[INFO] [stdout]     |
[INFO] [stdout] 590 |             assert_eq!(State::Empty, (*q.head_of_queue.get()).nodes[0].state());
[INFO] [stdout]     |                                      ^^---------------------^^^^^^^^^^
[INFO] [stdout]     |                                        |
[INFO] [stdout]     |                                        this raw pointer has type `*mut BufferList<i32>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stdout] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stdout]    --> src/lib.rs:590:38
[INFO] [stdout]     |
[INFO] [stdout] 590 |             assert_eq!(State::Empty, (*q.head_of_queue.get()).nodes[0].state());
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(dangerous_implicit_autorefs)]` on by default
[INFO] [stdout] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stdout]     |
[INFO] [stdout] 590 |             assert_eq!(State::Empty, (&(*q.head_of_queue.get()).nodes)[0].state());
[INFO] [stdout]     |                                      ++                              +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stdout]    --> src/lib.rs:593:38
[INFO] [stdout]     |
[INFO] [stdout] 593 |             assert_eq!(State::Empty, (*q.head_of_queue.get()).nodes[1].state());
[INFO] [stdout]     |                                      ^^---------------------^^^^^^^^^^
[INFO] [stdout]     |                                        |
[INFO] [stdout]     |                                        this raw pointer has type `*mut BufferList<i32>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stdout] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stdout]    --> src/lib.rs:593:38
[INFO] [stdout]     |
[INFO] [stdout] 593 |             assert_eq!(State::Empty, (*q.head_of_queue.get()).nodes[1].state());
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stdout]     |
[INFO] [stdout] 593 |             assert_eq!(State::Empty, (&(*q.head_of_queue.get()).nodes)[1].state());
[INFO] [stdout]     |                                      ++                              +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stdout]    --> src/lib.rs:600:28
[INFO] [stdout]     |
[INFO] [stdout] 600 |             assert_eq!(42, (*q.head_of_queue.get()).nodes[0].data.assume_init());
[INFO] [stdout]     |                            ^^---------------------^^^^^^^^^^
[INFO] [stdout]     |                              |
[INFO] [stdout]     |                              this raw pointer has type `*mut BufferList<i32>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stdout] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stdout]    --> src/lib.rs:600:28
[INFO] [stdout]     |
[INFO] [stdout] 600 |             assert_eq!(42, (*q.head_of_queue.get()).nodes[0].data.assume_init());
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stdout]     |
[INFO] [stdout] 600 |             assert_eq!(42, (&(*q.head_of_queue.get()).nodes)[0].data.assume_init());
[INFO] [stdout]     |                            ++                              +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stdout]    --> src/lib.rs:603:36
[INFO] [stdout]     |
[INFO] [stdout] 603 |             assert_eq!(State::Set, (*q.head_of_queue.get()).nodes[0].state());
[INFO] [stdout]     |                                    ^^---------------------^^^^^^^^^^
[INFO] [stdout]     |                                      |
[INFO] [stdout]     |                                      this raw pointer has type `*mut BufferList<i32>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stdout] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stdout]    --> src/lib.rs:603:36
[INFO] [stdout]     |
[INFO] [stdout] 603 |             assert_eq!(State::Set, (*q.head_of_queue.get()).nodes[0].state());
[INFO] [stdout]     |                                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stdout]     |
[INFO] [stdout] 603 |             assert_eq!(State::Set, (&(*q.head_of_queue.get()).nodes)[0].state());
[INFO] [stdout]     |                                    ++                              +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stdout]    --> src/lib.rs:606:28
[INFO] [stdout]     |
[INFO] [stdout] 606 |             assert_eq!(43, (*q.head_of_queue.get()).nodes[1].data.assume_init());
[INFO] [stdout]     |                            ^^---------------------^^^^^^^^^^
[INFO] [stdout]     |                              |
[INFO] [stdout]     |                              this raw pointer has type `*mut BufferList<i32>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stdout] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stdout]    --> src/lib.rs:606:28
[INFO] [stdout]     |
[INFO] [stdout] 606 |             assert_eq!(43, (*q.head_of_queue.get()).nodes[1].data.assume_init());
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stdout]     |
[INFO] [stdout] 606 |             assert_eq!(43, (&(*q.head_of_queue.get()).nodes)[1].data.assume_init());
[INFO] [stdout]     |                            ++                              +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stdout]    --> src/lib.rs:609:36
[INFO] [stdout]     |
[INFO] [stdout] 609 |             assert_eq!(State::Set, (*q.head_of_queue.get()).nodes[1].state());
[INFO] [stdout]     |                                    ^^---------------------^^^^^^^^^^
[INFO] [stdout]     |                                      |
[INFO] [stdout]     |                                      this raw pointer has type `*mut BufferList<i32>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stdout] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stdout]    --> src/lib.rs:609:36
[INFO] [stdout]     |
[INFO] [stdout] 609 |             assert_eq!(State::Set, (*q.head_of_queue.get()).nodes[1].state());
[INFO] [stdout]     |                                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stdout]     |
[INFO] [stdout] 609 |             assert_eq!(State::Set, (&(*q.head_of_queue.get()).nodes)[1].state());
[INFO] [stdout]     |                                    ++                              +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stdout]    --> src/lib.rs:627:35
[INFO] [stdout]     |
[INFO] [stdout] 627 |                     assert_eq!(i, (*q.head_of_queue.get()).nodes[index].data.assume_init());
[INFO] [stdout]     |                                   ^^---------------------^^^^^^^^^^^^^^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     this raw pointer has type `*mut BufferList<usize>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stdout] note: autoref is being applied to this expression, resulting in: `&Vec<Node<usize>>`
[INFO] [stdout]    --> src/lib.rs:627:35
[INFO] [stdout]     |
[INFO] [stdout] 627 |                     assert_eq!(i, (*q.head_of_queue.get()).nodes[index].data.assume_init());
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stdout]     |
[INFO] [stdout] 627 |                     assert_eq!(i, (&(*q.head_of_queue.get()).nodes)[index].data.assume_init());
[INFO] [stdout]     |                                   ++                              +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stdout]    --> src/lib.rs:633:25
[INFO] [stdout]     |
[INFO] [stdout] 633 |                         (*q.tail_of_queue.load(Ordering::SeqCst)).nodes[index]
[INFO] [stdout]     |                         ^^--------------------------------------^^^^^^^^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           this raw pointer has type `*mut BufferList<usize>`
[INFO] [stdout]     |
[INFO] [stdout]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stdout] note: autoref is being applied to this expression, resulting in: `&Vec<Node<usize>>`
[INFO] [stdout]    --> src/lib.rs:633:25
[INFO] [stdout]     |
[INFO] [stdout] 633 |                         (*q.tail_of_queue.load(Ordering::SeqCst)).nodes[index]
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stdout]     |
[INFO] [stdout] 633 |                         (&(*q.tail_of_queue.load(Ordering::SeqCst)).nodes)[index]
[INFO] [stdout]     |                         ++                                               +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 44.98s
[INFO] running `Command { std: "docker" "inspect" "cc1fde4f0f0addd87e91f3d016440cc589ccfc5f7860ed89feb0d5497a788c16", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cc1fde4f0f0addd87e91f3d016440cc589ccfc5f7860ed89feb0d5497a788c16", kill_on_drop: false }`
[INFO] [stdout] cc1fde4f0f0addd87e91f3d016440cc589ccfc5f7860ed89feb0d5497a788c16
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/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" "RUSTDOCFLAGS=--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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 5d9d153de61441e0e030e300ae709bab36f41e5e9c023f88ecf3100bea005c94
[INFO] running `Command { std: "docker" "start" "-a" "5d9d153de61441e0e030e300ae709bab36f41e5e9c023f88ecf3100bea005c94", kill_on_drop: false }`
[INFO] [stderr] warning: use of deprecated method `std::sync::atomic::AtomicPtr::<T>::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead
[INFO] [stderr]    --> src/lib.rs:246:40
[INFO] [stderr]     |
[INFO] [stderr] 246 |                     self.tail_of_queue.compare_and_swap(
[INFO] [stderr]     |                                        ^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `riffy` (lib) generated 1 warning
[INFO] [stderr] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stderr]    --> src/lib.rs:590:38
[INFO] [stderr]     |
[INFO] [stderr] 590 |             assert_eq!(State::Empty, (*q.head_of_queue.get()).nodes[0].state());
[INFO] [stderr]     |                                      ^^---------------------^^^^^^^^^^
[INFO] [stderr]     |                                        |
[INFO] [stderr]     |                                        this raw pointer has type `*mut BufferList<i32>`
[INFO] [stderr]     |
[INFO] [stderr]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stderr] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stderr]    --> src/lib.rs:590:38
[INFO] [stderr]     |
[INFO] [stderr] 590 |             assert_eq!(State::Empty, (*q.head_of_queue.get()).nodes[0].state());
[INFO] [stderr]     |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     = note: `#[warn(dangerous_implicit_autorefs)]` on by default
[INFO] [stderr] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stderr]     |
[INFO] [stderr] 590 |             assert_eq!(State::Empty, (&(*q.head_of_queue.get()).nodes)[0].state());
[INFO] [stderr]     |                                      ++                              +
[INFO] [stderr] 
[INFO] [stderr] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stderr]    --> src/lib.rs:593:38
[INFO] [stderr]     |
[INFO] [stderr] 593 |             assert_eq!(State::Empty, (*q.head_of_queue.get()).nodes[1].state());
[INFO] [stderr]     |                                      ^^---------------------^^^^^^^^^^
[INFO] [stderr]     |                                        |
[INFO] [stderr]     |                                        this raw pointer has type `*mut BufferList<i32>`
[INFO] [stderr]     |
[INFO] [stderr]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stderr] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stderr]    --> src/lib.rs:593:38
[INFO] [stderr]     |
[INFO] [stderr] 593 |             assert_eq!(State::Empty, (*q.head_of_queue.get()).nodes[1].state());
[INFO] [stderr]     |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stderr]     |
[INFO] [stderr] 593 |             assert_eq!(State::Empty, (&(*q.head_of_queue.get()).nodes)[1].state());
[INFO] [stderr]     |                                      ++                              +
[INFO] [stderr] 
[INFO] [stderr] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stderr]    --> src/lib.rs:600:28
[INFO] [stderr]     |
[INFO] [stderr] 600 |             assert_eq!(42, (*q.head_of_queue.get()).nodes[0].data.assume_init());
[INFO] [stderr]     |                            ^^---------------------^^^^^^^^^^
[INFO] [stderr]     |                              |
[INFO] [stderr]     |                              this raw pointer has type `*mut BufferList<i32>`
[INFO] [stderr]     |
[INFO] [stderr]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stderr] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stderr]    --> src/lib.rs:600:28
[INFO] [stderr]     |
[INFO] [stderr] 600 |             assert_eq!(42, (*q.head_of_queue.get()).nodes[0].data.assume_init());
[INFO] [stderr]     |                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stderr]     |
[INFO] [stderr] 600 |             assert_eq!(42, (&(*q.head_of_queue.get()).nodes)[0].data.assume_init());
[INFO] [stderr]     |                            ++                              +
[INFO] [stderr] 
[INFO] [stderr] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stderr]    --> src/lib.rs:603:36
[INFO] [stderr]     |
[INFO] [stderr] 603 |             assert_eq!(State::Set, (*q.head_of_queue.get()).nodes[0].state());
[INFO] [stderr]     |                                    ^^---------------------^^^^^^^^^^
[INFO] [stderr]     |                                      |
[INFO] [stderr]     |                                      this raw pointer has type `*mut BufferList<i32>`
[INFO] [stderr]     |
[INFO] [stderr]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stderr] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stderr]    --> src/lib.rs:603:36
[INFO] [stderr]     |
[INFO] [stderr] 603 |             assert_eq!(State::Set, (*q.head_of_queue.get()).nodes[0].state());
[INFO] [stderr]     |                                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stderr]     |
[INFO] [stderr] 603 |             assert_eq!(State::Set, (&(*q.head_of_queue.get()).nodes)[0].state());
[INFO] [stderr]     |                                    ++                              +
[INFO] [stderr] 
[INFO] [stderr] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stderr]    --> src/lib.rs:606:28
[INFO] [stderr]     |
[INFO] [stderr] 606 |             assert_eq!(43, (*q.head_of_queue.get()).nodes[1].data.assume_init());
[INFO] [stderr]     |                            ^^---------------------^^^^^^^^^^
[INFO] [stderr]     |                              |
[INFO] [stderr]     |                              this raw pointer has type `*mut BufferList<i32>`
[INFO] [stderr]     |
[INFO] [stderr]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stderr] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stderr]    --> src/lib.rs:606:28
[INFO] [stderr]     |
[INFO] [stderr] 606 |             assert_eq!(43, (*q.head_of_queue.get()).nodes[1].data.assume_init());
[INFO] [stderr]     |                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stderr]     |
[INFO] [stderr] 606 |             assert_eq!(43, (&(*q.head_of_queue.get()).nodes)[1].data.assume_init());
[INFO] [stderr]     |                            ++                              +
[INFO] [stderr] 
[INFO] [stderr] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stderr]    --> src/lib.rs:609:36
[INFO] [stderr]     |
[INFO] [stderr] 609 |             assert_eq!(State::Set, (*q.head_of_queue.get()).nodes[1].state());
[INFO] [stderr]     |                                    ^^---------------------^^^^^^^^^^
[INFO] [stderr]     |                                      |
[INFO] [stderr]     |                                      this raw pointer has type `*mut BufferList<i32>`
[INFO] [stderr]     |
[INFO] [stderr]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stderr] note: autoref is being applied to this expression, resulting in: `&Vec<Node<i32>>`
[INFO] [stderr]    --> src/lib.rs:609:36
[INFO] [stderr]     |
[INFO] [stderr] 609 |             assert_eq!(State::Set, (*q.head_of_queue.get()).nodes[1].state());
[INFO] [stderr]     |                                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stderr]     |
[INFO] [stderr] 609 |             assert_eq!(State::Set, (&(*q.head_of_queue.get()).nodes)[1].state());
[INFO] [stderr]     |                                    ++                              +
[INFO] [stderr] 
[INFO] [stderr] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stderr]    --> src/lib.rs:627:35
[INFO] [stderr]     |
[INFO] [stderr] 627 |                     assert_eq!(i, (*q.head_of_queue.get()).nodes[index].data.assume_init());
[INFO] [stderr]     |                                   ^^---------------------^^^^^^^^^^^^^^
[INFO] [stderr]     |                                     |
[INFO] [stderr]     |                                     this raw pointer has type `*mut BufferList<usize>`
[INFO] [stderr]     |
[INFO] [stderr]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stderr] note: autoref is being applied to this expression, resulting in: `&Vec<Node<usize>>`
[INFO] [stderr]    --> src/lib.rs:627:35
[INFO] [stderr]     |
[INFO] [stderr] 627 |                     assert_eq!(i, (*q.head_of_queue.get()).nodes[index].data.assume_init());
[INFO] [stderr]     |                                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stderr]     |
[INFO] [stderr] 627 |                     assert_eq!(i, (&(*q.head_of_queue.get()).nodes)[index].data.assume_init());
[INFO] [stderr]     |                                   ++                              +
[INFO] [stderr] 
[INFO] [stderr] warning: implicit autoref creates a reference to the dereference of a raw pointer
[INFO] [stderr]    --> src/lib.rs:633:25
[INFO] [stderr]     |
[INFO] [stderr] 633 |                         (*q.tail_of_queue.load(Ordering::SeqCst)).nodes[index]
[INFO] [stderr]     |                         ^^--------------------------------------^^^^^^^^^^^^^^
[INFO] [stderr]     |                           |
[INFO] [stderr]     |                           this raw pointer has type `*mut BufferList<usize>`
[INFO] [stderr]     |
[INFO] [stderr]     = note: creating a reference requires the pointer target to be valid and imposes aliasing requirements
[INFO] [stderr] note: autoref is being applied to this expression, resulting in: `&Vec<Node<usize>>`
[INFO] [stderr]    --> src/lib.rs:633:25
[INFO] [stderr]     |
[INFO] [stderr] 633 |                         (*q.tail_of_queue.load(Ordering::SeqCst)).nodes[index]
[INFO] [stderr]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] help: try using a raw pointer method instead; or if this reference is intentional, make it explicit
[INFO] [stderr]     |
[INFO] [stderr] 633 |                         (&(*q.tail_of_queue.load(Ordering::SeqCst)).nodes)[index]
[INFO] [stderr]     |                         ++                                               +
[INFO] [stderr] 
[INFO] [stderr] warning: `riffy` (lib test) generated 9 warnings (1 duplicate)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.18s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/riffy-eb0bc1f82d21411d)
[INFO] [stdout] 
[INFO] [stdout] running 6 tests
[INFO] [stdout] test tests::enqueue ... ok
[INFO] [stdout] test tests::enqueue_exceeds_buffer ... ok
[INFO] [stdout] test tests::dequeue ... ok
[INFO] [stdout] test tests::dequeue_exceeds_buffer ... ok
[INFO] [stdout] test tests::multi_threaded_direct ... ok
[INFO] [stdout] test tests::multi_threaded_channel ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests riffy
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test src/lib.rs - MpscQueue (line 141) ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.26s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "5d9d153de61441e0e030e300ae709bab36f41e5e9c023f88ecf3100bea005c94", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5d9d153de61441e0e030e300ae709bab36f41e5e9c023f88ecf3100bea005c94", kill_on_drop: false }`
[INFO] [stdout] 5d9d153de61441e0e030e300ae709bab36f41e5e9c023f88ecf3100bea005c94
