[INFO] fetching crate happy 0.1.1...
[INFO] checking happy-0.1.1 against master#30f74ff0dc4d66debc8b50724c446f817e5f75f4 for pr-121848-1
[INFO] extracting crate happy 0.1.1 into /workspace/builds/worker-6-tc1/source
[INFO] validating manifest of crates.io crate happy 0.1.1 on toolchain 30f74ff0dc4d66debc8b50724c446f817e5f75f4
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate happy 0.1.1
[INFO] finished tweaking crates.io crate happy 0.1.1
[INFO] tweaked toml for crates.io crate happy 0.1.1 written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded ascii v0.7.1
[INFO] [stderr]   Downloaded combine v2.4.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7acc97b557ccc77a1bdc135613dea34aca4fa54056b6c3d66a9e62418088072d
[INFO] running `Command { std: "docker" "start" "-a" "7acc97b557ccc77a1bdc135613dea34aca4fa54056b6c3d66a9e62418088072d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7acc97b557ccc77a1bdc135613dea34aca4fa54056b6c3d66a9e62418088072d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7acc97b557ccc77a1bdc135613dea34aca4fa54056b6c3d66a9e62418088072d", kill_on_drop: false }`
[INFO] [stdout] 7acc97b557ccc77a1bdc135613dea34aca4fa54056b6c3d66a9e62418088072d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cfc75f9ec5f55ee84e002839b32241713caf1bf935084bc7698bfff916fa20c6
[INFO] running `Command { std: "docker" "start" "-a" "cfc75f9ec5f55ee84e002839b32241713caf1bf935084bc7698bfff916fa20c6", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.153
[INFO] [stderr]     Checking cfg-if v0.1.10
[INFO] [stderr]     Checking futures v0.1.31
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling maybe-uninit v2.0.0
[INFO] [stderr]    Compiling semver-parser v0.7.0
[INFO] [stderr]     Checking log v0.4.21
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]     Checking scopeguard v1.2.0
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]    Compiling memoffset v0.5.6
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]    Compiling unicase v2.7.0
[INFO] [stderr]     Checking scoped-tls v0.1.2
[INFO] [stderr]    Compiling httparse v1.8.0
[INFO] [stderr]     Checking try-lock v0.1.0
[INFO] [stderr]     Checking smallvec v0.2.1
[INFO] [stderr]     Checking mime v0.3.17
[INFO] [stderr]     Checking lock_api v0.3.4
[INFO] [stderr]    Compiling regex v0.2.11
[INFO] [stderr]     Checking safemem v0.3.3
[INFO] [stderr]     Checking ucd-util v0.1.10
[INFO] [stderr]    Compiling semver v0.9.0
[INFO] [stderr]     Checking log v0.3.9
[INFO] [stderr]     Checking slab v0.3.0
[INFO] [stderr]     Checking take v0.1.0
[INFO] [stderr]     Checking memchr v2.7.2
[INFO] [stderr]     Checking base64 v0.9.3
[INFO] [stderr]     Checking regex-syntax v0.5.6
[INFO] [stderr]     Checking thread_local v0.3.6
[INFO] [stderr]     Checking percent-encoding v1.0.1
[INFO] [stderr]     Checking language-tags v0.2.2
[INFO] [stderr]    Compiling rustc_version v0.2.3
[INFO] [stderr]     Checking smallvec v0.6.14
[INFO] [stderr]     Checking ascii v0.7.1
[INFO] [stderr]     Checking utf8-ranges v1.0.5
[INFO] [stderr]     Checking void v1.0.2
[INFO] [stderr]    Compiling parking_lot_core v0.6.3
[INFO] [stderr]    Compiling parking_lot v0.9.0
[INFO] [stderr]    Compiling mime_guess v2.0.4
[INFO] [stderr]     Checking combine v2.4.0
[INFO] [stderr]     Checking aho-corasick v0.6.10
[INFO] [stderr]     Checking crossbeam-queue v0.2.3
[INFO] [stderr]     Checking crossbeam-deque v0.7.4
[INFO] [stderr]     Checking iovec v0.1.4
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking net2 v0.2.39
[INFO] [stderr]     Checking rand v0.4.6
[INFO] [stderr]     Checking time v0.1.45
[INFO] [stderr]     Checking bytes v0.4.12
[INFO] [stderr]     Checking tokio-executor v0.1.10
[INFO] [stderr]     Checking tokio-sync v0.1.8
[INFO] [stderr]     Checking tokio-service v0.1.0
[INFO] [stderr]     Checking want v0.0.4
[INFO] [stderr]     Checking relay v0.1.1
[INFO] [stderr]     Checking futures-cpupool v0.1.8
[INFO] [stderr]     Checking mio v0.6.23
[INFO] [stderr]     Checking tokio-threadpool v0.1.18
[INFO] [stderr]     Checking tokio-current-thread v0.1.7
[INFO] [stderr]     Checking tokio-timer v0.2.13
[INFO] [stderr]     Checking tokio-io v0.1.13
[INFO] [stderr]     Checking rand v0.3.23
[INFO] [stderr]     Checking tokio-codec v0.1.2
[INFO] [stderr]     Checking tokio-fs v0.1.7
[INFO] [stderr]     Checking tokio-reactor v0.1.12
[INFO] [stderr]     Checking mio-uds v0.6.8
[INFO] [stderr]     Checking tokio-udp v0.1.6
[INFO] [stderr]     Checking tokio-tcp v0.1.4
[INFO] [stderr]     Checking tokio-uds v0.2.7
[INFO] [stderr]     Checking tokio v0.1.22
[INFO] [stderr]     Checking tokio-core v0.1.18
[INFO] [stderr]     Checking tokio-proto v0.1.1
[INFO] [stderr]     Checking hyper v0.11.27
[INFO] [stderr]     Checking happy v0.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the item `futures` is imported redundantly
[INFO] [stdout]   --> src/api.rs:1:5
[INFO] [stdout]    |
[INFO] [stdout] 1  | use futures;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:11:1
[INFO] [stdout]    |
[INFO] [stdout] 11 | extern crate futures;
[INFO] [stdout]    | --------------------- the item `futures` is already imported here
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `serde_json` is imported redundantly
[INFO] [stdout]  --> src/api.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde_json;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | extern crate serde_json;
[INFO] [stdout]   | ------------------------ the item `serde_json` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `hyper` is imported redundantly
[INFO] [stdout]   --> src/api.rs:3:5
[INFO] [stdout]    |
[INFO] [stdout] 3  | use hyper;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | extern crate hyper;
[INFO] [stdout]    | ------------------- the item `hyper` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `futures` is imported redundantly
[INFO] [stdout]   --> src/api.rs:1:5
[INFO] [stdout]    |
[INFO] [stdout] 1  | use futures;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:11:1
[INFO] [stdout]    |
[INFO] [stdout] 11 | extern crate futures;
[INFO] [stdout]    | --------------------- the item `futures` is already imported here
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/api.rs:26:23
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  _______________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout]    | |________^
[INFO] [stdout] ...
[INFO] [stdout] 30 |            hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout]    |                                   ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 ~ type Handler = Box<Fn((hyper::Method, 
[INFO] [stdout] 27 |          hyper::Uri, 
[INFO] [stdout] 28 |          hyper::HttpVersion, 
[INFO] [stdout] 29 ~          hyper::header::Headers), Vec<u8>) -> 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `serde_json` is imported redundantly
[INFO] [stdout]  --> src/api.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde_json;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | extern crate serde_json;
[INFO] [stdout]   | ------------------------ the item `serde_json` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `hyper` is imported redundantly
[INFO] [stdout]   --> src/api.rs:3:5
[INFO] [stdout]    |
[INFO] [stdout] 3  | use hyper;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | extern crate hyper;
[INFO] [stdout]    | ------------------- the item `hyper` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]   --> src/api.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 5  | use futures::{BoxFuture, Future};
[INFO] [stdout]    |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 81 |         use futures::Future;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]    --> src/api.rs:179:13
[INFO] [stdout]     |
[INFO] [stdout] 5   | use futures::{BoxFuture, Future};
[INFO] [stdout]     |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 179 |         use futures::Future;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `combine` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:1:15
[INFO] [stdout]   |
[INFO] [stdout] 1 | use combine::{self, Parser}; 
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | extern crate combine;
[INFO] [stdout]   | --------------------- the item `combine` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:1:21
[INFO] [stdout]   |
[INFO] [stdout] 1 | use combine::{self, Parser}; 
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 2 | use combine::*;
[INFO] [stdout]   |     ---------- the item `Parser` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `regex` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use regex;
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:7:1
[INFO] [stdout]   |
[INFO] [stdout] 7 | extern crate regex;
[INFO] [stdout]   | ------------------- the item `regex` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]   --> src/parse_route.rs:91:9
[INFO] [stdout]    |
[INFO] [stdout] 1  | use combine::{self, Parser}; 
[INFO] [stdout]    |                     ------ the item `Parser` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 91 |     use combine::Parser;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/api.rs:26:23
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  _______________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout]    | |________^
[INFO] [stdout] ...
[INFO] [stdout] 30 |            hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout]    |                                   ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 ~ type Handler = Box<Fn((hyper::Method, 
[INFO] [stdout] 27 |          hyper::Uri, 
[INFO] [stdout] 28 |          hyper::HttpVersion, 
[INFO] [stdout] 29 ~          hyper::header::Headers), Vec<u8>) -> 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]   --> src/api.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 5  | use futures::{BoxFuture, Future};
[INFO] [stdout]    |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 81 |         use futures::Future;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]    --> src/api.rs:179:13
[INFO] [stdout]     |
[INFO] [stdout] 5   | use futures::{BoxFuture, Future};
[INFO] [stdout]     |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 179 |         use futures::Future;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `combine` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:1:15
[INFO] [stdout]   |
[INFO] [stdout] 1 | use combine::{self, Parser}; 
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | extern crate combine;
[INFO] [stdout]   | --------------------- the item `combine` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:1:21
[INFO] [stdout]   |
[INFO] [stdout] 1 | use combine::{self, Parser}; 
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 2 | use combine::*;
[INFO] [stdout]   |     ---------- the item `Parser` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `regex` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use regex;
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:7:1
[INFO] [stdout]   |
[INFO] [stdout] 7 | extern crate regex;
[INFO] [stdout]   | ------------------- the item `regex` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]   --> src/parse_route.rs:91:9
[INFO] [stdout]    |
[INFO] [stdout] 1  | use combine::{self, Parser}; 
[INFO] [stdout]    |                     ------ the item `Parser` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 91 |     use combine::Parser;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `ParseError` is imported redundantly
[INFO] [stdout]    --> src/parse_route.rs:104:19
[INFO] [stdout]     |
[INFO] [stdout] 104 |     use combine::{ParseError};
[INFO] [stdout]     |                   ^^^^^^^^^^
[INFO] [stdout] 105 |     use super::*;
[INFO] [stdout]     |         -------- the item `ParseError` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]  --> src/api.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use futures::{BoxFuture, Future};
[INFO] [stdout]   |               ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    |             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |           F: Fn(Request) -> BoxFuture<Response, ErrorKind> + Send + Sync + 'static {
[INFO] [stdout]     |                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:174:19
[INFO] [stdout]     |
[INFO] [stdout] 174 |     type Future = BoxFuture<Response, ::hyper::Error>;
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::ascii::AsciiExt::eq_ignore_ascii_case`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:62:40
[INFO] [stdout]    |
[INFO] [stdout] 62 |         string_cmp(s, |a, b| AsciiExt::eq_ignore_ascii_case(&a, &b))
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated trait `std::ascii::AsciiExt`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:48:21
[INFO] [stdout]    |
[INFO] [stdout] 48 |     use std::ascii::AsciiExt;
[INFO] [stdout]    |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]  --> src/static_file.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use mime_guess::guess_mime_type;
[INFO] [stdout]   |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]   --> src/static_file.rs:30:24
[INFO] [stdout]    |
[INFO] [stdout] 30 |             let mime = guess_mime_type(&local_path);
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<Error + Send + 'static>),
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<dyn Error + Send + 'static>),
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:26:20
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  ____________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout] 28 | |          hyper::Uri, 
[INFO] [stdout] 29 | |          hyper::HttpVersion, 
[INFO] [stdout] 30 | |          hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout] 31 | |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    | |________________________________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 26 | type Handler = Box<dyn Fn((
[INFO] [stdout]    |                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]  --> src/api.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use futures::{BoxFuture, Future};
[INFO] [stdout]   |               ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    |             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |           F: Fn(Request) -> BoxFuture<Response, ErrorKind> + Send + Sync + 'static {
[INFO] [stdout]     |                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:174:19
[INFO] [stdout]     |
[INFO] [stdout] 174 |     type Future = BoxFuture<Response, ::hyper::Error>;
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::ascii::AsciiExt::eq_ignore_ascii_case`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:62:40
[INFO] [stdout]    |
[INFO] [stdout] 62 |         string_cmp(s, |a, b| AsciiExt::eq_ignore_ascii_case(&a, &b))
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated trait `std::ascii::AsciiExt`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:48:21
[INFO] [stdout]    |
[INFO] [stdout] 48 |     use std::ascii::AsciiExt;
[INFO] [stdout]    |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]  --> src/static_file.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use mime_guess::guess_mime_type;
[INFO] [stdout]   |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]   --> src/static_file.rs:30:24
[INFO] [stdout]    |
[INFO] [stdout] 30 |             let mime = guess_mime_type(&local_path);
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<Error + Send + 'static>),
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<dyn Error + Send + 'static>),
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:26:20
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  ____________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout] 28 | |          hyper::Uri, 
[INFO] [stdout] 29 | |          hyper::HttpVersion, 
[INFO] [stdout] 30 | |          hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout] 31 | |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    | |________________________________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 26 | type Handler = Box<dyn Fn((
[INFO] [stdout]    |                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/parse_route.rs:21:25
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = dyn combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/parse_route.rs:21:25
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = dyn combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:89:65
[INFO] [stdout]    |
[INFO] [stdout] 89 |                 Err(e) => return err(ErrorKind::Deserialize(e)).boxed(),
[INFO] [stdout]    |                                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:108:16
[INFO] [stdout]     |
[INFO] [stdout] 108 |             }).boxed()
[INFO] [stdout]     |                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:89:65
[INFO] [stdout]    |
[INFO] [stdout] 89 |                 Err(e) => return err(ErrorKind::Deserialize(e)).boxed(),
[INFO] [stdout]    |                                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:108:16
[INFO] [stdout]     |
[INFO] [stdout] 108 |             }).boxed()
[INFO] [stdout]     |                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:191:33
[INFO] [stdout]     |
[INFO] [stdout] 191 |             return ok(response).boxed()
[INFO] [stdout]     |                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:191:33
[INFO] [stdout]     |
[INFO] [stdout] 191 |             return ok(response).boxed()
[INFO] [stdout]     |                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:235:20
[INFO] [stdout]     |
[INFO] [stdout] 235 |             result.boxed()
[INFO] [stdout]     |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:243:21
[INFO] [stdout]     |
[INFO] [stdout] 243 |             ok(res).boxed()
[INFO] [stdout]     |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:235:20
[INFO] [stdout]     |
[INFO] [stdout] 235 |             result.boxed()
[INFO] [stdout]     |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:243:21
[INFO] [stdout]     |
[INFO] [stdout] 243 |             ok(res).boxed()
[INFO] [stdout]     |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn verb<'a>() -> Box<StrParser<'a, Option<Method>>> {
[INFO] [stdout]    |         -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 69 |     optional(verbs_and_space).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn verb<'a>() -> Box<StrParser<'a, Option<Method>>> {
[INFO] [stdout]    |         -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 69 |     optional(verbs_and_space).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | fn segment_piece<'a>() -> Box<StrParser<'a, SegmentPiece>> {
[INFO] [stdout]    |                  -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 78 |     literal.map(|r| SegmentPiece::Literal(r)).or(pattern).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 81 | fn segment<'a>() -> Box<StrParser<'a, Segment>> {
[INFO] [stdout]    |            -- lifetime `'a` defined here
[INFO] [stdout] 82 |     many1(segment_piece()).map(Segment).and(optional(token('/'))).map(|(v, _)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn url<'a>() -> Box<StrParser<'a, Vec<Segment>>> {
[INFO] [stdout]    |        -- lifetime `'a` defined here
[INFO] [stdout] 86 |     optional(token('/')).and(many1(segment())).map(|(_, v)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | fn segment_piece<'a>() -> Box<StrParser<'a, SegmentPiece>> {
[INFO] [stdout]    |                  -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 78 |     literal.map(|r| SegmentPiece::Literal(r)).or(pattern).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 81 | fn segment<'a>() -> Box<StrParser<'a, Segment>> {
[INFO] [stdout]    |            -- lifetime `'a` defined here
[INFO] [stdout] 82 |     many1(segment_piece()).map(Segment).and(optional(token('/'))).map(|(v, _)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 4 previous errors; 26 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn url<'a>() -> Box<StrParser<'a, Vec<Segment>>> {
[INFO] [stdout]    |        -- lifetime `'a` defined here
[INFO] [stdout] 86 |     optional(token('/')).and(many1(segment())).map(|(_, v)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `happy` (lib) due to 5 previous errors; 26 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error: aborting due to 4 previous errors; 27 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `happy` (lib test) due to 5 previous errors; 27 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "cfc75f9ec5f55ee84e002839b32241713caf1bf935084bc7698bfff916fa20c6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cfc75f9ec5f55ee84e002839b32241713caf1bf935084bc7698bfff916fa20c6", kill_on_drop: false }`
[INFO] [stdout] cfc75f9ec5f55ee84e002839b32241713caf1bf935084bc7698bfff916fa20c6
[INFO] checking happy-0.1.1 against try#72eda894eb3548c7ba774079ce0afab42958d4ee for pr-121848-1
[INFO] extracting crate happy 0.1.1 into /workspace/builds/worker-6-tc2/source
[INFO] validating manifest of crates.io crate happy 0.1.1 on toolchain 72eda894eb3548c7ba774079ce0afab42958d4ee
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate happy 0.1.1
[INFO] finished tweaking crates.io crate happy 0.1.1
[INFO] tweaked toml for crates.io crate happy 0.1.1 written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] ed30ed7d4c9ae730895b30a08a6a8c359ccb016abea594a831dee7dd239bd385
[INFO] running `Command { std: "docker" "start" "-a" "ed30ed7d4c9ae730895b30a08a6a8c359ccb016abea594a831dee7dd239bd385", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "ed30ed7d4c9ae730895b30a08a6a8c359ccb016abea594a831dee7dd239bd385", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ed30ed7d4c9ae730895b30a08a6a8c359ccb016abea594a831dee7dd239bd385", kill_on_drop: false }`
[INFO] [stdout] ed30ed7d4c9ae730895b30a08a6a8c359ccb016abea594a831dee7dd239bd385
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] af3f30e803c9c8fbb4efd7f22204997139ea8f292e4b3fcdaa487488bdeea089
[INFO] running `Command { std: "docker" "start" "-a" "af3f30e803c9c8fbb4efd7f22204997139ea8f292e4b3fcdaa487488bdeea089", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.153
[INFO] [stderr]     Checking cfg-if v0.1.10
[INFO] [stderr]     Checking futures v0.1.31
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling maybe-uninit v2.0.0
[INFO] [stderr]     Checking log v0.4.21
[INFO] [stderr]    Compiling semver-parser v0.7.0
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]     Checking scopeguard v1.2.0
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]    Compiling memoffset v0.5.6
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]    Compiling unicase v2.7.0
[INFO] [stderr]     Checking scoped-tls v0.1.2
[INFO] [stderr]    Compiling httparse v1.8.0
[INFO] [stderr]     Checking try-lock v0.1.0
[INFO] [stderr]     Checking memchr v2.7.2
[INFO] [stderr]     Checking lock_api v0.3.4
[INFO] [stderr]     Checking mime v0.3.17
[INFO] [stderr]     Checking ucd-util v0.1.10
[INFO] [stderr]     Checking take v0.1.0
[INFO] [stderr]    Compiling semver v0.9.0
[INFO] [stderr]     Checking log v0.3.9
[INFO] [stderr]     Checking smallvec v0.2.1
[INFO] [stderr]    Compiling rustc_version v0.2.3
[INFO] [stderr]    Compiling regex v0.2.11
[INFO] [stderr]     Checking slab v0.3.0
[INFO] [stderr]     Checking safemem v0.3.3
[INFO] [stderr]     Checking smallvec v0.6.14
[INFO] [stderr]     Checking regex-syntax v0.5.6
[INFO] [stderr]     Checking base64 v0.9.3
[INFO] [stderr]     Checking thread_local v0.3.6
[INFO] [stderr]     Checking ascii v0.7.1
[INFO] [stderr]     Checking percent-encoding v1.0.1
[INFO] [stderr]     Checking language-tags v0.2.2
[INFO] [stderr]     Checking utf8-ranges v1.0.5
[INFO] [stderr]     Checking aho-corasick v0.6.10
[INFO] [stderr]     Checking void v1.0.2
[INFO] [stderr]     Checking combine v2.4.0
[INFO] [stderr]    Compiling parking_lot_core v0.6.3
[INFO] [stderr]    Compiling parking_lot v0.9.0
[INFO] [stderr]    Compiling mime_guess v2.0.4
[INFO] [stderr]     Checking tokio-sync v0.1.8
[INFO] [stderr]     Checking tokio-service v0.1.0
[INFO] [stderr]     Checking relay v0.1.1
[INFO] [stderr]     Checking want v0.0.4
[INFO] [stderr]     Checking iovec v0.1.4
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking net2 v0.2.39
[INFO] [stderr]     Checking rand v0.4.6
[INFO] [stderr]     Checking time v0.1.45
[INFO] [stderr]     Checking bytes v0.4.12
[INFO] [stderr]     Checking tokio-executor v0.1.10
[INFO] [stderr]     Checking crossbeam-queue v0.2.3
[INFO] [stderr]     Checking futures-cpupool v0.1.8
[INFO] [stderr]     Checking mio v0.6.23
[INFO] [stderr]     Checking tokio-current-thread v0.1.7
[INFO] [stderr]     Checking tokio-timer v0.2.13
[INFO] [stderr]     Checking crossbeam-deque v0.7.4
[INFO] [stderr]     Checking tokio-io v0.1.13
[INFO] [stderr]     Checking tokio-threadpool v0.1.18
[INFO] [stderr]     Checking rand v0.3.23
[INFO] [stderr]     Checking tokio-codec v0.1.2
[INFO] [stderr]     Checking tokio-fs v0.1.7
[INFO] [stderr]     Checking tokio-reactor v0.1.12
[INFO] [stderr]     Checking mio-uds v0.6.8
[INFO] [stderr]     Checking tokio-uds v0.2.7
[INFO] [stderr]     Checking tokio-udp v0.1.6
[INFO] [stderr]     Checking tokio-tcp v0.1.4
[INFO] [stderr]     Checking tokio v0.1.22
[INFO] [stderr]     Checking tokio-core v0.1.18
[INFO] [stderr]     Checking tokio-proto v0.1.1
[INFO] [stderr]     Checking hyper v0.11.27
[INFO] [stderr]     Checking happy v0.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the item `futures` is imported redundantly
[INFO] [stdout]   --> src/api.rs:1:5
[INFO] [stdout]    |
[INFO] [stdout] 1  | use futures;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:11:1
[INFO] [stdout]    |
[INFO] [stdout] 11 | extern crate futures;
[INFO] [stdout]    | --------------------- the item `futures` is already imported here
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `serde_json` is imported redundantly
[INFO] [stdout]  --> src/api.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde_json;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | extern crate serde_json;
[INFO] [stdout]   | ------------------------ the item `serde_json` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `hyper` is imported redundantly
[INFO] [stdout]   --> src/api.rs:3:5
[INFO] [stdout]    |
[INFO] [stdout] 3  | use hyper;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | extern crate hyper;
[INFO] [stdout]    | ------------------- the item `hyper` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `futures` is imported redundantly
[INFO] [stdout]   --> src/api.rs:1:5
[INFO] [stdout]    |
[INFO] [stdout] 1  | use futures;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:11:1
[INFO] [stdout]    |
[INFO] [stdout] 11 | extern crate futures;
[INFO] [stdout]    | --------------------- the item `futures` is already imported here
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `serde_json` is imported redundantly
[INFO] [stdout]  --> src/api.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde_json;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | extern crate serde_json;
[INFO] [stdout]   | ------------------------ the item `serde_json` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `hyper` is imported redundantly
[INFO] [stdout]   --> src/api.rs:3:5
[INFO] [stdout]    |
[INFO] [stdout] 3  | use hyper;
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | extern crate hyper;
[INFO] [stdout]    | ------------------- the item `hyper` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/api.rs:26:23
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  _______________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout]    | |________^
[INFO] [stdout] ...
[INFO] [stdout] 30 |            hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout]    |                                   ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 ~ type Handler = Box<Fn((hyper::Method, 
[INFO] [stdout] 27 |          hyper::Uri, 
[INFO] [stdout] 28 |          hyper::HttpVersion, 
[INFO] [stdout] 29 ~          hyper::header::Headers), Vec<u8>) -> 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]   --> src/api.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 5  | use futures::{BoxFuture, Future};
[INFO] [stdout]    |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 81 |         use futures::Future;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]    --> src/api.rs:179:13
[INFO] [stdout]     |
[INFO] [stdout] 5   | use futures::{BoxFuture, Future};
[INFO] [stdout]     |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 179 |         use futures::Future;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `combine` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:1:15
[INFO] [stdout]   |
[INFO] [stdout] 1 | use combine::{self, Parser}; 
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | extern crate combine;
[INFO] [stdout]   | --------------------- the item `combine` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:1:21
[INFO] [stdout]   |
[INFO] [stdout] 1 | use combine::{self, Parser}; 
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 2 | use combine::*;
[INFO] [stdout]   |     ---------- the item `Parser` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `regex` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use regex;
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:7:1
[INFO] [stdout]   |
[INFO] [stdout] 7 | extern crate regex;
[INFO] [stdout]   | ------------------- the item `regex` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]   --> src/parse_route.rs:91:9
[INFO] [stdout]    |
[INFO] [stdout] 1  | use combine::{self, Parser}; 
[INFO] [stdout]    |                     ------ the item `Parser` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 91 |     use combine::Parser;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/api.rs:26:23
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  _______________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout]    | |________^
[INFO] [stdout] ...
[INFO] [stdout] 30 |            hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout]    |                                   ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 ~ type Handler = Box<Fn((hyper::Method, 
[INFO] [stdout] 27 |          hyper::Uri, 
[INFO] [stdout] 28 |          hyper::HttpVersion, 
[INFO] [stdout] 29 ~          hyper::header::Headers), Vec<u8>) -> 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]   --> src/api.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 5  | use futures::{BoxFuture, Future};
[INFO] [stdout]    |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 81 |         use futures::Future;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]    --> src/api.rs:179:13
[INFO] [stdout]     |
[INFO] [stdout] 5   | use futures::{BoxFuture, Future};
[INFO] [stdout]     |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 179 |         use futures::Future;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `combine` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:1:15
[INFO] [stdout]   |
[INFO] [stdout] 1 | use combine::{self, Parser}; 
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | extern crate combine;
[INFO] [stdout]   | --------------------- the item `combine` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:1:21
[INFO] [stdout]   |
[INFO] [stdout] 1 | use combine::{self, Parser}; 
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 2 | use combine::*;
[INFO] [stdout]   |     ---------- the item `Parser` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `regex` is imported redundantly
[INFO] [stdout]  --> src/parse_route.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use regex;
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]  ::: src/lib.rs:7:1
[INFO] [stdout]   |
[INFO] [stdout] 7 | extern crate regex;
[INFO] [stdout]   | ------------------- the item `regex` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]   --> src/parse_route.rs:91:9
[INFO] [stdout]    |
[INFO] [stdout] 1  | use combine::{self, Parser}; 
[INFO] [stdout]    |                     ------ the item `Parser` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 91 |     use combine::Parser;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `ParseError` is imported redundantly
[INFO] [stdout]    --> src/parse_route.rs:104:19
[INFO] [stdout]     |
[INFO] [stdout] 104 |     use combine::{ParseError};
[INFO] [stdout]     |                   ^^^^^^^^^^
[INFO] [stdout] 105 |     use super::*;
[INFO] [stdout]     |         -------- the item `ParseError` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]  --> src/api.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use futures::{BoxFuture, Future};
[INFO] [stdout]   |               ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]  --> src/api.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use futures::{BoxFuture, Future};
[INFO] [stdout]   |               ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    |             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    |             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |           F: Fn(Request) -> BoxFuture<Response, ErrorKind> + Send + Sync + 'static {
[INFO] [stdout]     |                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |           F: Fn(Request) -> BoxFuture<Response, ErrorKind> + Send + Sync + 'static {
[INFO] [stdout]     |                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:174:19
[INFO] [stdout]     |
[INFO] [stdout] 174 |     type Future = BoxFuture<Response, ::hyper::Error>;
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:174:19
[INFO] [stdout]     |
[INFO] [stdout] 174 |     type Future = BoxFuture<Response, ::hyper::Error>;
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::ascii::AsciiExt::eq_ignore_ascii_case`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:62:40
[INFO] [stdout]    |
[INFO] [stdout] 62 |         string_cmp(s, |a, b| AsciiExt::eq_ignore_ascii_case(&a, &b))
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::ascii::AsciiExt::eq_ignore_ascii_case`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:62:40
[INFO] [stdout]    |
[INFO] [stdout] 62 |         string_cmp(s, |a, b| AsciiExt::eq_ignore_ascii_case(&a, &b))
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated trait `std::ascii::AsciiExt`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:48:21
[INFO] [stdout]    |
[INFO] [stdout] 48 |     use std::ascii::AsciiExt;
[INFO] [stdout]    |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated trait `std::ascii::AsciiExt`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:48:21
[INFO] [stdout]    |
[INFO] [stdout] 48 |     use std::ascii::AsciiExt;
[INFO] [stdout]    |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]  --> src/static_file.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use mime_guess::guess_mime_type;
[INFO] [stdout]   |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]   --> src/static_file.rs:30:24
[INFO] [stdout]    |
[INFO] [stdout] 30 |             let mime = guess_mime_type(&local_path);
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]  --> src/static_file.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use mime_guess::guess_mime_type;
[INFO] [stdout]   |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]   --> src/static_file.rs:30:24
[INFO] [stdout]    |
[INFO] [stdout] 30 |             let mime = guess_mime_type(&local_path);
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<Error + Send + 'static>),
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<dyn Error + Send + 'static>),
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<Error + Send + 'static>),
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<dyn Error + Send + 'static>),
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:26:20
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  ____________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout] 28 | |          hyper::Uri, 
[INFO] [stdout] 29 | |          hyper::HttpVersion, 
[INFO] [stdout] 30 | |          hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout] 31 | |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    | |________________________________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 26 | type Handler = Box<dyn Fn((
[INFO] [stdout]    |                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:26:20
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  ____________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout] 28 | |          hyper::Uri, 
[INFO] [stdout] 29 | |          hyper::HttpVersion, 
[INFO] [stdout] 30 | |          hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout] 31 | |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    | |________________________________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 26 | type Handler = Box<dyn Fn((
[INFO] [stdout]    |                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/parse_route.rs:21:25
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = dyn combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/parse_route.rs:21:25
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = dyn combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:89:65
[INFO] [stdout]    |
[INFO] [stdout] 89 |                 Err(e) => return err(ErrorKind::Deserialize(e)).boxed(),
[INFO] [stdout]    |                                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:89:65
[INFO] [stdout]    |
[INFO] [stdout] 89 |                 Err(e) => return err(ErrorKind::Deserialize(e)).boxed(),
[INFO] [stdout]    |                                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:108:16
[INFO] [stdout]     |
[INFO] [stdout] 108 |             }).boxed()
[INFO] [stdout]     |                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:108:16
[INFO] [stdout]     |
[INFO] [stdout] 108 |             }).boxed()
[INFO] [stdout]     |                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:191:33
[INFO] [stdout]     |
[INFO] [stdout] 191 |             return ok(response).boxed()
[INFO] [stdout]     |                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:191:33
[INFO] [stdout]     |
[INFO] [stdout] 191 |             return ok(response).boxed()
[INFO] [stdout]     |                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:235:20
[INFO] [stdout]     |
[INFO] [stdout] 235 |             result.boxed()
[INFO] [stdout]     |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:235:20
[INFO] [stdout]     |
[INFO] [stdout] 235 |             result.boxed()
[INFO] [stdout]     |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:243:21
[INFO] [stdout]     |
[INFO] [stdout] 243 |             ok(res).boxed()
[INFO] [stdout]     |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:243:21
[INFO] [stdout]     |
[INFO] [stdout] 243 |             ok(res).boxed()
[INFO] [stdout]     |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn verb<'a>() -> Box<StrParser<'a, Option<Method>>> {
[INFO] [stdout]    |         -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 69 |     optional(verbs_and_space).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn verb<'a>() -> Box<StrParser<'a, Option<Method>>> {
[INFO] [stdout]    |         -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 69 |     optional(verbs_and_space).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | fn segment_piece<'a>() -> Box<StrParser<'a, SegmentPiece>> {
[INFO] [stdout]    |                  -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 78 |     literal.map(|r| SegmentPiece::Literal(r)).or(pattern).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 81 | fn segment<'a>() -> Box<StrParser<'a, Segment>> {
[INFO] [stdout]    |            -- lifetime `'a` defined here
[INFO] [stdout] 82 |     many1(segment_piece()).map(Segment).and(optional(token('/'))).map(|(v, _)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn url<'a>() -> Box<StrParser<'a, Vec<Segment>>> {
[INFO] [stdout]    |        -- lifetime `'a` defined here
[INFO] [stdout] 86 |     optional(token('/')).and(many1(segment())).map(|(_, v)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | fn segment_piece<'a>() -> Box<StrParser<'a, SegmentPiece>> {
[INFO] [stdout]    |                  -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 78 |     literal.map(|r| SegmentPiece::Literal(r)).or(pattern).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 81 | fn segment<'a>() -> Box<StrParser<'a, Segment>> {
[INFO] [stdout]    |            -- lifetime `'a` defined here
[INFO] [stdout] 82 |     many1(segment_piece()).map(Segment).and(optional(token('/'))).map(|(v, _)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 4 previous errors; 26 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn url<'a>() -> Box<StrParser<'a, Vec<Segment>>> {
[INFO] [stdout]    |        -- lifetime `'a` defined here
[INFO] [stdout] 86 |     optional(token('/')).and(many1(segment())).map(|(_, v)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `happy` (lib) due to 5 previous errors; 26 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error: aborting due to 4 previous errors; 27 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `happy` (lib test) due to 5 previous errors; 27 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "af3f30e803c9c8fbb4efd7f22204997139ea8f292e4b3fcdaa487488bdeea089", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "af3f30e803c9c8fbb4efd7f22204997139ea8f292e4b3fcdaa487488bdeea089", kill_on_drop: false }`
[INFO] [stdout] af3f30e803c9c8fbb4efd7f22204997139ea8f292e4b3fcdaa487488bdeea089
