[INFO] fetching crate japi 0.3.2...
[INFO] testing japi-0.3.2 against master#c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38 for pr-146098-7
[INFO] extracting crate japi 0.3.2 into /workspace/builds/worker-3-tc1/source
[INFO] started tweaking crates.io crate japi 0.3.2
[INFO] finished tweaking crates.io crate japi 0.3.2
[INFO] tweaked toml for crates.io crate japi 0.3.2 written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate japi 0.3.2 on toolchain c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "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" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 11 packages to latest compatible versions
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] a317b81d2e50191ef18b27b2e905ec6c68ec960a60f70171b4386c8a215b2b13
[INFO] running `Command { std: "docker" "start" "-a" "a317b81d2e50191ef18b27b2e905ec6c68ec960a60f70171b4386c8a215b2b13", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "a317b81d2e50191ef18b27b2e905ec6c68ec960a60f70171b4386c8a215b2b13", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a317b81d2e50191ef18b27b2e905ec6c68ec960a60f70171b4386c8a215b2b13", kill_on_drop: false }`
[INFO] [stdout] a317b81d2e50191ef18b27b2e905ec6c68ec960a60f70171b4386c8a215b2b13
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 16ed2513948499783a96e8f2635ec664e737bcfaefd56e4df1787575c850f434
[INFO] running `Command { std: "docker" "start" "-a" "16ed2513948499783a96e8f2635ec664e737bcfaefd56e4df1787575c850f434", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.110
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling japi v0.3.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Deserialize`
[INFO] [stdout]  --> src/optional_vec.rs:1:31
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde_derive::{Serialize, Deserialize};
[INFO] [stdout]   |                               ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error`
[INFO] [stdout]  --> src/object/resource.rs:3:18
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json::{Error, Value, self};
[INFO] [stdout]   |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TryInto`
[INFO] [stdout]  --> src/object/resource.rs:4:29
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::convert::{TryFrom, TryInto};
[INFO] [stdout]   |                             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Links` and `Relationships`
[INFO] [stdout]  --> src/object/identifier.rs:1:19
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::{Meta, Relationships, Links, GenericObject, ResourceObject, Attributes};
[INFO] [stdout]   |                   ^^^^^^^^^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TryInto`
[INFO] [stdout]  --> src/object/identifier.rs:4:29
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::convert::{TryFrom, TryInto};
[INFO] [stdout]   |                             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Value`
[INFO] [stdout]  --> src/object/conversion_error.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 |     Value,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::Value`
[INFO] [stdout]  --> src/links.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json::Value;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserialize`
[INFO] [stdout]  --> src/optional.rs:1:31
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde_derive::{Serialize, Deserialize};
[INFO] [stdout]   |                               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error`
[INFO] [stdout]  --> src/optional.rs:2:62
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde::de::{DeserializeOwned, Deserializer, Deserialize, Error};
[INFO] [stdout]   |                                                              ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `id`
[INFO] [stdout]   --> src/object/resource.rs:86:14
[INFO] [stdout]    |
[INFO] [stdout] 86 |     fn links(id: &str) -> Option<Links> {
[INFO] [stdout]    |              ^^ help: if this is intentional, prefix it with an underscore: `_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 5.82s
[INFO] running `Command { std: "docker" "inspect" "16ed2513948499783a96e8f2635ec664e737bcfaefd56e4df1787575c850f434", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "16ed2513948499783a96e8f2635ec664e737bcfaefd56e4df1787575c850f434", kill_on_drop: false }`
[INFO] [stdout] 16ed2513948499783a96e8f2635ec664e737bcfaefd56e4df1787575c850f434
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b6298145d1fe906edfdf1288032337cd4d4631cecd3de918ff046ba628aba508
[INFO] running `Command { std: "docker" "start" "-a" "b6298145d1fe906edfdf1288032337cd4d4631cecd3de918ff046ba628aba508", kill_on_drop: false }`
[INFO] [stdout] warning: unused import: `Deserialize`
[INFO] [stdout]  --> src/optional_vec.rs:1:31
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde_derive::{Serialize, Deserialize};
[INFO] [stdout]   |                               ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error`
[INFO] [stdout]  --> src/object/resource.rs:3:18
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json::{Error, Value, self};
[INFO] [stdout]   |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TryInto`
[INFO] [stdout]  --> src/object/resource.rs:4:29
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::convert::{TryFrom, TryInto};
[INFO] [stdout]   |                             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Links` and `Relationships`
[INFO] [stdout]  --> src/object/identifier.rs:1:19
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::{Meta, Relationships, Links, GenericObject, ResourceObject, Attributes};
[INFO] [stdout]   |                   ^^^^^^^^^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TryInto`
[INFO] [stdout]  --> src/object/identifier.rs:4:29
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::convert::{TryFrom, TryInto};
[INFO] [stdout]   |                             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling japi v0.3.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Value`
[INFO] [stdout]  --> src/object/conversion_error.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 |     Value,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::Value`
[INFO] [stdout]  --> src/links.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json::Value;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserialize`
[INFO] [stdout]  --> src/optional.rs:1:31
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde_derive::{Serialize, Deserialize};
[INFO] [stdout]   |                               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error`
[INFO] [stdout]  --> src/optional.rs:2:62
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde::de::{DeserializeOwned, Deserializer, Deserialize, Error};
[INFO] [stdout]   |                                                              ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `id`
[INFO] [stdout]   --> src/object/resource.rs:86:14
[INFO] [stdout]    |
[INFO] [stdout] 86 |     fn links(id: &str) -> Option<Links> {
[INFO] [stdout]    |              ^^ help: if this is intentional, prefix it with an underscore: `_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Relationships`
[INFO] [stdout]  --> tests/article.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     Relationships, 
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `json`
[INFO] [stdout]   --> tests/article.rs:13:24
[INFO] [stdout]    |
[INFO] [stdout] 13 | use serde_json::{self, json};
[INFO] [stdout]    |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/object/generic.rs:137:10
[INFO] [stdout]     |
[INFO] [stdout] 137 |         };
[INFO] [stdout]     |          ^ help: remove this semicolon
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(redundant_semicolons)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error`
[INFO] [stdout]  --> src/object/resource.rs:3:18
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json::{Error, Value, self};
[INFO] [stdout]   |                  ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Links` and `Relationships`
[INFO] [stdout]  --> src/object/identifier.rs:1:19
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::{Meta, Relationships, Links, GenericObject, ResourceObject, Attributes};
[INFO] [stdout]   |                   ^^^^^^^^^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Value`
[INFO] [stdout]  --> src/object/conversion_error.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 |     Value,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::Value`
[INFO] [stdout]  --> src/links.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json::Value;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error`
[INFO] [stdout]  --> src/optional.rs:2:62
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde::de::{DeserializeOwned, Deserializer, Deserialize, Error};
[INFO] [stdout]   |                                                              ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this method call resolves to `<&[T; N] as IntoIterator>::into_iter` (due to backwards compatibility), but will resolve to `<[T; N] as IntoIterator>::into_iter` in Rust 2021
[INFO] [stdout]    --> tests/article.rs:123:30
[INFO] [stdout]     |
[INFO] [stdout] 123 |     included.extend(comments.into_iter().map(|v| GenericObject::from(v)));
[INFO] [stdout]     |                              ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this changes meaning in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/IntoIterator-for-arrays.html>
[INFO] [stdout]     = note: `#[warn(array_into_iter)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: use `.iter()` instead of `.into_iter()` to avoid ambiguity
[INFO] [stdout]     |
[INFO] [stdout] 123 -     included.extend(comments.into_iter().map(|v| GenericObject::from(v)));
[INFO] [stdout] 123 +     included.extend(comments.iter().map(|v| GenericObject::from(v)));
[INFO] [stdout]     |
[INFO] [stdout] help: or use `IntoIterator::into_iter(..)` instead of `.into_iter()` to explicitly iterate by value
[INFO] [stdout]     |
[INFO] [stdout] 123 -     included.extend(comments.into_iter().map(|v| GenericObject::from(v)));
[INFO] [stdout] 123 +     included.extend(IntoIterator::into_iter(comments).map(|v| GenericObject::from(v)));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `id`
[INFO] [stdout]   --> src/object/resource.rs:86:14
[INFO] [stdout]    |
[INFO] [stdout] 86 |     fn links(id: &str) -> Option<Links> {
[INFO] [stdout]    |              ^^ help: if this is intentional, prefix it with an underscore: `_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.39s
[INFO] running `Command { std: "docker" "inspect" "b6298145d1fe906edfdf1288032337cd4d4631cecd3de918ff046ba628aba508", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b6298145d1fe906edfdf1288032337cd4d4631cecd3de918ff046ba628aba508", kill_on_drop: false }`
[INFO] [stdout] b6298145d1fe906edfdf1288032337cd4d4631cecd3de918ff046ba628aba508
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 316167a8c76a740d9244f7d54d1695ab160a77a744840bd1111ff491dd7342d6
[INFO] running `Command { std: "docker" "start" "-a" "316167a8c76a740d9244f7d54d1695ab160a77a744840bd1111ff491dd7342d6", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `Deserialize`
[INFO] [stderr]  --> src/optional_vec.rs:1:31
[INFO] [stderr]   |
[INFO] [stderr] 1 | use serde_derive::{Serialize, Deserialize};
[INFO] [stderr]   |                               ^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Error`
[INFO] [stderr]  --> src/object/resource.rs:3:18
[INFO] [stderr]   |
[INFO] [stderr] 3 | use serde_json::{Error, Value, self};
[INFO] [stderr]   |                  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `TryInto`
[INFO] [stderr]  --> src/object/resource.rs:4:29
[INFO] [stderr]   |
[INFO] [stderr] 4 | use std::convert::{TryFrom, TryInto};
[INFO] [stderr]   |                             ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Links` and `Relationships`
[INFO] [stderr]  --> src/object/identifier.rs:1:19
[INFO] [stderr]   |
[INFO] [stderr] 1 | use crate::{Meta, Relationships, Links, GenericObject, ResourceObject, Attributes};
[INFO] [stderr]   |                   ^^^^^^^^^^^^^  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `TryInto`
[INFO] [stderr]  --> src/object/identifier.rs:4:29
[INFO] [stderr]   |
[INFO] [stderr] 4 | use std::convert::{TryFrom, TryInto};
[INFO] [stderr]   |                             ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Value`
[INFO] [stderr]  --> src/object/conversion_error.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 |     Value,
[INFO] [stderr]   |     ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `serde_json::Value`
[INFO] [stderr]  --> src/links.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use serde_json::Value;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Deserialize`
[INFO] [stderr]  --> src/optional.rs:1:31
[INFO] [stderr]   |
[INFO] [stderr] 1 | use serde_derive::{Serialize, Deserialize};
[INFO] [stderr]   |                               ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Error`
[INFO] [stderr]  --> src/optional.rs:2:62
[INFO] [stderr]   |
[INFO] [stderr] 2 | use serde::de::{DeserializeOwned, Deserializer, Deserialize, Error};
[INFO] [stderr]   |                                                              ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `id`
[INFO] [stderr]   --> src/object/resource.rs:86:14
[INFO] [stderr]    |
[INFO] [stderr] 86 |     fn links(id: &str) -> Option<Links> {
[INFO] [stderr]    |              ^^ help: if this is intentional, prefix it with an underscore: `_id`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary trailing semicolon
[INFO] [stderr]    --> src/object/generic.rs:137:10
[INFO] [stderr]     |
[INFO] [stderr] 137 |         };
[INFO] [stderr]     |          ^ help: remove this semicolon
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(redundant_semicolons)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Error`
[INFO] [stderr]  --> src/object/resource.rs:3:18
[INFO] [stderr]   |
[INFO] [stderr] 3 | use serde_json::{Error, Value, self};
[INFO] [stderr]   |                  ^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `japi` (lib) generated 10 warnings (run `cargo fix --lib -p japi` to apply 10 suggestions)
[INFO] [stderr] warning: `japi` (lib test) generated 7 warnings (5 duplicates) (run `cargo fix --lib -p japi --tests` to apply 1 suggestion)
[INFO] [stderr] warning: unused import: `Relationships`
[INFO] [stderr]  --> tests/article.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 |     Relationships, 
[INFO] [stderr]   |     ^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `json`
[INFO] [stderr]   --> tests/article.rs:13:24
[INFO] [stderr]    |
[INFO] [stderr] 13 | use serde_json::{self, json};
[INFO] [stderr]    |                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: this method call resolves to `<&[T; N] as IntoIterator>::into_iter` (due to backwards compatibility), but will resolve to `<[T; N] as IntoIterator>::into_iter` in Rust 2021
[INFO] [stderr]    --> tests/article.rs:123:30
[INFO] [stderr]     |
[INFO] [stderr] 123 |     included.extend(comments.into_iter().map(|v| GenericObject::from(v)));
[INFO] [stderr]     |                              ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this changes meaning in Rust 2021
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/IntoIterator-for-arrays.html>
[INFO] [stderr]     = note: `#[warn(array_into_iter)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stderr] help: use `.iter()` instead of `.into_iter()` to avoid ambiguity
[INFO] [stderr]     |
[INFO] [stderr] 123 -     included.extend(comments.into_iter().map(|v| GenericObject::from(v)));
[INFO] [stderr] 123 +     included.extend(comments.iter().map(|v| GenericObject::from(v)));
[INFO] [stderr]     |
[INFO] [stderr] help: or use `IntoIterator::into_iter(..)` instead of `.into_iter()` to explicitly iterate by value
[INFO] [stderr]     |
[INFO] [stderr] 123 -     included.extend(comments.into_iter().map(|v| GenericObject::from(v)));
[INFO] [stderr] 123 +     included.extend(IntoIterator::into_iter(comments).map(|v| GenericObject::from(v)));
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: `japi` (test "article") generated 3 warnings (run `cargo fix --test "article" -p japi` to apply 3 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.04s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/japi-62ed9d5400214520)
[INFO] [stdout] 
[INFO] [stdout] running 61 tests
[INFO] [stdout] test document::test::serde_empty ... ok
[INFO] [stdout] test document::test::serde_full ... ok
[INFO] [stdout] test error::error_test::serde_empty ... ok
[INFO] [stdout] test error::error_source_test::serde_empty ... ok
[INFO] [stdout] test jsonapi::test::serde_empty ... ok
[INFO] [stdout] test error::error_test::serde_full ... ok
[INFO] [stdout] test error::error_source_test::serde_full ... ok
[INFO] [stdout] test jsonapi::test::serde_full ... ok
[INFO] [stdout] test links::link_test::serde_object ... ok
[INFO] [stdout] test links::links_test::serde ... ok
[INFO] [stdout] test meta::test::serde ... ok
[INFO] [stdout] test object::generic::test::from_id ... ok
[INFO] [stdout] test object::generic::test::from_ro ... ok
[INFO] [stdout] test object::generic::test::serde_full ... ok
[INFO] [stdout] test object::generic::test::serde_empty ... ok
[INFO] [stdout] test links::link_test::serde_url ... ok
[INFO] [stdout] test object::identifier::test::from_go ... ok
[INFO] [stdout] test object::identifier::test::from_ro ... ok
[INFO] [stdout] test object::identifier::test::serde ... ok
[INFO] [stdout] test object::resource::test::from_go_fail_attributes ... ok
[INFO] [stdout] test object::resource::test::from_go_fail_type ... ok
[INFO] [stdout] test object::resource::test::from_go_success ... ok
[INFO] [stdout] test object::resource::test::from_id ... ok
[INFO] [stdout] test object::resource::test::from_id_fail ... ok
[INFO] [stdout] test optional::test::default ... ok
[INFO] [stdout] test optional::test::is ... ok
[INFO] [stdout] test optional::test::map ... ok
[INFO] [stdout] test optional::test::map_null ... ok
[INFO] [stdout] test optional::test::serde_not_present ... ok
[INFO] [stdout] test optional::test::serde_null ... ok
[INFO] [stdout] test optional::test::serde_present ... ok
[INFO] [stdout] test optional::test::test_as ... ok
[INFO] [stdout] test optional::test::unwrap_success ... ok
[INFO] [stdout] test optional_vec::test::into_vec ... ok
[INFO] [stdout] test optional_vec::test::is ... ok
[INFO] [stdout] test optional_vec::test::many_or ... ok
[INFO] [stdout] test optional_vec::test::map ... ok
[INFO] [stdout] test optional_vec::test::unwrap_many_many ... ok
[INFO] [stdout] test optional_vec::test::serde_to_many ... ok
[INFO] [stdout] test optional_vec::test::serde_empty_to_one ... ok
[INFO] [stdout] test optional_vec::test::one_or ... ok
[INFO] [stdout] test optional_vec::test::serde_not_present ... ok
[INFO] [stdout] test optional_vec::test::unwrap_one_some ... ok
[INFO] [stdout] test optional_vec::test::serde_to_one ... ok
[INFO] [stdout] test relationships::relationship_test::serde_full ... ok
[INFO] [stdout] test relationships::relationships_test::serde ... ok
[INFO] [stdout] test relationships::relationship_test::serde_empty ... ok
[INFO] [stdout] test optional::test::expect_not_present - should panic ... ok
[INFO] [stdout] test optional::test::expect_null - should panic ... ok
[INFO] [stdout] test optional::test::failed_deserialize - should panic ... ok
[INFO] [stdout] test optional::test::unwrap_not_present - should panic ... ok
[INFO] [stdout] test optional::test::unwrap_null - should panic ... ok
[INFO] [stdout] test optional::test::unwrap_or_else_null - should panic ... ok
[INFO] [stdout] test optional::test::unwrap_or_null - should panic ... ok
[INFO] [stdout] test optional_vec::test::failed_deserialize - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_many_not_present - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_many_none - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_many_some - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_one_many - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_one_none - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_one_not_present - should panic ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 61 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/article.rs (/opt/rustwide/target/debug/deps/article-fd3f64c961079ce5)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test test ... ok
[INFO] [stderr]    Doc-tests japi
[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" "316167a8c76a740d9244f7d54d1695ab160a77a744840bd1111ff491dd7342d6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "316167a8c76a740d9244f7d54d1695ab160a77a744840bd1111ff491dd7342d6", kill_on_drop: false }`
[INFO] [stdout] 316167a8c76a740d9244f7d54d1695ab160a77a744840bd1111ff491dd7342d6
