[INFO] fetching crate japi 0.3.2...
[INFO] testing japi-0.3.2 against try#c2e32f1c9652b13ed99608599c1e855462f421f3 for pr-146098-7
[INFO] extracting crate japi 0.3.2 into /workspace/builds/worker-3-tc2/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-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate japi 0.3.2 on toolchain c2e32f1c9652b13ed99608599c1e855462f421f3
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 6b7263c42d157cdb38234a2b7c0bc2635f162fd70d0ef22224d8533114ab5402
[INFO] running `Command { std: "docker" "start" "-a" "6b7263c42d157cdb38234a2b7c0bc2635f162fd70d0ef22224d8533114ab5402", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "6b7263c42d157cdb38234a2b7c0bc2635f162fd70d0ef22224d8533114ab5402", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6b7263c42d157cdb38234a2b7c0bc2635f162fd70d0ef22224d8533114ab5402", kill_on_drop: false }`
[INFO] [stdout] 6b7263c42d157cdb38234a2b7c0bc2635f162fd70d0ef22224d8533114ab5402
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2b728b75a4fbdbf4f02e5fa4bf80a04d4dd8dbe03ab5e133601e552983d47ebf
[INFO] running `Command { std: "docker" "start" "-a" "2b728b75a4fbdbf4f02e5fa4bf80a04d4dd8dbe03ab5e133601e552983d47ebf", 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.84s
[INFO] running `Command { std: "docker" "inspect" "2b728b75a4fbdbf4f02e5fa4bf80a04d4dd8dbe03ab5e133601e552983d47ebf", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2b728b75a4fbdbf4f02e5fa4bf80a04d4dd8dbe03ab5e133601e552983d47ebf", kill_on_drop: false }`
[INFO] [stdout] 2b728b75a4fbdbf4f02e5fa4bf80a04d4dd8dbe03ab5e133601e552983d47ebf
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d7b22935df16e61a4c8b763d07ecc38a871d4e2d429bf6ebf92261398cfbe140
[INFO] running `Command { std: "docker" "start" "-a" "d7b22935df16e61a4c8b763d07ecc38a871d4e2d429bf6ebf92261398cfbe140", kill_on_drop: false }`
[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] [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: 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: 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: 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 2.49s
[INFO] running `Command { std: "docker" "inspect" "d7b22935df16e61a4c8b763d07ecc38a871d4e2d429bf6ebf92261398cfbe140", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d7b22935df16e61a4c8b763d07ecc38a871d4e2d429bf6ebf92261398cfbe140", kill_on_drop: false }`
[INFO] [stdout] d7b22935df16e61a4c8b763d07ecc38a871d4e2d429bf6ebf92261398cfbe140
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] a203ab3aebb07ca6bb12c0fdf315f9f3799ee6856ba68b650980bc722ac79ac9
[INFO] running `Command { std: "docker" "start" "-a" "a203ab3aebb07ca6bb12c0fdf315f9f3799ee6856ba68b650980bc722ac79ac9", 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: `japi` (lib) generated 10 warnings (run `cargo fix --lib -p japi` to apply 10 suggestions)
[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: 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` (test "article") generated 3 warnings (run `cargo fix --test "article" -p japi` to apply 3 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]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.07s
[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 error::error_source_test::serde_full ... ok
[INFO] [stdout] test document::test::serde_full ... ok
[INFO] [stdout] test error::error_test::serde_empty ... ok
[INFO] [stdout] test error::error_test::serde_full ... ok
[INFO] [stdout] test jsonapi::test::serde_empty ... 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 links::link_test::serde_url ... ok
[INFO] [stdout] test object::generic::test::from_id ... ok
[INFO] [stdout] test meta::test::serde ... ok
[INFO] [stdout] test object::generic::test::from_ro ... ok
[INFO] [stdout] test object::generic::test::serde_empty ... ok
[INFO] [stdout] test object::generic::test::serde_full ... 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_fail ... ok
[INFO] [stdout] test object::resource::test::from_id ... ok
[INFO] [stdout] test optional::test::serde_present ... ok
[INFO] [stdout] test optional::test::is ... ok
[INFO] [stdout] test optional::test::test_as ... ok
[INFO] [stdout] test error::error_source_test::serde_empty ... ok
[INFO] [stdout] test optional::test::default ... ok
[INFO] [stdout] test optional::test::map_null ... ok
[INFO] [stdout] test optional::test::map ... ok
[INFO] [stdout] test optional::test::serde_not_present ... 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::one_or ... ok
[INFO] [stdout] test optional_vec::test::serde_empty_to_one ... ok
[INFO] [stdout] test optional_vec::test::serde_not_present ... ok
[INFO] [stdout] test optional_vec::test::serde_to_many ... ok
[INFO] [stdout] test optional_vec::test::serde_to_one ... ok
[INFO] [stdout] test optional_vec::test::unwrap_many_many ... ok
[INFO] [stdout] test optional_vec::test::unwrap_one_some ... ok
[INFO] [stdout] test relationships::relationship_test::serde_empty ... ok
[INFO] [stdout] test relationships::relationship_test::serde_full ... ok
[INFO] [stdout] test relationships::relationships_test::serde ... ok
[INFO] [stdout] test optional::test::serde_null ... ok
[INFO] [stdout] test optional::test::expect_not_present - 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_none - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_many_not_present - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_one_many - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_one_not_present - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_one_none - should panic ... ok
[INFO] [stdout] test optional::test::expect_null - should panic ... ok
[INFO] [stdout] test optional_vec::test::unwrap_many_some - should panic ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 61 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.05s
[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" "a203ab3aebb07ca6bb12c0fdf315f9f3799ee6856ba68b650980bc722ac79ac9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a203ab3aebb07ca6bb12c0fdf315f9f3799ee6856ba68b650980bc722ac79ac9", kill_on_drop: false }`
[INFO] [stdout] a203ab3aebb07ca6bb12c0fdf315f9f3799ee6856ba68b650980bc722ac79ac9
