Aug 29 23:20:25.784 INFO checking twist-0.7.1 against try#bc5a74802bb3ffc82f51ef04bca58d64220124c4 for pr-53699 Aug 29 23:20:25.784 INFO running: cargo +bc5a74802bb3ffc82f51ef04bca58d64220124c4-alt check --frozen --all --all-targets Aug 29 23:20:25.784 INFO running `"docker" "create" "-v" "/home/ec2-user/crater/./work/local/test-source/worker-2/pr-53699/try#bc5a74802bb3ffc82f51ef04bca58d64220124c4:/source:ro,Z" "-v" "/home/ec2-user/crater/./work/local/target-dirs/pr-53699/worker-2/try#bc5a74802bb3ffc82f51ef04bca58d64220124c4:/target:rw,Z" "-v" "/home/ec2-user/crater/./work/local/cargo-home:/cargo-home:ro,Z" "-v" "/home/ec2-user/crater/./work/local/rustup-home:/rustup-home:ro,Z" "-e" "USER_ID=500" "-e" "CMD=cargo +bc5a74802bb3ffc82f51ef04bca58d64220124c4-alt check --frozen --all --all-targets" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-m" "2G" "crater"` Aug 29 23:20:25.973 INFO blam! fe54fd16250c76e1162326582b5e6122f19e24c68448d5ca5c4a286d25380d06 Aug 29 23:20:25.975 INFO running `"docker" "start" "-a" "fe54fd16250c76e1162326582b5e6122f19e24c68448d5ca5c4a286d25380d06"` Aug 29 23:20:26.799 INFO kablam! Checking vatfluid v0.3.0 Aug 29 23:20:27.477 INFO kablam! Checking twist v0.7.1 (file:///source) Aug 29 23:20:28.907 INFO kablam! warning: unused import: `str` Aug 29 23:20:28.907 INFO kablam! --> src/codec/mod.rs:11:15 Aug 29 23:20:28.907 INFO kablam! | Aug 29 23:20:28.907 INFO kablam! 11 | use std::{io, str}; Aug 29 23:20:28.907 INFO kablam! | ^^^ Aug 29 23:20:28.907 INFO kablam! | Aug 29 23:20:28.908 INFO kablam! = note: #[warn(unused_imports)] on by default Aug 29 23:20:28.908 INFO kablam! Aug 29 23:20:28.909 INFO kablam! warning: doc comment not used by rustdoc Aug 29 23:20:28.909 INFO kablam! --> src/codec/server/handshake.rs:141:9 Aug 29 23:20:28.909 INFO kablam! | Aug 29 23:20:28.909 INFO kablam! 141 | /// Add the other headers to the response. Aug 29 23:20:28.909 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Aug 29 23:20:28.909 INFO kablam! | Aug 29 23:20:28.909 INFO kablam! = note: #[warn(unused_doc_comments)] on by default Aug 29 23:20:28.909 INFO kablam! Aug 29 23:20:28.913 INFO kablam! warning: doc comment not used by rustdoc Aug 29 23:20:28.913 INFO kablam! --> src/proto/client/mod.rs:42:9 Aug 29 23:20:28.913 INFO kablam! | Aug 29 23:20:28.913 INFO kablam! 42 | /// Setup the protocol middleware chain. Aug 29 23:20:28.913 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Aug 29 23:20:28.913 INFO kablam! Aug 29 23:20:28.914 INFO kablam! warning: unused import: `str` Aug 29 23:20:28.914 INFO kablam! --> src/proto/server/fragmented.rs:8:15 Aug 29 23:20:28.914 INFO kablam! | Aug 29 23:20:28.914 INFO kablam! 8 | use std::{io, str}; Aug 29 23:20:28.914 INFO kablam! | ^^^ Aug 29 23:20:28.914 INFO kablam! Aug 29 23:20:28.915 INFO kablam! warning: doc comment not used by rustdoc Aug 29 23:20:28.915 INFO kablam! --> src/proto/server/mod.rs:86:9 Aug 29 23:20:28.915 INFO kablam! | Aug 29 23:20:28.915 INFO kablam! 86 | /// Setup the protocol middleware chain. Aug 29 23:20:28.915 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Aug 29 23:20:28.915 INFO kablam! Aug 29 23:20:28.953 INFO kablam! warning: use of deprecated item 'tokio_io::codec::Framed': Moved to tokio-codec Aug 29 23:20:28.953 INFO kablam! --> src/proto/client/mod.rs:7:5 Aug 29 23:20:28.953 INFO kablam! | Aug 29 23:20:28.953 INFO kablam! 7 | use tokio_io::codec::Framed; Aug 29 23:20:28.953 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^ Aug 29 23:20:28.953 INFO kablam! | Aug 29 23:20:28.953 INFO kablam! = note: #[warn(deprecated)] on by default Aug 29 23:20:28.953 INFO kablam! Aug 29 23:20:28.953 INFO kablam! warning: use of deprecated item 'tokio_io::codec::Framed': Moved to tokio-codec Aug 29 23:20:28.953 INFO kablam! --> src/proto/server/mod.rs:10:5 Aug 29 23:20:28.953 INFO kablam! | Aug 29 23:20:28.953 INFO kablam! 10 | use tokio_io::codec::Framed; Aug 29 23:20:28.953 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^ Aug 29 23:20:28.953 INFO kablam! Aug 29 23:20:28.953 INFO kablam! warning: use of deprecated item 'tokio_io::codec::Framed': Moved to tokio-codec Aug 29 23:20:28.953 INFO kablam! --> src/proto/server/mod.rs:21:21 Aug 29 23:20:28.953 INFO kablam! | Aug 29 23:20:28.954 INFO kablam! 21 | type BaseCodec = Framed; Aug 29 23:20:28.954 INFO kablam! | ^^^^^^^^^^^^^^^^ Aug 29 23:20:28.954 INFO kablam! Aug 29 23:20:28.955 INFO kablam! warning: use of deprecated item 'tokio_io::codec::Framed': Moved to tokio-codec Aug 29 23:20:28.955 INFO kablam! --> src/proto/client/mod.rs:17:38 Aug 29 23:20:28.955 INFO kablam! | Aug 29 23:20:28.955 INFO kablam! 17 | type Transport = ClientHandshake>; Aug 29 23:20:28.955 INFO kablam! | ^^^^^^^^^^^^^^^^ Aug 29 23:20:28.955 INFO kablam! Aug 29 23:20:29.098 INFO kablam! warning: unused import: `str` Aug 29 23:20:29.098 INFO kablam! --> src/codec/mod.rs:11:15 Aug 29 23:20:29.098 INFO kablam! | Aug 29 23:20:29.098 INFO kablam! 11 | use std::{io, str}; Aug 29 23:20:29.098 INFO kablam! | ^^^ Aug 29 23:20:29.098 INFO kablam! | Aug 29 23:20:29.098 INFO kablam! = note: #[warn(unused_imports)] on by default Aug 29 23:20:29.098 INFO kablam! Aug 29 23:20:29.099 INFO kablam! warning: doc comment not used by rustdoc Aug 29 23:20:29.099 INFO kablam! --> src/codec/server/handshake.rs:141:9 Aug 29 23:20:29.099 INFO kablam! | Aug 29 23:20:29.099 INFO kablam! 141 | /// Add the other headers to the response. Aug 29 23:20:29.099 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Aug 29 23:20:29.100 INFO kablam! | Aug 29 23:20:29.100 INFO kablam! = note: #[warn(unused_doc_comments)] on by default Aug 29 23:20:29.100 INFO kablam! Aug 29 23:20:29.105 INFO kablam! warning: doc comment not used by rustdoc Aug 29 23:20:29.105 INFO kablam! --> src/proto/client/mod.rs:42:9 Aug 29 23:20:29.105 INFO kablam! | Aug 29 23:20:29.105 INFO kablam! 42 | /// Setup the protocol middleware chain. Aug 29 23:20:29.105 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Aug 29 23:20:29.105 INFO kablam! Aug 29 23:20:29.106 INFO kablam! warning: unused import: `str` Aug 29 23:20:29.106 INFO kablam! --> src/proto/server/fragmented.rs:8:15 Aug 29 23:20:29.106 INFO kablam! | Aug 29 23:20:29.106 INFO kablam! 8 | use std::{io, str}; Aug 29 23:20:29.106 INFO kablam! | ^^^ Aug 29 23:20:29.106 INFO kablam! Aug 29 23:20:29.107 INFO kablam! warning: doc comment not used by rustdoc Aug 29 23:20:29.107 INFO kablam! --> src/proto/server/mod.rs:86:9 Aug 29 23:20:29.107 INFO kablam! | Aug 29 23:20:29.107 INFO kablam! 86 | /// Setup the protocol middleware chain. Aug 29 23:20:29.107 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Aug 29 23:20:29.107 INFO kablam! Aug 29 23:20:29.162 INFO kablam! warning: use of deprecated item 'tokio_io::codec::Framed': Moved to tokio-codec Aug 29 23:20:29.162 INFO kablam! --> src/proto/client/mod.rs:7:5 Aug 29 23:20:29.162 INFO kablam! | Aug 29 23:20:29.162 INFO kablam! 7 | use tokio_io::codec::Framed; Aug 29 23:20:29.162 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^ Aug 29 23:20:29.162 INFO kablam! | Aug 29 23:20:29.162 INFO kablam! = note: #[warn(deprecated)] on by default Aug 29 23:20:29.162 INFO kablam! Aug 29 23:20:29.162 INFO kablam! warning: use of deprecated item 'tokio_io::codec::Framed': Moved to tokio-codec Aug 29 23:20:29.162 INFO kablam! --> src/proto/server/mod.rs:10:5 Aug 29 23:20:29.162 INFO kablam! | Aug 29 23:20:29.162 INFO kablam! 10 | use tokio_io::codec::Framed; Aug 29 23:20:29.163 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^ Aug 29 23:20:29.163 INFO kablam! Aug 29 23:20:29.163 INFO kablam! warning: use of deprecated item 'tokio_io::codec::Framed': Moved to tokio-codec Aug 29 23:20:29.163 INFO kablam! --> src/proto/server/mod.rs:21:21 Aug 29 23:20:29.163 INFO kablam! | Aug 29 23:20:29.163 INFO kablam! 21 | type BaseCodec = Framed; Aug 29 23:20:29.163 INFO kablam! | ^^^^^^^^^^^^^^^^ Aug 29 23:20:29.163 INFO kablam! Aug 29 23:20:29.164 INFO kablam! warning: use of deprecated item 'tokio_io::codec::Framed': Moved to tokio-codec Aug 29 23:20:29.164 INFO kablam! --> src/proto/client/mod.rs:17:38 Aug 29 23:20:29.164 INFO kablam! | Aug 29 23:20:29.164 INFO kablam! 17 | type Transport = ClientHandshake>; Aug 29 23:20:29.164 INFO kablam! | ^^^^^^^^^^^^^^^^ Aug 29 23:20:29.164 INFO kablam! Aug 29 23:20:29.310 INFO kablam! warning: use of deprecated item 'bytes::BufMut::put_u32': use put_u32_be or put_u32_le Aug 29 23:20:29.310 INFO kablam! --> src/codec/base.rs:114:14 Aug 29 23:20:29.310 INFO kablam! | Aug 29 23:20:29.310 INFO kablam! 114 | mask_buf.put_u32::(mask); Aug 29 23:20:29.310 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.310 INFO kablam! Aug 29 23:20:29.327 INFO kablam! warning: use of deprecated item 'bytes::Buf::get_u16': use get_u16_be or get_u16_le Aug 29 23:20:29.327 INFO kablam! --> src/codec/base.rs:186:64 Aug 29 23:20:29.327 INFO kablam! | Aug 29 23:20:29.327 INFO kablam! 186 | let len = Cursor::new(buf.split_to(2)).get_u16::(); Aug 29 23:20:29.327 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.327 INFO kablam! Aug 29 23:20:29.328 INFO kablam! warning: use of deprecated item 'bytes::Buf::get_u64': use get_u64_be or get_u64_le Aug 29 23:20:29.328 INFO kablam! --> src/codec/base.rs:195:64 Aug 29 23:20:29.328 INFO kablam! | Aug 29 23:20:29.328 INFO kablam! 195 | let len = Cursor::new(buf.split_to(8)).get_u64::(); Aug 29 23:20:29.328 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.328 INFO kablam! Aug 29 23:20:29.330 INFO kablam! warning: use of deprecated item 'bytes::Buf::get_u32': use get_u32_be or get_u32_le Aug 29 23:20:29.330 INFO kablam! --> src/codec/base.rs:213:65 Aug 29 23:20:29.330 INFO kablam! | Aug 29 23:20:29.330 INFO kablam! 213 | let mask = Cursor::new(buf.split_to(4)).get_u32::(); Aug 29 23:20:29.330 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.331 INFO kablam! Aug 29 23:20:29.349 INFO kablam! warning: use of deprecated item 'bytes::BufMut::put_u16': use put_u16_be or put_u16_le Aug 29 23:20:29.349 INFO kablam! --> src/codec/base.rs:314:21 Aug 29 23:20:29.349 INFO kablam! | Aug 29 23:20:29.349 INFO kablam! 314 | len_buf.put_u16::(cast_len); Aug 29 23:20:29.350 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.350 INFO kablam! Aug 29 23:20:29.350 INFO kablam! warning: use of deprecated item 'bytes::BufMut::put_u64': use put_u64_be or put_u64_le Aug 29 23:20:29.350 INFO kablam! --> src/codec/base.rs:320:21 Aug 29 23:20:29.350 INFO kablam! | Aug 29 23:20:29.351 INFO kablam! 320 | len_buf.put_u64::(len); Aug 29 23:20:29.351 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.351 INFO kablam! Aug 29 23:20:29.351 INFO kablam! warning: use of deprecated item 'bytes::BufMut::put_u32': use put_u32_be or put_u32_le Aug 29 23:20:29.351 INFO kablam! --> src/codec/base.rs:327:22 Aug 29 23:20:29.351 INFO kablam! | Aug 29 23:20:29.351 INFO kablam! 327 | mask_buf.put_u32::(msg.mask()); Aug 29 23:20:29.352 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.352 INFO kablam! Aug 29 23:20:29.604 INFO kablam! warning: use of deprecated item 'bytes::BufMut::put_u32': use put_u32_be or put_u32_le Aug 29 23:20:29.604 INFO kablam! --> src/codec/base.rs:114:14 Aug 29 23:20:29.604 INFO kablam! | Aug 29 23:20:29.604 INFO kablam! 114 | mask_buf.put_u32::(mask); Aug 29 23:20:29.604 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.604 INFO kablam! Aug 29 23:20:29.628 INFO kablam! warning: use of deprecated item 'bytes::Buf::get_u16': use get_u16_be or get_u16_le Aug 29 23:20:29.628 INFO kablam! --> src/codec/base.rs:186:64 Aug 29 23:20:29.628 INFO kablam! | Aug 29 23:20:29.628 INFO kablam! 186 | let len = Cursor::new(buf.split_to(2)).get_u16::(); Aug 29 23:20:29.628 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.628 INFO kablam! Aug 29 23:20:29.629 INFO kablam! warning: use of deprecated item 'bytes::Buf::get_u64': use get_u64_be or get_u64_le Aug 29 23:20:29.629 INFO kablam! --> src/codec/base.rs:195:64 Aug 29 23:20:29.629 INFO kablam! | Aug 29 23:20:29.629 INFO kablam! 195 | let len = Cursor::new(buf.split_to(8)).get_u64::(); Aug 29 23:20:29.629 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.629 INFO kablam! Aug 29 23:20:29.631 INFO kablam! warning: use of deprecated item 'bytes::Buf::get_u32': use get_u32_be or get_u32_le Aug 29 23:20:29.631 INFO kablam! --> src/codec/base.rs:213:65 Aug 29 23:20:29.631 INFO kablam! | Aug 29 23:20:29.631 INFO kablam! 213 | let mask = Cursor::new(buf.split_to(4)).get_u32::(); Aug 29 23:20:29.631 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.631 INFO kablam! Aug 29 23:20:29.660 INFO kablam! warning: use of deprecated item 'bytes::BufMut::put_u16': use put_u16_be or put_u16_le Aug 29 23:20:29.660 INFO kablam! --> src/codec/base.rs:314:21 Aug 29 23:20:29.660 INFO kablam! | Aug 29 23:20:29.660 INFO kablam! 314 | len_buf.put_u16::(cast_len); Aug 29 23:20:29.660 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.660 INFO kablam! Aug 29 23:20:29.661 INFO kablam! warning: use of deprecated item 'bytes::BufMut::put_u64': use put_u64_be or put_u64_le Aug 29 23:20:29.661 INFO kablam! --> src/codec/base.rs:320:21 Aug 29 23:20:29.661 INFO kablam! | Aug 29 23:20:29.661 INFO kablam! 320 | len_buf.put_u64::(len); Aug 29 23:20:29.661 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.661 INFO kablam! Aug 29 23:20:29.662 INFO kablam! warning: use of deprecated item 'bytes::BufMut::put_u32': use put_u32_be or put_u32_le Aug 29 23:20:29.662 INFO kablam! --> src/codec/base.rs:327:22 Aug 29 23:20:29.662 INFO kablam! | Aug 29 23:20:29.662 INFO kablam! 327 | mask_buf.put_u32::(msg.mask()); Aug 29 23:20:29.662 INFO kablam! | ^^^^^^^ Aug 29 23:20:29.662 INFO kablam! Aug 29 23:20:29.694 INFO kablam! warning: use of deprecated item 'tokio_io::AsyncRead::framed': Use tokio_codec::Decoder::framed instead Aug 29 23:20:29.694 INFO kablam! --> src/proto/client/mod.rs:35:53 Aug 29 23:20:29.694 INFO kablam! | Aug 29 23:20:29.694 INFO kablam! 35 | let mut handshake = ClientHandshake::new(io.framed(twist)); Aug 29 23:20:29.694 INFO kablam! | ^^^^^^ Aug 29 23:20:29.694 INFO kablam! Aug 29 23:20:29.727 INFO kablam! warning: use of deprecated item 'tokio_io::AsyncRead::framed': Use tokio_codec::Decoder::framed instead Aug 29 23:20:29.727 INFO kablam! --> src/proto/server/mod.rs:48:49 Aug 29 23:20:29.727 INFO kablam! | Aug 29 23:20:29.727 INFO kablam! 48 | let mut fragmented = Fragmented::new(io.framed(twist), Aug 29 23:20:29.727 INFO kablam! | ^^^^^^ Aug 29 23:20:29.727 INFO kablam! Aug 29 23:20:29.992 INFO kablam! warning: use of deprecated item 'tokio_io::AsyncRead::framed': Use tokio_codec::Decoder::framed instead Aug 29 23:20:29.992 INFO kablam! --> src/proto/client/mod.rs:35:53 Aug 29 23:20:29.992 INFO kablam! | Aug 29 23:20:29.992 INFO kablam! 35 | let mut handshake = ClientHandshake::new(io.framed(twist)); Aug 29 23:20:29.992 INFO kablam! | ^^^^^^ Aug 29 23:20:29.992 INFO kablam! Aug 29 23:20:30.024 INFO kablam! warning: use of deprecated item 'tokio_io::AsyncRead::framed': Use tokio_codec::Decoder::framed instead Aug 29 23:20:30.024 INFO kablam! --> src/proto/server/mod.rs:48:49 Aug 29 23:20:30.024 INFO kablam! | Aug 29 23:20:30.024 INFO kablam! 48 | let mut fragmented = Fragmented::new(io.framed(twist), Aug 29 23:20:30.024 INFO kablam! | ^^^^^^ Aug 29 23:20:30.024 INFO kablam! Aug 29 23:20:30.484 INFO kablam! warning: variable does not need to be mutable Aug 29 23:20:30.484 INFO kablam! --> src/proto/mod.rs:76:13 Aug 29 23:20:30.484 INFO kablam! | Aug 29 23:20:30.484 INFO kablam! 76 | let mut vec = map.entry(self.uuid).or_insert_with(Vec::new); Aug 29 23:20:30.484 INFO kablam! | ----^^^ Aug 29 23:20:30.485 INFO kablam! | | Aug 29 23:20:30.485 INFO kablam! | help: remove this `mut` Aug 29 23:20:30.485 INFO kablam! | Aug 29 23:20:30.485 INFO kablam! = note: #[warn(unused_mut)] on by default Aug 29 23:20:30.485 INFO kablam! Aug 29 23:20:30.489 INFO kablam! warning: variable does not need to be mutable Aug 29 23:20:30.489 INFO kablam! --> src/proto/mod.rs:90:13 Aug 29 23:20:30.489 INFO kablam! | Aug 29 23:20:30.489 INFO kablam! 90 | let mut vec = map.entry(self.uuid).or_insert_with(Vec::new); Aug 29 23:20:30.489 INFO kablam! | ----^^^ Aug 29 23:20:30.489 INFO kablam! | | Aug 29 23:20:30.489 INFO kablam! | help: remove this `mut` Aug 29 23:20:30.489 INFO kablam! Aug 29 23:20:30.783 INFO kablam! warning: variable does not need to be mutable Aug 29 23:20:30.783 INFO kablam! --> src/proto/mod.rs:76:13 Aug 29 23:20:30.783 INFO kablam! | Aug 29 23:20:30.783 INFO kablam! 76 | let mut vec = map.entry(self.uuid).or_insert_with(Vec::new); Aug 29 23:20:30.784 INFO kablam! | ----^^^ Aug 29 23:20:30.784 INFO kablam! | | Aug 29 23:20:30.784 INFO kablam! | help: remove this `mut` Aug 29 23:20:30.784 INFO kablam! | Aug 29 23:20:30.784 INFO kablam! = note: #[warn(unused_mut)] on by default Aug 29 23:20:30.784 INFO kablam! Aug 29 23:20:30.788 INFO kablam! warning: variable does not need to be mutable Aug 29 23:20:30.788 INFO kablam! --> src/proto/mod.rs:90:13 Aug 29 23:20:30.788 INFO kablam! | Aug 29 23:20:30.788 INFO kablam! 90 | let mut vec = map.entry(self.uuid).or_insert_with(Vec::new); Aug 29 23:20:30.788 INFO kablam! | ----^^^ Aug 29 23:20:30.788 INFO kablam! | | Aug 29 23:20:30.788 INFO kablam! | help: remove this `mut` Aug 29 23:20:30.788 INFO kablam! Aug 29 23:20:31.072 INFO kablam! Finished dev [unoptimized + debuginfo] target(s) in 4.42s Aug 29 23:20:31.085 INFO kablam! su: No module specific data is present Aug 29 23:20:31.494 INFO running `"docker" "rm" "-f" "fe54fd16250c76e1162326582b5e6122f19e24c68448d5ca5c4a286d25380d06"` Aug 29 23:20:31.637 INFO blam! fe54fd16250c76e1162326582b5e6122f19e24c68448d5ca5c4a286d25380d06