[INFO] fetching crate pi_http 0.3.8... [INFO] testing pi_http-0.3.8 against try#b83b707f97d809763b7861afa7638871f3339a33 for pr-145838-1 [INFO] extracting crate pi_http 0.3.8 into /workspace/builds/worker-5-tc2/source [INFO] started tweaking crates.io crate pi_http 0.3.8 [INFO] removed 0 missing tests [INFO] finished tweaking crates.io crate pi_http 0.3.8 [INFO] tweaked toml for crates.io crate pi_http 0.3.8 written to /workspace/builds/worker-5-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate pi_http 0.3.8 on toolchain b83b707f97d809763b7861afa7638871f3339a33 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b83b707f97d809763b7861afa7638871f3339a33" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate pi_http 0.3.8 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" "+b83b707f97d809763b7861afa7638871f3339a33" "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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+b83b707f97d809763b7861afa7638871f3339a33" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 0fbaa433d7cd17ff052721d17a3959189f7eb9019072148fe7bfb43a93ff0586 [INFO] running `Command { std: "docker" "start" "-a" "0fbaa433d7cd17ff052721d17a3959189f7eb9019072148fe7bfb43a93ff0586", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "0fbaa433d7cd17ff052721d17a3959189f7eb9019072148fe7bfb43a93ff0586", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "0fbaa433d7cd17ff052721d17a3959189f7eb9019072148fe7bfb43a93ff0586", kill_on_drop: false }` [INFO] [stdout] 0fbaa433d7cd17ff052721d17a3959189f7eb9019072148fe7bfb43a93ff0586 [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=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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+b83b707f97d809763b7861afa7638871f3339a33" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 0d5f3d3c34890b9a9ea31521e518702227adf75afcfb2a9dfb2275c0ef3c5265 [INFO] running `Command { std: "docker" "start" "-a" "0d5f3d3c34890b9a9ea31521e518702227adf75afcfb2a9dfb2275c0ef3c5265", kill_on_drop: false }` [INFO] [stderr] Compiling memchr v2.7.4 [INFO] [stderr] Compiling lock_api v0.4.13 [INFO] [stderr] Compiling cc v1.2.26 [INFO] [stderr] Compiling slotmap v1.0.7 [INFO] [stderr] Compiling futures-channel v0.3.31 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling syn v2.0.101 [INFO] [stderr] Compiling getrandom v0.2.16 [INFO] [stderr] Compiling parking_lot_core v0.9.11 [INFO] [stderr] Compiling getrandom v0.3.3 [INFO] [stderr] Compiling crossbeam-queue v0.3.12 [INFO] [stderr] Compiling crossbeam-channel v0.5.15 [INFO] [stderr] Compiling miniz_oxide v0.8.8 [INFO] [stderr] Compiling pi_ext_heap v0.1.1 [INFO] [stderr] Compiling pi_null v0.1.11 [INFO] [stderr] Compiling pi_wheel v0.1.0 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling nanorand v0.7.0 [INFO] [stderr] Compiling pi_share v0.5.2 [INFO] [stderr] Compiling pi_timer v0.1.0 [INFO] [stderr] Compiling quanta v0.12.5 [INFO] [stderr] Compiling rand_core v0.9.3 [INFO] [stderr] Compiling st3 v0.4.1 [INFO] [stderr] Compiling num_cpus v1.17.0 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling pi_wrr v0.1.1 [INFO] [stderr] Compiling crossbeam v0.8.4 [INFO] [stderr] Compiling pi_slotmap v0.2.1 [INFO] [stderr] Compiling spin v0.9.8 [INFO] [stderr] Compiling parking_lot v0.12.4 [INFO] [stderr] Compiling dashmap v6.1.0 [INFO] [stderr] Compiling rustls v0.20.9 [INFO] [stderr] Compiling object v0.36.7 [INFO] [stderr] Compiling rand v0.9.1 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling flume v0.11.1 [INFO] [stderr] Compiling pi_slot_deque v0.2.1 [INFO] [stderr] Compiling pi_slot_wheel v0.2.0 [INFO] [stderr] Compiling pi_key_alloter v0.6.1 [INFO] [stderr] Compiling aho-corasick v1.1.3 [INFO] [stderr] Compiling rayon v1.10.0 [INFO] [stderr] Compiling smol_str v0.2.2 [INFO] [stderr] Compiling percent-encoding v2.3.1 [INFO] [stderr] Compiling spin_sleep v1.3.1 [INFO] [stderr] Compiling pi_cancel_timer v0.2.0 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Compiling brotli-decompressor v2.5.1 [INFO] [stderr] Compiling pi_gray v0.1.0 [INFO] [stderr] Compiling mio v0.8.11 [INFO] [stderr] Compiling path-dedot v3.1.1 [INFO] [stderr] Compiling spin_sleep_util v0.1.1 [INFO] [stderr] Compiling num-integer v0.1.46 [INFO] [stderr] Compiling twox-hash v1.6.3 [INFO] [stderr] Compiling form_urlencoded v1.2.1 [INFO] [stderr] Compiling normpath v1.3.0 [INFO] [stderr] Compiling unchecked-index v0.2.2 [INFO] [stderr] Compiling pi_adler32 v0.1.1 [INFO] [stderr] Compiling path-absolutize v3.1.1 [INFO] [stderr] Compiling flate2 v1.1.2 [INFO] [stderr] Compiling twoway v0.2.2 [INFO] [stderr] Compiling pi_hash v0.1.1 [INFO] [stderr] Compiling num-bigint v0.4.6 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling ring v0.16.20 [INFO] [stderr] Compiling brotli v3.5.0 [INFO] [stderr] Compiling regex-automata v0.4.9 [INFO] [stderr] Compiling pi_bon v0.3.1 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.0 [INFO] [stderr] Compiling zerovec-derive v0.11.1 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling async-stream-impl v0.3.6 [INFO] [stderr] Compiling sysinfo v0.29.11 [INFO] [stderr] Compiling async-stream v0.3.6 [INFO] [stderr] Compiling backtrace v0.3.75 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling yoke v0.8.0 [INFO] [stderr] Compiling zerovec v0.11.2 [INFO] [stderr] Compiling zerotrie v0.2.2 [INFO] [stderr] Compiling regex v1.11.1 [INFO] [stderr] Compiling webpki v0.22.4 [INFO] [stderr] Compiling sct v0.7.1 [INFO] [stderr] Compiling tinystr v0.8.1 [INFO] [stderr] Compiling potential_utf v0.1.2 [INFO] [stderr] Compiling icu_collections v2.0.0 [INFO] [stderr] Compiling icu_locale_core v2.0.0 [INFO] [stderr] Compiling serde v1.0.219 [INFO] [stderr] Compiling icu_provider v2.0.0 [INFO] [stderr] Compiling icu_normalizer v2.0.0 [INFO] [stderr] Compiling icu_properties v2.0.1 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.0.3 [INFO] [stderr] Compiling futures-executor v0.3.31 [INFO] [stderr] Compiling futures v0.3.31 [INFO] [stderr] Compiling pi-async-rt v0.2.5 [INFO] [stderr] Compiling url v2.5.4 [INFO] [stderr] Compiling pi_atom v0.6.1 [INFO] [stderr] Compiling serde_json v1.0.140 [INFO] [stderr] Compiling pi_handler v0.2.1 [INFO] [stderr] Compiling pi_async_buffer v0.8.0 [INFO] [stderr] Compiling pi_async_file v0.7.0 [INFO] [stderr] Compiling pi_tcp v0.5.5 [INFO] [stderr] Compiling pi_http v0.3.8 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `utils::SocketContext` [INFO] [stdout] --> src/server.rs:11:11 [INFO] [stdout] | [INFO] [stdout] 11 | utils::SocketContext}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around block return value [INFO] [stdout] --> src/server.rs:127:53 [INFO] [stdout] | [INFO] [stdout] 127 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 127 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] 127 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `HttpService` [INFO] [stdout] --> src/acceptor.rs:12:39 [INFO] [stdout] | [INFO] [stdout] 12 | service::{ServiceFactory, HttpService}, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around type [INFO] [stdout] --> src/acceptor.rs:26:25 [INFO] [stdout] | [INFO] [stdout] 26 | marker: PhantomData<(S)>, [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 26 - marker: PhantomData<(S)>, [INFO] [stdout] 26 + marker: PhantomData, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around block return value [INFO] [stdout] --> src/acceptor.rs:78:41 [INFO] [stdout] | [INFO] [stdout] 78 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 78 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] 78 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Ready` and `SocketContext` [INFO] [stdout] --> src/connect.rs:10:19 [INFO] [stdout] | [INFO] [stdout] 10 | utils::{SocketContext, Ready}}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `HttpService` [INFO] [stdout] --> src/virtual_host.rs:9:23 [INFO] [stdout] | [INFO] [stdout] 9 | use crate::{service::{HttpService, ServiceFactory}, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `service::HttpService` [INFO] [stdout] --> src/route.rs:14:13 [INFO] [stdout] | [INFO] [stdout] 14 | use crate::{service::HttpService, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `CompressorWriter` [INFO] [stdout] --> src/default_parser.rs:8:32 [INFO] [stdout] | [INFO] [stdout] 8 | use brotli::{CompressorReader, CompressorWriter}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/multi_parts.rs:94:52 [INFO] [stdout] | [INFO] [stdout] 94 | ... let boundary_str = (MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 94 - let boundary_str = (MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK); [INFO] [stdout] 94 + let boundary_str = MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/file_load.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/files_load.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/batch_load.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `httpdate::fmt_http_date` [INFO] [stdout] --> src/batch_load.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | use httpdate::fmt_http_date; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `pi_adler32::adler32` [INFO] [stdout] --> src/batch_load.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | use pi_adler32::adler32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/port.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `SocketHandle` and `Socket` [INFO] [stdout] --> src/response.rs:12:11 [INFO] [stdout] | [INFO] [stdout] 12 | use tcp::{Socket, SocketHandle}; [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tcp::connect::TcpSocket` [INFO] [stdout] --> src/packet.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use tcp::connect::TcpSocket; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around block return value [INFO] [stdout] --> src/packet.rs:82:49 [INFO] [stdout] | [INFO] [stdout] 82 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 82 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] 82 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::thread` [INFO] [stdout] --> src/utils.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::thread; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::pin::Pin` [INFO] [stdout] --> src/utils.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::pin::Pin; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::sync::Arc` [INFO] [stdout] --> src/utils.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::sync::Arc; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::time::Duration` [INFO] [stdout] --> src/utils.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::time::Duration; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::future::Future` [INFO] [stdout] --> src/utils.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::future::Future; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::result::Result as GenResult` [INFO] [stdout] --> src/utils.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::result::Result as GenResult; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Context`, `Poll`, and `Waker` [INFO] [stdout] --> src/utils.rs:8:17 [INFO] [stdout] | [INFO] [stdout] 8 | use std::task::{Context, Poll, Waker}; [INFO] [stdout] | ^^^^^^^ ^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `AtomicBool`, `AtomicUsize`, and `Ordering` [INFO] [stdout] --> src/utils.rs:10:25 [INFO] [stdout] | [INFO] [stdout] 10 | use std::sync::atomic::{AtomicBool, AtomicUsize, Ordering}; [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `bytes::Buf` [INFO] [stdout] --> src/utils.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use bytes::Buf; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `FutureExt` and `LocalBoxFuture` [INFO] [stdout] --> src/utils.rs:13:24 [INFO] [stdout] | [INFO] [stdout] 13 | use futures::{future::{FutureExt, LocalBoxFuture}}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `SocketHandle`, `Socket`, and `utils::Ready` [INFO] [stdout] --> src/utils.rs:16:11 [INFO] [stdout] | [INFO] [stdout] 16 | use tcp::{Socket, SocketHandle, [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] 17 | utils::Ready}; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `async_await` has been stable since 1.39.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:3:12 [INFO] [stdout] | [INFO] [stdout] 3 | #![feature(async_await)] [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(stable_features)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `entry_insert` has been stable since 1.83.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:4:12 [INFO] [stdout] | [INFO] [stdout] 4 | #![feature(entry_insert)] [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `mem_take` has been stable since 1.40.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:1:12 [INFO] [stdout] | [INFO] [stdout] 1 | #![feature(mem_take)] [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `map_first_last` has been stable since 1.66.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:5:12 [INFO] [stdout] | [INFO] [stdout] 5 | #![feature(map_first_last)] [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `http_request_result` is never read [INFO] [stdout] --> src/acceptor.rs:60:17 [INFO] [stdout] | [INFO] [stdout] 60 | let mut http_request_result = None; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/acceptor.rs:137:37 [INFO] [stdout] | [INFO] [stdout] 137 | ... let mut connect = HttpConnect::new(handle.clone(), [INFO] [stdout] | ----^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `std::sync::atomic::AtomicBool::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead [INFO] [stdout] --> src/static_cache.rs:334:37 [INFO] [stdout] | [INFO] [stdout] 334 | if cache.is_running.compare_and_swap(false, true, Ordering::SeqCst) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `http_request_result` is never read [INFO] [stdout] --> src/server.rs:109:29 [INFO] [stdout] | [INFO] [stdout] 109 | let mut http_request_result = None; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/multi_parts.rs:212:17 [INFO] [stdout] | [INFO] [stdout] 212 | if let Some(mut part_buf) = context.take_part_buf() { [INFO] [stdout] | ----^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/multi_parts.rs:222:17 [INFO] [stdout] | [INFO] [stdout] 222 | if let Some(mut part_buf) = context.take_part_buf() { [INFO] [stdout] | ----^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/range_load.rs:45:29 [INFO] [stdout] | [INFO] [stdout] 45 | let mut vec: Vec<&str> = range_str.split("-").collect(); [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `file_path_id` is never read [INFO] [stdout] --> src/file_load.rs:104:21 [INFO] [stdout] | [INFO] [stdout] 104 | let mut file_path_id = Atom::from(""); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `timeout` [INFO] [stdout] --> src/file_load.rs:656:31 [INFO] [stdout] | [INFO] [stdout] 656 | let now = if let Some(timeout) = interval { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_timeout` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cache_key` [INFO] [stdout] --> src/static_cache.rs:620:13 [INFO] [stdout] | [INFO] [stdout] 620 | let cache_key = if let Some(owner) = owner { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cache_key` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `with_capacity` is never used [INFO] [stdout] --> src/route.rs:64:12 [INFO] [stdout] | [INFO] [stdout] 52 | impl> WildcardRouter { [INFO] [stdout] | -------------------------------------------------------------------------------------------------------------------- associated function in this implementation [INFO] [stdout] ... [INFO] [stdout] 64 | pub fn with_capacity(capacity: usize) -> Self { [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 `buf_size` is never read [INFO] [stdout] --> src/default_parser.rs:39:5 [INFO] [stdout] | [INFO] [stdout] 36 | pub struct DefaultParser { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 39 | buf_size: usize, //压缩缓冲区大小 [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DefaultParser` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `HTTPS_ASYNC_FILE_UPLOAD_PRIORITY` is never used [INFO] [stdout] --> src/upload.rs:29:7 [INFO] [stdout] | [INFO] [stdout] 29 | const HTTPS_ASYNC_FILE_UPLOAD_PRIORITY: usize = 100; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `Stop` is never constructed [INFO] [stdout] --> src/static_cache.rs:269:5 [INFO] [stdout] | [INFO] [stdout] 268 | enum CollectCmd { [INFO] [stdout] | ---------- variant in this enum [INFO] [stdout] 269 | Stop(String), //关闭整理 [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `CollectCmd` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `DEFAULT_BLOCK_SIZE` is never used [INFO] [stdout] --> src/request.rs:16:7 [INFO] [stdout] | [INFO] [stdout] 16 | const DEFAULT_BLOCK_SIZE: usize = 8192; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `MAX_BLOCK_LIMIT` is never used [INFO] [stdout] --> src/request.rs:21:7 [INFO] [stdout] | [INFO] [stdout] 21 | const MAX_BLOCK_LIMIT: usize = 16 * 1024 * 1024; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `is_stream` is never read [INFO] [stdout] --> src/response.rs:45:5 [INFO] [stdout] | [INFO] [stdout] 44 | pub struct RespBody { [INFO] [stdout] | -------- field in this struct [INFO] [stdout] 45 | is_stream: bool, //是否是流响应体 [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:37:17 [INFO] [stdout] | [INFO] [stdout] 37 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 38 | | format!("Http server connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stdout] 39 | | handle.get_token(), [INFO] [stdout] 40 | | handle.get_remote(), [INFO] [stdout] 41 | | handle.get_local(), [INFO] [stdout] 42 | | e)))); [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 37 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:56:17 [INFO] [stdout] | [INFO] [stdout] 56 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 57 | | format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stdout] 58 | | handle.get_token(), [INFO] [stdout] 59 | | handle.get_remote(), [INFO] [stdout] 60 | | handle.get_local(), [INFO] [stdout] 61 | | e)))); [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 56 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:98:21 [INFO] [stdout] | [INFO] [stdout] 98 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] 99 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid http connect ... [INFO] [stdout] 100 | | ... handle.get_token(), [INFO] [stdout] 101 | | ... handle.get_remote(), [INFO] [stdout] 102 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 98 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:117:29 [INFO] [stdout] | [INFO] [stdout] 117 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 118 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, buf_len: {:?}, buf: {:?}, rea... [INFO] [stdout] 119 | | ... handle.get_token(), [INFO] [stdout] 120 | | ... handle.get_remote(), [INFO] [stdout] 121 | | ... handle.get_local(), [INFO] [stdout] 122 | | ... buf.len(), [INFO] [stdout] 123 | | ... buf)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 117 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:155:29 [INFO] [stdout] | [INFO] [stdout] 155 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 156 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid read buffer", [INFO] [stdout] 157 | | ... handle.get_token(), [INFO] [stdout] 158 | | ... handle.get_remote(), [INFO] [stdout] 159 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 155 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:203:53 [INFO] [stdout] | [INFO] [stdout] 203 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] 204 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, url: {:?}, reason: invalid url", [INFO] [stdout] 205 | | ... handle.get_token(), [INFO] [stdout] 206 | | ... handle.get_remote(), [INFO] [stdout] 207 | | ... handle.get_local(), [INFO] [stdout] 208 | | ... url)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 203 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:215:41 [INFO] [stdout] | [INFO] [stdout] 215 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 216 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid host header", [INFO] [stdout] 217 | | ... handle.get_token(), [INFO] [stdout] 218 | | ... handle.get_remote(), [INFO] [stdout] 219 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 215 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:224:37 [INFO] [stdout] | [INFO] [stdout] 224 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 225 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: host header not exist", [INFO] [stdout] 226 | | ... handle.get_token(), [INFO] [stdout] 227 | | ... handle.get_remote(), [INFO] [stdout] 228 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 224 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:241:21 [INFO] [stdout] | [INFO] [stdout] 241 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] 242 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid http connect", [INFO] [stdout] 243 | | ... handle.get_token(), [INFO] [stdout] 244 | | ... handle.get_remote(), [INFO] [stdout] 245 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 241 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:258:17 [INFO] [stdout] | [INFO] [stdout] 258 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 259 | | format!("Http server write failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stdout] 260 | | handle.get_token(), [INFO] [stdout] 261 | | handle.get_remote(), [INFO] [stdout] 262 | | handle.get_local(), [INFO] [stdout] 263 | | e)))); [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 258 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:321:17 [INFO] [stdout] | [INFO] [stdout] 321 | handle.close(Ok(())); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 321 | let _ = handle.close(Ok(())); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:68:17 [INFO] [stdout] | [INFO] [stdout] 68 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 69 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, buf_len: {:?}, buf: {:?}, reason:... [INFO] [stdout] 70 | | ... handle.get_token(), [INFO] [stdout] 71 | | ... handle.get_remote(), [INFO] [stdout] 72 | | ... handle.get_local(), [INFO] [stdout] 73 | | ... buf.len(), [INFO] [stdout] 74 | | ... buf)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 68 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:107:17 [INFO] [stdout] | [INFO] [stdout] 107 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 108 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid read buffer", [INFO] [stdout] 109 | | ... handle.get_token(), [INFO] [stdout] 110 | | ... handle.get_remote(), [INFO] [stdout] 111 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 107 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:160:45 [INFO] [stdout] | [INFO] [stdout] 160 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 161 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, url: {:?}, reason: invalid url", [INFO] [stdout] 162 | | ... handle.get_token(), [INFO] [stdout] 163 | | ... handle.get_remote(), [INFO] [stdout] 164 | | ... handle.get_local(), [INFO] [stdout] 165 | | ... url)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 160 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:172:33 [INFO] [stdout] | [INFO] [stdout] 172 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 173 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, host: {:?}, reason: host not exist", [INFO] [stdout] 174 | | ... handle.get_token(), [INFO] [stdout] 175 | | ... handle.get_remote(), [INFO] [stdout] 176 | | ... handle.get_local(), [INFO] [stdout] 177 | | ... host_name)))); [INFO] [stdout] | |_______________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 172 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:182:29 [INFO] [stdout] | [INFO] [stdout] 182 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 183 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid host header", [INFO] [stdout] 184 | | ... handle.get_token(), [INFO] [stdout] 185 | | ... handle.get_remote(), [INFO] [stdout] 186 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 182 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:191:25 [INFO] [stdout] | [INFO] [stdout] 191 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 192 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: host header not exist", [INFO] [stdout] 193 | | ... handle.get_token(), [INFO] [stdout] 194 | | ... handle.get_remote(), [INFO] [stdout] 195 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 191 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/route.rs:338:9 [INFO] [stdout] | [INFO] [stdout] 338 | tab.finish(); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 338 | let _ = tab.finish(); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/file_load.rs:269:29 [INFO] [stdout] | [INFO] [stdout] 269 | / ... async_load_file_chunks( [INFO] [stdout] 270 | | ... self.files_async_runtime.clone(), [INFO] [stdout] 271 | | ... &resp, [INFO] [stdout] 272 | | ... path, [INFO] [stdout] 273 | | ... chunk_size, [INFO] [stdout] 274 | | ... self.interval, [INFO] [stdout] 275 | | ... ); [INFO] [stdout] | |_______________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 269 | let _ = async_load_file_chunks( [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/file_load.rs:655:5 [INFO] [stdout] | [INFO] [stdout] 655 | / files_async_runtime.spawn(async move { [INFO] [stdout] 656 | | let now = if let Some(timeout) = interval { [INFO] [stdout] 657 | | //设置了加载间隔时间 [INFO] [stdout] 658 | | Some(Instant::now()) [INFO] [stdout] ... | [INFO] [stdout] 720 | | }); [INFO] [stdout] | |______^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 655 | let _ = files_async_runtime.spawn(async move { [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:330:9 [INFO] [stdout] | [INFO] [stdout] 330 | / Builder::new() [INFO] [stdout] 331 | | .name(thread_name.clone()) [INFO] [stdout] 332 | | .spawn(move || { [INFO] [stdout] ... | [INFO] [stdout] 395 | | cache.is_running.store(false, Ordering::SeqCst); //设置缓存的整理状态为已停止 [INFO] [stdout] 396 | | }); [INFO] [stdout] | |______________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 330 | let _ = Builder::new() [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:518:13 [INFO] [stdout] | [INFO] [stdout] 518 | self.collect_sent.send(CollectCmd::Clear(value_size)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 518 | let _ = self.collect_sent.send(CollectCmd::Clear(value_size)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:530:13 [INFO] [stdout] | [INFO] [stdout] 530 | self.collect_sent.send(CollectCmd::Clear(0)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 530 | let _ = self.collect_sent.send(CollectCmd::Clear(0)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:568:21 [INFO] [stdout] | [INFO] [stdout] 568 | / self [INFO] [stdout] 569 | | .collect_sent [INFO] [stdout] 570 | | .send(CollectCmd::Index((timeout, cache_key.clone()))); //更新缓存的超时索引 [INFO] [stdout] | |______________________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 568 | let _ = self [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/packet.rs:37:17 [INFO] [stdout] | [INFO] [stdout] 37 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 38 | | ... format!("Http server parse header failed, token: {:?}, remote: {:?}, local: {:?}, reason: parse request... [INFO] [stdout] 39 | | ... handle.get_token(), [INFO] [stdout] 40 | | ... handle.get_remote(), [INFO] [stdout] ... | [INFO] [stdout] 43 | | ... buf, [INFO] [stdout] 44 | | ... e)))); [INFO] [stdout] | |_______________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 37 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/packet.rs:59:25 [INFO] [stdout] | [INFO] [stdout] 59 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 60 | | ... format!("Http server parse header failed, token: {:?}, remote: {:?}, local: {:?}, version: {}, reason: ... [INFO] [stdout] 61 | | ... handle.get_token(), [INFO] [stdout] 62 | | ... handle.get_remote(), [INFO] [stdout] 63 | | ... handle.get_local(), [INFO] [stdout] 64 | | ... ver)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 59 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/packet.rs:87:25 [INFO] [stdout] | [INFO] [stdout] 87 | handle.close(Err(e)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 87 | let _ = handle.close(Err(e)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 31.79s [INFO] running `Command { std: "docker" "inspect" "0d5f3d3c34890b9a9ea31521e518702227adf75afcfb2a9dfb2275c0ef3c5265", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "0d5f3d3c34890b9a9ea31521e518702227adf75afcfb2a9dfb2275c0ef3c5265", kill_on_drop: false }` [INFO] [stdout] 0d5f3d3c34890b9a9ea31521e518702227adf75afcfb2a9dfb2275c0ef3c5265 [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=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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+b83b707f97d809763b7861afa7638871f3339a33" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] fe928b378c1215d3c3f9a6366b41d7239d6c2488add1ab5aecf364d590f6f22f [INFO] running `Command { std: "docker" "start" "-a" "fe928b378c1215d3c3f9a6366b41d7239d6c2488add1ab5aecf364d590f6f22f", kill_on_drop: false }` [INFO] [stderr] Compiling libnghttp2-sys v0.1.11+1.64.0 [INFO] [stderr] Compiling libz-sys v1.1.22 [INFO] [stderr] Compiling openssl-sys v0.9.109 [INFO] [stderr] Compiling curl-sys v0.4.82+curl-8.14.1 [INFO] [stderr] Compiling tracing-attributes v0.1.29 [INFO] [stderr] Compiling pin-project-internal v1.1.10 [INFO] [stderr] Compiling polling v2.8.0 [INFO] [stderr] Compiling curl v0.4.48 [INFO] [stderr] Compiling anstyle-parse v0.2.7 [INFO] [stderr] Compiling socket2 v0.5.10 [INFO] [stderr] Compiling colorchoice v1.0.4 [INFO] [stderr] Compiling anstyle v1.0.11 [INFO] [stderr] Compiling isahc v1.7.2 [INFO] [stderr] Compiling anstyle-query v1.1.3 [INFO] [stderr] Compiling waker-fn v1.2.0 [INFO] [stderr] Compiling sluice v0.5.5 [INFO] [stderr] Compiling futures-lite v1.13.0 [INFO] [stderr] Compiling env_filter v0.1.3 [INFO] [stderr] Compiling castaway v0.1.2 [INFO] [stderr] Compiling jiff v0.2.14 [INFO] [stderr] Compiling route-recognizer v0.3.1 [INFO] [stdout] warning: unused import: `utils::SocketContext` [INFO] [stdout] --> src/server.rs:11:11 [INFO] [stdout] | [INFO] [stdout] 11 | utils::SocketContext}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around block return value [INFO] [stdout] --> src/server.rs:127:53 [INFO] [stdout] | [INFO] [stdout] 127 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 127 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] 127 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `HttpService` [INFO] [stdout] --> src/acceptor.rs:12:39 [INFO] [stdout] | [INFO] [stdout] 12 | service::{ServiceFactory, HttpService}, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around type [INFO] [stdout] --> src/acceptor.rs:26:25 [INFO] [stdout] | [INFO] [stdout] 26 | marker: PhantomData<(S)>, [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 26 - marker: PhantomData<(S)>, [INFO] [stdout] 26 + marker: PhantomData, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around block return value [INFO] [stdout] --> src/acceptor.rs:78:41 [INFO] [stdout] | [INFO] [stdout] 78 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 78 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] 78 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Ready` and `SocketContext` [INFO] [stdout] --> src/connect.rs:10:19 [INFO] [stdout] | [INFO] [stdout] 10 | utils::{SocketContext, Ready}}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `HttpService` [INFO] [stdout] --> src/virtual_host.rs:9:23 [INFO] [stdout] | [INFO] [stdout] 9 | use crate::{service::{HttpService, ServiceFactory}, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `service::HttpService` [INFO] [stdout] --> src/route.rs:14:13 [INFO] [stdout] | [INFO] [stdout] 14 | use crate::{service::HttpService, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `CompressorWriter` [INFO] [stdout] --> src/default_parser.rs:8:32 [INFO] [stdout] | [INFO] [stdout] 8 | use brotli::{CompressorReader, CompressorWriter}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/multi_parts.rs:94:52 [INFO] [stdout] | [INFO] [stdout] 94 | ... let boundary_str = (MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 94 - let boundary_str = (MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK); [INFO] [stdout] 94 + let boundary_str = MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/file_load.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/files_load.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/batch_load.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `httpdate::fmt_http_date` [INFO] [stdout] --> src/batch_load.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | use httpdate::fmt_http_date; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `pi_adler32::adler32` [INFO] [stdout] --> src/batch_load.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | use pi_adler32::adler32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/port.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `SocketHandle` and `Socket` [INFO] [stdout] --> src/response.rs:12:11 [INFO] [stdout] | [INFO] [stdout] 12 | use tcp::{Socket, SocketHandle}; [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tcp::connect::TcpSocket` [INFO] [stdout] --> src/packet.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use tcp::connect::TcpSocket; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around block return value [INFO] [stdout] --> src/packet.rs:82:49 [INFO] [stdout] | [INFO] [stdout] 82 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 82 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] 82 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::thread` [INFO] [stdout] --> src/utils.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::thread; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::pin::Pin` [INFO] [stdout] --> src/utils.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::pin::Pin; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::sync::Arc` [INFO] [stdout] --> src/utils.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::sync::Arc; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::time::Duration` [INFO] [stdout] --> src/utils.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::time::Duration; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::future::Future` [INFO] [stdout] --> src/utils.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::future::Future; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::result::Result as GenResult` [INFO] [stdout] --> src/utils.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::result::Result as GenResult; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Context`, `Poll`, and `Waker` [INFO] [stdout] --> src/utils.rs:8:17 [INFO] [stdout] | [INFO] [stdout] 8 | use std::task::{Context, Poll, Waker}; [INFO] [stdout] | ^^^^^^^ ^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `AtomicBool`, `AtomicUsize`, and `Ordering` [INFO] [stdout] --> src/utils.rs:10:25 [INFO] [stdout] | [INFO] [stdout] 10 | use std::sync::atomic::{AtomicBool, AtomicUsize, Ordering}; [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `bytes::Buf` [INFO] [stdout] --> src/utils.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use bytes::Buf; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `FutureExt` and `LocalBoxFuture` [INFO] [stdout] --> src/utils.rs:13:24 [INFO] [stdout] | [INFO] [stdout] 13 | use futures::{future::{FutureExt, LocalBoxFuture}}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `SocketHandle`, `Socket`, and `utils::Ready` [INFO] [stdout] --> src/utils.rs:16:11 [INFO] [stdout] | [INFO] [stdout] 16 | use tcp::{Socket, SocketHandle, [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] 17 | utils::Ready}; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `async_await` has been stable since 1.39.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:3:12 [INFO] [stdout] | [INFO] [stdout] 3 | #![feature(async_await)] [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(stable_features)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `entry_insert` has been stable since 1.83.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:4:12 [INFO] [stdout] | [INFO] [stdout] 4 | #![feature(entry_insert)] [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `mem_take` has been stable since 1.40.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:1:12 [INFO] [stdout] | [INFO] [stdout] 1 | #![feature(mem_take)] [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `map_first_last` has been stable since 1.66.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:5:12 [INFO] [stdout] | [INFO] [stdout] 5 | #![feature(map_first_last)] [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `http_request_result` is never read [INFO] [stdout] --> src/acceptor.rs:60:17 [INFO] [stdout] | [INFO] [stdout] 60 | let mut http_request_result = None; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/acceptor.rs:137:37 [INFO] [stdout] | [INFO] [stdout] 137 | ... let mut connect = HttpConnect::new(handle.clone(), [INFO] [stdout] | ----^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `std::sync::atomic::AtomicBool::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead [INFO] [stdout] --> src/static_cache.rs:334:37 [INFO] [stdout] | [INFO] [stdout] 334 | if cache.is_running.compare_and_swap(false, true, Ordering::SeqCst) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `http_request_result` is never read [INFO] [stdout] --> src/server.rs:109:29 [INFO] [stdout] | [INFO] [stdout] 109 | let mut http_request_result = None; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/multi_parts.rs:212:17 [INFO] [stdout] | [INFO] [stdout] 212 | if let Some(mut part_buf) = context.take_part_buf() { [INFO] [stdout] | ----^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/multi_parts.rs:222:17 [INFO] [stdout] | [INFO] [stdout] 222 | if let Some(mut part_buf) = context.take_part_buf() { [INFO] [stdout] | ----^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/range_load.rs:45:29 [INFO] [stdout] | [INFO] [stdout] 45 | let mut vec: Vec<&str> = range_str.split("-").collect(); [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `file_path_id` is never read [INFO] [stdout] --> src/file_load.rs:104:21 [INFO] [stdout] | [INFO] [stdout] 104 | let mut file_path_id = Atom::from(""); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `timeout` [INFO] [stdout] --> src/file_load.rs:656:31 [INFO] [stdout] | [INFO] [stdout] 656 | let now = if let Some(timeout) = interval { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_timeout` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cache_key` [INFO] [stdout] --> src/static_cache.rs:620:13 [INFO] [stdout] | [INFO] [stdout] 620 | let cache_key = if let Some(owner) = owner { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cache_key` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `with_capacity` is never used [INFO] [stdout] --> src/route.rs:64:12 [INFO] [stdout] | [INFO] [stdout] 52 | impl> WildcardRouter { [INFO] [stdout] | -------------------------------------------------------------------------------------------------------------------- associated function in this implementation [INFO] [stdout] ... [INFO] [stdout] 64 | pub fn with_capacity(capacity: usize) -> Self { [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 `buf_size` is never read [INFO] [stdout] --> src/default_parser.rs:39:5 [INFO] [stdout] | [INFO] [stdout] 36 | pub struct DefaultParser { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 39 | buf_size: usize, //压缩缓冲区大小 [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DefaultParser` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `HTTPS_ASYNC_FILE_UPLOAD_PRIORITY` is never used [INFO] [stdout] --> src/upload.rs:29:7 [INFO] [stdout] | [INFO] [stdout] 29 | const HTTPS_ASYNC_FILE_UPLOAD_PRIORITY: usize = 100; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `Stop` is never constructed [INFO] [stdout] --> src/static_cache.rs:269:5 [INFO] [stdout] | [INFO] [stdout] 268 | enum CollectCmd { [INFO] [stdout] | ---------- variant in this enum [INFO] [stdout] 269 | Stop(String), //关闭整理 [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `CollectCmd` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `DEFAULT_BLOCK_SIZE` is never used [INFO] [stdout] --> src/request.rs:16:7 [INFO] [stdout] | [INFO] [stdout] 16 | const DEFAULT_BLOCK_SIZE: usize = 8192; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `MAX_BLOCK_LIMIT` is never used [INFO] [stdout] --> src/request.rs:21:7 [INFO] [stdout] | [INFO] [stdout] 21 | const MAX_BLOCK_LIMIT: usize = 16 * 1024 * 1024; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `is_stream` is never read [INFO] [stdout] --> src/response.rs:45:5 [INFO] [stdout] | [INFO] [stdout] 44 | pub struct RespBody { [INFO] [stdout] | -------- field in this struct [INFO] [stdout] 45 | is_stream: bool, //是否是流响应体 [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:37:17 [INFO] [stdout] | [INFO] [stdout] 37 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 38 | | format!("Http server connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stdout] 39 | | handle.get_token(), [INFO] [stdout] 40 | | handle.get_remote(), [INFO] [stdout] 41 | | handle.get_local(), [INFO] [stdout] 42 | | e)))); [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 37 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:56:17 [INFO] [stdout] | [INFO] [stdout] 56 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 57 | | format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stdout] 58 | | handle.get_token(), [INFO] [stdout] 59 | | handle.get_remote(), [INFO] [stdout] 60 | | handle.get_local(), [INFO] [stdout] 61 | | e)))); [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 56 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:98:21 [INFO] [stdout] | [INFO] [stdout] 98 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] 99 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid http connect ... [INFO] [stdout] 100 | | ... handle.get_token(), [INFO] [stdout] 101 | | ... handle.get_remote(), [INFO] [stdout] 102 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 98 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:117:29 [INFO] [stdout] | [INFO] [stdout] 117 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 118 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, buf_len: {:?}, buf: {:?}, rea... [INFO] [stdout] 119 | | ... handle.get_token(), [INFO] [stdout] 120 | | ... handle.get_remote(), [INFO] [stdout] 121 | | ... handle.get_local(), [INFO] [stdout] 122 | | ... buf.len(), [INFO] [stdout] 123 | | ... buf)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 117 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:155:29 [INFO] [stdout] | [INFO] [stdout] 155 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 156 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid read buffer", [INFO] [stdout] 157 | | ... handle.get_token(), [INFO] [stdout] 158 | | ... handle.get_remote(), [INFO] [stdout] 159 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 155 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:203:53 [INFO] [stdout] | [INFO] [stdout] 203 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] 204 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, url: {:?}, reason: invalid url", [INFO] [stdout] 205 | | ... handle.get_token(), [INFO] [stdout] 206 | | ... handle.get_remote(), [INFO] [stdout] 207 | | ... handle.get_local(), [INFO] [stdout] 208 | | ... url)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 203 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:215:41 [INFO] [stdout] | [INFO] [stdout] 215 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 216 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid host header", [INFO] [stdout] 217 | | ... handle.get_token(), [INFO] [stdout] 218 | | ... handle.get_remote(), [INFO] [stdout] 219 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 215 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:224:37 [INFO] [stdout] | [INFO] [stdout] 224 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 225 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: host header not exist", [INFO] [stdout] 226 | | ... handle.get_token(), [INFO] [stdout] 227 | | ... handle.get_remote(), [INFO] [stdout] 228 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 224 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:241:21 [INFO] [stdout] | [INFO] [stdout] 241 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] 242 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid http connect", [INFO] [stdout] 243 | | ... handle.get_token(), [INFO] [stdout] 244 | | ... handle.get_remote(), [INFO] [stdout] 245 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 241 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:258:17 [INFO] [stdout] | [INFO] [stdout] 258 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 259 | | format!("Http server write failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stdout] 260 | | handle.get_token(), [INFO] [stdout] 261 | | handle.get_remote(), [INFO] [stdout] 262 | | handle.get_local(), [INFO] [stdout] 263 | | e)))); [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 258 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:321:17 [INFO] [stdout] | [INFO] [stdout] 321 | handle.close(Ok(())); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 321 | let _ = handle.close(Ok(())); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:68:17 [INFO] [stdout] | [INFO] [stdout] 68 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 69 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, buf_len: {:?}, buf: {:?}, reason:... [INFO] [stdout] 70 | | ... handle.get_token(), [INFO] [stdout] 71 | | ... handle.get_remote(), [INFO] [stdout] 72 | | ... handle.get_local(), [INFO] [stdout] 73 | | ... buf.len(), [INFO] [stdout] 74 | | ... buf)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 68 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:107:17 [INFO] [stdout] | [INFO] [stdout] 107 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 108 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid read buffer", [INFO] [stdout] 109 | | ... handle.get_token(), [INFO] [stdout] 110 | | ... handle.get_remote(), [INFO] [stdout] 111 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 107 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:160:45 [INFO] [stdout] | [INFO] [stdout] 160 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 161 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, url: {:?}, reason: invalid url", [INFO] [stdout] 162 | | ... handle.get_token(), [INFO] [stdout] 163 | | ... handle.get_remote(), [INFO] [stdout] 164 | | ... handle.get_local(), [INFO] [stdout] 165 | | ... url)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 160 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:172:33 [INFO] [stdout] | [INFO] [stdout] 172 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 173 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, host: {:?}, reason: host not exist", [INFO] [stdout] 174 | | ... handle.get_token(), [INFO] [stdout] 175 | | ... handle.get_remote(), [INFO] [stdout] 176 | | ... handle.get_local(), [INFO] [stdout] 177 | | ... host_name)))); [INFO] [stdout] | |_______________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 172 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:182:29 [INFO] [stdout] | [INFO] [stdout] 182 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 183 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid host header", [INFO] [stdout] 184 | | ... handle.get_token(), [INFO] [stdout] 185 | | ... handle.get_remote(), [INFO] [stdout] 186 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 182 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:191:25 [INFO] [stdout] | [INFO] [stdout] 191 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 192 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: host header not exist", [INFO] [stdout] 193 | | ... handle.get_token(), [INFO] [stdout] 194 | | ... handle.get_remote(), [INFO] [stdout] 195 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 191 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/route.rs:338:9 [INFO] [stdout] | [INFO] [stdout] 338 | tab.finish(); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 338 | let _ = tab.finish(); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/file_load.rs:269:29 [INFO] [stdout] | [INFO] [stdout] 269 | / ... async_load_file_chunks( [INFO] [stdout] 270 | | ... self.files_async_runtime.clone(), [INFO] [stdout] 271 | | ... &resp, [INFO] [stdout] 272 | | ... path, [INFO] [stdout] 273 | | ... chunk_size, [INFO] [stdout] 274 | | ... self.interval, [INFO] [stdout] 275 | | ... ); [INFO] [stdout] | |_______________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 269 | let _ = async_load_file_chunks( [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/file_load.rs:655:5 [INFO] [stdout] | [INFO] [stdout] 655 | / files_async_runtime.spawn(async move { [INFO] [stdout] 656 | | let now = if let Some(timeout) = interval { [INFO] [stdout] 657 | | //设置了加载间隔时间 [INFO] [stdout] 658 | | Some(Instant::now()) [INFO] [stdout] ... | [INFO] [stdout] 720 | | }); [INFO] [stdout] | |______^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 655 | let _ = files_async_runtime.spawn(async move { [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:330:9 [INFO] [stdout] | [INFO] [stdout] 330 | / Builder::new() [INFO] [stdout] 331 | | .name(thread_name.clone()) [INFO] [stdout] 332 | | .spawn(move || { [INFO] [stdout] ... | [INFO] [stdout] 395 | | cache.is_running.store(false, Ordering::SeqCst); //设置缓存的整理状态为已停止 [INFO] [stdout] 396 | | }); [INFO] [stdout] | |______________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 330 | let _ = Builder::new() [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:518:13 [INFO] [stdout] | [INFO] [stdout] 518 | self.collect_sent.send(CollectCmd::Clear(value_size)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 518 | let _ = self.collect_sent.send(CollectCmd::Clear(value_size)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:530:13 [INFO] [stdout] | [INFO] [stdout] 530 | self.collect_sent.send(CollectCmd::Clear(0)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 530 | let _ = self.collect_sent.send(CollectCmd::Clear(0)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:568:21 [INFO] [stdout] | [INFO] [stdout] 568 | / self [INFO] [stdout] 569 | | .collect_sent [INFO] [stdout] 570 | | .send(CollectCmd::Index((timeout, cache_key.clone()))); //更新缓存的超时索引 [INFO] [stdout] | |______________________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 568 | let _ = self [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/packet.rs:37:17 [INFO] [stdout] | [INFO] [stdout] 37 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 38 | | ... format!("Http server parse header failed, token: {:?}, remote: {:?}, local: {:?}, reason: parse request... [INFO] [stdout] 39 | | ... handle.get_token(), [INFO] [stdout] 40 | | ... handle.get_remote(), [INFO] [stdout] ... | [INFO] [stdout] 43 | | ... buf, [INFO] [stdout] 44 | | ... e)))); [INFO] [stdout] | |_______________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 37 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/packet.rs:59:25 [INFO] [stdout] | [INFO] [stdout] 59 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 60 | | ... format!("Http server parse header failed, token: {:?}, remote: {:?}, local: {:?}, version: {}, reason: ... [INFO] [stdout] 61 | | ... handle.get_token(), [INFO] [stdout] 62 | | ... handle.get_remote(), [INFO] [stdout] 63 | | ... handle.get_local(), [INFO] [stdout] 64 | | ... ver)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 59 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/packet.rs:87:25 [INFO] [stdout] | [INFO] [stdout] 87 | handle.close(Err(e)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 87 | let _ = handle.close(Err(e)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling anstream v0.6.19 [INFO] [stderr] Compiling pin-project v1.1.10 [INFO] [stderr] Compiling tracing v0.1.41 [INFO] [stderr] Compiling tracing-futures v0.2.5 [INFO] [stderr] Compiling env_logger v0.11.8 [INFO] [stderr] Compiling pi_http v0.3.8 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused imports: `AsyncService`, `Ready`, `SocketEvent`, `SocketHandle`, and `SocketStatus` [INFO] [stdout] --> tests/test.rs:30:11 [INFO] [stdout] | [INFO] [stdout] 30 | use tcp::{AsyncService, Socket, SocketHandle, SocketConfig, SocketStatus, SocketEvent, [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 34 | utils::{TlsConfig, Ready}}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> tests/test.rs:279:28 [INFO] [stdout] | [INFO] [stdout] 279 | let boundary_end_str = (String::from_utf8_lossy(b"------WebKitFormBoundaryda3kjf6KAEbPATkF") + "--\r\n"); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 279 - let boundary_end_str = (String::from_utf8_lossy(b"------WebKitFormBoundaryda3kjf6KAEbPATkF") + "--\r\n"); [INFO] [stdout] 279 + let boundary_end_str = String::from_utf8_lossy(b"------WebKitFormBoundaryda3kjf6KAEbPATkF") + "--\r\n"; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `utils::SocketContext` [INFO] [stdout] --> src/server.rs:11:11 [INFO] [stdout] | [INFO] [stdout] 11 | utils::SocketContext}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around block return value [INFO] [stdout] --> src/server.rs:127:53 [INFO] [stdout] | [INFO] [stdout] 127 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 127 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] 127 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `HttpService` [INFO] [stdout] --> src/acceptor.rs:12:39 [INFO] [stdout] | [INFO] [stdout] 12 | service::{ServiceFactory, HttpService}, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around type [INFO] [stdout] --> src/acceptor.rs:26:25 [INFO] [stdout] | [INFO] [stdout] 26 | marker: PhantomData<(S)>, [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 26 - marker: PhantomData<(S)>, [INFO] [stdout] 26 + marker: PhantomData, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around block return value [INFO] [stdout] --> src/acceptor.rs:78:41 [INFO] [stdout] | [INFO] [stdout] 78 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 78 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] 78 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Ready` and `SocketContext` [INFO] [stdout] --> src/connect.rs:10:19 [INFO] [stdout] | [INFO] [stdout] 10 | utils::{SocketContext, Ready}}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `HttpService` [INFO] [stdout] --> src/virtual_host.rs:9:23 [INFO] [stdout] | [INFO] [stdout] 9 | use crate::{service::{HttpService, ServiceFactory}, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `service::HttpService` [INFO] [stdout] --> src/route.rs:14:13 [INFO] [stdout] | [INFO] [stdout] 14 | use crate::{service::HttpService, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `CompressorWriter` [INFO] [stdout] --> src/default_parser.rs:8:32 [INFO] [stdout] | [INFO] [stdout] 8 | use brotli::{CompressorReader, CompressorWriter}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/multi_parts.rs:94:52 [INFO] [stdout] | [INFO] [stdout] 94 | ... let boundary_str = (MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 94 - let boundary_str = (MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK); [INFO] [stdout] 94 + let boundary_str = MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/file_load.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/files_load.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/batch_load.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `httpdate::fmt_http_date` [INFO] [stdout] --> src/batch_load.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | use httpdate::fmt_http_date; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `pi_adler32::adler32` [INFO] [stdout] --> src/batch_load.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | use pi_adler32::adler32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::str::FromStr` [INFO] [stdout] --> src/port.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::str::FromStr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `SocketHandle` and `Socket` [INFO] [stdout] --> src/response.rs:12:11 [INFO] [stdout] | [INFO] [stdout] 12 | use tcp::{Socket, SocketHandle}; [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tcp::connect::TcpSocket` [INFO] [stdout] --> src/packet.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use tcp::connect::TcpSocket; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around block return value [INFO] [stdout] --> src/packet.rs:82:49 [INFO] [stdout] | [INFO] [stdout] 82 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 82 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stdout] 82 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::thread` [INFO] [stdout] --> src/utils.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::thread; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::pin::Pin` [INFO] [stdout] --> src/utils.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::pin::Pin; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::sync::Arc` [INFO] [stdout] --> src/utils.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::sync::Arc; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::time::Duration` [INFO] [stdout] --> src/utils.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::time::Duration; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::future::Future` [INFO] [stdout] --> src/utils.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::future::Future; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::result::Result as GenResult` [INFO] [stdout] --> src/utils.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::result::Result as GenResult; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Context`, `Poll`, and `Waker` [INFO] [stdout] --> src/utils.rs:8:17 [INFO] [stdout] | [INFO] [stdout] 8 | use std::task::{Context, Poll, Waker}; [INFO] [stdout] | ^^^^^^^ ^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `AtomicBool`, `AtomicUsize`, and `Ordering` [INFO] [stdout] --> src/utils.rs:10:25 [INFO] [stdout] | [INFO] [stdout] 10 | use std::sync::atomic::{AtomicBool, AtomicUsize, Ordering}; [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `bytes::Buf` [INFO] [stdout] --> src/utils.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use bytes::Buf; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `FutureExt` and `LocalBoxFuture` [INFO] [stdout] --> src/utils.rs:13:24 [INFO] [stdout] | [INFO] [stdout] 13 | use futures::{future::{FutureExt, LocalBoxFuture}}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `SocketHandle`, `Socket`, and `utils::Ready` [INFO] [stdout] --> src/utils.rs:16:11 [INFO] [stdout] | [INFO] [stdout] 16 | use tcp::{Socket, SocketHandle, [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] 17 | utils::Ready}; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `async_await` has been stable since 1.39.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:3:12 [INFO] [stdout] | [INFO] [stdout] 3 | #![feature(async_await)] [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(stable_features)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `entry_insert` has been stable since 1.83.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:4:12 [INFO] [stdout] | [INFO] [stdout] 4 | #![feature(entry_insert)] [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `mem_take` has been stable since 1.40.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:1:12 [INFO] [stdout] | [INFO] [stdout] 1 | #![feature(mem_take)] [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `map_first_last` has been stable since 1.66.0 and no longer requires an attribute to enable [INFO] [stdout] --> src/lib.rs:5:12 [INFO] [stdout] | [INFO] [stdout] 5 | #![feature(map_first_last)] [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `http_request_result` is never read [INFO] [stdout] --> src/acceptor.rs:60:17 [INFO] [stdout] | [INFO] [stdout] 60 | let mut http_request_result = None; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Write` [INFO] [stdout] --> tests/test.rs:6:21 [INFO] [stdout] | [INFO] [stdout] 6 | use std::io::{Read, Write}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/acceptor.rs:137:37 [INFO] [stdout] | [INFO] [stdout] 137 | ... let mut connect = HttpConnect::new(handle.clone(), [INFO] [stdout] | ----^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> tests/test.rs:77:9 [INFO] [stdout] | [INFO] [stdout] 77 | let mut vec0 = vec![ [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> tests/test.rs:85:9 [INFO] [stdout] | [INFO] [stdout] 85 | let mut vec1 = vec![ [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> tests/test.rs:93:9 [INFO] [stdout] | [INFO] [stdout] 93 | let mut vec2 = vec![ [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `context` [INFO] [stdout] --> tests/test.rs:338:21 [INFO] [stdout] | [INFO] [stdout] 338 | context: &'a mut GatewayContext, [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `msg` [INFO] [stdout] --> tests/test.rs:390:9 [INFO] [stdout] | [INFO] [stdout] 390 | let msg = WrapMsg(msg); [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_msg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `env` [INFO] [stdout] --> tests/test.rs:383:28 [INFO] [stdout] | [INFO] [stdout] 383 | ... env: Arc, [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_env` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `method` [INFO] [stdout] --> tests/test.rs:386:28 [INFO] [stdout] | [INFO] [stdout] 386 | ... method: String, [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_method` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `headers` [INFO] [stdout] --> tests/test.rs:387:28 [INFO] [stdout] | [INFO] [stdout] 387 | ... headers: Arc, [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_headers` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `driver` [INFO] [stdout] --> tests/test.rs:556:12 [INFO] [stdout] | [INFO] [stdout] 556 | Ok(driver) => { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_driver` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> tests/test.rs:421:9 [INFO] [stdout] | [INFO] [stdout] 421 | let mut builder = MultiTaskRuntimeBuilder::default(); [INFO] [stdout] | ----^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `driver` [INFO] [stdout] --> tests/test.rs:740:12 [INFO] [stdout] | [INFO] [stdout] 740 | Ok(driver) => { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_driver` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> tests/test.rs:605:9 [INFO] [stdout] | [INFO] [stdout] 605 | let mut builder = MultiTaskRuntimeBuilder::default(); [INFO] [stdout] | ----^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> tests/test.rs:725:9 [INFO] [stdout] | [INFO] [stdout] 725 | let mut config = SocketConfig::with_tls("0.0.0.0", &[(443, tls_config)]); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `TestMultiPartsHandler` is never constructed [INFO] [stdout] --> tests/test.rs:309:8 [INFO] [stdout] | [INFO] [stdout] 309 | struct TestMultiPartsHandler; [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] --> tests/test.rs:350:16 [INFO] [stdout] | [INFO] [stdout] 350 | struct WrapMsg(Arc>>); [INFO] [stdout] | ------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | field in this struct [INFO] [stdout] | [INFO] [stdout] = help: consider removing this field [INFO] [stdout] = note: `WrapMsg` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> tests/test.rs:394:5 [INFO] [stdout] | [INFO] [stdout] 394 | / rt.spawn(async move { [INFO] [stdout] ... | [INFO] [stdout] 410 | | println!("!!!!!!http gateway handle ok, topic: {:?}, addr: {:?}", topic.as_str(), addr); [INFO] [stdout] 411 | | }); [INFO] [stdout] | |______^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 394 | let _ = rt.spawn(async move { [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> tests/test.rs:409:9 [INFO] [stdout] | [INFO] [stdout] 409 | resp_handler.finish().await; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 409 | let _ = resp_handler.finish().await; [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> tests/test.rs:442:5 [INFO] [stdout] | [INFO] [stdout] 442 | cors_handler.allow_origin("http".to_string(), "msg.highapp.com".to_string(), 80, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 442 | let _ = cors_handler.allow_origin("http".to_string(), "msg.highapp.com".to_string(), 80, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> tests/test.rs:443:5 [INFO] [stdout] | [INFO] [stdout] 443 | cors_handler.allow_origin("http".to_string(), "127.0.0.1".to_string(), 80, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 443 | let _ = cors_handler.allow_origin("http".to_string(), "127.0.0.1".to_string(), 80, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> tests/test.rs:534:5 [INFO] [stdout] | [INFO] [stdout] 534 | hosts.add("test.17youx.cn", host.clone()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 534 | let _ = hosts.add("test.17youx.cn", host.clone()); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> tests/test.rs:535:5 [INFO] [stdout] | [INFO] [stdout] 535 | hosts.add_default(host); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 535 | let _ = hosts.add_default(host); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> tests/test.rs:621:5 [INFO] [stdout] | [INFO] [stdout] 621 | cors_handler.allow_origin("https".to_string(), "msg.highapp.com".to_string(), 443, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 621 | let _ = cors_handler.allow_origin("https".to_string(), "msg.highapp.com".to_string(), 443, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> tests/test.rs:622:5 [INFO] [stdout] | [INFO] [stdout] 622 | cors_handler.allow_origin("https".to_string(), "127.0.0.1".to_string(), 443, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 622 | let _ = cors_handler.allow_origin("https".to_string(), "127.0.0.1".to_string(), 443, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> tests/test.rs:709:5 [INFO] [stdout] | [INFO] [stdout] 709 | hosts.add("test.17youx.cn", host.clone()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 709 | let _ = hosts.add("test.17youx.cn", host.clone()); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> tests/test.rs:710:5 [INFO] [stdout] | [INFO] [stdout] 710 | hosts.add_default(host); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 710 | let _ = hosts.add_default(host); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `std::sync::atomic::AtomicBool::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead [INFO] [stdout] --> src/static_cache.rs:334:37 [INFO] [stdout] | [INFO] [stdout] 334 | if cache.is_running.compare_and_swap(false, true, Ordering::SeqCst) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `http_request_result` is never read [INFO] [stdout] --> src/server.rs:109:29 [INFO] [stdout] | [INFO] [stdout] 109 | let mut http_request_result = None; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/multi_parts.rs:212:17 [INFO] [stdout] | [INFO] [stdout] 212 | if let Some(mut part_buf) = context.take_part_buf() { [INFO] [stdout] | ----^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/multi_parts.rs:222:17 [INFO] [stdout] | [INFO] [stdout] 222 | if let Some(mut part_buf) = context.take_part_buf() { [INFO] [stdout] | ----^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/range_load.rs:45:29 [INFO] [stdout] | [INFO] [stdout] 45 | let mut vec: Vec<&str> = range_str.split("-").collect(); [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `file_path_id` is never read [INFO] [stdout] --> src/file_load.rs:104:21 [INFO] [stdout] | [INFO] [stdout] 104 | let mut file_path_id = Atom::from(""); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `timeout` [INFO] [stdout] --> src/file_load.rs:656:31 [INFO] [stdout] | [INFO] [stdout] 656 | let now = if let Some(timeout) = interval { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_timeout` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cache_key` [INFO] [stdout] --> src/static_cache.rs:620:13 [INFO] [stdout] | [INFO] [stdout] 620 | let cache_key = if let Some(owner) = owner { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cache_key` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `with_capacity` is never used [INFO] [stdout] --> src/route.rs:64:12 [INFO] [stdout] | [INFO] [stdout] 52 | impl> WildcardRouter { [INFO] [stdout] | -------------------------------------------------------------------------------------------------------------------- associated function in this implementation [INFO] [stdout] ... [INFO] [stdout] 64 | pub fn with_capacity(capacity: usize) -> Self { [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 `buf_size` is never read [INFO] [stdout] --> src/default_parser.rs:39:5 [INFO] [stdout] | [INFO] [stdout] 36 | pub struct DefaultParser { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 39 | buf_size: usize, //压缩缓冲区大小 [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DefaultParser` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `HTTPS_ASYNC_FILE_UPLOAD_PRIORITY` is never used [INFO] [stdout] --> src/upload.rs:29:7 [INFO] [stdout] | [INFO] [stdout] 29 | const HTTPS_ASYNC_FILE_UPLOAD_PRIORITY: usize = 100; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `Stop` is never constructed [INFO] [stdout] --> src/static_cache.rs:269:5 [INFO] [stdout] | [INFO] [stdout] 268 | enum CollectCmd { [INFO] [stdout] | ---------- variant in this enum [INFO] [stdout] 269 | Stop(String), //关闭整理 [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `CollectCmd` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `DEFAULT_BLOCK_SIZE` is never used [INFO] [stdout] --> src/request.rs:16:7 [INFO] [stdout] | [INFO] [stdout] 16 | const DEFAULT_BLOCK_SIZE: usize = 8192; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `MAX_BLOCK_LIMIT` is never used [INFO] [stdout] --> src/request.rs:21:7 [INFO] [stdout] | [INFO] [stdout] 21 | const MAX_BLOCK_LIMIT: usize = 16 * 1024 * 1024; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `is_stream` is never read [INFO] [stdout] --> src/response.rs:45:5 [INFO] [stdout] | [INFO] [stdout] 44 | pub struct RespBody { [INFO] [stdout] | -------- field in this struct [INFO] [stdout] 45 | is_stream: bool, //是否是流响应体 [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:37:17 [INFO] [stdout] | [INFO] [stdout] 37 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 38 | | format!("Http server connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stdout] 39 | | handle.get_token(), [INFO] [stdout] 40 | | handle.get_remote(), [INFO] [stdout] 41 | | handle.get_local(), [INFO] [stdout] 42 | | e)))); [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 37 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:56:17 [INFO] [stdout] | [INFO] [stdout] 56 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 57 | | format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stdout] 58 | | handle.get_token(), [INFO] [stdout] 59 | | handle.get_remote(), [INFO] [stdout] 60 | | handle.get_local(), [INFO] [stdout] 61 | | e)))); [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 56 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:98:21 [INFO] [stdout] | [INFO] [stdout] 98 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] 99 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid http connect ... [INFO] [stdout] 100 | | ... handle.get_token(), [INFO] [stdout] 101 | | ... handle.get_remote(), [INFO] [stdout] 102 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 98 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:117:29 [INFO] [stdout] | [INFO] [stdout] 117 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 118 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, buf_len: {:?}, buf: {:?}, rea... [INFO] [stdout] 119 | | ... handle.get_token(), [INFO] [stdout] 120 | | ... handle.get_remote(), [INFO] [stdout] 121 | | ... handle.get_local(), [INFO] [stdout] 122 | | ... buf.len(), [INFO] [stdout] 123 | | ... buf)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 117 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:155:29 [INFO] [stdout] | [INFO] [stdout] 155 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 156 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid read buffer", [INFO] [stdout] 157 | | ... handle.get_token(), [INFO] [stdout] 158 | | ... handle.get_remote(), [INFO] [stdout] 159 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 155 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:203:53 [INFO] [stdout] | [INFO] [stdout] 203 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] 204 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, url: {:?}, reason: invalid url", [INFO] [stdout] 205 | | ... handle.get_token(), [INFO] [stdout] 206 | | ... handle.get_remote(), [INFO] [stdout] 207 | | ... handle.get_local(), [INFO] [stdout] 208 | | ... url)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 203 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:215:41 [INFO] [stdout] | [INFO] [stdout] 215 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 216 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid host header", [INFO] [stdout] 217 | | ... handle.get_token(), [INFO] [stdout] 218 | | ... handle.get_remote(), [INFO] [stdout] 219 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 215 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:224:37 [INFO] [stdout] | [INFO] [stdout] 224 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 225 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: host header not exist", [INFO] [stdout] 226 | | ... handle.get_token(), [INFO] [stdout] 227 | | ... handle.get_remote(), [INFO] [stdout] 228 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 224 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:241:21 [INFO] [stdout] | [INFO] [stdout] 241 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] 242 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid http connect", [INFO] [stdout] 243 | | ... handle.get_token(), [INFO] [stdout] 244 | | ... handle.get_remote(), [INFO] [stdout] 245 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 241 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:258:17 [INFO] [stdout] | [INFO] [stdout] 258 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 259 | | format!("Http server write failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stdout] 260 | | handle.get_token(), [INFO] [stdout] 261 | | handle.get_remote(), [INFO] [stdout] 262 | | handle.get_local(), [INFO] [stdout] 263 | | e)))); [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 258 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/server.rs:321:17 [INFO] [stdout] | [INFO] [stdout] 321 | handle.close(Ok(())); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 321 | let _ = handle.close(Ok(())); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:68:17 [INFO] [stdout] | [INFO] [stdout] 68 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 69 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, buf_len: {:?}, buf: {:?}, reason:... [INFO] [stdout] 70 | | ... handle.get_token(), [INFO] [stdout] 71 | | ... handle.get_remote(), [INFO] [stdout] 72 | | ... handle.get_local(), [INFO] [stdout] 73 | | ... buf.len(), [INFO] [stdout] 74 | | ... buf)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 68 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:107:17 [INFO] [stdout] | [INFO] [stdout] 107 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 108 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid read buffer", [INFO] [stdout] 109 | | ... handle.get_token(), [INFO] [stdout] 110 | | ... handle.get_remote(), [INFO] [stdout] 111 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 107 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:160:45 [INFO] [stdout] | [INFO] [stdout] 160 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 161 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, url: {:?}, reason: invalid url", [INFO] [stdout] 162 | | ... handle.get_token(), [INFO] [stdout] 163 | | ... handle.get_remote(), [INFO] [stdout] 164 | | ... handle.get_local(), [INFO] [stdout] 165 | | ... url)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 160 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:172:33 [INFO] [stdout] | [INFO] [stdout] 172 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 173 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, host: {:?}, reason: host not exist", [INFO] [stdout] 174 | | ... handle.get_token(), [INFO] [stdout] 175 | | ... handle.get_remote(), [INFO] [stdout] 176 | | ... handle.get_local(), [INFO] [stdout] 177 | | ... host_name)))); [INFO] [stdout] | |_______________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 172 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:182:29 [INFO] [stdout] | [INFO] [stdout] 182 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 183 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid host header", [INFO] [stdout] 184 | | ... handle.get_token(), [INFO] [stdout] 185 | | ... handle.get_remote(), [INFO] [stdout] 186 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 182 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/acceptor.rs:191:25 [INFO] [stdout] | [INFO] [stdout] 191 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 192 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: host header not exist", [INFO] [stdout] 193 | | ... handle.get_token(), [INFO] [stdout] 194 | | ... handle.get_remote(), [INFO] [stdout] 195 | | ... handle.get_local())))); [INFO] [stdout] | |________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 191 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/route.rs:338:9 [INFO] [stdout] | [INFO] [stdout] 338 | tab.finish(); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 338 | let _ = tab.finish(); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/file_load.rs:269:29 [INFO] [stdout] | [INFO] [stdout] 269 | / ... async_load_file_chunks( [INFO] [stdout] 270 | | ... self.files_async_runtime.clone(), [INFO] [stdout] 271 | | ... &resp, [INFO] [stdout] 272 | | ... path, [INFO] [stdout] 273 | | ... chunk_size, [INFO] [stdout] 274 | | ... self.interval, [INFO] [stdout] 275 | | ... ); [INFO] [stdout] | |_______________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 269 | let _ = async_load_file_chunks( [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/file_load.rs:655:5 [INFO] [stdout] | [INFO] [stdout] 655 | / files_async_runtime.spawn(async move { [INFO] [stdout] 656 | | let now = if let Some(timeout) = interval { [INFO] [stdout] 657 | | //设置了加载间隔时间 [INFO] [stdout] 658 | | Some(Instant::now()) [INFO] [stdout] ... | [INFO] [stdout] 720 | | }); [INFO] [stdout] | |______^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 655 | let _ = files_async_runtime.spawn(async move { [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:330:9 [INFO] [stdout] | [INFO] [stdout] 330 | / Builder::new() [INFO] [stdout] 331 | | .name(thread_name.clone()) [INFO] [stdout] 332 | | .spawn(move || { [INFO] [stdout] ... | [INFO] [stdout] 395 | | cache.is_running.store(false, Ordering::SeqCst); //设置缓存的整理状态为已停止 [INFO] [stdout] 396 | | }); [INFO] [stdout] | |______________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 330 | let _ = Builder::new() [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:518:13 [INFO] [stdout] | [INFO] [stdout] 518 | self.collect_sent.send(CollectCmd::Clear(value_size)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 518 | let _ = self.collect_sent.send(CollectCmd::Clear(value_size)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:530:13 [INFO] [stdout] | [INFO] [stdout] 530 | self.collect_sent.send(CollectCmd::Clear(0)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 530 | let _ = self.collect_sent.send(CollectCmd::Clear(0)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/static_cache.rs:568:21 [INFO] [stdout] | [INFO] [stdout] 568 | / self [INFO] [stdout] 569 | | .collect_sent [INFO] [stdout] 570 | | .send(CollectCmd::Index((timeout, cache_key.clone()))); //更新缓存的超时索引 [INFO] [stdout] | |______________________________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 568 | let _ = self [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/packet.rs:37:17 [INFO] [stdout] | [INFO] [stdout] 37 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 38 | | ... format!("Http server parse header failed, token: {:?}, remote: {:?}, local: {:?}, reason: parse request... [INFO] [stdout] 39 | | ... handle.get_token(), [INFO] [stdout] 40 | | ... handle.get_remote(), [INFO] [stdout] ... | [INFO] [stdout] 43 | | ... buf, [INFO] [stdout] 44 | | ... e)))); [INFO] [stdout] | |_______________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 37 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/packet.rs:59:25 [INFO] [stdout] | [INFO] [stdout] 59 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] 60 | | ... format!("Http server parse header failed, token: {:?}, remote: {:?}, local: {:?}, version: {}, reason: ... [INFO] [stdout] 61 | | ... handle.get_token(), [INFO] [stdout] 62 | | ... handle.get_remote(), [INFO] [stdout] 63 | | ... handle.get_local(), [INFO] [stdout] 64 | | ... ver)))); [INFO] [stdout] | |_________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 59 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/packet.rs:87:25 [INFO] [stdout] | [INFO] [stdout] 87 | handle.close(Err(e)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 87 | let _ = handle.close(Err(e)); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 31.62s [INFO] running `Command { std: "docker" "inspect" "fe928b378c1215d3c3f9a6366b41d7239d6c2488add1ab5aecf364d590f6f22f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "fe928b378c1215d3c3f9a6366b41d7239d6c2488add1ab5aecf364d590f6f22f", kill_on_drop: false }` [INFO] [stdout] fe928b378c1215d3c3f9a6366b41d7239d6c2488add1ab5aecf364d590f6f22f [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=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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+b83b707f97d809763b7861afa7638871f3339a33" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 842bb745ba45922d6cc4be248ce7b3a516714cc5f11cb8f0af21e8bf3a87a64a [INFO] running `Command { std: "docker" "start" "-a" "842bb745ba45922d6cc4be248ce7b3a516714cc5f11cb8f0af21e8bf3a87a64a", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `utils::SocketContext` [INFO] [stderr] --> src/server.rs:11:11 [INFO] [stderr] | [INFO] [stderr] 11 | utils::SocketContext}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around block return value [INFO] [stderr] --> src/server.rs:127:53 [INFO] [stderr] | [INFO] [stderr] 127 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 127 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stderr] 127 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused import: `HttpService` [INFO] [stderr] --> src/acceptor.rs:12:39 [INFO] [stderr] | [INFO] [stderr] 12 | service::{ServiceFactory, HttpService}, [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around type [INFO] [stderr] --> src/acceptor.rs:26:25 [INFO] [stderr] | [INFO] [stderr] 26 | marker: PhantomData<(S)>, [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 26 - marker: PhantomData<(S)>, [INFO] [stderr] 26 + marker: PhantomData, [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around block return value [INFO] [stderr] --> src/acceptor.rs:78:41 [INFO] [stderr] | [INFO] [stderr] 78 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 78 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stderr] 78 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Ready` and `SocketContext` [INFO] [stderr] --> src/connect.rs:10:19 [INFO] [stderr] | [INFO] [stderr] 10 | utils::{SocketContext, Ready}}; [INFO] [stderr] | ^^^^^^^^^^^^^ ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `HttpService` [INFO] [stderr] --> src/virtual_host.rs:9:23 [INFO] [stderr] | [INFO] [stderr] 9 | use crate::{service::{HttpService, ServiceFactory}, [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `service::HttpService` [INFO] [stderr] --> src/route.rs:14:13 [INFO] [stderr] | [INFO] [stderr] 14 | use crate::{service::HttpService, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `CompressorWriter` [INFO] [stderr] --> src/default_parser.rs:8:32 [INFO] [stderr] | [INFO] [stderr] 8 | use brotli::{CompressorReader, CompressorWriter}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> src/multi_parts.rs:94:52 [INFO] [stderr] | [INFO] [stderr] 94 | ... let boundary_str = (MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 94 - let boundary_str = (MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK); [INFO] [stderr] 94 + let boundary_str = MULTI_PARTS_COMMON_PREFIX_SUFFIX_BIN.to_string() + param.as_str() + MULTI_PARTS_LINE_BREAK; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::str::FromStr` [INFO] [stderr] --> src/file_load.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use std::str::FromStr; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::str::FromStr` [INFO] [stderr] --> src/files_load.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use std::str::FromStr; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::str::FromStr` [INFO] [stderr] --> src/batch_load.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use std::str::FromStr; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `httpdate::fmt_http_date` [INFO] [stderr] --> src/batch_load.rs:13:5 [INFO] [stderr] | [INFO] [stderr] 13 | use httpdate::fmt_http_date; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `pi_adler32::adler32` [INFO] [stderr] --> src/batch_load.rs:20:5 [INFO] [stderr] | [INFO] [stderr] 20 | use pi_adler32::adler32; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::str::FromStr` [INFO] [stderr] --> src/port.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::str::FromStr; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `SocketHandle` and `Socket` [INFO] [stderr] --> src/response.rs:12:11 [INFO] [stderr] | [INFO] [stderr] 12 | use tcp::{Socket, SocketHandle}; [INFO] [stderr] | ^^^^^^ ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tcp::connect::TcpSocket` [INFO] [stderr] --> src/packet.rs:11:5 [INFO] [stderr] | [INFO] [stderr] 11 | use tcp::connect::TcpSocket; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around block return value [INFO] [stderr] --> src/packet.rs:82:49 [INFO] [stderr] | [INFO] [stderr] 82 | if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 82 - if let Some(bin) = unsafe { (&mut *handle.get_read_buffer().get()) } { [INFO] [stderr] 82 + if let Some(bin) = unsafe { &mut *handle.get_read_buffer().get() } { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::thread` [INFO] [stderr] --> src/utils.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::thread; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::pin::Pin` [INFO] [stderr] --> src/utils.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::pin::Pin; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::sync::Arc` [INFO] [stderr] --> src/utils.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::sync::Arc; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::time::Duration` [INFO] [stderr] --> src/utils.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use std::time::Duration; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::future::Future` [INFO] [stderr] --> src/utils.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use std::future::Future; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::result::Result as GenResult` [INFO] [stderr] --> src/utils.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use std::result::Result as GenResult; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Context`, `Poll`, and `Waker` [INFO] [stderr] --> src/utils.rs:8:17 [INFO] [stderr] | [INFO] [stderr] 8 | use std::task::{Context, Poll, Waker}; [INFO] [stderr] | ^^^^^^^ ^^^^ ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `AtomicBool`, `AtomicUsize`, and `Ordering` [INFO] [stderr] --> src/utils.rs:10:25 [INFO] [stderr] | [INFO] [stderr] 10 | use std::sync::atomic::{AtomicBool, AtomicUsize, Ordering}; [INFO] [stderr] | ^^^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `bytes::Buf` [INFO] [stderr] --> src/utils.rs:12:5 [INFO] [stderr] | [INFO] [stderr] 12 | use bytes::Buf; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `FutureExt` and `LocalBoxFuture` [INFO] [stderr] --> src/utils.rs:13:24 [INFO] [stderr] | [INFO] [stderr] 13 | use futures::{future::{FutureExt, LocalBoxFuture}}; [INFO] [stderr] | ^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `SocketHandle`, `Socket`, and `utils::Ready` [INFO] [stderr] --> src/utils.rs:16:11 [INFO] [stderr] | [INFO] [stderr] 16 | use tcp::{Socket, SocketHandle, [INFO] [stderr] | ^^^^^^ ^^^^^^^^^^^^ [INFO] [stderr] 17 | utils::Ready}; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: the feature `async_await` has been stable since 1.39.0 and no longer requires an attribute to enable [INFO] [stderr] --> src/lib.rs:3:12 [INFO] [stderr] | [INFO] [stderr] 3 | #![feature(async_await)] [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(stable_features)]` on by default [INFO] [stderr] [INFO] [stderr] warning: the feature `entry_insert` has been stable since 1.83.0 and no longer requires an attribute to enable [INFO] [stderr] --> src/lib.rs:4:12 [INFO] [stderr] | [INFO] [stderr] 4 | #![feature(entry_insert)] [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: the feature `mem_take` has been stable since 1.40.0 and no longer requires an attribute to enable [INFO] [stderr] --> src/lib.rs:1:12 [INFO] [stderr] | [INFO] [stderr] 1 | #![feature(mem_take)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: the feature `map_first_last` has been stable since 1.66.0 and no longer requires an attribute to enable [INFO] [stderr] --> src/lib.rs:5:12 [INFO] [stderr] | [INFO] [stderr] 5 | #![feature(map_first_last)] [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: value assigned to `http_request_result` is never read [INFO] [stderr] --> src/acceptor.rs:60:17 [INFO] [stderr] | [INFO] [stderr] 60 | let mut http_request_result = None; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/acceptor.rs:137:37 [INFO] [stderr] | [INFO] [stderr] 137 | ... let mut connect = HttpConnect::new(handle.clone(), [INFO] [stderr] | ----^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `std::sync::atomic::AtomicBool::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead [INFO] [stderr] --> src/static_cache.rs:334:37 [INFO] [stderr] | [INFO] [stderr] 334 | if cache.is_running.compare_and_swap(false, true, Ordering::SeqCst) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: value assigned to `http_request_result` is never read [INFO] [stderr] --> src/server.rs:109:29 [INFO] [stderr] | [INFO] [stderr] 109 | let mut http_request_result = None; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/multi_parts.rs:212:17 [INFO] [stderr] | [INFO] [stderr] 212 | if let Some(mut part_buf) = context.take_part_buf() { [INFO] [stderr] | ----^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/multi_parts.rs:222:17 [INFO] [stderr] | [INFO] [stderr] 222 | if let Some(mut part_buf) = context.take_part_buf() { [INFO] [stderr] | ----^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/range_load.rs:45:29 [INFO] [stderr] | [INFO] [stderr] 45 | let mut vec: Vec<&str> = range_str.split("-").collect(); [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: value assigned to `file_path_id` is never read [INFO] [stderr] --> src/file_load.rs:104:21 [INFO] [stderr] | [INFO] [stderr] 104 | let mut file_path_id = Atom::from(""); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] [INFO] [stderr] warning: unused variable: `timeout` [INFO] [stderr] --> src/file_load.rs:656:31 [INFO] [stderr] | [INFO] [stderr] 656 | let now = if let Some(timeout) = interval { [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_timeout` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `cache_key` [INFO] [stderr] --> src/static_cache.rs:620:13 [INFO] [stderr] | [INFO] [stderr] 620 | let cache_key = if let Some(owner) = owner { [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cache_key` [INFO] [stderr] [INFO] [stderr] warning: associated function `with_capacity` is never used [INFO] [stderr] --> src/route.rs:64:12 [INFO] [stderr] | [INFO] [stderr] 52 | impl> WildcardRouter { [INFO] [stderr] | -------------------------------------------------------------------------------------------------------------------- associated function in this implementation [INFO] [stderr] ... [INFO] [stderr] 64 | pub fn with_capacity(capacity: usize) -> Self { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: field `buf_size` is never read [INFO] [stderr] --> src/default_parser.rs:39:5 [INFO] [stderr] | [INFO] [stderr] 36 | pub struct DefaultParser { [INFO] [stderr] | ------------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 39 | buf_size: usize, //压缩缓冲区大小 [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `DefaultParser` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: constant `HTTPS_ASYNC_FILE_UPLOAD_PRIORITY` is never used [INFO] [stderr] --> src/upload.rs:29:7 [INFO] [stderr] | [INFO] [stderr] 29 | const HTTPS_ASYNC_FILE_UPLOAD_PRIORITY: usize = 100; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant `Stop` is never constructed [INFO] [stderr] --> src/static_cache.rs:269:5 [INFO] [stderr] | [INFO] [stderr] 268 | enum CollectCmd { [INFO] [stderr] | ---------- variant in this enum [INFO] [stderr] 269 | Stop(String), //关闭整理 [INFO] [stderr] | ^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `CollectCmd` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: constant `DEFAULT_BLOCK_SIZE` is never used [INFO] [stderr] --> src/request.rs:16:7 [INFO] [stderr] | [INFO] [stderr] 16 | const DEFAULT_BLOCK_SIZE: usize = 8192; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: constant `MAX_BLOCK_LIMIT` is never used [INFO] [stderr] --> src/request.rs:21:7 [INFO] [stderr] | [INFO] [stderr] 21 | const MAX_BLOCK_LIMIT: usize = 16 * 1024 * 1024; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `is_stream` is never read [INFO] [stderr] --> src/response.rs:45:5 [INFO] [stderr] | [INFO] [stderr] 44 | pub struct RespBody { [INFO] [stderr] | -------- field in this struct [INFO] [stderr] 45 | is_stream: bool, //是否是流响应体 [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:37:17 [INFO] [stderr] | [INFO] [stderr] 37 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 38 | | format!("Http server connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stderr] 39 | | handle.get_token(), [INFO] [stderr] 40 | | handle.get_remote(), [INFO] [stderr] 41 | | handle.get_local(), [INFO] [stderr] 42 | | e)))); [INFO] [stderr] | |_________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 37 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:56:17 [INFO] [stderr] | [INFO] [stderr] 56 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 57 | | format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stderr] 58 | | handle.get_token(), [INFO] [stderr] 59 | | handle.get_remote(), [INFO] [stderr] 60 | | handle.get_local(), [INFO] [stderr] 61 | | e)))); [INFO] [stderr] | |_________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 56 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:98:21 [INFO] [stderr] | [INFO] [stderr] 98 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stderr] 99 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid http connect ... [INFO] [stderr] 100 | | ... handle.get_token(), [INFO] [stderr] 101 | | ... handle.get_remote(), [INFO] [stderr] 102 | | ... handle.get_local())))); [INFO] [stderr] | |________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 98 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:117:29 [INFO] [stderr] | [INFO] [stderr] 117 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 118 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, buf_len: {:?}, buf: {:?}, rea... [INFO] [stderr] 119 | | ... handle.get_token(), [INFO] [stderr] 120 | | ... handle.get_remote(), [INFO] [stderr] 121 | | ... handle.get_local(), [INFO] [stderr] 122 | | ... buf.len(), [INFO] [stderr] 123 | | ... buf)))); [INFO] [stderr] | |_________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 117 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:155:29 [INFO] [stderr] | [INFO] [stderr] 155 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 156 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid read buffer", [INFO] [stderr] 157 | | ... handle.get_token(), [INFO] [stderr] 158 | | ... handle.get_remote(), [INFO] [stderr] 159 | | ... handle.get_local())))); [INFO] [stderr] | |________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 155 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:203:53 [INFO] [stderr] | [INFO] [stderr] 203 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stderr] 204 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, url: {:?}, reason: invalid url", [INFO] [stderr] 205 | | ... handle.get_token(), [INFO] [stderr] 206 | | ... handle.get_remote(), [INFO] [stderr] 207 | | ... handle.get_local(), [INFO] [stderr] 208 | | ... url)))); [INFO] [stderr] | |_________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 203 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:215:41 [INFO] [stderr] | [INFO] [stderr] 215 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 216 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid host header", [INFO] [stderr] 217 | | ... handle.get_token(), [INFO] [stderr] 218 | | ... handle.get_remote(), [INFO] [stderr] 219 | | ... handle.get_local())))); [INFO] [stderr] | |________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 215 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:224:37 [INFO] [stderr] | [INFO] [stderr] 224 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 225 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: host header not exist", [INFO] [stderr] 226 | | ... handle.get_token(), [INFO] [stderr] 227 | | ... handle.get_remote(), [INFO] [stderr] 228 | | ... handle.get_local())))); [INFO] [stderr] | |________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 224 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:241:21 [INFO] [stderr] | [INFO] [stderr] 241 | / ... handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stderr] 242 | | ... format!("Http server read failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid http connect", [INFO] [stderr] 243 | | ... handle.get_token(), [INFO] [stderr] 244 | | ... handle.get_remote(), [INFO] [stderr] 245 | | ... handle.get_local())))); [INFO] [stderr] | |________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 241 | let _ = handle.close(Err(Error::new(ErrorKind::ConnectionRefused, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:258:17 [INFO] [stderr] | [INFO] [stderr] 258 | / handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 259 | | format!("Http server write failed, token: {:?}, remote: {:?}, local: {:?}, reason: {:?}", [INFO] [stderr] 260 | | handle.get_token(), [INFO] [stderr] 261 | | handle.get_remote(), [INFO] [stderr] 262 | | handle.get_local(), [INFO] [stderr] 263 | | e)))); [INFO] [stderr] | |_________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 258 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/server.rs:321:17 [INFO] [stderr] | [INFO] [stderr] 321 | handle.close(Ok(())); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 321 | let _ = handle.close(Ok(())); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/acceptor.rs:68:17 [INFO] [stderr] | [INFO] [stderr] 68 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 69 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, buf_len: {:?}, buf: {:?}, reason:... [INFO] [stderr] 70 | | ... handle.get_token(), [INFO] [stderr] 71 | | ... handle.get_remote(), [INFO] [stderr] 72 | | ... handle.get_local(), [INFO] [stderr] 73 | | ... buf.len(), [INFO] [stderr] 74 | | ... buf)))); [INFO] [stderr] | |_________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 68 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/acceptor.rs:107:17 [INFO] [stderr] | [INFO] [stderr] 107 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 108 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid read buffer", [INFO] [stderr] 109 | | ... handle.get_token(), [INFO] [stderr] 110 | | ... handle.get_remote(), [INFO] [stderr] 111 | | ... handle.get_local())))); [INFO] [stderr] | |________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 107 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/acceptor.rs:160:45 [INFO] [stderr] | [INFO] [stderr] 160 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 161 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, url: {:?}, reason: invalid url", [INFO] [stderr] 162 | | ... handle.get_token(), [INFO] [stderr] 163 | | ... handle.get_remote(), [INFO] [stderr] 164 | | ... handle.get_local(), [INFO] [stderr] 165 | | ... url)))); [INFO] [stderr] | |_________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 160 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/acceptor.rs:172:33 [INFO] [stderr] | [INFO] [stderr] 172 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 173 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, host: {:?}, reason: host not exist", [INFO] [stderr] 174 | | ... handle.get_token(), [INFO] [stderr] 175 | | ... handle.get_remote(), [INFO] [stderr] 176 | | ... handle.get_local(), [INFO] [stderr] 177 | | ... host_name)))); [INFO] [stderr] | |_______________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 172 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/acceptor.rs:182:29 [INFO] [stderr] | [INFO] [stderr] 182 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 183 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: invalid host header", [INFO] [stderr] 184 | | ... handle.get_token(), [INFO] [stderr] 185 | | ... handle.get_remote(), [INFO] [stderr] 186 | | ... handle.get_local())))); [INFO] [stderr] | |________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 182 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/acceptor.rs:191:25 [INFO] [stderr] | [INFO] [stderr] 191 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 192 | | ... format!("Http connect failed, token: {:?}, remote: {:?}, local: {:?}, reason: host header not exist", [INFO] [stderr] 193 | | ... handle.get_token(), [INFO] [stderr] 194 | | ... handle.get_remote(), [INFO] [stderr] 195 | | ... handle.get_local())))); [INFO] [stderr] | |________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 191 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/route.rs:338:9 [INFO] [stderr] | [INFO] [stderr] 338 | tab.finish(); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 338 | let _ = tab.finish(); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/file_load.rs:269:29 [INFO] [stderr] | [INFO] [stderr] 269 | / ... async_load_file_chunks( [INFO] [stderr] 270 | | ... self.files_async_runtime.clone(), [INFO] [stderr] 271 | | ... &resp, [INFO] [stderr] 272 | | ... path, [INFO] [stderr] 273 | | ... chunk_size, [INFO] [stderr] 274 | | ... self.interval, [INFO] [stderr] 275 | | ... ); [INFO] [stderr] | |_______________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 269 | let _ = async_load_file_chunks( [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/file_load.rs:655:5 [INFO] [stderr] | [INFO] [stderr] 655 | / files_async_runtime.spawn(async move { [INFO] [stderr] 656 | | let now = if let Some(timeout) = interval { [INFO] [stderr] 657 | | //设置了加载间隔时间 [INFO] [stderr] 658 | | Some(Instant::now()) [INFO] [stderr] ... | [INFO] [stderr] 720 | | }); [INFO] [stderr] | |______^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 655 | let _ = files_async_runtime.spawn(async move { [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/static_cache.rs:330:9 [INFO] [stderr] | [INFO] [stderr] 330 | / Builder::new() [INFO] [stderr] 331 | | .name(thread_name.clone()) [INFO] [stderr] 332 | | .spawn(move || { [INFO] [stderr] ... | [INFO] [stderr] 395 | | cache.is_running.store(false, Ordering::SeqCst); //设置缓存的整理状态为已停止 [INFO] [stderr] 396 | | }); [INFO] [stderr] | |______________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 330 | let _ = Builder::new() [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/static_cache.rs:518:13 [INFO] [stderr] | [INFO] [stderr] 518 | self.collect_sent.send(CollectCmd::Clear(value_size)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 518 | let _ = self.collect_sent.send(CollectCmd::Clear(value_size)); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/static_cache.rs:530:13 [INFO] [stderr] | [INFO] [stderr] 530 | self.collect_sent.send(CollectCmd::Clear(0)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 530 | let _ = self.collect_sent.send(CollectCmd::Clear(0)); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/static_cache.rs:568:21 [INFO] [stderr] | [INFO] [stderr] 568 | / self [INFO] [stderr] 569 | | .collect_sent [INFO] [stderr] 570 | | .send(CollectCmd::Index((timeout, cache_key.clone()))); //更新缓存的超时索引 [INFO] [stderr] | |______________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 568 | let _ = self [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/packet.rs:37:17 [INFO] [stderr] | [INFO] [stderr] 37 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 38 | | ... format!("Http server parse header failed, token: {:?}, remote: {:?}, local: {:?}, reason: parse request... [INFO] [stderr] 39 | | ... handle.get_token(), [INFO] [stderr] 40 | | ... handle.get_remote(), [INFO] [stderr] ... | [INFO] [stderr] 43 | | ... buf, [INFO] [stderr] 44 | | ... e)))); [INFO] [stderr] | |_______________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 37 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/packet.rs:59:25 [INFO] [stderr] | [INFO] [stderr] 59 | / ... handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] 60 | | ... format!("Http server parse header failed, token: {:?}, remote: {:?}, local: {:?}, version: {}, reason: ... [INFO] [stderr] 61 | | ... handle.get_token(), [INFO] [stderr] 62 | | ... handle.get_remote(), [INFO] [stderr] 63 | | ... handle.get_local(), [INFO] [stderr] 64 | | ... ver)))); [INFO] [stderr] | |_________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 59 | let _ = handle.close(Err(Error::new(ErrorKind::Other, [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/packet.rs:87:25 [INFO] [stderr] | [INFO] [stderr] 87 | handle.close(Err(e)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 87 | let _ = handle.close(Err(e)); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: `pi_http` (lib) generated 78 warnings (run `cargo fix --lib -p pi_http` to apply 34 suggestions) [INFO] [stderr] warning: unused imports: `AsyncService`, `Ready`, `SocketEvent`, `SocketHandle`, and `SocketStatus` [INFO] [stderr] --> tests/test.rs:30:11 [INFO] [stderr] | [INFO] [stderr] 30 | use tcp::{AsyncService, Socket, SocketHandle, SocketConfig, SocketStatus, SocketEvent, [INFO] [stderr] | ^^^^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 34 | utils::{TlsConfig, Ready}}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> tests/test.rs:279:28 [INFO] [stderr] | [INFO] [stderr] 279 | let boundary_end_str = (String::from_utf8_lossy(b"------WebKitFormBoundaryda3kjf6KAEbPATkF") + "--\r\n"); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 279 - let boundary_end_str = (String::from_utf8_lossy(b"------WebKitFormBoundaryda3kjf6KAEbPATkF") + "--\r\n"); [INFO] [stderr] 279 + let boundary_end_str = String::from_utf8_lossy(b"------WebKitFormBoundaryda3kjf6KAEbPATkF") + "--\r\n"; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused import: `Write` [INFO] [stderr] --> tests/test.rs:6:21 [INFO] [stderr] | [INFO] [stderr] 6 | use std::io::{Read, Write}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> tests/test.rs:77:9 [INFO] [stderr] | [INFO] [stderr] 77 | let mut vec0 = vec![ [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> tests/test.rs:85:9 [INFO] [stderr] | [INFO] [stderr] 85 | let mut vec1 = vec![ [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> tests/test.rs:93:9 [INFO] [stderr] | [INFO] [stderr] 93 | let mut vec2 = vec![ [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `context` [INFO] [stderr] --> tests/test.rs:338:21 [INFO] [stderr] | [INFO] [stderr] 338 | context: &'a mut GatewayContext, [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `msg` [INFO] [stderr] --> tests/test.rs:390:9 [INFO] [stderr] | [INFO] [stderr] 390 | let msg = WrapMsg(msg); [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_msg` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `env` [INFO] [stderr] --> tests/test.rs:383:28 [INFO] [stderr] | [INFO] [stderr] 383 | ... env: Arc, [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_env` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `method` [INFO] [stderr] --> tests/test.rs:386:28 [INFO] [stderr] | [INFO] [stderr] 386 | ... method: String, [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_method` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `headers` [INFO] [stderr] --> tests/test.rs:387:28 [INFO] [stderr] | [INFO] [stderr] 387 | ... headers: Arc, [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_headers` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `driver` [INFO] [stderr] --> tests/test.rs:556:12 [INFO] [stderr] | [INFO] [stderr] 556 | Ok(driver) => { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_driver` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> tests/test.rs:421:9 [INFO] [stderr] | [INFO] [stderr] 421 | let mut builder = MultiTaskRuntimeBuilder::default(); [INFO] [stderr] | ----^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `driver` [INFO] [stderr] --> tests/test.rs:740:12 [INFO] [stderr] | [INFO] [stderr] 740 | Ok(driver) => { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_driver` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> tests/test.rs:605:9 [INFO] [stderr] | [INFO] [stderr] 605 | let mut builder = MultiTaskRuntimeBuilder::default(); [INFO] [stderr] | ----^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> tests/test.rs:725:9 [INFO] [stderr] | [INFO] [stderr] 725 | let mut config = SocketConfig::with_tls("0.0.0.0", &[(443, tls_config)]); [INFO] [stderr] | ----^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: struct `TestMultiPartsHandler` is never constructed [INFO] [stderr] --> tests/test.rs:309:8 [INFO] [stderr] | [INFO] [stderr] 309 | struct TestMultiPartsHandler; [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] --> tests/test.rs:350:16 [INFO] [stderr] | [INFO] [stderr] 350 | struct WrapMsg(Arc>>); [INFO] [stderr] | ------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | field in this struct [INFO] [stderr] | [INFO] [stderr] = help: consider removing this field [INFO] [stderr] = note: `WrapMsg` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> tests/test.rs:394:5 [INFO] [stderr] | [INFO] [stderr] 394 | / rt.spawn(async move { [INFO] [stderr] ... | [INFO] [stderr] 410 | | println!("!!!!!!http gateway handle ok, topic: {:?}, addr: {:?}", topic.as_str(), addr); [INFO] [stderr] 411 | | }); [INFO] [stderr] | |______^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 394 | let _ = rt.spawn(async move { [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> tests/test.rs:409:9 [INFO] [stderr] | [INFO] [stderr] 409 | resp_handler.finish().await; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 409 | let _ = resp_handler.finish().await; [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> tests/test.rs:442:5 [INFO] [stderr] | [INFO] [stderr] 442 | cors_handler.allow_origin("http".to_string(), "msg.highapp.com".to_string(), 80, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 442 | let _ = cors_handler.allow_origin("http".to_string(), "msg.highapp.com".to_string(), 80, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> tests/test.rs:443:5 [INFO] [stderr] | [INFO] [stderr] 443 | cors_handler.allow_origin("http".to_string(), "127.0.0.1".to_string(), 80, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 443 | let _ = cors_handler.allow_origin("http".to_string(), "127.0.0.1".to_string(), 80, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> tests/test.rs:534:5 [INFO] [stderr] | [INFO] [stderr] 534 | hosts.add("test.17youx.cn", host.clone()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 534 | let _ = hosts.add("test.17youx.cn", host.clone()); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> tests/test.rs:535:5 [INFO] [stderr] | [INFO] [stderr] 535 | hosts.add_default(host); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 535 | let _ = hosts.add_default(host); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> tests/test.rs:621:5 [INFO] [stderr] | [INFO] [stderr] 621 | cors_handler.allow_origin("https".to_string(), "msg.highapp.com".to_string(), 443, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 621 | let _ = cors_handler.allow_origin("https".to_string(), "msg.highapp.com".to_string(), 443, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> tests/test.rs:622:5 [INFO] [stderr] | [INFO] [stderr] 622 | cors_handler.allow_origin("https".to_string(), "127.0.0.1".to_string(), 443, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 622 | let _ = cors_handler.allow_origin("https".to_string(), "127.0.0.1".to_string(), 443, &["OPTIONS".to_string(), "GET".to_string(), "POST".to_string()], &[], Some(10)); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> tests/test.rs:709:5 [INFO] [stderr] | [INFO] [stderr] 709 | hosts.add("test.17youx.cn", host.clone()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 709 | let _ = hosts.add("test.17youx.cn", host.clone()); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> tests/test.rs:710:5 [INFO] [stderr] | [INFO] [stderr] 710 | hosts.add_default(host); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 710 | let _ = hosts.add_default(host); [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: `pi_http` (lib test) generated 78 warnings (78 duplicates) [INFO] [stderr] warning: `pi_http` (test "test") generated 28 warnings (run `cargo fix --test "test"` to apply 8 suggestions) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.40s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/pi_http-d492c81105c0d91e) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/test.rs (/opt/rustwide/target/debug/deps/test-968227e01cc5483b) [INFO] [stdout] [INFO] [stdout] running 7 tests [INFO] [stdout] test test_find_bytes ... ok [INFO] [stdout] test test_compress ... ok [INFO] [stdout] test test_router ... ok [INFO] [stdout] test test_brotli_compress ... ok [INFO] [stdout] test test_http_hosts ... FAILED [INFO] [stdout] test test_https_hosts ... FAILED [INFO] [stdout] test test_regex ... ok [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- test_http_hosts stdout ---- [INFO] [stdout] [INFO] [stdout] thread 'test_http_hosts' (29) panicked at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/env_logger-0.11.8/src/logger.rs:522:14: [INFO] [stdout] Builder::init should not be called after logger initialized: SetLoggerError(()) [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x5c76fdc46d62 - std::backtrace_rs::backtrace::libunwind::trace::h589a96ef7638b383 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x5c76fdc46d62 - std::backtrace_rs::backtrace::trace_unsynchronized::h23a30a7548c40de4 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x5c76fdc46d62 - std::sys::backtrace::_print_fmt::h87dabd6535c8c07a [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x5c76fdc46d62 - ::fmt::hffd20ad4e5eca8ab [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x5c76fdc5a00f - core::fmt::rt::Argument::fmt::h75c83e3fd5ce2419 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x5c76fdc5a00f - core::fmt::write::h6d9d3a7cfd7b84f5 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x5c76fdc113e3 - std::io::default_write_fmt::he11a713685e2464d [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x5c76fdc113e3 - std::io::Write::write_fmt::h9d08f7e050bd2612 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x5c76fdc1db92 - std::sys::backtrace::BacktraceLock::print::hb28797143397220e [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x5c76fdc22e4f - std::panicking::default_hook::{{closure}}::h7555113b62983743 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x5c76fdc22ce1 - std::panicking::default_hook::h2714b564abe8d914 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x5c76fd20331e - as core::ops::function::Fn>::call::h0e9de8cceb22406e [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x5c76fd20331e - test::test_main_with_exit_callback::{{closure}}::h8125bd66cf4739d0 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x5c76fdc234ee - as core::ops::function::Fn>::call::h1fd0a0802eaec16b [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x5c76fdc234ee - std::panicking::panic_with_hook::h190dc82263685ec5 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x5c76fdc232ba - std::panicking::panic_handler::{{closure}}::h8b036a1b366643ac [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x5c76fdc1dcc9 - std::sys::backtrace::__rust_end_short_backtrace::h45affcfc0c830da8 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x5c76fdc04b7d - __rustc[9b67c8562bba447b]::rust_begin_unwind [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x5c76fdc63a00 - core::panicking::panic_fmt::hc084f85b1e76c16d [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x5c76fdc629b6 - core::result::unwrap_failed::hf926a4254073b4aa [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x5c76fd648eab - core::result::Result::expect::h49282a62182bda41 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/result.rs:1175:23 [INFO] [stdout] 21: 0x5c76fd64681d - env_logger::logger::Builder::init::hebc449b55d11e6b7 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/env_logger-0.11.8/src/logger.rs:522:14 [INFO] [stdout] 22: 0x5c76fd0ffb96 - test::test_http_hosts::had15c9a26baf3a18 [INFO] [stdout] at /opt/rustwide/workdir/tests/test.rs:417:53 [INFO] [stdout] 23: 0x5c76fd1036a7 - test::test_http_hosts::{{closure}}::h9c7279f02b8f41b1 [INFO] [stdout] at /opt/rustwide/workdir/tests/test.rs:415:21 [INFO] [stdout] 24: 0x5c76fd062126 - core::ops::function::FnOnce::call_once::hac7032a8416e89e7 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x5c76fd2030db - core::ops::function::FnOnce::call_once::hdbf42be2a49fb464 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 26: 0x5c76fd2030db - test::__rust_begin_short_backtrace::h8ae08814d38cb356 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:663:18 [INFO] [stdout] 27: 0x5c76fd218bc5 - test::run_test_in_process::{{closure}}::h54574ee4f414d690 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:686:74 [INFO] [stdout] 28: 0x5c76fd218bc5 - as core::ops::function::FnOnce<()>>::call_once::h01a0b7e7aad1a501 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 29: 0x5c76fd218bc5 - std::panicking::catch_unwind::do_call::h23820e817c5612cd [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:590:40 [INFO] [stdout] 30: 0x5c76fd218bc5 - std::panicking::catch_unwind::h89c73a1febce5587 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:553:19 [INFO] [stdout] 31: 0x5c76fd218bc5 - std::panic::catch_unwind::h6f55caf410861914 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panic.rs:359:14 [INFO] [stdout] 32: 0x5c76fd218bc5 - test::run_test_in_process::h4db851878e5d3983 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:686:27 [INFO] [stdout] 33: 0x5c76fd218bc5 - test::run_test::{{closure}}::h57e8c5acaceacd24 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:607:43 [INFO] [stdout] 34: 0x5c76fd1ef5b4 - test::run_test::{{closure}}::he775ccc3a9d3b97e [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:637:41 [INFO] [stdout] 35: 0x5c76fd1ef5b4 - std::sys::backtrace::__rust_begin_short_backtrace::hcd94d85d7765225a [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 36: 0x5c76fd1f2dfa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::ha814de8393f07830 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 37: 0x5c76fd1f2dfa - as core::ops::function::FnOnce<()>>::call_once::h8deb00af0abdeaf1 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 38: 0x5c76fd1f2dfa - std::panicking::catch_unwind::do_call::h1917979b0c279ea2 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:590:40 [INFO] [stdout] 39: 0x5c76fd1f2dfa - std::panicking::catch_unwind::h791ad91fee6ce34e [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:553:19 [INFO] [stdout] 40: 0x5c76fd1f2dfa - std::panic::catch_unwind::h982b8f40ed9c3cce [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panic.rs:359:14 [INFO] [stdout] 41: 0x5c76fd1f2dfa - std::thread::Builder::spawn_unchecked_::{{closure}}::h545e54700c945db4 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 42: 0x5c76fd1f2dfa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb427481a5227d78a [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 43: 0x5c76fdc17bcf - as core::ops::function::FnOnce>::call_once::h1d452951a81e9d0a [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 44: 0x5c76fdc17bcf - std::sys::pal::unix::thread::Thread::new::thread_start::h29c84e109630689a [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 45: 0x7c989761faa4 - [INFO] [stdout] 46: 0x7c98976aca34 - clone [INFO] [stdout] 47: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- test_https_hosts stdout ---- [INFO] [stdout] [INFO] [stdout] thread 'test_https_hosts' (30) panicked at tests/test.rs:724:48: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: Custom { kind: Other, error: "Open certs failed, path: \"./tests/17youx.cn.pem\", reason: Os { code: 2, kind: NotFound, message: \"No such file or directory\" }" } [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x5c76fdc46d62 - std::backtrace_rs::backtrace::libunwind::trace::h589a96ef7638b383 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x5c76fdc46d62 - std::backtrace_rs::backtrace::trace_unsynchronized::h23a30a7548c40de4 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x5c76fdc46d62 - std::sys::backtrace::_print_fmt::h87dabd6535c8c07a [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x5c76fdc46d62 - ::fmt::hffd20ad4e5eca8ab [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x5c76fdc5a00f - core::fmt::rt::Argument::fmt::h75c83e3fd5ce2419 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x5c76fdc5a00f - core::fmt::write::h6d9d3a7cfd7b84f5 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x5c76fdc113e3 - std::io::default_write_fmt::he11a713685e2464d [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x5c76fdc113e3 - std::io::Write::write_fmt::h9d08f7e050bd2612 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x5c76fdc1db92 - std::sys::backtrace::BacktraceLock::print::hb28797143397220e [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x5c76fdc22e4f - std::panicking::default_hook::{{closure}}::h7555113b62983743 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x5c76fdc22ce1 - std::panicking::default_hook::h2714b564abe8d914 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x5c76fd20331e - as core::ops::function::Fn>::call::h0e9de8cceb22406e [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x5c76fd20331e - test::test_main_with_exit_callback::{{closure}}::h8125bd66cf4739d0 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x5c76fdc234ee - as core::ops::function::Fn>::call::h1fd0a0802eaec16b [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x5c76fdc234ee - std::panicking::panic_with_hook::h190dc82263685ec5 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x5c76fdc232ba - std::panicking::panic_handler::{{closure}}::h8b036a1b366643ac [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x5c76fdc1dcc9 - std::sys::backtrace::__rust_end_short_backtrace::h45affcfc0c830da8 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x5c76fdc04b7d - __rustc[9b67c8562bba447b]::rust_begin_unwind [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x5c76fdc63a00 - core::panicking::panic_fmt::hc084f85b1e76c16d [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x5c76fdc629b6 - core::result::unwrap_failed::hf926a4254073b4aa [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x5c76fd10604e - core::result::Result::unwrap::hdc32041cded6da2d [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x5c76fd10604e - test::test_https_hosts::hf231f0bdd05c8c8a [INFO] [stdout] at /opt/rustwide/workdir/tests/test.rs:724:48 [INFO] [stdout] 22: 0x5c76fd106937 - test::test_https_hosts::{{closure}}::had46504a9914f1ba [INFO] [stdout] at /opt/rustwide/workdir/tests/test.rs:599:22 [INFO] [stdout] 23: 0x5c76fd062736 - core::ops::function::FnOnce::call_once::hf22b957d31915b6d [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x5c76fd2030db - core::ops::function::FnOnce::call_once::hdbf42be2a49fb464 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x5c76fd2030db - test::__rust_begin_short_backtrace::h8ae08814d38cb356 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x5c76fd218bc5 - test::run_test_in_process::{{closure}}::h54574ee4f414d690 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x5c76fd218bc5 - as core::ops::function::FnOnce<()>>::call_once::h01a0b7e7aad1a501 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x5c76fd218bc5 - std::panicking::catch_unwind::do_call::h23820e817c5612cd [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x5c76fd218bc5 - std::panicking::catch_unwind::h89c73a1febce5587 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x5c76fd218bc5 - std::panic::catch_unwind::h6f55caf410861914 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x5c76fd218bc5 - test::run_test_in_process::h4db851878e5d3983 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x5c76fd218bc5 - test::run_test::{{closure}}::h57e8c5acaceacd24 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x5c76fd1ef5b4 - test::run_test::{{closure}}::he775ccc3a9d3b97e [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x5c76fd1ef5b4 - std::sys::backtrace::__rust_begin_short_backtrace::hcd94d85d7765225a [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x5c76fd1f2dfa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::ha814de8393f07830 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x5c76fd1f2dfa - as core::ops::function::FnOnce<()>>::call_once::h8deb00af0abdeaf1 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x5c76fd1f2dfa - std::panicking::catch_unwind::do_call::h1917979b0c279ea2 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x5c76fd1f2dfa - std::panicking::catch_unwind::h791ad91fee6ce34e [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x5c76fd1f2dfa - std::panic::catch_unwind::h982b8f40ed9c3cce [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x5c76fd1f2dfa - std::thread::Builder::spawn_unchecked_::{{closure}}::h545e54700c945db4 [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x5c76fd1f2dfa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb427481a5227d78a [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x5c76fdc17bcf - as core::ops::function::FnOnce>::call_once::h1d452951a81e9d0a [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x5c76fdc17bcf - std::sys::pal::unix::thread::Thread::new::thread_start::h29c84e109630689a [INFO] [stdout] at /rustc/b83b707f97d809763b7861afa7638871f3339a33/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7c989761faa4 - [INFO] [stdout] 45: 0x7c98976aca34 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] test_http_hosts [INFO] [stdout] test_https_hosts [INFO] [stdout] [INFO] [stdout] test result: FAILED. 5 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.34s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `--test test` [INFO] running `Command { std: "docker" "inspect" "842bb745ba45922d6cc4be248ce7b3a516714cc5f11cb8f0af21e8bf3a87a64a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "842bb745ba45922d6cc4be248ce7b3a516714cc5f11cb8f0af21e8bf3a87a64a", kill_on_drop: false }` [INFO] [stdout] 842bb745ba45922d6cc4be248ce7b3a516714cc5f11cb8f0af21e8bf3a87a64a