[INFO] crate shs_async 0.3.0 is already in cache
[INFO] checking shs_async-0.3.0 against master#bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc for pr-70917
[INFO] extracting crate shs_async 0.3.0 into /workspace/builds/worker-14/source
[INFO] validating manifest of crates.io crate shs_async 0.3.0 on toolchain bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking crates.io crate shs_async 0.3.0
[INFO] finished tweaking crates.io crate shs_async 0.3.0
[INFO] tweaked toml for crates.io crate shs_async 0.3.0 written to /workspace/builds/worker-14/source/Cargo.toml
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"`
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-14/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-14/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" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "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] f90f4451d759f521a495a0ffacc62f814392b8992f823582f6ab7b64b7a058fe
[INFO] running `"docker" "start" "-a" "f90f4451d759f521a495a0ffacc62f814392b8992f823582f6ab7b64b7a058fe"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Checking readwrite v0.1.1
[INFO] [stderr]     Checking async-ringbuffer v0.5.5
[INFO] [stderr]     Checking futures-util-preview v0.3.0-alpha.19
[INFO] [stderr]     Checking ssb-crypto v0.1.4
[INFO] [stderr]     Checking shs_core v0.3.0
[INFO] [stderr]     Checking futures-executor-preview v0.3.0-alpha.19
[INFO] [stderr]     Checking futures-preview v0.3.0-alpha.19
[INFO] [stderr]     Checking shs_async v0.3.0 (/opt/rustwide/workdir)
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:27:13
[INFO] [stderr]    |
[INFO] [stderr] 27 |     let r = await!(try_client_side(&mut stream, net_key, pk, sk, server_pk));
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `try_client_side(&mut stream, net_key, pk, sk, server_pk).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:29:9
[INFO] [stderr]    |
[INFO] [stderr] 29 |         await!(stream.close()).unwrap_or(());
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.close().await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:49:5
[INFO] [stderr]    |
[INFO] [stderr] 49 |     await!(stream.write_all(&hello.as_slice()))?;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.write_all(&hello.as_slice()).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:50:5
[INFO] [stderr]    |
[INFO] [stderr] 50 |     await!(stream.flush())?;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.flush().await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:54:9
[INFO] [stderr]    |
[INFO] [stderr] 54 |         await!(stream.read_exact(&mut buf))?;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.read_exact(&mut buf).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:67:5
[INFO] [stderr]    |
[INFO] [stderr] 67 |     await!(stream.write_all(client_auth.as_slice()))?;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.write_all(client_auth.as_slice()).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:68:5
[INFO] [stderr]    |
[INFO] [stderr] 68 |     await!(stream.flush())?;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.flush().await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:71:5
[INFO] [stderr]    |
[INFO] [stderr] 71 |     await!(stream.read_exact(&mut buf))?;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.read_exact(&mut buf).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:94:13
[INFO] [stderr]    |
[INFO] [stderr] 94 |     let r = await!(try_server_side(&mut stream, net_key, pk, sk));
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `try_server_side(&mut stream, net_key, pk, sk).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:96:9
[INFO] [stderr]    |
[INFO] [stderr] 96 |         await!(stream.close()).unwrap_or(());
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.close().await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:117:9
[INFO] [stderr]     |
[INFO] [stderr] 117 |         await!(stream.read_exact(&mut buf))?;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.read_exact(&mut buf).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:124:5
[INFO] [stderr]     |
[INFO] [stderr] 124 |     await!(stream.write_all(hello.as_slice()))?;
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.write_all(hello.as_slice()).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:125:5
[INFO] [stderr]     |
[INFO] [stderr] 125 |     await!(stream.flush())?;
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.flush().await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:134:9
[INFO] [stderr]     |
[INFO] [stderr] 134 |         await!(stream.read_exact(&mut buf))?;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.read_exact(&mut buf).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:146:5
[INFO] [stderr]     |
[INFO] [stderr] 146 |     await!(stream.write_all(server_acc.as_slice()))?;
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.write_all(server_acc.as_slice()).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:147:5
[INFO] [stderr]     |
[INFO] [stderr] 147 |     await!(stream.flush())?;
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.flush().await`
[INFO] [stderr] 
[INFO] [stderr] error[E0557]: feature has been removed
[INFO] [stderr]  --> src/lib.rs:1:25
[INFO] [stderr]   |
[INFO] [stderr] 1 | #![feature(async_await, await_macro)]
[INFO] [stderr]   |                         ^^^^^^^^^^^ feature has been removed
[INFO] [stderr]   |
[INFO] [stderr]   = note: subsumed by `.await` syntax
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:27:13
[INFO] [stderr]    |
[INFO] [stderr] 27 |     let r = await!(try_client_side(&mut stream, net_key, pk, sk, server_pk));
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `try_client_side(&mut stream, net_key, pk, sk, server_pk).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:29:9
[INFO] [stderr]    |
[INFO] [stderr] 29 |         await!(stream.close()).unwrap_or(());
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.close().await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:49:5
[INFO] [stderr]    |
[INFO] [stderr] 49 |     await!(stream.write_all(&hello.as_slice()))?;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.write_all(&hello.as_slice()).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:50:5
[INFO] [stderr]    |
[INFO] [stderr] 50 |     await!(stream.flush())?;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.flush().await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:54:9
[INFO] [stderr]    |
[INFO] [stderr] 54 |         await!(stream.read_exact(&mut buf))?;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.read_exact(&mut buf).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:67:5
[INFO] [stderr]    |
[INFO] [stderr] 67 |     await!(stream.write_all(client_auth.as_slice()))?;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.write_all(client_auth.as_slice()).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:68:5
[INFO] [stderr]    |
[INFO] [stderr] 68 |     await!(stream.flush())?;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.flush().await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:71:5
[INFO] [stderr]    |
[INFO] [stderr] 71 |     await!(stream.read_exact(&mut buf))?;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.read_exact(&mut buf).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:94:13
[INFO] [stderr]    |
[INFO] [stderr] 94 |     let r = await!(try_server_side(&mut stream, net_key, pk, sk));
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `try_server_side(&mut stream, net_key, pk, sk).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]   --> src/lib.rs:96:9
[INFO] [stderr]    |
[INFO] [stderr] 96 |         await!(stream.close()).unwrap_or(());
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.close().await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:117:9
[INFO] [stderr]     |
[INFO] [stderr] 117 |         await!(stream.read_exact(&mut buf))?;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.read_exact(&mut buf).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:124:5
[INFO] [stderr]     |
[INFO] [stderr] 124 |     await!(stream.write_all(hello.as_slice()))?;
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.write_all(hello.as_slice()).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:125:5
[INFO] [stderr]     |
[INFO] [stderr] 125 |     await!(stream.flush())?;
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.flush().await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:134:9
[INFO] [stderr]     |
[INFO] [stderr] 134 |         await!(stream.read_exact(&mut buf))?;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.read_exact(&mut buf).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:146:5
[INFO] [stderr]     |
[INFO] [stderr] 146 |     await!(stream.write_all(server_acc.as_slice()))?;
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.write_all(server_acc.as_slice()).await`
[INFO] [stderr] 
[INFO] [stderr] error: incorrect use of `await`
[INFO] [stderr]    --> src/lib.rs:147:5
[INFO] [stderr]     |
[INFO] [stderr] 147 |     await!(stream.flush())?;
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^ help: `await` is a postfix operation: `stream.flush().await`
[INFO] [stderr] 
[INFO] [stderr] error[E0557]: feature has been removed
[INFO] [stderr]  --> src/lib.rs:1:25
[INFO] [stderr]   |
[INFO] [stderr] 1 | #![feature(async_await, await_macro)]
[INFO] [stderr]   |                         ^^^^^^^^^^^ feature has been removed
[INFO] [stderr]   |
[INFO] [stderr]   = note: subsumed by `.await` syntax
[INFO] [stderr] 
[INFO] [stderr] error[E0432]: unresolved import `futures::join`
[INFO] [stderr]    --> src/lib.rs:164:19
[INFO] [stderr]     |
[INFO] [stderr] 164 |     use futures::{join, Poll};
[INFO] [stderr]     |                   ^^^^ no `join` in the root
[INFO] [stderr] 
[INFO] [stderr] error: cannot determine resolution for the macro `join`
[INFO] [stderr]    --> src/lib.rs:223:13
[INFO] [stderr]     |
[INFO] [stderr] 223 |             join!(client_side, server_side)
[INFO] [stderr]     |             ^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: import resolution is stuck, try simplifying macro imports
[INFO] [stderr] 
[INFO] [stderr] error: cannot determine resolution for the macro `join`
[INFO] [stderr]    --> src/lib.rs:256:13
[INFO] [stderr]     |
[INFO] [stderr] 256 |             join!(client_side, server_side)
[INFO] [stderr]     |             ^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: import resolution is stuck, try simplifying macro imports
[INFO] [stderr] 
[INFO] [stderr] error: cannot determine resolution for the macro `join`
[INFO] [stderr]    --> src/lib.rs:288:13
[INFO] [stderr]     |
[INFO] [stderr] 288 |             join!(client_side, server_side)
[INFO] [stderr]     |             ^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: import resolution is stuck, try simplifying macro imports
[INFO] [stderr] 
[INFO] [stderr] error: aborting due to 17 previous errors
[INFO] [stderr] 
[INFO] [stderr] For more information about this error, try `rustc --explain E0557`.
[INFO] [stderr] error: could not compile `shs_async`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Reader: futures::AsyncRead` is not satisfied
[INFO] [stderr]    --> src/lib.rs:219:27
[INFO] [stderr]     |
[INFO] [stderr] 19  | pub async fn client<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 25  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |          --------- required by this bound in `client`
[INFO] [stderr] ...
[INFO] [stderr] 219 |         let client_side = client(&mut c_stream, net_key.clone(), c_pk, c_sk, s_pk.clone());
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncRead` is not implemented for `tests::async_ringbuffer::Reader`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Writer: futures::AsyncWrite` is not satisfied
[INFO] [stderr]    --> src/lib.rs:219:27
[INFO] [stderr]     |
[INFO] [stderr] 19  | pub async fn client<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 25  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |                      ---------- required by this bound in `client`
[INFO] [stderr] ...
[INFO] [stderr] 219 |         let client_side = client(&mut c_stream, net_key.clone(), c_pk, c_sk, s_pk.clone());
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncWrite` is not implemented for `tests::async_ringbuffer::Writer`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Reader: futures::AsyncRead` is not satisfied
[INFO] [stderr]    --> src/lib.rs:220:27
[INFO] [stderr]     |
[INFO] [stderr] 87  | pub async fn server<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 92  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |          --------- required by this bound in `server`
[INFO] [stderr] ...
[INFO] [stderr] 220 |         let server_side = server(&mut s_stream, net_key.clone(), s_pk, s_sk);
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncRead` is not implemented for `tests::async_ringbuffer::Reader`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Writer: futures::AsyncWrite` is not satisfied
[INFO] [stderr]    --> src/lib.rs:220:27
[INFO] [stderr]     |
[INFO] [stderr] 87  | pub async fn server<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 92  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |                      ---------- required by this bound in `server`
[INFO] [stderr] ...
[INFO] [stderr] 220 |         let server_side = server(&mut s_stream, net_key.clone(), s_pk, s_sk);
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncWrite` is not implemented for `tests::async_ringbuffer::Writer`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Reader: futures::AsyncRead` is not satisfied
[INFO] [stderr]    --> src/lib.rs:252:27
[INFO] [stderr]     |
[INFO] [stderr] 19  | pub async fn client<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 25  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |          --------- required by this bound in `client`
[INFO] [stderr] ...
[INFO] [stderr] 252 |         let client_side = client(&mut c_stream, NetworkKey::random(), c_pk, c_sk, s_pk.clone());
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncRead` is not implemented for `tests::async_ringbuffer::Reader`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Writer: futures::AsyncWrite` is not satisfied
[INFO] [stderr]    --> src/lib.rs:252:27
[INFO] [stderr]     |
[INFO] [stderr] 19  | pub async fn client<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 25  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |                      ---------- required by this bound in `client`
[INFO] [stderr] ...
[INFO] [stderr] 252 |         let client_side = client(&mut c_stream, NetworkKey::random(), c_pk, c_sk, s_pk.clone());
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncWrite` is not implemented for `tests::async_ringbuffer::Writer`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Reader: futures::AsyncRead` is not satisfied
[INFO] [stderr]    --> src/lib.rs:253:27
[INFO] [stderr]     |
[INFO] [stderr] 87  | pub async fn server<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 92  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |          --------- required by this bound in `server`
[INFO] [stderr] ...
[INFO] [stderr] 253 |         let server_side = server(&mut s_stream, NetworkKey::random(), s_pk, s_sk);
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncRead` is not implemented for `tests::async_ringbuffer::Reader`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Writer: futures::AsyncWrite` is not satisfied
[INFO] [stderr]    --> src/lib.rs:253:27
[INFO] [stderr]     |
[INFO] [stderr] 87  | pub async fn server<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 92  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |                      ---------- required by this bound in `server`
[INFO] [stderr] ...
[INFO] [stderr] 253 |         let server_side = server(&mut s_stream, NetworkKey::random(), s_pk, s_sk);
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncWrite` is not implemented for `tests::async_ringbuffer::Writer`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Reader: futures::AsyncRead` is not satisfied
[INFO] [stderr]    --> src/lib.rs:284:27
[INFO] [stderr]     |
[INFO] [stderr] 19  | pub async fn client<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 25  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |          --------- required by this bound in `client`
[INFO] [stderr] ...
[INFO] [stderr] 284 |         let client_side = client(&mut c_stream, net_key.clone(), c_pk, c_sk, bad_pk);
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncRead` is not implemented for `tests::async_ringbuffer::Reader`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Writer: futures::AsyncWrite` is not satisfied
[INFO] [stderr]    --> src/lib.rs:284:27
[INFO] [stderr]     |
[INFO] [stderr] 19  | pub async fn client<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 25  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |                      ---------- required by this bound in `client`
[INFO] [stderr] ...
[INFO] [stderr] 284 |         let client_side = client(&mut c_stream, net_key.clone(), c_pk, c_sk, bad_pk);
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncWrite` is not implemented for `tests::async_ringbuffer::Writer`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Reader: futures::AsyncRead` is not satisfied
[INFO] [stderr]    --> src/lib.rs:285:27
[INFO] [stderr]     |
[INFO] [stderr] 87  | pub async fn server<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 92  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |          --------- required by this bound in `server`
[INFO] [stderr] ...
[INFO] [stderr] 285 |         let server_side = server(&mut s_stream, net_key.clone(), s_pk, s_sk);
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncRead` is not implemented for `tests::async_ringbuffer::Reader`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncRead` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: the trait bound `tests::async_ringbuffer::Writer: futures::AsyncWrite` is not satisfied
[INFO] [stderr]    --> src/lib.rs:285:27
[INFO] [stderr]     |
[INFO] [stderr] 87  | pub async fn server<S>(mut stream: S,
[INFO] [stderr]     |              ------
[INFO] [stderr] ...
[INFO] [stderr] 92  | where S: AsyncRead + AsyncWrite + Unpin
[INFO] [stderr]     |                      ---------- required by this bound in `server`
[INFO] [stderr] ...
[INFO] [stderr] 285 |         let server_side = server(&mut s_stream, net_key.clone(), s_pk, s_sk);
[INFO] [stderr]     |                           ^^^^^^ the trait `futures::AsyncWrite` is not implemented for `tests::async_ringbuffer::Writer`
[INFO] [stderr]     |
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr]     = note: required because of the requirements on the impl of `futures::AsyncWrite` for `&mut tests::Duplex<tests::async_ringbuffer::Reader, tests::async_ringbuffer::Writer>`
[INFO] [stderr] 
[INFO] [stderr] error: aborting due to 33 previous errors
[INFO] [stderr] 
[INFO] [stderr] Some errors have detailed explanations: E0277, E0432, E0557.
[INFO] [stderr] For more information about an error, try `rustc --explain E0277`.
[INFO] [stderr] error: could not compile `shs_async`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] running `"docker" "inspect" "f90f4451d759f521a495a0ffacc62f814392b8992f823582f6ab7b64b7a058fe"`
[INFO] running `"docker" "rm" "-f" "f90f4451d759f521a495a0ffacc62f814392b8992f823582f6ab7b64b7a058fe"`
[INFO] [stdout] f90f4451d759f521a495a0ffacc62f814392b8992f823582f6ab7b64b7a058fe
