[INFO] fetching crate open-library 0.7.1...
[INFO] testing open-library-0.7.1 against 1.90.0 for beta-1.91-3
[INFO] extracting crate open-library 0.7.1 into /workspace/builds/worker-5-tc1/source
[INFO] started tweaking crates.io crate open-library 0.7.1
[INFO] finished tweaking crates.io crate open-library 0.7.1
[INFO] tweaked toml for crates.io crate open-library 0.7.1 written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate open-library 0.7.1 on toolchain 1.90.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.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.90.0" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 215 packages to latest compatible versions
[INFO] [stderr]       Adding http v0.2.12 (available: v1.3.1)
[INFO] [stderr]       Adding itertools v0.10.5 (available: v0.14.0)
[INFO] [stderr]       Adding reqwest v0.11.27 (available: v0.12.23)
[INFO] [stderr]       Adding test-case v1.2.1 (available: v1.2.3)
[INFO] [stderr]       Adding thiserror v1.0.69 (available: v2.0.17)
[INFO] [stderr]       Adding wiremock v0.5.22 (available: v0.6.5)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded assert-json-diff v2.0.2
[INFO] [stderr]   Downloaded wiremock v0.5.22
[INFO] [stderr]   Downloaded test-case v1.2.1
[INFO] [stderr]   Downloaded retain_mut v0.1.9
[INFO] [stderr]   Downloaded deadpool-runtime v0.1.4
[INFO] [stderr]   Downloaded infer v0.2.3
[INFO] [stderr]   Downloaded deadpool v0.9.5
[INFO] [stderr]   Downloaded serde_qs v0.8.5
[INFO] [stderr]   Downloaded http-types v2.12.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 6a86cf3683edeb8fd86325e4c7a63d120439ad107754f3bf3436a04ce3108117
[INFO] running `Command { std: "docker" "start" "-a" "6a86cf3683edeb8fd86325e4c7a63d120439ad107754f3bf3436a04ce3108117", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "6a86cf3683edeb8fd86325e4c7a63d120439ad107754f3bf3436a04ce3108117", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6a86cf3683edeb8fd86325e4c7a63d120439ad107754f3bf3436a04ce3108117", kill_on_drop: false }`
[INFO] [stdout] 6a86cf3683edeb8fd86325e4c7a63d120439ad107754f3bf3436a04ce3108117
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 178c1b2eee9b35392b11df37437f50cb7e90ffb34faa7631f4122b758af4123c
[INFO] running `Command { std: "docker" "start" "-a" "178c1b2eee9b35392b11df37437f50cb7e90ffb34faa7631f4122b758af4123c", kill_on_drop: false }`
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling memchr v2.7.6
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling tokio-util v0.7.16
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling hyper-tls v0.5.0
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling open-library v0.7.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `crate::format::KeyedValue`
[INFO] [stdout]  --> src/models/works.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::format::KeyedValue;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AuthorType`
[INFO] [stdout]  --> src/models/works.rs:2:47
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::models::authors::{AuthorReference, AuthorType};
[INFO] [stdout]   |                                               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::NaiveDate`
[INFO] [stdout]  --> src/models/works.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::NaiveDate;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserializer`
[INFO] [stdout]  --> src/models/works.rs:5:26
[INFO] [stdout]   |
[INFO] [stdout] 5 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::datetime_from_str`: use `DateTime::parse_from_str` or `NaiveDateTime::parse_from_str` with `and_utc()` or `and_local_timezone()` instead
[INFO] [stdout]   --> src/format.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |         Utc.datetime_from_str(&String::deserialize(deserializer)?, FORMAT)
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORMAT` is never used
[INFO] [stdout]   --> src/format.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 |     const FORMAT: &str = "%d %B %Y";
[INFO] [stdout]    |           ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/format.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub fn serialize<S>(date: &NaiveDate, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/format.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn deserialize<'de, D>(deserializer: D) -> Result<NaiveDate, D::Error>
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORMAT` is never used
[INFO] [stdout]   --> src/format.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 |     const FORMAT: &str = "%B %d, %Y";
[INFO] [stdout]    |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/format.rs:56:12
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn serialize<S>(date: &NaiveDate, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/format.rs:64:12
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub fn deserialize<'de, D>(deserializer: D) -> Result<NaiveDate, D::Error>
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/format.rs:82:12
[INFO] [stdout]    |
[INFO] [stdout] 82 |     pub fn serialize<S, T>(value: &T, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/format.rs:90:12
[INFO] [stdout]    |
[INFO] [stdout] 90 |     pub fn deserialize<'de, D, T>(deserializer: D) -> Result<T, D::Error>
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]    --> src/format.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub fn serialize<S, T>(values: &[T], serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]    --> src/format.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout] 115 |     pub fn deserialize<'de, D, T>(deserializer: D) -> Result<Vec<T>, D::Error>
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 21.63s
[INFO] running `Command { std: "docker" "inspect" "178c1b2eee9b35392b11df37437f50cb7e90ffb34faa7631f4122b758af4123c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "178c1b2eee9b35392b11df37437f50cb7e90ffb34faa7631f4122b758af4123c", kill_on_drop: false }`
[INFO] [stdout] 178c1b2eee9b35392b11df37437f50cb7e90ffb34faa7631f4122b758af4123c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7b1242f45f95c58cb90a7f72efadac60d18108356caa906e5e166a2a666c1818
[INFO] running `Command { std: "docker" "start" "-a" "7b1242f45f95c58cb90a7f72efadac60d18108356caa906e5e166a2a666c1818", kill_on_drop: false }`
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling anyhow v1.0.100
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling http-types v2.12.0
[INFO] [stderr]    Compiling event-listener v2.5.3
[INFO] [stderr]    Compiling waker-fn v1.2.0
[INFO] [stderr]    Compiling regex-syntax v0.8.6
[INFO] [stderr]    Compiling parking v2.2.1
[INFO] [stderr]    Compiling fastrand v1.9.0
[INFO] [stderr]    Compiling test-case v1.2.1
[INFO] [stderr]    Compiling serde_qs v0.8.5
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling retain_mut v0.1.9
[INFO] [stderr]    Compiling deadpool-runtime v0.1.4
[INFO] [stderr]    Compiling infer v0.2.3
[INFO] [stderr]    Compiling assert-json-diff v2.0.2
[INFO] [stderr]    Compiling futures-timer v3.0.3
[INFO] [stdout] warning: unused import: `crate::format::KeyedValue`
[INFO] [stdout]  --> src/models/works.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::format::KeyedValue;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AuthorType`
[INFO] [stdout]  --> src/models/works.rs:2:47
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::models::authors::{AuthorReference, AuthorType};
[INFO] [stdout]   |                                               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::NaiveDate`
[INFO] [stdout]  --> src/models/works.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::NaiveDate;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserializer`
[INFO] [stdout]  --> src/models/works.rs:5:26
[INFO] [stdout]   |
[INFO] [stdout] 5 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::datetime_from_str`: use `DateTime::parse_from_str` or `NaiveDateTime::parse_from_str` with `and_utc()` or `and_local_timezone()` instead
[INFO] [stdout]   --> src/format.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |         Utc.datetime_from_str(&String::deserialize(deserializer)?, FORMAT)
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORMAT` is never used
[INFO] [stdout]   --> src/format.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 |     const FORMAT: &str = "%d %B %Y";
[INFO] [stdout]    |           ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/format.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub fn serialize<S>(date: &NaiveDate, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/format.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn deserialize<'de, D>(deserializer: D) -> Result<NaiveDate, D::Error>
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORMAT` is never used
[INFO] [stdout]   --> src/format.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 |     const FORMAT: &str = "%B %d, %Y";
[INFO] [stdout]    |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/format.rs:56:12
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn serialize<S>(date: &NaiveDate, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/format.rs:64:12
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub fn deserialize<'de, D>(deserializer: D) -> Result<NaiveDate, D::Error>
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/format.rs:82:12
[INFO] [stdout]    |
[INFO] [stdout] 82 |     pub fn serialize<S, T>(value: &T, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/format.rs:90:12
[INFO] [stdout]    |
[INFO] [stdout] 90 |     pub fn deserialize<'de, D, T>(deserializer: D) -> Result<T, D::Error>
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]    --> src/format.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub fn serialize<S, T>(values: &[T], serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]    --> src/format.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout] 115 |     pub fn deserialize<'de, D, T>(deserializer: D) -> Result<Vec<T>, D::Error>
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling futures-lite v1.13.0
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling deadpool v0.9.5
[INFO] [stderr]    Compiling async-channel v1.9.0
[INFO] [stderr]    Compiling regex-automata v0.4.11
[INFO] [stderr]    Compiling regex v1.11.3
[INFO] [stderr]    Compiling wiremock v0.5.22
[INFO] [stderr]    Compiling open-library v0.7.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `crate::format::KeyedValue`
[INFO] [stdout]  --> src/models/works.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::format::KeyedValue;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AuthorType`
[INFO] [stdout]  --> src/models/works.rs:2:47
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::models::authors::{AuthorReference, AuthorType};
[INFO] [stdout]   |                                               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::NaiveDate`
[INFO] [stdout]  --> src/models/works.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::NaiveDate;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserializer`
[INFO] [stdout]  --> src/models/works.rs:5:26
[INFO] [stdout]   |
[INFO] [stdout] 5 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::datetime_from_str`: use `DateTime::parse_from_str` or `NaiveDateTime::parse_from_str` with `and_utc()` or `and_local_timezone()` instead
[INFO] [stdout]   --> src/format.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |         Utc.datetime_from_str(&String::deserialize(deserializer)?, FORMAT)
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORMAT` is never used
[INFO] [stdout]   --> src/format.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 |     const FORMAT: &str = "%d %B %Y";
[INFO] [stdout]    |           ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/format.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub fn serialize<S>(date: &NaiveDate, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/format.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn deserialize<'de, D>(deserializer: D) -> Result<NaiveDate, D::Error>
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORMAT` is never used
[INFO] [stdout]   --> src/format.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 |     const FORMAT: &str = "%B %d, %Y";
[INFO] [stdout]    |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/format.rs:56:12
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn serialize<S>(date: &NaiveDate, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/format.rs:64:12
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub fn deserialize<'de, D>(deserializer: D) -> Result<NaiveDate, D::Error>
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/format.rs:82:12
[INFO] [stdout]    |
[INFO] [stdout] 82 |     pub fn serialize<S, T>(value: &T, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/format.rs:90:12
[INFO] [stdout]    |
[INFO] [stdout] 90 |     pub fn deserialize<'de, D, T>(deserializer: D) -> Result<T, D::Error>
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]    --> src/format.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub fn serialize<S, T>(values: &[T], serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]    --> src/format.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout] 115 |     pub fn deserialize<'de, D, T>(deserializer: D) -> Result<Vec<T>, D::Error>
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 17.83s
[INFO] running `Command { std: "docker" "inspect" "7b1242f45f95c58cb90a7f72efadac60d18108356caa906e5e166a2a666c1818", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7b1242f45f95c58cb90a7f72efadac60d18108356caa906e5e166a2a666c1818", kill_on_drop: false }`
[INFO] [stdout] 7b1242f45f95c58cb90a7f72efadac60d18108356caa906e5e166a2a666c1818
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] c2802aebe078eb64ce77e3539be984b53be2e8cdf347ef8bbb0d57733b69ff31
[INFO] running `Command { std: "docker" "start" "-a" "c2802aebe078eb64ce77e3539be984b53be2e8cdf347ef8bbb0d57733b69ff31", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `crate::format::KeyedValue`
[INFO] [stderr]  --> src/models/works.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use crate::format::KeyedValue;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `AuthorType`
[INFO] [stderr]  --> src/models/works.rs:2:47
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::models::authors::{AuthorReference, AuthorType};
[INFO] [stderr]   |                                               ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `chrono::NaiveDate`
[INFO] [stderr]  --> src/models/works.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use chrono::NaiveDate;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Deserializer`
[INFO] [stderr]  --> src/models/works.rs:5:26
[INFO] [stderr]   |
[INFO] [stderr] 5 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stderr]   |                          ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::datetime_from_str`: use `DateTime::parse_from_str` or `NaiveDateTime::parse_from_str` with `and_utc()` or `and_local_timezone()` instead
[INFO] [stderr]   --> src/format.rs:22:13
[INFO] [stderr]    |
[INFO] [stderr] 22 |         Utc.datetime_from_str(&String::deserialize(deserializer)?, FORMAT)
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `FORMAT` is never used
[INFO] [stderr]   --> src/format.rs:31:11
[INFO] [stderr]    |
[INFO] [stderr] 31 |     const FORMAT: &str = "%d %B %Y";
[INFO] [stderr]    |           ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `serialize` is never used
[INFO] [stderr]   --> src/format.rs:33:12
[INFO] [stderr]    |
[INFO] [stderr] 33 |     pub fn serialize<S>(date: &NaiveDate, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `deserialize` is never used
[INFO] [stderr]   --> src/format.rs:41:12
[INFO] [stderr]    |
[INFO] [stderr] 41 |     pub fn deserialize<'de, D>(deserializer: D) -> Result<NaiveDate, D::Error>
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `FORMAT` is never used
[INFO] [stderr]   --> src/format.rs:54:11
[INFO] [stderr]    |
[INFO] [stderr] 54 |     const FORMAT: &str = "%B %d, %Y";
[INFO] [stderr]    |           ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `serialize` is never used
[INFO] [stderr]   --> src/format.rs:56:12
[INFO] [stderr]    |
[INFO] [stderr] 56 |     pub fn serialize<S>(date: &NaiveDate, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `deserialize` is never used
[INFO] [stderr]   --> src/format.rs:64:12
[INFO] [stderr]    |
[INFO] [stderr] 64 |     pub fn deserialize<'de, D>(deserializer: D) -> Result<NaiveDate, D::Error>
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `serialize` is never used
[INFO] [stderr]   --> src/format.rs:82:12
[INFO] [stderr]    |
[INFO] [stderr] 82 |     pub fn serialize<S, T>(value: &T, serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `deserialize` is never used
[INFO] [stderr]   --> src/format.rs:90:12
[INFO] [stderr]    |
[INFO] [stderr] 90 |     pub fn deserialize<'de, D, T>(deserializer: D) -> Result<T, D::Error>
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `serialize` is never used
[INFO] [stderr]    --> src/format.rs:103:12
[INFO] [stderr]     |
[INFO] [stderr] 103 |     pub fn serialize<S, T>(values: &[T], serializer: S) -> Result<S::Ok, S::Error>
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `deserialize` is never used
[INFO] [stderr]    --> src/format.rs:115:12
[INFO] [stderr]     |
[INFO] [stderr] 115 |     pub fn deserialize<'de, D, T>(deserializer: D) -> Result<Vec<T>, D::Error>
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `open-library` (lib) generated 15 warnings (run `cargo fix --lib -p open-library` to apply 4 suggestions)
[INFO] [stderr] warning: `open-library` (lib test) generated 15 warnings (15 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.26s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/open_library-9ebbce049d7005e7)
[INFO] [stdout] 
[INFO] [stdout] running 39 tests
[INFO] [stdout] test clients::tests::account::test_reading_log_endpoints_returns_failure_when_error_is_returned::already_read ... ok
[INFO] [stdout] test clients::tests::author::test_author_search_returns_failure_when_request_fails ... ok
[INFO] [stdout] test clients::tests::books::test_book_search_returns_failure_when_request_fails ... ok
[INFO] [stdout] test models::tests::account::test_reading_log_response_serde ... ok
[INFO] [stdout] test models::tests::authors::test_author_details_response_serde ... ok
[INFO] [stdout] test clients::tests::books::get::test_book_get_returns_success ... ok
[INFO] [stdout] test models::tests::authors::test_author_search_response_serde ... ok
[INFO] [stdout] test clients::tests::books::isbn::test_get_isbn_returns_success ... ok
[INFO] [stdout] test clients::tests::account::test_reading_log_endpoints_returns_failure_when_error_is_returned::currently_reading ... ok
[INFO] [stdout] test clients::tests::account::test_reading_log_endpoints_returns_failure_when_error_is_returned::want_to_read ... ok
[INFO] [stdout] test clients::tests::books::isbn::test_get_isbn_returns_error_when_invalid_json_returned ... ok
[INFO] [stdout] test clients::tests::account::ensure_reading_log_endpoint_returns_success::currently_reading ... ok
[INFO] [stdout] test clients::tests::account::ensure_reading_log_endpoint_returns_success::already_read ... ok
[INFO] [stdout] test clients::tests::books::test_book_search_returns_success ... ok
[INFO] [stdout] test clients::tests::works::test_works_get_returns_success ... ok
[INFO] [stdout] test models::tests::authors::test_author_works_from_identifier ... ok
[INFO] [stdout] test models::tests::authors::test_author_works_from_url ... ok
[INFO] [stdout] test clients::tests::author::get::test_author_get_returns_success ... ok
[INFO] [stdout] test models::tests::books::test_bibliography_key_serde::isbn10 ... ok
[INFO] [stdout] test clients::tests::books::isbn::test_get_isbn_returns_error_when_book_does_not_exist ... ok
[INFO] [stdout] test models::tests::books::test_bibliography_key_serde::isbn13 ... ok
[INFO] [stdout] test models::tests::books::test_bibliography_key_serde::lccn ... ok
[INFO] [stdout] test models::tests::books::test_bibliography_key_serde::oclc ... ok
[INFO] [stdout] test models::tests::books::test_bibliography_key_to_string::isbn10 ... ok
[INFO] [stdout] test models::tests::books::test_bibliography_key_serde::open_library ... ok
[INFO] [stdout] test models::tests::books::test_bibliography_key_to_string::lccn ... ok
[INFO] [stdout] test models::tests::books::test_serde_book_all_fields ... ok
[INFO] [stdout] test models::tests::books::test_serde_book_required_fields ... ok
[INFO] [stdout] test models::tests::books::test_bibliography_key_to_string::open_library ... ok
[INFO] [stdout] test models::tests::books::test_bibliography_key_to_string::isbn13 ... ok
[INFO] [stdout] test clients::tests::account::test_login_returns_error_on_failure ... ok
[INFO] [stdout] test models::tests::books::test_bibliography_key_to_string::oclc ... ok
[INFO] [stdout] test clients::tests::account::ensure_reading_log_endpoint_returns_success::want_to_read ... ok
[INFO] [stdout] test models::tests::authors::test_author_works_response_serde ... ok
[INFO] [stdout] test clients::tests::account::test_login_returns_success ... ok
[INFO] [stdout] test clients::tests::author::test_author_search_returns_success ... ok
[INFO] [stdout] test tests::clients::test_get_returns_error_when_receives_invalid_json ... ok
[INFO] [stdout] test tests::clients::test_get_returns_error_when_api_responds_with_error ... ok
[INFO] [stdout] test tests::clients::test_get_returns_successfully ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 39 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.41s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/tests.rs (/opt/rustwide/target/debug/deps/tests-2a978270d1612d95)
[INFO] [stdout] 
[INFO] [stdout] running 10 tests
[INFO] [stdout] test test_login ... FAILED
[INFO] [stdout] test test_want_to_read ... FAILED
[INFO] [stdout] test test_author_get_works ... FAILED
[INFO] [stdout] test test_book_by_isbn ... FAILED
[INFO] [stdout] test test_book_get ... FAILED
[INFO] [stdout] test test_author_search ... FAILED
[INFO] [stdout] test test_works_get ... FAILED
[INFO] [stdout] test test_author_get ... FAILED
[INFO] [stdout] test test_author_get_works_from_url ... FAILED
[INFO] [stdout] test test_book_search ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- test_login stdout ----
[INFO] [stdout] Error: NotAuthenticated { reason: "Unable to find username in environment variables!" }
[INFO] [stdout] 
[INFO] [stdout] ---- test_want_to_read stdout ----
[INFO] [stdout] Error: NotAuthenticated { reason: "Unable to find username in environment variables!" }
[INFO] [stdout] 
[INFO] [stdout] ---- test_author_get_works stdout ----
[INFO] [stdout] Error: RequestFailed { source: reqwest::Error { kind: Request, url: Url { scheme: "https", cannot_be_a_base: false, username: "", password: None, host: Some(Domain("openlibrary.org")), port: None, path: "/authors/OL4452558A/works.json", query: Some("limit=50&offset=0"), fragment: None }, source: hyper::Error(Connect, ConnectError("dns error", Custom { kind: Uncategorized, error: "failed to lookup address information: Temporary failure in name resolution" })) } }
[INFO] [stdout] 
[INFO] [stdout] ---- test_book_by_isbn stdout ----
[INFO] [stdout] Error: RequestFailed { source: reqwest::Error { kind: Request, url: Url { scheme: "https", cannot_be_a_base: false, username: "", password: None, host: Some(Domain("openlibrary.org")), port: None, path: "/isbn/0374386137.json", query: None, fragment: None }, source: hyper::Error(Connect, ConnectError("dns error", Custom { kind: Uncategorized, error: "failed to lookup address information: Temporary failure in name resolution" })) } }
[INFO] [stdout] 
[INFO] [stdout] ---- test_book_get stdout ----
[INFO] [stdout] Error: RequestFailed { source: reqwest::Error { kind: Request, url: Url { scheme: "https", cannot_be_a_base: false, username: "", password: None, host: Some(Domain("openlibrary.org")), port: None, path: "/books/OL8458764M.json", query: None, fragment: None }, source: hyper::Error(Connect, ConnectError("dns error", Custom { kind: Uncategorized, error: "failed to lookup address information: Temporary failure in name resolution" })) } }
[INFO] [stdout] 
[INFO] [stdout] ---- test_author_search stdout ----
[INFO] [stdout] Error: RequestFailed { source: reqwest::Error { kind: Request, url: Url { scheme: "https", cannot_be_a_base: false, username: "", password: None, host: Some(Domain("openlibrary.org")), port: None, path: "/search/authors.json", query: Some("q=Markus+Zusak"), fragment: None }, source: hyper::Error(Connect, ConnectError("dns error", Custom { kind: Uncategorized, error: "failed to lookup address information: Temporary failure in name resolution" })) } }
[INFO] [stdout] 
[INFO] [stdout] ---- test_works_get stdout ----
[INFO] [stdout] Error: RequestFailed { source: reqwest::Error { kind: Request, url: Url { scheme: "https", cannot_be_a_base: false, username: "", password: None, host: Some(Domain("openlibrary.org")), port: None, path: "/works/OL7353617M.json", query: None, fragment: None }, source: hyper::Error(Connect, ConnectError("dns error", Custom { kind: Uncategorized, error: "failed to lookup address information: Temporary failure in name resolution" })) } }
[INFO] [stdout] 
[INFO] [stdout] ---- test_author_get stdout ----
[INFO] [stdout] Error: RequestFailed { source: reqwest::Error { kind: Request, url: Url { scheme: "https", cannot_be_a_base: false, username: "", password: None, host: Some(Domain("openlibrary.org")), port: None, path: "/authors/OL4452558A.json", query: None, fragment: None }, source: hyper::Error(Connect, ConnectError("dns error", Custom { kind: Uncategorized, error: "failed to lookup address information: Temporary failure in name resolution" })) } }
[INFO] [stdout] 
[INFO] [stdout] ---- test_author_get_works_from_url stdout ----
[INFO] [stdout] Error: RequestFailed { source: reqwest::Error { kind: Request, url: Url { scheme: "https", cannot_be_a_base: false, username: "", password: None, host: Some(Domain("openlibrary.org")), port: None, path: "/authors/OL4452558A/works.json", query: Some("limit=25&offset=10"), fragment: None }, source: hyper::Error(Connect, ConnectError("dns error", Custom { kind: Uncategorized, error: "failed to lookup address information: Temporary failure in name resolution" })) } }
[INFO] [stdout] 
[INFO] [stdout] ---- test_book_search stdout ----
[INFO] [stdout] Error: RequestFailed { source: reqwest::Error { kind: Request, url: Url { scheme: "https", cannot_be_a_base: false, username: "", password: None, host: Some(Domain("openlibrary.org")), port: None, path: "/api/books", query: Some("bibkeys=ISBN%3A0374386137&format=json&jscmd=data"), fragment: None }, source: hyper::Error(Connect, ConnectError("dns error", Custom { kind: Uncategorized, error: "failed to lookup address information: Temporary failure in name resolution" })) } }
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     test_author_get
[INFO] [stdout]     test_author_get_works
[INFO] [stdout]     test_author_get_works_from_url
[INFO] [stdout]     test_author_search
[INFO] [stdout]     test_book_by_isbn
[INFO] [stdout]     test_book_get
[INFO] [stdout]     test_book_search
[INFO] [stdout]     test_login
[INFO] [stdout]     test_want_to_read
[INFO] [stdout]     test_works_get
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 10 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.68s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--test tests`
[INFO] running `Command { std: "docker" "inspect" "c2802aebe078eb64ce77e3539be984b53be2e8cdf347ef8bbb0d57733b69ff31", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c2802aebe078eb64ce77e3539be984b53be2e8cdf347ef8bbb0d57733b69ff31", kill_on_drop: false }`
[INFO] [stdout] c2802aebe078eb64ce77e3539be984b53be2e8cdf347ef8bbb0d57733b69ff31
