[INFO] cloning repository https://github.com/telecrab-rs/telecrab
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/telecrab-rs/telecrab" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftelecrab-rs%2Ftelecrab", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftelecrab-rs%2Ftelecrab'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 4d3b19231b1614cabf73d4ea64ed474c4c2e43cd
[INFO] testing telecrab-rs/telecrab against beta-2025-09-21 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftelecrab-rs%2Ftelecrab" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/telecrab-rs/telecrab
[INFO] finished tweaking git repo https://github.com/telecrab-rs/telecrab
[INFO] tweaked toml for git repo https://github.com/telecrab-rs/telecrab written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/telecrab-rs/telecrab on toolchain beta-2025-09-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/telecrab-rs/telecrab already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 99531750707c0dd02b2cf7954671aff358b4d3d730e49b02d696b45676f8e74b
[INFO] running `Command { std: "docker" "start" "-a" "99531750707c0dd02b2cf7954671aff358b4d3d730e49b02d696b45676f8e74b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "99531750707c0dd02b2cf7954671aff358b4d3d730e49b02d696b45676f8e74b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "99531750707c0dd02b2cf7954671aff358b4d3d730e49b02d696b45676f8e74b", kill_on_drop: false }`
[INFO] [stdout] 99531750707c0dd02b2cf7954671aff358b4d3d730e49b02d696b45676f8e74b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 91746b01f0224654a38ccdadfc0023524439319d539c1c278cd6cf5f219e5a1f
[INFO] running `Command { std: "docker" "start" "-a" "91746b01f0224654a38ccdadfc0023524439319d539c1c278cd6cf5f219e5a1f", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.79
[INFO] [stderr]    Compiling libc v0.2.153
[INFO] [stderr]    Compiling semver v1.0.22
[INFO] [stderr]    Compiling serde v1.0.197
[INFO] [stderr]    Compiling subtle v2.5.0
[INFO] [stderr]    Compiling platforms v3.3.0
[INFO] [stderr]    Compiling futures-core v0.3.30
[INFO] [stderr]    Compiling utf8parse v0.2.1
[INFO] [stderr]    Compiling futures-sink v0.3.30
[INFO] [stderr]    Compiling anstyle-parse v0.2.3
[INFO] [stderr]    Compiling inout v0.1.3
[INFO] [stderr]    Compiling colorchoice v1.0.0
[INFO] [stderr]    Compiling futures-channel v0.3.30
[INFO] [stderr]    Compiling anstyle-query v1.0.2
[INFO] [stderr]    Compiling smallvec v1.13.2
[INFO] [stderr]    Compiling anstyle v1.0.6
[INFO] [stderr]    Compiling indexmap v2.2.6
[INFO] [stderr]    Compiling cipher v0.4.4
[INFO] [stderr]    Compiling quote v1.0.35
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling clap_lex v0.7.0
[INFO] [stderr]    Compiling anstream v0.6.13
[INFO] [stderr]    Compiling strsim v0.11.0
[INFO] [stderr]    Compiling winnow v0.6.5
[INFO] [stderr]    Compiling rustc_version v0.4.0
[INFO] [stderr]    Compiling syn v2.0.53
[INFO] [stderr]    Compiling bytes v1.6.0
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling clap_builder v4.5.2
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling curve25519-dalek v4.1.2
[INFO] [stderr]    Compiling getrandom v0.2.12
[INFO] [stderr]    Compiling parking_lot_core v0.9.9
[INFO] [stderr]    Compiling num_cpus v1.16.0
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling parking_lot v0.12.1
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling signal-hook-registry v1.4.1
[INFO] [stderr]    Compiling socket2 v0.5.6
[INFO] [stderr]    Compiling mio v0.8.11
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling ctr v0.9.2
[INFO] [stderr]    Compiling aes v0.8.4
[INFO] [stderr]    Compiling base64 v0.22.0
[INFO] [stderr]    Compiling serde_derive v1.0.197
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]    Compiling zeroize_derive v1.4.2
[INFO] [stderr]    Compiling curve25519-dalek-derive v0.1.1
[INFO] [stderr]    Compiling tokio-macros v2.2.0
[INFO] [stderr]    Compiling clap_derive v4.5.3
[INFO] [stderr]    Compiling zeroize v1.7.0
[INFO] [stderr]    Compiling tokio v1.36.0
[INFO] [stderr]    Compiling futures-util v0.3.30
[INFO] [stderr]    Compiling x25519-dalek v2.0.1
[INFO] [stderr]    Compiling clap v4.5.3
[INFO] [stderr]    Compiling futures-executor v0.3.30
[INFO] [stderr]    Compiling futures v0.3.30
[INFO] [stderr]    Compiling serde_spanned v0.6.5
[INFO] [stderr]    Compiling toml_datetime v0.6.5
[INFO] [stderr]    Compiling toml_edit v0.22.9
[INFO] [stderr]    Compiling toml v0.8.12
[INFO] [stderr]    Compiling telecrab v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `dc`
[INFO] [stdout]    --> src/tokio_utils.rs:140:21
[INFO] [stdout]     |
[INFO] [stdout] 140 |         let (inner, dc, encryptor, decryptor) = (
[INFO] [stdout]     |                     ^^ help: if this is intentional, prefix it with an underscore: `_dc`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_DC` is never used
[INFO] [stdout]  --> src/obfuscated2/frame.rs:1:11
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub const DEFAULT_DC: u8 = 2;
[INFO] [stdout]   |           ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/proxy.rs:20:30
[INFO] [stdout]    |
[INFO] [stdout] 20 |     TelegramConnectionOpened(std::net::SocketAddr),
[INFO] [stdout]    |     ------------------------ ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 20 -     TelegramConnectionOpened(std::net::SocketAddr),
[INFO] [stdout] 20 +     TelegramConnectionOpened(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/proxy.rs:21:22
[INFO] [stdout]    |
[INFO] [stdout] 21 |     ConnectionOpened(std::net::SocketAddr),
[INFO] [stdout]    |     ---------------- ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 21 -     ConnectionOpened(std::net::SocketAddr),
[INFO] [stdout] 21 +     ConnectionOpened(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/proxy.rs:22:22
[INFO] [stdout]    |
[INFO] [stdout] 22 |     ConnectionClosed(Option<std::net::SocketAddr>),
[INFO] [stdout]    |     ---------------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 22 -     ConnectionClosed(Option<std::net::SocketAddr>),
[INFO] [stdout] 22 +     ConnectionClosed(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `0` and `1` are never read
[INFO] [stdout]   --> src/proxy.rs:23:18
[INFO] [stdout]    |
[INFO] [stdout] 23 |     DataReceived(std::net::SocketAddr, Vec<u8>),
[INFO] [stdout]    |     ------------ ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     fields in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the fields to be of unit type to suppress this warning while preserving the field numbering, or remove the fields
[INFO] [stdout]    |
[INFO] [stdout] 23 -     DataReceived(std::net::SocketAddr, Vec<u8>),
[INFO] [stdout] 23 +     DataReceived((), ()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `0` and `1` are never read
[INFO] [stdout]   --> src/proxy.rs:24:14
[INFO] [stdout]    |
[INFO] [stdout] 24 |     DataSent(std::net::SocketAddr, Vec<u8>),
[INFO] [stdout]    |     -------- ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     fields in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the fields to be of unit type to suppress this warning while preserving the field numbering, or remove the fields
[INFO] [stdout]    |
[INFO] [stdout] 24 -     DataSent(std::net::SocketAddr, Vec<u8>),
[INFO] [stdout] 24 +     DataSent((), ()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/proxy.rs:25:16
[INFO] [stdout]    |
[INFO] [stdout] 25 |     DCFallback(i32),
[INFO] [stdout]    |     ---------- ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 25 -     DCFallback(i32),
[INFO] [stdout] 25 +     DCFallback(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/proxy.rs:26:19
[INFO] [stdout]    |
[INFO] [stdout] 26 |     ConnectedToDC(i32),
[INFO] [stdout]    |     ------------- ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 26 -     ConnectedToDC(i32),
[INFO] [stdout] 26 +     ConnectedToDC(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `ProxiedDataToClient` and `ProxiedDataToTelegram` are never constructed
[INFO] [stdout]   --> src/proxy.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub enum ProxyEvent {
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 28 |     ProxiedDataToClient(std::net::SocketAddr, usize),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 29 |     ProxiedDataToTelegram(std::net::SocketAddr, usize),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/proxy.rs:108:17
[INFO] [stdout]     |
[INFO] [stdout] 106 |         &'a self,
[INFO] [stdout]     |          -- the lifetime is named here
[INFO] [stdout] 107 |         socket: &mut tokio::net::TcpStream,
[INFO] [stdout] 108 |     ) -> Result<&crate::config::User, std::io::Error> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^ the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 108 |     ) -> Result<&'a crate::config::User, std::io::Error> {
[INFO] [stdout]     |                  ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/tokio_utils.rs:139:32
[INFO] [stdout]     |
[INFO] [stdout] 139 |     fn split(&'a mut self) -> (HalfReadObfuscatedStream<R>, HalfWriteObfuscatedStream<W>) {
[INFO] [stdout]     |               --               ^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |               |                |
[INFO] [stdout]     |               |                the same lifetime is hidden here
[INFO] [stdout]     |               the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 139 |     fn split(&'a mut self) -> (HalfReadObfuscatedStream<'a, R>, HalfWriteObfuscatedStream<'a, W>) {
[INFO] [stdout]     |                                                         +++                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 56.85s
[INFO] running `Command { std: "docker" "inspect" "91746b01f0224654a38ccdadfc0023524439319d539c1c278cd6cf5f219e5a1f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "91746b01f0224654a38ccdadfc0023524439319d539c1c278cd6cf5f219e5a1f", kill_on_drop: false }`
[INFO] [stdout] 91746b01f0224654a38ccdadfc0023524439319d539c1c278cd6cf5f219e5a1f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f577e715ed6625548399f4400e98b437b624dd379e6d3af691be353f07781fb7
[INFO] running `Command { std: "docker" "start" "-a" "f577e715ed6625548399f4400e98b437b624dd379e6d3af691be353f07781fb7", kill_on_drop: false }`
[INFO] [stderr]    Compiling telecrab v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `dc`
[INFO] [stdout]    --> src/tokio_utils.rs:140:21
[INFO] [stdout]     |
[INFO] [stdout] 140 |         let (inner, dc, encryptor, decryptor) = (
[INFO] [stdout]     |                     ^^ help: if this is intentional, prefix it with an underscore: `_dc`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_DC` is never used
[INFO] [stdout]  --> src/obfuscated2/frame.rs:1:11
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub const DEFAULT_DC: u8 = 2;
[INFO] [stdout]   |           ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/proxy.rs:20:30
[INFO] [stdout]    |
[INFO] [stdout] 20 |     TelegramConnectionOpened(std::net::SocketAddr),
[INFO] [stdout]    |     ------------------------ ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 20 -     TelegramConnectionOpened(std::net::SocketAddr),
[INFO] [stdout] 20 +     TelegramConnectionOpened(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/proxy.rs:21:22
[INFO] [stdout]    |
[INFO] [stdout] 21 |     ConnectionOpened(std::net::SocketAddr),
[INFO] [stdout]    |     ---------------- ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 21 -     ConnectionOpened(std::net::SocketAddr),
[INFO] [stdout] 21 +     ConnectionOpened(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/proxy.rs:22:22
[INFO] [stdout]    |
[INFO] [stdout] 22 |     ConnectionClosed(Option<std::net::SocketAddr>),
[INFO] [stdout]    |     ---------------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 22 -     ConnectionClosed(Option<std::net::SocketAddr>),
[INFO] [stdout] 22 +     ConnectionClosed(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `0` and `1` are never read
[INFO] [stdout]   --> src/proxy.rs:23:18
[INFO] [stdout]    |
[INFO] [stdout] 23 |     DataReceived(std::net::SocketAddr, Vec<u8>),
[INFO] [stdout]    |     ------------ ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     fields in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the fields to be of unit type to suppress this warning while preserving the field numbering, or remove the fields
[INFO] [stdout]    |
[INFO] [stdout] 23 -     DataReceived(std::net::SocketAddr, Vec<u8>),
[INFO] [stdout] 23 +     DataReceived((), ()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `0` and `1` are never read
[INFO] [stdout]   --> src/proxy.rs:24:14
[INFO] [stdout]    |
[INFO] [stdout] 24 |     DataSent(std::net::SocketAddr, Vec<u8>),
[INFO] [stdout]    |     -------- ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     fields in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the fields to be of unit type to suppress this warning while preserving the field numbering, or remove the fields
[INFO] [stdout]    |
[INFO] [stdout] 24 -     DataSent(std::net::SocketAddr, Vec<u8>),
[INFO] [stdout] 24 +     DataSent((), ()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/proxy.rs:25:16
[INFO] [stdout]    |
[INFO] [stdout] 25 |     DCFallback(i32),
[INFO] [stdout]    |     ---------- ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 25 -     DCFallback(i32),
[INFO] [stdout] 25 +     DCFallback(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/proxy.rs:26:19
[INFO] [stdout]    |
[INFO] [stdout] 26 |     ConnectedToDC(i32),
[INFO] [stdout]    |     ------------- ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 26 -     ConnectedToDC(i32),
[INFO] [stdout] 26 +     ConnectedToDC(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `ProxiedDataToClient` and `ProxiedDataToTelegram` are never constructed
[INFO] [stdout]   --> src/proxy.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub enum ProxyEvent {
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 28 |     ProxiedDataToClient(std::net::SocketAddr, usize),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 29 |     ProxiedDataToTelegram(std::net::SocketAddr, usize),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/proxy.rs:108:17
[INFO] [stdout]     |
[INFO] [stdout] 106 |         &'a self,
[INFO] [stdout]     |          -- the lifetime is named here
[INFO] [stdout] 107 |         socket: &mut tokio::net::TcpStream,
[INFO] [stdout] 108 |     ) -> Result<&crate::config::User, std::io::Error> {
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^ the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 108 |     ) -> Result<&'a crate::config::User, std::io::Error> {
[INFO] [stdout]     |                  ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/tokio_utils.rs:139:32
[INFO] [stdout]     |
[INFO] [stdout] 139 |     fn split(&'a mut self) -> (HalfReadObfuscatedStream<R>, HalfWriteObfuscatedStream<W>) {
[INFO] [stdout]     |               --               ^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |               |                |
[INFO] [stdout]     |               |                the same lifetime is hidden here
[INFO] [stdout]     |               the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 139 |     fn split(&'a mut self) -> (HalfReadObfuscatedStream<'a, R>, HalfWriteObfuscatedStream<'a, W>) {
[INFO] [stdout]     |                                                         +++                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 2.50s
[INFO] running `Command { std: "docker" "inspect" "f577e715ed6625548399f4400e98b437b624dd379e6d3af691be353f07781fb7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f577e715ed6625548399f4400e98b437b624dd379e6d3af691be353f07781fb7", kill_on_drop: false }`
[INFO] [stdout] f577e715ed6625548399f4400e98b437b624dd379e6d3af691be353f07781fb7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 32030d75aaafda659231f3f766b03e5c20dbf764f4d7f1b84274e9d87f1d578e
[INFO] running `Command { std: "docker" "start" "-a" "32030d75aaafda659231f3f766b03e5c20dbf764f4d7f1b84274e9d87f1d578e", kill_on_drop: false }`
[INFO] [stderr] warning: unused variable: `dc`
[INFO] [stderr]    --> src/tokio_utils.rs:140:21
[INFO] [stderr]     |
[INFO] [stderr] 140 |         let (inner, dc, encryptor, decryptor) = (
[INFO] [stderr]     |                     ^^ help: if this is intentional, prefix it with an underscore: `_dc`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `DEFAULT_DC` is never used
[INFO] [stderr]  --> src/obfuscated2/frame.rs:1:11
[INFO] [stderr]   |
[INFO] [stderr] 1 | pub const DEFAULT_DC: u8 = 2;
[INFO] [stderr]   |           ^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/proxy.rs:20:30
[INFO] [stderr]    |
[INFO] [stderr] 20 |     TelegramConnectionOpened(std::net::SocketAddr),
[INFO] [stderr]    |     ------------------------ ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 20 -     TelegramConnectionOpened(std::net::SocketAddr),
[INFO] [stderr] 20 +     TelegramConnectionOpened(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/proxy.rs:21:22
[INFO] [stderr]    |
[INFO] [stderr] 21 |     ConnectionOpened(std::net::SocketAddr),
[INFO] [stderr]    |     ---------------- ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 21 -     ConnectionOpened(std::net::SocketAddr),
[INFO] [stderr] 21 +     ConnectionOpened(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/proxy.rs:22:22
[INFO] [stderr]    |
[INFO] [stderr] 22 |     ConnectionClosed(Option<std::net::SocketAddr>),
[INFO] [stderr]    |     ---------------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 22 -     ConnectionClosed(Option<std::net::SocketAddr>),
[INFO] [stderr] 22 +     ConnectionClosed(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: fields `0` and `1` are never read
[INFO] [stderr]   --> src/proxy.rs:23:18
[INFO] [stderr]    |
[INFO] [stderr] 23 |     DataReceived(std::net::SocketAddr, Vec<u8>),
[INFO] [stderr]    |     ------------ ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     fields in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the fields to be of unit type to suppress this warning while preserving the field numbering, or remove the fields
[INFO] [stderr]    |
[INFO] [stderr] 23 -     DataReceived(std::net::SocketAddr, Vec<u8>),
[INFO] [stderr] 23 +     DataReceived((), ()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: fields `0` and `1` are never read
[INFO] [stderr]   --> src/proxy.rs:24:14
[INFO] [stderr]    |
[INFO] [stderr] 24 |     DataSent(std::net::SocketAddr, Vec<u8>),
[INFO] [stderr]    |     -------- ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     fields in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the fields to be of unit type to suppress this warning while preserving the field numbering, or remove the fields
[INFO] [stderr]    |
[INFO] [stderr] 24 -     DataSent(std::net::SocketAddr, Vec<u8>),
[INFO] [stderr] 24 +     DataSent((), ()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/proxy.rs:25:16
[INFO] [stderr]    |
[INFO] [stderr] 25 |     DCFallback(i32),
[INFO] [stderr]    |     ---------- ^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 25 -     DCFallback(i32),
[INFO] [stderr] 25 +     DCFallback(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/proxy.rs:26:19
[INFO] [stderr]    |
[INFO] [stderr] 26 |     ConnectedToDC(i32),
[INFO] [stderr]    |     ------------- ^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 26 -     ConnectedToDC(i32),
[INFO] [stderr] 26 +     ConnectedToDC(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: variants `ProxiedDataToClient` and `ProxiedDataToTelegram` are never constructed
[INFO] [stderr]   --> src/proxy.rs:28:5
[INFO] [stderr]    |
[INFO] [stderr] 19 | pub enum ProxyEvent {
[INFO] [stderr]    |          ---------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 28 |     ProxiedDataToClient(std::net::SocketAddr, usize),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 29 |     ProxiedDataToTelegram(std::net::SocketAddr, usize),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProxyEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/proxy.rs:108:17
[INFO] [stderr]     |
[INFO] [stderr] 106 |         &'a self,
[INFO] [stderr]     |          -- the lifetime is named here
[INFO] [stderr] 107 |         socket: &mut tokio::net::TcpStream,
[INFO] [stderr] 108 |     ) -> Result<&crate::config::User, std::io::Error> {
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^ the same lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 108 |     ) -> Result<&'a crate::config::User, std::io::Error> {
[INFO] [stderr]     |                  ++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/tokio_utils.rs:139:32
[INFO] [stderr]     |
[INFO] [stderr] 139 |     fn split(&'a mut self) -> (HalfReadObfuscatedStream<R>, HalfWriteObfuscatedStream<W>) {
[INFO] [stderr]     |               --               ^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |               |                |
[INFO] [stderr]     |               |                the same lifetime is hidden here
[INFO] [stderr]     |               the lifetime is named here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 139 |     fn split(&'a mut self) -> (HalfReadObfuscatedStream<'a, R>, HalfWriteObfuscatedStream<'a, W>) {
[INFO] [stderr]     |                                                         +++                               +++
[INFO] [stderr] 
[INFO] [stderr] warning: `telecrab` (bin "telecrab" test) generated 12 warnings (run `cargo fix --bin "telecrab" --tests` to apply 2 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.20s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/telecrab-8ec789e1a1a327b5)
[INFO] [stdout] 
[INFO] [stdout] running 8 tests
[INFO] [stdout] test faketls::tests::tests::test_case_bad_0_fails ... ok
[INFO] [stdout] test faketls::tests::tests::test_case_good_0_ok ... ok
[INFO] [stdout] test faketls::tests::tests::test_case_good_1_ok ... ok
[INFO] [stdout] test obfuscated2::test::test_known_ok_handshake_2 ... ok
[INFO] [stdout] test obfuscated2::test::test_known_ok_handshake_1 ... ok
[INFO] [stdout] test faketls::conn::test::test_faketls_stream ... ok
[INFO] [stdout] test faketls::tests::tests::generate_server_hello_should_return_something_reasonable ... ok
[INFO] [stdout] test proxy::test::test_relay_data_simple ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- proxy::test::test_relay_data_simple stdout ----
[INFO] [stdout] Transferred 8 bytes client -->tg
[INFO] [stdout] Transferred 8 bytes client<--- tg
[INFO] [stdout] ConnectionClosed(Some(127.0.0.1:8888))
[INFO] [stdout] ConnectionClosed(Some(127.0.0.1:9999))
[INFO] [stdout] 
[INFO] [stdout] thread 'proxy::test::test_relay_data_simple' (24) panicked at src/proxy.rs:354:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: [1, 2, 3, 4, 5, 6, 7, 8]
[INFO] [stdout]  right: [9, 10, 11, 12, 13, 14, 15, 16]
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x64dd896c5da2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x64dd896c5da2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x64dd896c5da2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x64dd896c5da2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h67edf0e4d33c343c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x64dd896d70df - core::fmt::rt::Argument::fmt::hef94184842aeafdd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x64dd896d70df - core::fmt::write::hcf0c66b48a8fa606
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x64dd89692a81 - std::io::default_write_fmt::h69967ac0ba93195f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x64dd89692a81 - std::io::Write::write_fmt::h8db9396209deaa1c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x64dd8969ed32 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x64dd896a3b9f - std::panicking::default_hook::{{closure}}::h91001850288db5f7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x64dd896a3a31 - std::panicking::default_hook::h2346dbb704ef5512
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x64dd89553bae - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h18383b2e29377420
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   12:     0x64dd89553bae - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x64dd896a430f - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h6dba6e441651a0d1
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   14:     0x64dd896a430f - std::panicking::panic_with_hook::hd2b063a6090d23a4
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x64dd896a40ba - std::panicking::panic_handler::{{closure}}::he666d95f139a333e
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13
[INFO] [stdout]   16:     0x64dd8969ee69 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x64dd89686efd - __rustc[1d67440d6e82e4f]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x64dd896deea0 - core::panicking::panic_fmt::h420ddb7fd73daf53
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x64dd896deca3 - core::panicking::assert_failed_inner::h448e1d534f4c3d4b
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:439:17
[INFO] [stdout]   20:     0x64dd89500b53 - core::panicking::assert_failed::h0ac4951519d6ae12
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x64dd8952e6f2 - telecrab::proxy::test::test_relay_data_simple::{{closure}}::hc08ab746174c5fb5
[INFO] [stdout]                                at /opt/rustwide/workdir/src/proxy.rs:354:9
[INFO] [stdout]   22:     0x64dd89515db2 - <core::pin::Pin<P> as core::future::future::Future>::poll::he4ec79367c25ad6d
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x64dd89515d2d - <core::pin::Pin<P> as core::future::future::Future>::poll::ha5dc94f142b0bd7d
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x64dd89515bed - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::{{closure}}::h56063ef835aef6c5
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/scheduler/current_thread/mod.rs:659:73
[INFO] [stdout]   25:     0x64dd8951599b - tokio::runtime::coop::with_budget::h2aed8cbbff80ee40
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/coop.rs:107:5
[INFO] [stdout]   26:     0x64dd8951599b - tokio::runtime::coop::budget::h2a61497ce8bb807c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/coop.rs:73:5
[INFO] [stdout]   27:     0x64dd8951599b - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::h5e3d3ff0bd106fd9
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/scheduler/current_thread/mod.rs:659:25
[INFO] [stdout]   28:     0x64dd89512fb0 - tokio::runtime::scheduler::current_thread::Context::enter::h80aac08527ccf30b
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/scheduler/current_thread/mod.rs:404:19
[INFO] [stdout]   29:     0x64dd89515050 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::hf6eb4e977ed3878e
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/scheduler/current_thread/mod.rs:658:44
[INFO] [stdout]   30:     0x64dd89514254 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::{{closure}}::h0aa46eeec18a58fd
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/scheduler/current_thread/mod.rs:737:68
[INFO] [stdout]   31:     0x64dd89518bab - tokio::runtime::context::scoped::Scoped<T>::set::hd98aef18a52c6ade
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x64dd89522029 - tokio::runtime::context::set_scheduler::{{closure}}::h749da167221b1a3e
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/context.rs:176:38
[INFO] [stdout]   33:     0x64dd8951fbc2 - std::thread::local::LocalKey<T>::try_with::h070cd1657bf5faab
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/local.rs:315:12
[INFO] [stdout]   34:     0x64dd8951fa0e - std::thread::local::LocalKey<T>::with::hb78ef9f832372f76
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/local.rs:279:20
[INFO] [stdout]   35:     0x64dd89521f9d - tokio::runtime::context::set_scheduler::hf21a5f9c3127310c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/context.rs:176:17
[INFO] [stdout]   36:     0x64dd89513be0 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::h6df0a7634a87ff7c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/scheduler/current_thread/mod.rs:737:27
[INFO] [stdout]   37:     0x64dd895142f3 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::h8830f526e544f947
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/scheduler/current_thread/mod.rs:646:24
[INFO] [stdout]   38:     0x64dd89512555 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::{{closure}}::h52008f5b2db1be99
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/scheduler/current_thread/mod.rs:175:33
[INFO] [stdout]   39:     0x64dd89518e70 - tokio::runtime::context::runtime::enter_runtime::h20cae211a2debb19
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x64dd895122d1 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::hfb4d40d952e2e037
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/scheduler/current_thread/mod.rs:167:9
[INFO] [stdout]   41:     0x64dd8951210a - tokio::runtime::runtime::Runtime::block_on::h83169a9b0684f8f3
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.36.0/src/runtime/runtime.rs:348:52
[INFO] [stdout]   42:     0x64dd8952dbaf - telecrab::proxy::test::test_relay_data_simple::h3f3058df06f5596c
[INFO] [stdout]                                at /opt/rustwide/workdir/src/proxy.rs:368:10
[INFO] [stdout]   43:     0x64dd8952dc47 - telecrab::proxy::test::test_relay_data_simple::{{closure}}::h3482dc99e18f73bb
[INFO] [stdout]                                at /opt/rustwide/workdir/src/proxy.rs:325:38
[INFO] [stdout]   44:     0x64dd894fe156 - core::ops::function::FnOnce::call_once::h67d0cca0764905b2
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   45:     0x64dd8955396b - core::ops::function::FnOnce::call_once::h70887edf07a630ba
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x64dd8955396b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18
[INFO] [stdout]   47:     0x64dd895695d5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74
[INFO] [stdout]   48:     0x64dd895695d5 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   49:     0x64dd895695d5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   50:     0x64dd895695d5 - std::panicking::catch_unwind::hae1ec7bf94407afa
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   51:     0x64dd895695d5 - std::panic::catch_unwind::h0f4ff4773d84d3cd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   52:     0x64dd895695d5 - test::run_test_in_process::h03fbc77ae48b3f10
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27
[INFO] [stdout]   53:     0x64dd895695d5 - test::run_test::{{closure}}::h83476a9c453dc4d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43
[INFO] [stdout]   54:     0x64dd8953fdc4 - test::run_test::{{closure}}::h515482ad1e7fe7de
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41
[INFO] [stdout]   55:     0x64dd8953fdc4 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   56:     0x64dd8954368a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   57:     0x64dd8954368a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   58:     0x64dd8954368a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   59:     0x64dd8954368a - std::panicking::catch_unwind::h9e402d6a96fef41c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   60:     0x64dd8954368a - std::panic::catch_unwind::h9213c0c54aec70e0
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   61:     0x64dd8954368a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   62:     0x64dd8954368a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   63:     0x64dd89699fcf - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h2044e71c41d3958a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   64:     0x64dd89699fcf - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17
[INFO] [stdout]   65:     0x7293b2860aa4 - <unknown>
[INFO] [stdout]   66:     0x7293b28eda34 - clone
[INFO] [stdout]   67:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     proxy::test::test_relay_data_simple
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 7 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.10s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin telecrab`
[INFO] running `Command { std: "docker" "inspect" "32030d75aaafda659231f3f766b03e5c20dbf764f4d7f1b84274e9d87f1d578e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "32030d75aaafda659231f3f766b03e5c20dbf764f4d7f1b84274e9d87f1d578e", kill_on_drop: false }`
[INFO] [stdout] 32030d75aaafda659231f3f766b03e5c20dbf764f4d7f1b84274e9d87f1d578e
