[INFO] crate rusqbin 0.2.3 is already in cache
[INFO] checking rusqbin-0.2.3 against master#209b2be09fcaff937480d1fbbe8b31646e361c7a for pr-70917
[INFO] extracting crate rusqbin 0.2.3 into /workspace/builds/worker-11/source
[INFO] validating manifest of crates.io crate rusqbin 0.2.3 on toolchain 209b2be09fcaff937480d1fbbe8b31646e361c7a
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking crates.io crate rusqbin 0.2.3
[INFO] finished tweaking crates.io crate rusqbin 0.2.3
[INFO] tweaked toml for crates.io crate rusqbin 0.2.3 written to /workspace/builds/worker-11/source/Cargo.toml
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-11/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-11/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "check" "--frozen" "--all" "--all-targets"`
[INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
[INFO] [stdout] 46f950c3e3a016aad26e99aa76ad4792f70a8632d46be9e55a95f8cc1b5b29af
[INFO] running `"docker" "start" "-a" "46f950c3e3a016aad26e99aa76ad4792f70a8632d46be9e55a95f8cc1b5b29af"`
[INFO] [stderr]     Checking rusqbin v0.2.3 (/opt/rustwide/workdir)
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/server.rs:76:23
[INFO] [stderr]    |
[INFO] [stderr] 76 |     type Future = Box<future::Future<Item = Self::Response, Error = Self::Error>>;
[INFO] [stderr]    |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn future::Future<Item = Self::Response, Error = Self::Error>`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/server.rs:80:32
[INFO] [stderr]    |
[INFO] [stderr] 80 |         let result_future: Box<Future<Item = Response, Error = errors::Error>> = {
[INFO] [stderr]    |                                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Response, Error = errors::Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]   --> src/server.rs:97:30
[INFO] [stderr]    |
[INFO] [stderr] 97 |                     Box::new((self.insert_request(req)))
[INFO] [stderr]    |                              ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:119:10
[INFO] [stderr]     |
[INFO] [stderr] 119 | ) -> Box<Future<Item = Response, Error = errors::Error>> {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Response, Error = errors::Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:230:51
[INFO] [stderr]     |
[INFO] [stderr] 230 |     fn insert_request(&self, req: Request) -> Box<future::Future<Item = Response, Error = Error>> {
[INFO] [stderr]     |                                                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn future::Future<Item = Response, Error = Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:288:10
[INFO] [stderr]     |
[INFO] [stderr] 288 | ) -> Box<Future<Item = models::Request, Error = errors::Error>> {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = models::Request, Error = errors::Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:315:26
[INFO] [stderr]     |
[INFO] [stderr] 315 |     let future_body: Box<Future<Item = Option<String>, Error = errors::Error>> =
[INFO] [stderr]     |                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Option<String>, Error = errors::Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:370:40
[INFO] [stderr]     |
[INFO] [stderr] 370 | fn read_to_string(req: Request) -> Box<Future<Item = Option<String>, Error = Error>> {
[INFO] [stderr]     |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Option<String>, Error = Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:382:39
[INFO] [stderr]     |
[INFO] [stderr] 382 | fn read_to_bytes(req: Request) -> Box<Future<Item = Vec<u8>, Error = Error>> {
[INFO] [stderr]     |                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Vec<u8>, Error = Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/errors.rs:109:32
[INFO] [stderr]     |
[INFO] [stderr] 109 |     fn cause(&self) -> Option<&StdErr> {
[INFO] [stderr]     |                                ^^^^^^ help: use `dyn`: `dyn StdErr`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::ONCE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/server.rs:32:1
[INFO] [stderr]    |
[INFO] [stderr] 32 | / lazy_static! {
[INFO] [stderr] 33 | |     static ref BIN_SUMMARY_PATH_REGEXP: Regex = {
[INFO] [stderr] 34 | |         Regex::new(r"/rusqbins/((?i)[A-F0-9]{8}\-[A-F0-9]{4}\-4[A-F0-9]{3}\-[89AB][A-F0-9]{3}\-[A-F0-9]{12})$").unwrap()
[INFO] [stderr] 35 | |     };
[INFO] [stderr] ...  |
[INFO] [stderr] 38 | |     };
[INFO] [stderr] 39 | | }
[INFO] [stderr]    | |_^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr]    = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::ONCE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/server.rs:32:1
[INFO] [stderr]    |
[INFO] [stderr] 32 | / lazy_static! {
[INFO] [stderr] 33 | |     static ref BIN_SUMMARY_PATH_REGEXP: Regex = {
[INFO] [stderr] 34 | |         Regex::new(r"/rusqbins/((?i)[A-F0-9]{8}\-[A-F0-9]{4}\-4[A-F0-9]{3}\-[89AB][A-F0-9]{3}\-[A-F0-9]{12})$").unwrap()
[INFO] [stderr] 35 | |     };
[INFO] [stderr] ...  |
[INFO] [stderr] 38 | |     };
[INFO] [stderr] 39 | | }
[INFO] [stderr]    | |_^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/server.rs:76:23
[INFO] [stderr]    |
[INFO] [stderr] 76 |     type Future = Box<future::Future<Item = Self::Response, Error = Self::Error>>;
[INFO] [stderr]    |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn future::Future<Item = Self::Response, Error = Self::Error>`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/server.rs:80:32
[INFO] [stderr]    |
[INFO] [stderr] 80 |         let result_future: Box<Future<Item = Response, Error = errors::Error>> = {
[INFO] [stderr]    |                                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Response, Error = errors::Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]   --> src/server.rs:97:30
[INFO] [stderr]    |
[INFO] [stderr] 97 |                     Box::new((self.insert_request(req)))
[INFO] [stderr]    |                              ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:119:10
[INFO] [stderr]     |
[INFO] [stderr] 119 | ) -> Box<Future<Item = Response, Error = errors::Error>> {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Response, Error = errors::Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:230:51
[INFO] [stderr]     |
[INFO] [stderr] 230 |     fn insert_request(&self, req: Request) -> Box<future::Future<Item = Response, Error = Error>> {
[INFO] [stderr]     |                                                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn future::Future<Item = Response, Error = Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:288:10
[INFO] [stderr]     |
[INFO] [stderr] 288 | ) -> Box<Future<Item = models::Request, Error = errors::Error>> {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = models::Request, Error = errors::Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:315:26
[INFO] [stderr]     |
[INFO] [stderr] 315 |     let future_body: Box<Future<Item = Option<String>, Error = errors::Error>> =
[INFO] [stderr]     |                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Option<String>, Error = errors::Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:370:40
[INFO] [stderr]     |
[INFO] [stderr] 370 | fn read_to_string(req: Request) -> Box<Future<Item = Option<String>, Error = Error>> {
[INFO] [stderr]     |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Option<String>, Error = Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/server.rs:382:39
[INFO] [stderr]     |
[INFO] [stderr] 382 | fn read_to_bytes(req: Request) -> Box<Future<Item = Vec<u8>, Error = Error>> {
[INFO] [stderr]     |                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Vec<u8>, Error = Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/errors.rs:109:32
[INFO] [stderr]     |
[INFO] [stderr] 109 |     fn cause(&self) -> Option<&StdErr> {
[INFO] [stderr]     |                                ^^^^^^ help: use `dyn`: `dyn StdErr`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::ONCE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/server.rs:32:1
[INFO] [stderr]    |
[INFO] [stderr] 32 | / lazy_static! {
[INFO] [stderr] 33 | |     static ref BIN_SUMMARY_PATH_REGEXP: Regex = {
[INFO] [stderr] 34 | |         Regex::new(r"/rusqbins/((?i)[A-F0-9]{8}\-[A-F0-9]{4}\-4[A-F0-9]{3}\-[89AB][A-F0-9]{3}\-[A-F0-9]{12})$").unwrap()
[INFO] [stderr] 35 | |     };
[INFO] [stderr] ...  |
[INFO] [stderr] 38 | |     };
[INFO] [stderr] 39 | | }
[INFO] [stderr]    | |_^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr]    = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::ONCE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/server.rs:32:1
[INFO] [stderr]    |
[INFO] [stderr] 32 | / lazy_static! {
[INFO] [stderr] 33 | |     static ref BIN_SUMMARY_PATH_REGEXP: Regex = {
[INFO] [stderr] 34 | |         Regex::new(r"/rusqbins/((?i)[A-F0-9]{8}\-[A-F0-9]{4}\-4[A-F0-9]{3}\-[89AB][A-F0-9]{3}\-[A-F0-9]{12})$").unwrap()
[INFO] [stderr] 35 | |     };
[INFO] [stderr] ...  |
[INFO] [stderr] 38 | |     };
[INFO] [stderr] 39 | | }
[INFO] [stderr]    | |_^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:100:44
[INFO] [stderr]     |
[INFO] [stderr] 100 |             &AddressParsingErr(ref e) => e.description(),
[INFO] [stderr]     |                                            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:101:44
[INFO] [stderr]     |
[INFO] [stderr] 101 |             &JsonEncodingError(ref e) => e.description(),
[INFO] [stderr]     |                                            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:102:34
[INFO] [stderr]     |
[INFO] [stderr] 102 |             &IOError(ref e) => e.description(),
[INFO] [stderr]     |                                  ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:103:37
[INFO] [stderr]     |
[INFO] [stderr] 103 |             &RegexError(ref e) => e.description(),
[INFO] [stderr]     |                                     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:104:40
[INFO] [stderr]     |
[INFO] [stderr] 104 |             &UrlParseError(ref e) => e.description(),
[INFO] [stderr]     |                                        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:105:38
[INFO] [stderr]     |
[INFO] [stderr] 105 |             &ServerError(ref e) => e.description(),
[INFO] [stderr]     |                                      ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:100:44
[INFO] [stderr]     |
[INFO] [stderr] 100 |             &AddressParsingErr(ref e) => e.description(),
[INFO] [stderr]     |                                            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:101:44
[INFO] [stderr]     |
[INFO] [stderr] 101 |             &JsonEncodingError(ref e) => e.description(),
[INFO] [stderr]     |                                            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:102:34
[INFO] [stderr]     |
[INFO] [stderr] 102 |             &IOError(ref e) => e.description(),
[INFO] [stderr]     |                                  ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:103:37
[INFO] [stderr]     |
[INFO] [stderr] 103 |             &RegexError(ref e) => e.description(),
[INFO] [stderr]     |                                     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:104:40
[INFO] [stderr]     |
[INFO] [stderr] 104 |             &UrlParseError(ref e) => e.description(),
[INFO] [stderr]     |                                        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/errors.rs:105:38
[INFO] [stderr]     |
[INFO] [stderr] 105 |             &ServerError(ref e) => e.description(),
[INFO] [stderr]     |                                      ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/main.rs:45:35
[INFO] [stderr]    |
[INFO] [stderr] 45 | fn inner_main() -> Result<(), Box<Error>> {
[INFO] [stderr]    |                                   ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/main.rs:77:46
[INFO] [stderr]    |
[INFO] [stderr] 77 | fn start_on_port(p: usize) -> Result<(), Box<Error>> {
[INFO] [stderr]    |                                              ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> tests/common/mod.rs:73:60
[INFO] [stderr]    |
[INFO] [stderr] 73 |     pub fn create_bin(&mut self) -> Result<BinSummary, Box<Error>> {
[INFO] [stderr]    |                                                            ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> tests/common/mod.rs:82:78
[INFO] [stderr]    |
[INFO] [stderr] 82 |     pub fn get_bin_summary(&mut self, bin_id: &Id) -> Result<BinSummary, Box<Error>> {
[INFO] [stderr]    |                                                                              ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> tests/common/mod.rs:90:67
[INFO] [stderr]    |
[INFO] [stderr] 90 |     pub fn delete_bin(&mut self, bin_id: &Id) -> Result<bool, Box<Error>> {
[INFO] [stderr]    |                                                                   ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> tests/common/mod.rs:99:81
[INFO] [stderr]    |
[INFO] [stderr] 99 |     pub fn get_bin_requests(&mut self, bin_id: &Id) -> Result<Vec<Request>, Box<Error>> {
[INFO] [stderr]    |                                                                                 ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> tests/common/mod.rs:199:46
[INFO] [stderr]     |
[INFO] [stderr] 199 | pub fn read_to_string(resp: Response) -> Box<Future<Item = String, Error = TestingError>> {
[INFO] [stderr]     |                                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = String, Error = TestingError>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> tests/common/mod.rs:206:45
[INFO] [stderr]     |
[INFO] [stderr] 206 | pub fn read_to_bytes(resp: Response) -> Box<Future<Item = Vec<u8>, Error = TestingError>> {
[INFO] [stderr]     |                                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Vec<u8>, Error = TestingError>`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> tests/common/mod.rs:30:48
[INFO] [stderr]    |
[INFO] [stderr] 30 | use std::sync::atomic::{AtomicUsize, Ordering, ATOMIC_USIZE_INIT};
[INFO] [stderr]    |                                                ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> tests/common/mod.rs:32:32
[INFO] [stderr]    |
[INFO] [stderr] 32 | static PORT_NUM: AtomicUsize = ATOMIC_USIZE_INIT;
[INFO] [stderr]    |                                ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `AtomicUsize::new(0)`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/main.rs:45:35
[INFO] [stderr]    |
[INFO] [stderr] 45 | fn inner_main() -> Result<(), Box<Error>> {
[INFO] [stderr]    |                                   ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/main.rs:77:46
[INFO] [stderr]    |
[INFO] [stderr] 77 | fn start_on_port(p: usize) -> Result<(), Box<Error>> {
[INFO] [stderr]    |                                              ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> tests/common/mod.rs:73:60
[INFO] [stderr]    |
[INFO] [stderr] 73 |     pub fn create_bin(&mut self) -> Result<BinSummary, Box<Error>> {
[INFO] [stderr]    |                                                            ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> tests/common/mod.rs:82:78
[INFO] [stderr]    |
[INFO] [stderr] 82 |     pub fn get_bin_summary(&mut self, bin_id: &Id) -> Result<BinSummary, Box<Error>> {
[INFO] [stderr]    |                                                                              ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> tests/common/mod.rs:90:67
[INFO] [stderr]    |
[INFO] [stderr] 90 |     pub fn delete_bin(&mut self, bin_id: &Id) -> Result<bool, Box<Error>> {
[INFO] [stderr]    |                                                                   ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> tests/common/mod.rs:99:81
[INFO] [stderr]    |
[INFO] [stderr] 99 |     pub fn get_bin_requests(&mut self, bin_id: &Id) -> Result<Vec<Request>, Box<Error>> {
[INFO] [stderr]    |                                                                                 ^^^^^ help: use `dyn`: `dyn Error`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> tests/common/mod.rs:199:46
[INFO] [stderr]     |
[INFO] [stderr] 199 | pub fn read_to_string(resp: Response) -> Box<Future<Item = String, Error = TestingError>> {
[INFO] [stderr]     |                                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = String, Error = TestingError>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> tests/common/mod.rs:206:45
[INFO] [stderr]     |
[INFO] [stderr] 206 | pub fn read_to_bytes(resp: Response) -> Box<Future<Item = Vec<u8>, Error = TestingError>> {
[INFO] [stderr]     |                                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item = Vec<u8>, Error = TestingError>`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> tests/common/mod.rs:30:48
[INFO] [stderr]    |
[INFO] [stderr] 30 | use std::sync::atomic::{AtomicUsize, Ordering, ATOMIC_USIZE_INIT};
[INFO] [stderr]    |                                                ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> tests/common/mod.rs:32:32
[INFO] [stderr]    |
[INFO] [stderr] 32 | static PORT_NUM: AtomicUsize = ATOMIC_USIZE_INIT;
[INFO] [stderr]    |                                ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `AtomicUsize::new(0)`
[INFO] [stderr] 
[INFO] [stderr]     Finished dev [unoptimized + debuginfo] target(s) in 8.47s
[INFO] running `"docker" "inspect" "46f950c3e3a016aad26e99aa76ad4792f70a8632d46be9e55a95f8cc1b5b29af"`
[INFO] running `"docker" "rm" "-f" "46f950c3e3a016aad26e99aa76ad4792f70a8632d46be9e55a95f8cc1b5b29af"`
[INFO] [stdout] 46f950c3e3a016aad26e99aa76ad4792f70a8632d46be9e55a95f8cc1b5b29af
