[INFO] cloning repository https://github.com/iyulab/shell-tunnel [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/iyulab/shell-tunnel" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiyulab%2Fshell-tunnel", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiyulab%2Fshell-tunnel'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] b4761e46ba83726fb560e95f428d46f3772cfe9f [INFO] testing iyulab/shell-tunnel against master#562dee4820c458d823175268e41601d4c060588a for pr-154210 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiyulab%2Fshell-tunnel" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/iyulab/shell-tunnel [INFO] finished tweaking git repo https://github.com/iyulab/shell-tunnel [INFO] tweaked toml for git repo https://github.com/iyulab/shell-tunnel written to /workspace/builds/worker-3-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/iyulab/shell-tunnel on toolchain 562dee4820c458d823175268e41601d4c060588a [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/iyulab/shell-tunnel 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" "+562dee4820c458d823175268e41601d4c060588a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded portable-pty v0.9.0 [INFO] [stderr] Downloaded zipsign-api v0.1.5 [INFO] [stderr] Downloaded vt100 v0.16.2 [INFO] [stderr] Downloaded filedescriptor v0.8.3 [INFO] [stderr] Downloaded tokio-test v0.4.5 [INFO] [stderr] Downloaded vte v0.15.0 [INFO] [stderr] Downloaded lexopt v0.3.1 [INFO] [stderr] Downloaded self_update v0.42.0 [INFO] [stderr] Downloaded serial2 v0.2.33 [INFO] [stderr] Downloaded self-replace v1.5.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 948e836bbcf5992435dfc4062fb4c92b42eb980d746237285bb989981386ce50 [INFO] running `Command { std: "docker" "start" "-a" "948e836bbcf5992435dfc4062fb4c92b42eb980d746237285bb989981386ce50", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "948e836bbcf5992435dfc4062fb4c92b42eb980d746237285bb989981386ce50", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "948e836bbcf5992435dfc4062fb4c92b42eb980d746237285bb989981386ce50", kill_on_drop: false }` [INFO] [stdout] 948e836bbcf5992435dfc4062fb4c92b42eb980d746237285bb989981386ce50 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 18d882f2f272894117a7d23d3a9605f0675cc2db76da0f08d7984f9ef515b30a [INFO] running `Command { std: "docker" "start" "-a" "18d882f2f272894117a7d23d3a9605f0675cc2db76da0f08d7984f9ef515b30a", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.105 [INFO] [stderr] Compiling quote v1.0.43 [INFO] [stderr] Compiling libc v0.2.180 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling find-msvc-tools v0.1.7 [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling zerocopy v0.8.33 [INFO] [stderr] Compiling rustls-pki-types v1.13.2 [INFO] [stderr] Compiling rustix v1.1.3 [INFO] [stderr] Compiling linux-raw-sys v0.11.0 [INFO] [stderr] Compiling rustls v0.23.36 [INFO] [stderr] Compiling zmij v1.0.14 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling cc v1.2.52 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling regex-syntax v0.8.8 [INFO] [stderr] Compiling ryu v1.0.22 [INFO] [stderr] Compiling portable-atomic v1.13.0 [INFO] [stderr] Compiling nix v0.28.0 [INFO] [stderr] Compiling deranged v0.5.5 [INFO] [stderr] Compiling crc32fast v1.5.0 [INFO] [stderr] Compiling zip v2.4.2 [INFO] [stderr] Compiling iri-string v0.7.10 [INFO] [stderr] Compiling time-core v0.1.7 [INFO] [stderr] Compiling webpki-roots v1.0.5 [INFO] [stderr] Compiling simd-adler32 v0.3.8 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling number_prefix v0.4.0 [INFO] [stderr] Compiling syn v2.0.114 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling self_update v0.42.0 [INFO] [stderr] Compiling vte v0.15.0 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling quick-xml v0.37.5 [INFO] [stderr] Compiling semver v1.0.27 [INFO] [stderr] Compiling shell-words v1.1.1 [INFO] [stderr] Compiling vt100 v0.16.2 [INFO] [stderr] Compiling lexopt v0.3.1 [INFO] [stderr] Compiling flate2 v1.1.8 [INFO] [stderr] Compiling time v0.3.45 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling socket2 v0.6.1 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling console v0.15.11 [INFO] [stderr] Compiling filetime v0.2.26 [INFO] [stderr] Compiling serial2 v0.2.33 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling rand_core v0.9.5 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling xattr v1.6.1 [INFO] [stderr] Compiling tempfile v3.24.0 [INFO] [stderr] Compiling indicatif v0.17.11 [INFO] [stderr] Compiling tar v0.4.44 [INFO] [stderr] Compiling rand v0.9.2 [INFO] [stderr] Compiling self-replace v1.5.0 [INFO] [stderr] Compiling serde_path_to_error v0.1.20 [INFO] [stderr] Compiling regex v1.12.2 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling thiserror-impl v2.0.17 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling rustls-webpki v0.103.8 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling filedescriptor v0.8.3 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling axum-core v0.5.6 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling thiserror v2.0.17 [INFO] [stderr] Compiling portable-pty v0.9.0 [INFO] [stderr] Compiling tungstenite v0.28.0 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tokio-tungstenite v0.28.0 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.19 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling axum v0.8.8 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling shell-tunnel v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 19s [INFO] running `Command { std: "docker" "inspect" "18d882f2f272894117a7d23d3a9605f0675cc2db76da0f08d7984f9ef515b30a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "18d882f2f272894117a7d23d3a9605f0675cc2db76da0f08d7984f9ef515b30a", kill_on_drop: false }` [INFO] [stdout] 18d882f2f272894117a7d23d3a9605f0675cc2db76da0f08d7984f9ef515b30a [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 66c399442aa48c8838ce1603479dee9e4b79444c9c4e9cd52c303662a64ac5db [INFO] running `Command { std: "docker" "start" "-a" "66c399442aa48c8838ce1603479dee9e4b79444c9c4e9cd52c303662a64ac5db", kill_on_drop: false }` [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling tokio-tungstenite v0.28.0 [INFO] [stderr] Compiling tokio-stream v0.1.18 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling tokio-test v0.4.5 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.19 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling axum v0.8.8 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling self_update v0.42.0 [INFO] [stderr] Compiling shell-tunnel v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 40.00s [INFO] running `Command { std: "docker" "inspect" "66c399442aa48c8838ce1603479dee9e4b79444c9c4e9cd52c303662a64ac5db", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "66c399442aa48c8838ce1603479dee9e4b79444c9c4e9cd52c303662a64ac5db", kill_on_drop: false }` [INFO] [stdout] 66c399442aa48c8838ce1603479dee9e4b79444c9c4e9cd52c303662a64ac5db [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 3b145a5942e393ebbc75b257427b5e404dc1861eb20004d0d202fe029d3e6f57 [INFO] running `Command { std: "docker" "start" "-a" "3b145a5942e393ebbc75b257427b5e404dc1861eb20004d0d202fe029d3e6f57", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.33s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/shell_tunnel-3bb2ab7fcb726587) [INFO] [stdout] [INFO] [stdout] running 164 tests [INFO] [stdout] test api::handlers::tests::test_app_state_new ... ok [INFO] [stdout] test api::handlers::tests::test_api_info_endpoint ... ok [INFO] [stdout] test api::router::tests::test_server_config_with_security ... ok [INFO] [stdout] test api::types::tests::test_error_response_serialization ... ok [INFO] [stdout] test api::types::tests::test_ws_message_execute ... ok [INFO] [stdout] test api::types::tests::test_execute_command_request ... ok [INFO] [stdout] test api::router::tests::test_security_config_development ... ok [INFO] [stdout] test api::router::tests::test_server_config_custom ... ok [INFO] [stdout] test api::router::tests::test_server_config_default ... ok [INFO] [stdout] test api::router::tests::test_security_config_default ... ok [INFO] [stdout] test api::router::tests::test_router_creation ... ok [INFO] [stdout] test api::types::tests::test_create_session_request_default ... ok [INFO] [stdout] test api::types::tests::test_create_session_request_with_fields ... ok [INFO] [stdout] test api::router::tests::test_secure_router_creation ... ok [INFO] [stdout] test api::handlers::tests::test_health_endpoint ... ok [INFO] [stdout] test api::websocket::tests::test_ws_message_execute_parse ... ok [INFO] [stdout] test cli::tests::test_help_flag ... ok [INFO] [stdout] test cli::tests::test_invalid_host ... ok [INFO] [stdout] test cli::tests::test_invalid_port ... ok [INFO] [stdout] test cli::tests::test_host_port ... ok [INFO] [stdout] test cli::tests::test_no_auth ... ok [INFO] [stdout] test cli::tests::test_no_rate_limit ... ok [INFO] [stdout] test cli::tests::test_version_flag ... ok [INFO] [stdout] test cli::tests::test_long_options ... ok [INFO] [stdout] test config::tests::test_apply_args ... ok [INFO] [stdout] test config::tests::test_apply_no_auth ... ok [INFO] [stdout] test config::tests::test_default_config ... ok [INFO] [stdout] test config::tests::test_config_serialization ... ok [INFO] [stdout] test config::tests::test_invalid_host ... ok [INFO] [stdout] test cli::tests::test_api_key ... ok [INFO] [stdout] test error::tests::test_io_error_conversion ... ok [INFO] [stdout] test error::tests::test_session_exists_display ... ok [INFO] [stdout] test error::tests::test_session_not_found_display ... ok [INFO] [stdout] test error::tests::test_timeout_display ... ok [INFO] [stdout] test execution::command::tests::test_command_builder_build ... ok [INFO] [stdout] test cli::tests::test_config_file ... ok [INFO] [stdout] test cli::tests::test_default_args ... ok [INFO] [stdout] test config::tests::test_to_server_config ... ok [INFO] [stdout] test cli::tests::test_combined_options ... ok [INFO] [stdout] test error::tests::test_pty_error_display ... ok [INFO] [stdout] test config::tests::test_config_partial_json ... ok [INFO] [stdout] test api::websocket::tests::test_ws_message_ping_parse ... ok [INFO] [stdout] test cli::tests::test_log_level ... ok [INFO] [stdout] test execution::command::tests::test_command_builder_chain ... ok [INFO] [stdout] test config::tests::test_config_from_json ... ok [INFO] [stdout] test execution::command::tests::test_command_new ... ok [INFO] [stdout] test execution::command::tests::test_command_envs ... ok [INFO] [stdout] test execution::executor::tests::test_default_timeout ... ok [INFO] [stdout] test execution::executor::tests::test_execute_simple_echo ... ignored [INFO] [stdout] test execution::executor::tests::test_execute_with_timeout ... ignored [INFO] [stdout] test execution::executor::tests::test_executor_new ... ok [INFO] [stdout] test execution::result::tests::test_execution_result_failed ... ok [INFO] [stdout] test execution::executor::tests::test_command_builder ... ok [INFO] [stdout] test execution::result::tests::test_execution_result_success ... ok2026-03-31T04:57:58.342324Z  INFO shell_tunnel::logging::tests: test info message [INFO] [stdout] 2026-03-31T04:57:58.342955Z  WARN shell_tunnel::logging::tests: test warn message [INFO] [stdout] [INFO] [stdout] test execution::result::tests::test_output_chunk_combined ... ok [INFO] [stdout] test execution::result::tests::test_execution_result_new ... 2026-03-31T04:57:58.343241Z ERROR shell_tunnel::logging::tests: test error message [INFO] [stdout] ok [INFO] [stdout] test execution::result::tests::test_execution_result_timeout ... ok [INFO] [stdout] test execution::result::tests::test_output_chunk_stdout ... ok [INFO] [stdout] test execution::result::tests::test_output_lines ... ok [INFO] [stdout] test execution::result::tests::test_output_trimmed ... ok [INFO] [stdout] test output::sanitizer::tests::test_complex_sequence ... ok [INFO] [stdout] test output::sanitizer::tests::test_empty_input ... ok [INFO] [stdout] test output::sanitizer::tests::test_only_escape_codes ... ok [INFO] [stdout] test logging::tests::test_try_init_idempotent ... ok [INFO] [stdout] test output::sanitizer::tests::test_osc_title ... ok [INFO] [stdout] test output::sanitizer::tests::test_plain_text ... ok [INFO] [stdout] test output::sanitizer::tests::test_preserve_newlines ... ok [INFO] [stdout] test logging::tests::test_logging_works ... ok [INFO] [stdout] test output::sanitizer::tests::test_preserve_tabs ... ok [INFO] [stdout] test output::sanitizer::tests::test_strip_ansi_str ... ok [INFO] [stdout] test output::sanitizer::tests::test_strip_bold ... ok [INFO] [stdout] test output::sanitizer::tests::test_strip_color_codes ... ok [INFO] [stdout] test output::sanitizer::tests::test_strip_cursor_movement ... ok [INFO] [stdout] test output::screen::tests::test_clear_method ... ok [INFO] [stdout] test output::screen::tests::test_cursor_position ... ok [INFO] [stdout] test output::screen::tests::test_clear_screen_sequence ... ok [INFO] [stdout] test output::screen::tests::test_custom_size ... ok [INFO] [stdout] test output::screen::tests::test_process_ansi_colors ... ok [INFO] [stdout] test output::screen::tests::test_new_screen ... ok [INFO] [stdout] test output::screen::tests::test_process_text ... ok [INFO] [stdout] test output::screen::tests::test_process_with_newlines ... ok [INFO] [stdout] test pty::async_adapter::tests::test_async_reader_empty ... ok [INFO] [stdout] test pty::async_adapter::tests::test_async_reader_basic ... ok [INFO] [stdout] test pty::native::tests::test_write_and_read ... ignored [INFO] [stdout] test pty::tests::test_pty_size_default ... ok [INFO] [stdout] test api::router::tests::test_security_config_secure ... ok [INFO] [stdout] test output::screen::tests::test_lines_trimmed ... ok [INFO] [stdout] test pty::async_adapter::tests::test_async_writer_basic ... ok [INFO] [stdout] test pty::native::tests::test_spawn_shell ... ok [INFO] [stdout] test pty::native::tests::test_default_shell ... ok [INFO] [stdout] test execution::command::tests::test_command_builder_empty ... ok [INFO] [stdout] test pty::native::tests::test_custom_size ... ok [INFO] [stdout] test pty::async_adapter::tests::test_channel_creation ... ok [INFO] [stdout] test pty::async_adapter::tests::test_reader_channel_closed ... ok [INFO] [stdout] test pty::tests::test_pty_size_new ... ok [INFO] [stdout] test security::auth::tests::test_api_key_store_add_remove ... ok [INFO] [stdout] test security::auth::tests::test_api_key_store_disabled ... ok [INFO] [stdout] test security::auth::tests::test_api_key_store_extract ... ok [INFO] [stdout] test security::auth::tests::test_api_key_store_multiple_keys ... ok [INFO] [stdout] test security::auth::tests::test_auth_config_disabled ... ok [INFO] [stdout] test security::auth::tests::test_generate_api_key ... ok [INFO] [stdout] test security::rate_limit::tests::test_rate_limit_config_custom ... ok [INFO] [stdout] test security::rate_limit::tests::test_rate_limit_config_default ... ok [INFO] [stdout] test security::rate_limit::tests::test_rate_limit_config_disabled ... ok [INFO] [stdout] test security::rate_limit::tests::test_rate_limiter_allows_requests ... ok [INFO] [stdout] test security::rate_limit::tests::test_rate_limiter_different_ips ... ok [INFO] [stdout] test security::rate_limit::tests::test_rate_limiter_disabled ... ok [INFO] [stdout] test security::rate_limit::tests::test_rate_limiter_ipv6 ... ok [INFO] [stdout] test security::rate_limit::tests::test_rate_limiter_remaining_count ... ok [INFO] [stdout] test security::validation::tests::test_looks_like_injection ... ok [INFO] [stdout] test security::rate_limit::tests::test_rate_limiter_stats ... ok [INFO] [stdout] test security::validation::tests::test_sanitize_for_display ... ok [INFO] [stdout] test security::validation::tests::test_validate_command_ok ... ok [INFO] [stdout] test api::types::tests::test_ws_message_output ... ok [INFO] [stdout] test security::validation::tests::test_blocked_patterns ... ok [INFO] [stdout] test security::validation::tests::test_validate_command_empty ... ok [INFO] [stdout] test security::validation::tests::test_validate_dangerous_shutdown ... ok [INFO] [stdout] test security::validation::tests::test_validation_config_default ... ok [INFO] [stdout] test security::rate_limit::tests::test_rate_limiter_blocks_excess ... ok [INFO] [stdout] test session::context::tests::test_context_merge_env ... ok [INFO] [stdout] test security::validation::tests::test_validation_config_strict ... ok [INFO] [stdout] test security::validation::tests::test_permissive_allows_dangerous ... ok [INFO] [stdout] test session::context::tests::test_context_env ... ok [INFO] [stdout] test security::auth::tests::test_auth_config_default ... ok [INFO] [stdout] test security::validation::tests::test_validate_timeout ... ok [INFO] [stdout] test security::validation::tests::test_validate_null_byte ... ok [INFO] [stdout] test security::validation::tests::test_validate_dangerous_rm ... ok [INFO] [stdout] test session::context::tests::test_context_new ... ok [INFO] [stdout] test session::context::tests::test_context_record_execution ... ok [INFO] [stdout] test security::validation::tests::test_validate_working_dir ... ok [INFO] [stdout] test security::validation::tests::test_validate_command_too_long ... ok [INFO] [stdout] test session::context::tests::test_state_probe_parse_cwd ... ok [INFO] [stdout] test session::id::tests::test_display_format ... ok [INFO] [stdout] test session::context::tests::test_state_probe_parse_env ... ok [INFO] [stdout] test session::context::tests::test_state_probe_echo_marker ... ok [INFO] [stdout] test session::context::tests::test_state_probe_env_command ... ok [INFO] [stdout] test pty::native::tests::test_spawn_specific_shell ... ok [INFO] [stdout] test session::context::tests::test_state_probe_marker ... ok [INFO] [stdout] test session::context::tests::test_state_probe_cwd_command ... ok [INFO] [stdout] test session::id::tests::test_hash_eq ... ok [INFO] [stdout] test session::id::tests::test_parse_invalid ... ok [INFO] [stdout] test session::id::tests::test_parse_valid ... ok [INFO] [stdout] test session::id::tests::test_roundtrip ... ok [INFO] [stdout] test session::state::tests::test_is_terminal ... ok [INFO] [stdout] test session::state::tests::test_valid_transitions ... ok [INFO] [stdout] test session::store::tests::test_create_session ... ok [INFO] [stdout] test session::store::tests::test_get_session ... ok [INFO] [stdout] test session::store::tests::test_update_nonexistent ... ok [INFO] [stdout] test session::store::tests::test_get_nonexistent ... ok [INFO] [stdout] test session::store::tests::test_list_ids ... ok [INFO] [stdout] test session::store::tests::test_update_session ... ok [INFO] [stdout] test session::store::tests::test_remove_matching ... ok [INFO] [stdout] test session::state::tests::test_invalid_created_to_idle ... ok [INFO] [stdout] test session::state::tests::test_default ... ok [INFO] [stdout] test session::store::tests::test_remove_session ... ok [INFO] [stdout] test session::state::tests::test_can_execute ... ok [INFO] [stdout] test update::tests::test_version_comparison ... ok [INFO] [stdout] test session::state::tests::test_invalid_from_terminated ... ok [INFO] [stdout] test session::context::tests::test_context_set_cwd ... ok [INFO] [stdout] test session::context::tests::test_context_with_cwd ... ok [INFO] [stdout] test pty::tests::test_pty_size_equality ... ok [INFO] [stdout] test security::validation::tests::test_validate_dangerous_fork_bomb ... ok [INFO] [stdout] test session::id::tests::test_uniqueness ... ok [INFO] [stdout] test session::store::tests::test_concurrent_access ... ok [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/shell_tunnel-6390f6716fb3b57d) [INFO] [stdout] [INFO] [stdout] test result: ok. 161 passed; 0 failed; 3 ignored; 0 measured; 0 filtered out; finished in 0.08s [INFO] [stdout] [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/api_integration.rs (/opt/rustwide/target/debug/deps/api_integration-06ec84409d38db38) [INFO] [stdout] [INFO] [stdout] running 16 tests [INFO] [stdout] test test_execute_oneshot ... ignored, Requires PTY execution [INFO] [stdout] test test_api_info_endpoint ... ok [INFO] [stdout] test test_create_session_with_env ... ok [INFO] [stdout] test test_invalid_json_body ... ok [INFO] [stdout] test test_api_key_store_validation ... ok [INFO] [stdout] test test_command_validator_basics ... ok [INFO] [stdout] test test_get_session_not_found ... ok [INFO] [stdout] test test_create_session ... ok [INFO] [stdout] test test_dangerous_command_detection ... ok [INFO] [stdout] test test_health_endpoint ... ok [INFO] [stdout] test test_delete_session_not_found ... ok [INFO] [stdout] test test_list_sessions_empty ... ok [INFO] [stdout] test test_not_found_route ... ok [INFO] [stdout] test test_security_config_creation ... ok [INFO] [stdout] test test_method_not_allowed ... ok [INFO] [stdout] test test_security_config_development ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 15 passed; 0 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stderr] Running tests/cli_integration.rs (/opt/rustwide/target/debug/deps/cli_integration-6d4517a3cfae905d) [INFO] [stdout] [INFO] [stdout] running 12 tests [INFO] [stdout] test test_cli_defaults ... ok [INFO] [stdout] test test_cli_invalid_host ... ok [INFO] [stdout] test test_cli_full_options ... ok [INFO] [stdout] test test_cli_config_file ... ok [INFO] [stdout] test test_config_api_key_enables_auth ... ok [INFO] [stdout] test test_config_no_auth_disables ... ok [INFO] [stdout] test test_config_from_json_file ... ok [INFO] [stdout] test test_cli_invalid_port ... ok [INFO] [stdout] test test_config_to_server_config ... ok [INFO] [stdout] test test_config_priority_cli_over_file ... ok [INFO] [stdout] test test_config_roundtrip ... ok [INFO] [stdout] test test_config_partial_deserialization ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 12 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stderr] Doc-tests shell_tunnel [INFO] [stdout] [INFO] [stdout] running 6 tests [INFO] [stdout] test src/execution/mod.rs - execution (line 10) - compile ... ok [INFO] [stdout] test src/lib.rs - (line 20) - compile ... ok [INFO] [stdout] test src/lib.rs - (line 46) - compile ... ok [INFO] [stdout] test src/api/mod.rs - api (line 26) - compile ... ok [INFO] [stdout] test src/security/mod.rs - security (line 14) ... ok [INFO] [stdout] test src/output/mod.rs - output (line 9) ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.39s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "3b145a5942e393ebbc75b257427b5e404dc1861eb20004d0d202fe029d3e6f57", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "3b145a5942e393ebbc75b257427b5e404dc1861eb20004d0d202fe029d3e6f57", kill_on_drop: false }` [INFO] [stdout] 3b145a5942e393ebbc75b257427b5e404dc1861eb20004d0d202fe029d3e6f57