[INFO] cloning repository https://github.com/reisub0/tftp
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/reisub0/tftp" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Freisub0%2Ftftp", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Freisub0%2Ftftp'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 7c591390f05e5ba77f27c9291c478ce5fcacce79
[INFO] testing reisub0/tftp against try#bd7d74411512a3dd3b35d2f699c51dd2557c7e7e+cargoflags=-Zbuild-dir-new-layout for pr-149852-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Freisub0%2Ftftp" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/reisub0/tftp
[INFO] finished tweaking git repo https://github.com/reisub0/tftp
[INFO] tweaked toml for git repo https://github.com/reisub0/tftp written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/reisub0/tftp on toolchain bd7d74411512a3dd3b35d2f699c51dd2557c7e7e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/reisub0/tftp 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" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[ERROR] error running command: no output for 300 seconds
[INFO] testing reisub0/tftp against try#bd7d74411512a3dd3b35d2f699c51dd2557c7e7e+cargoflags=-Zbuild-dir-new-layout for pr-149852-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Freisub0%2Ftftp" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/reisub0/tftp
[INFO] finished tweaking git repo https://github.com/reisub0/tftp
[INFO] tweaked toml for git repo https://github.com/reisub0/tftp written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/reisub0/tftp on toolchain bd7d74411512a3dd3b35d2f699c51dd2557c7e7e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/reisub0/tftp 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" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 6bbeade11462b6eb6727f0a35ce47042535df01e723a1d2e1ab5f0983ad6667d
[INFO] running `Command { std: "docker" "start" "-a" "6bbeade11462b6eb6727f0a35ce47042535df01e723a1d2e1ab5f0983ad6667d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "6bbeade11462b6eb6727f0a35ce47042535df01e723a1d2e1ab5f0983ad6667d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6bbeade11462b6eb6727f0a35ce47042535df01e723a1d2e1ab5f0983ad6667d", kill_on_drop: false }`
[INFO] [stdout] 6bbeade11462b6eb6727f0a35ce47042535df01e723a1d2e1ab5f0983ad6667d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "build" "--frozen" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] fbc348df429b2f9bd23c7d48c8c1c01d000dcb3b2e8ed5ba386a08497100763d
[INFO] running `Command { std: "docker" "start" "-a" "fbc348df429b2f9bd23c7d48c8c1c01d000dcb3b2e8ed5ba386a08497100763d", kill_on_drop: false }`
[INFO] [stderr]    Compiling byteorder v1.2.7
[INFO] [stderr]    Compiling tftp-server v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: type `reader` should have an upper camel case name
[INFO] [stdout]   --> src/reader.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct reader<'a> {
[INFO] [stdout]    |            ^^^^^^ help: convert the identifier to upper camel case: `Reader`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `writer` should have an upper camel case name
[INFO] [stdout]   --> src/writer.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub struct writer<'a> {
[INFO] [stdout]    |            ^^^^^^ help: convert the identifier to upper camel case (notice the capitalization): `Writer`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/reader.rs:37:32
[INFO] [stdout]    |
[INFO] [stdout] 37 |     fn cause(&self) -> Option<&error::Error> {
[INFO] [stdout]    |                                ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 37 |     fn cause(&self) -> Option<&dyn error::Error> {
[INFO] [stdout]    |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/tftp.rs:272:32
[INFO] [stdout]     |
[INFO] [stdout] 272 |     fn cause(&self) -> Option<&error::Error> {
[INFO] [stdout]     |                                ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 272 |     fn cause(&self) -> Option<&dyn error::Error> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/writer.rs:30:32
[INFO] [stdout]    |
[INFO] [stdout] 30 |     fn cause(&self) -> Option<&std::error::Error> {
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 30 |     fn cause(&self) -> Option<&dyn std::error::Error> {
[INFO] [stdout]    |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `addr`
[INFO] [stdout]   --> src/main.rs:37:15
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn handle(addr: SocketAddr, src: SocketAddr, packet: tftp::Packet) -> Option<tftp::Packet> {
[INFO] [stdout]    |               ^^^^ help: if this is intentional, prefix it with an underscore: `_addr`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `src`
[INFO] [stdout]   --> src/main.rs:37:33
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn handle(addr: SocketAddr, src: SocketAddr, packet: tftp::Packet) -> Option<tftp::Packet> {
[INFO] [stdout]    |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_src`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `len` and `take_all` are never used
[INFO] [stdout]   --> src/reader.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | impl<'a> reader<'a> {
[INFO] [stdout]    | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn len(&self) -> usize {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 78 |     pub fn take_all(&mut self) -> Result<&'a [u8]> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `read` is never used
[INFO] [stdout]    --> src/tftp.rs:166:8
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl<'a> Data<'a> {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 166 |     fn read(buff: &mut reader::reader<'a>) -> Result<Self> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 0.92s
[INFO] running `Command { std: "docker" "inspect" "fbc348df429b2f9bd23c7d48c8c1c01d000dcb3b2e8ed5ba386a08497100763d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fbc348df429b2f9bd23c7d48c8c1c01d000dcb3b2e8ed5ba386a08497100763d", kill_on_drop: false }`
[INFO] [stdout] fbc348df429b2f9bd23c7d48c8c1c01d000dcb3b2e8ed5ba386a08497100763d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "--no-run" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 119abd07b1ed8d318f1b3d60522c53b76d2a283fa71349b32cff58a36fe36969
[INFO] running `Command { std: "docker" "start" "-a" "119abd07b1ed8d318f1b3d60522c53b76d2a283fa71349b32cff58a36fe36969", kill_on_drop: false }`
[INFO] [stderr]    Compiling tftp-server v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: type `reader` should have an upper camel case name
[INFO] [stdout]   --> src/reader.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct reader<'a> {
[INFO] [stdout]    |            ^^^^^^ help: convert the identifier to upper camel case: `Reader`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> src/tftp.rs:301:9
[INFO] [stdout]     |
[INFO] [stdout] 301 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `writer` should have an upper camel case name
[INFO] [stdout]   --> src/writer.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub struct writer<'a> {
[INFO] [stdout]    |            ^^^^^^ help: convert the identifier to upper camel case (notice the capitalization): `Writer`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> src/writer.rs:101:9
[INFO] [stdout]     |
[INFO] [stdout] 101 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]   --> src/main.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 |     use super::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/reader.rs:37:32
[INFO] [stdout]    |
[INFO] [stdout] 37 |     fn cause(&self) -> Option<&error::Error> {
[INFO] [stdout]    |                                ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 37 |     fn cause(&self) -> Option<&dyn error::Error> {
[INFO] [stdout]    |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/tftp.rs:272:32
[INFO] [stdout]     |
[INFO] [stdout] 272 |     fn cause(&self) -> Option<&error::Error> {
[INFO] [stdout]     |                                ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 272 |     fn cause(&self) -> Option<&dyn error::Error> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/writer.rs:30:32
[INFO] [stdout]    |
[INFO] [stdout] 30 |     fn cause(&self) -> Option<&std::error::Error> {
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 30 |     fn cause(&self) -> Option<&dyn std::error::Error> {
[INFO] [stdout]    |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `addr`
[INFO] [stdout]   --> src/main.rs:37:15
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn handle(addr: SocketAddr, src: SocketAddr, packet: tftp::Packet) -> Option<tftp::Packet> {
[INFO] [stdout]    |               ^^^^ help: if this is intentional, prefix it with an underscore: `_addr`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `src`
[INFO] [stdout]   --> src/main.rs:37:33
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn handle(addr: SocketAddr, src: SocketAddr, packet: tftp::Packet) -> Option<tftp::Packet> {
[INFO] [stdout]    |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_src`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `len` and `take_all` are never used
[INFO] [stdout]   --> src/reader.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | impl<'a> reader<'a> {
[INFO] [stdout]    | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn len(&self) -> usize {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 78 |     pub fn take_all(&mut self) -> Result<&'a [u8]> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `read` is never used
[INFO] [stdout]    --> src/tftp.rs:166:8
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl<'a> Data<'a> {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 166 |     fn read(buff: &mut reader::reader<'a>) -> Result<Self> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.51s
[INFO] running `Command { std: "docker" "inspect" "119abd07b1ed8d318f1b3d60522c53b76d2a283fa71349b32cff58a36fe36969", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "119abd07b1ed8d318f1b3d60522c53b76d2a283fa71349b32cff58a36fe36969", kill_on_drop: false }`
[INFO] [stdout] 119abd07b1ed8d318f1b3d60522c53b76d2a283fa71349b32cff58a36fe36969
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] e36e2c530796cfb3c0a0c9b442cb76980953d2d288342e2108bcdee09a2d15c5
[INFO] running `Command { std: "docker" "start" "-a" "e36e2c530796cfb3c0a0c9b442cb76980953d2d288342e2108bcdee09a2d15c5", kill_on_drop: false }`
[INFO] [stderr] warning: type `reader` should have an upper camel case name
[INFO] [stderr]   --> src/reader.rs:12:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct reader<'a> {
[INFO] [stderr]    |            ^^^^^^ help: convert the identifier to upper camel case: `Reader`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::*`
[INFO] [stderr]    --> src/tftp.rs:301:9
[INFO] [stderr]     |
[INFO] [stderr] 301 |     use super::*;
[INFO] [stderr]     |         ^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: type `writer` should have an upper camel case name
[INFO] [stderr]   --> src/writer.rs:38:12
[INFO] [stderr]    |
[INFO] [stderr] 38 | pub struct writer<'a> {
[INFO] [stderr]    |            ^^^^^^ help: convert the identifier to upper camel case (notice the capitalization): `Writer`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::*`
[INFO] [stderr]    --> src/writer.rs:101:9
[INFO] [stderr]     |
[INFO] [stderr] 101 |     use super::*;
[INFO] [stderr]     |         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::*`
[INFO] [stderr]   --> src/main.rs:44:9
[INFO] [stderr]    |
[INFO] [stderr] 44 |     use super::*;
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/reader.rs:37:32
[INFO] [stderr]    |
[INFO] [stderr] 37 |     fn cause(&self) -> Option<&error::Error> {
[INFO] [stderr]    |                                ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 37 |     fn cause(&self) -> Option<&dyn error::Error> {
[INFO] [stderr]    |                                +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/tftp.rs:272:32
[INFO] [stderr]     |
[INFO] [stderr] 272 |     fn cause(&self) -> Option<&error::Error> {
[INFO] [stderr]     |                                ^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 272 |     fn cause(&self) -> Option<&dyn error::Error> {
[INFO] [stderr]     |                                +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/writer.rs:30:32
[INFO] [stderr]    |
[INFO] [stderr] 30 |     fn cause(&self) -> Option<&std::error::Error> {
[INFO] [stderr]    |                                ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 30 |     fn cause(&self) -> Option<&dyn std::error::Error> {
[INFO] [stderr]    |                                +++
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `addr`
[INFO] [stderr]   --> src/main.rs:37:15
[INFO] [stderr]    |
[INFO] [stderr] 37 | pub fn handle(addr: SocketAddr, src: SocketAddr, packet: tftp::Packet) -> Option<tftp::Packet> {
[INFO] [stderr]    |               ^^^^ help: if this is intentional, prefix it with an underscore: `_addr`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `src`
[INFO] [stderr]   --> src/main.rs:37:33
[INFO] [stderr]    |
[INFO] [stderr] 37 | pub fn handle(addr: SocketAddr, src: SocketAddr, packet: tftp::Packet) -> Option<tftp::Packet> {
[INFO] [stderr]    |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_src`
[INFO] [stderr] 
[INFO] [stderr] warning: methods `len` and `take_all` are never used
[INFO] [stderr]   --> src/reader.rs:48:12
[INFO] [stderr]    |
[INFO] [stderr] 44 | impl<'a> reader<'a> {
[INFO] [stderr]    | ------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 48 |     pub fn len(&self) -> usize {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 78 |     pub fn take_all(&mut self) -> Result<&'a [u8]> {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `read` is never used
[INFO] [stderr]    --> src/tftp.rs:166:8
[INFO] [stderr]     |
[INFO] [stderr] 165 | impl<'a> Data<'a> {
[INFO] [stderr]     | ----------------- associated function in this implementation
[INFO] [stderr] 166 |     fn read(buff: &mut reader::reader<'a>) -> Result<Self> {
[INFO] [stderr]     |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `tftp-server` (bin "tftp-server" test) generated 12 warnings (run `cargo fix --bin "tftp-server" -p tftp-server --tests` to apply 8 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.02s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/build/tftp-server/222f6b76a29c203e/deps/tftp_server-222f6b76a29c203e)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test tftp::tests::it_works ... ok
[INFO] [stdout] test writer::tests::it_works ... ok
[INFO] [stdout] test tests::it_works ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "e36e2c530796cfb3c0a0c9b442cb76980953d2d288342e2108bcdee09a2d15c5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e36e2c530796cfb3c0a0c9b442cb76980953d2d288342e2108bcdee09a2d15c5", kill_on_drop: false }`
[INFO] [stdout] e36e2c530796cfb3c0a0c9b442cb76980953d2d288342e2108bcdee09a2d15c5
