[INFO] fetching crate tailscale-client 0.1.5...
[INFO] testing tailscale-client-0.1.5 against master#0d162b25edd5bf0dba9a22e83b614f1113e90474 for pr-150681
[INFO] extracting crate tailscale-client 0.1.5 into /workspace/builds/worker-5-tc1/source
[INFO] started tweaking crates.io crate tailscale-client 0.1.5
[INFO] finished tweaking crates.io crate tailscale-client 0.1.5
[INFO] tweaked toml for crates.io crate tailscale-client 0.1.5 written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate tailscale-client 0.1.5 on toolchain 0d162b25edd5bf0dba9a22e83b614f1113e90474
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 251 packages to latest compatible versions
[INFO] [stderr]       Adding reqwest v0.12.28 (available: v0.13.1)
[INFO] [stderr]       Adding testcontainers v0.23.3 (available: v0.26.3)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded structmeta-derive v0.3.0
[INFO] [stderr]   Downloaded hyperlocal v0.9.1
[INFO] [stderr]   Downloaded windows-registry v0.6.1
[INFO] [stderr]   Downloaded parse-display v0.9.1
[INFO] [stderr]   Downloaded docker_credential v1.3.2
[INFO] [stderr]   Downloaded tokio-tar v0.3.1
[INFO] [stderr]   Downloaded hyper-named-pipe v0.1.0
[INFO] [stderr]   Downloaded parse-display-derive v0.9.1
[INFO] [stderr]   Downloaded testcontainers v0.23.3
[INFO] [stderr]   Downloaded structmeta v0.3.0
[INFO] [stderr]   Downloaded bollard-stubs v1.47.1-rc.27.3.1
[INFO] [stderr]   Downloaded schemars v1.2.0
[INFO] [stderr]   Downloaded bollard v0.18.1
[INFO] [stderr]   Downloaded h2 v0.4.13
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] a343a4d8919e715bf27d5d566528e36d2043932f1b1858aee8c5b8ab86502d4e
[INFO] running `Command { std: "docker" "start" "-a" "a343a4d8919e715bf27d5d566528e36d2043932f1b1858aee8c5b8ab86502d4e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "a343a4d8919e715bf27d5d566528e36d2043932f1b1858aee8c5b8ab86502d4e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a343a4d8919e715bf27d5d566528e36d2043932f1b1858aee8c5b8ab86502d4e", kill_on_drop: false }`
[INFO] [stdout] a343a4d8919e715bf27d5d566528e36d2043932f1b1858aee8c5b8ab86502d4e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 3e7646957dd81aac1ab5c103b33c4e46078ca269c1388f2dcfe306b575a384c9
[INFO] running `Command { std: "docker" "start" "-a" "3e7646957dd81aac1ab5c103b33c4e46078ca269c1388f2dcfe306b575a384c9", kill_on_drop: false }`
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling rustls-pki-types v1.13.2
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling memchr v2.7.6
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling rustls v0.23.36
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling structmeta-derive v0.3.0
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling rustls-webpki v0.103.8
[INFO] [stderr]    Compiling structmeta v0.3.0
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling serde_with v3.16.1
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling serde_repr v0.1.20
[INFO] [stderr]    Compiling rustls-native-certs v0.8.3
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling xattr v1.6.1
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling rustls-pemfile v2.2.0
[INFO] [stderr]    Compiling filetime v0.2.26
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling docker_credential v1.3.2
[INFO] [stderr]    Compiling tokio-tar v0.3.1
[INFO] [stderr]    Compiling parse-display-derive v0.9.1
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling bollard-stubs v1.47.1-rc.27.3.1
[INFO] [stderr]    Compiling parse-display v0.9.1
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[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 hyperlocal v0.9.1
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling bollard v0.18.1
[INFO] [stderr]    Compiling testcontainers v0.23.3
[INFO] [stderr]    Compiling tailscale-client v0.1.5 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Error`
[INFO] [stdout]  --> src/lib.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use anyhow::{anyhow, Error, Result};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `testcontainers::core::ExecCommand`
[INFO] [stdout]  --> src/lib.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use testcontainers::core::ExecCommand;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `GenericImage`, `ImageExt`, `core::WaitFor`, and `runners::AsyncRunner`
[INFO] [stdout]  --> src/lib.rs:7:22
[INFO] [stdout]   |
[INFO] [stdout] 7 | use testcontainers::{core::WaitFor, runners::AsyncRunner, GenericImage, ImageExt};
[INFO] [stdout]   |                      ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `expirySeconds` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:325:9
[INFO] [stdout]     |
[INFO] [stdout] 325 |     pub expirySeconds: Option<u64>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `expiry_seconds`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `userId` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:373:9
[INFO] [stdout]     |
[INFO] [stdout] 373 |     pub userId: Option<String>,
[INFO] [stdout]     |         ^^^^^^ help: convert the identifier to snake case: `user_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `nodeId` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:406:9
[INFO] [stdout]     |
[INFO] [stdout] 406 |     pub nodeId: Option<String>,
[INFO] [stdout]     |         ^^^^^^ help: convert the identifier to snake case: `node_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `clientVersion` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:410:9
[INFO] [stdout]     |
[INFO] [stdout] 410 |     pub clientVersion: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_version`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `updateAvailable` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:411:9
[INFO] [stdout]     |
[INFO] [stdout] 411 |     pub updateAvailable: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `update_available`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `lastSeen` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:414:9
[INFO] [stdout]     |
[INFO] [stdout] 414 |     pub lastSeen: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `last_seen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `keyExpiryDisabled` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:415:9
[INFO] [stdout]     |
[INFO] [stdout] 415 |     pub keyExpiryDisabled: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `key_expiry_disabled`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `isExternal` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:418:9
[INFO] [stdout]     |
[INFO] [stdout] 418 |     pub isExternal: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: convert the identifier to snake case: `is_external`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `machineKey` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:419:9
[INFO] [stdout]     |
[INFO] [stdout] 419 |     pub machineKey: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: convert the identifier to snake case: `machine_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `nodeKey` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:420:9
[INFO] [stdout]     |
[INFO] [stdout] 420 |     pub nodeKey: Option<String>,
[INFO] [stdout]     |         ^^^^^^^ help: convert the identifier to snake case: `node_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `blocksIncomingConnections` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:421:9
[INFO] [stdout]     |
[INFO] [stdout] 421 |     pub blocksIncomingConnections: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `blocks_incoming_connections`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `enabledRoutes` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:422:9
[INFO] [stdout]     |
[INFO] [stdout] 422 |     pub enabledRoutes: Option<Vec<String>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `enabled_routes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `advertisedRoutes` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:423:9
[INFO] [stdout]     |
[INFO] [stdout] 423 |     pub advertisedRoutes: Option<Vec<String>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `advertised_routes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `clientConnectivity` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:424:9
[INFO] [stdout]     |
[INFO] [stdout] 424 |     pub clientConnectivity: Option<ClientConnectivity>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_connectivity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tailnetLockError` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:426:9
[INFO] [stdout]     |
[INFO] [stdout] 426 |     pub tailnetLockError: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tailnet_lock_error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tailnetLockKey` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:427:9
[INFO] [stdout]     |
[INFO] [stdout] 427 |     pub tailnetLockKey: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tailnet_lock_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `postureIdentity` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:428:9
[INFO] [stdout]     |
[INFO] [stdout] 428 |     pub postureIdentity: Option<PostureIdentity>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `posture_identity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `mappingVariesByDestIP` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:436:9
[INFO] [stdout]     |
[INFO] [stdout] 436 |     pub mappingVariesByDestIP: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `mapping_varies_by_dest_ip`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `clientSupports` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:437:9
[INFO] [stdout]     |
[INFO] [stdout] 437 |     pub clientSupports: Option<ClientSupports>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_supports`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `latencyMs` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:444:9
[INFO] [stdout]     |
[INFO] [stdout] 444 |     pub latencyMs: Option<f64>,
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `latency_ms`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `hairPinning` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:450:9
[INFO] [stdout]     |
[INFO] [stdout] 450 |     pub hairPinning: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^ help: convert the identifier to snake case: `hair_pinning`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `serialNumbers` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:461:9
[INFO] [stdout]     |
[INFO] [stdout] 461 |     pub serialNumbers: Option<Vec<String>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `serial_numbers`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 45s
[INFO] running `Command { std: "docker" "inspect" "3e7646957dd81aac1ab5c103b33c4e46078ca269c1388f2dcfe306b575a384c9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3e7646957dd81aac1ab5c103b33c4e46078ca269c1388f2dcfe306b575a384c9", kill_on_drop: false }`
[INFO] [stdout] 3e7646957dd81aac1ab5c103b33c4e46078ca269c1388f2dcfe306b575a384c9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 9bb45b2518745b1c8ec35c1b16d0b0aa48118935a7d034f31f0be44c45752148
[INFO] running `Command { std: "docker" "start" "-a" "9bb45b2518745b1c8ec35c1b16d0b0aa48118935a7d034f31f0be44c45752148", kill_on_drop: false }`
[INFO] [stderr]    Compiling tailscale-client v0.1.5 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Error`
[INFO] [stdout]  --> src/lib.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use anyhow::{anyhow, Error, Result};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `testcontainers::core::ExecCommand`
[INFO] [stdout]  --> src/lib.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use testcontainers::core::ExecCommand;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `GenericImage`, `ImageExt`, `core::WaitFor`, and `runners::AsyncRunner`
[INFO] [stdout]  --> src/lib.rs:7:22
[INFO] [stdout]   |
[INFO] [stdout] 7 | use testcontainers::{core::WaitFor, runners::AsyncRunner, GenericImage, ImageExt};
[INFO] [stdout]   |                      ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `expirySeconds` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:325:9
[INFO] [stdout]     |
[INFO] [stdout] 325 |     pub expirySeconds: Option<u64>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `expiry_seconds`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `userId` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:373:9
[INFO] [stdout]     |
[INFO] [stdout] 373 |     pub userId: Option<String>,
[INFO] [stdout]     |         ^^^^^^ help: convert the identifier to snake case: `user_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `nodeId` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:406:9
[INFO] [stdout]     |
[INFO] [stdout] 406 |     pub nodeId: Option<String>,
[INFO] [stdout]     |         ^^^^^^ help: convert the identifier to snake case: `node_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `clientVersion` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:410:9
[INFO] [stdout]     |
[INFO] [stdout] 410 |     pub clientVersion: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_version`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `updateAvailable` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:411:9
[INFO] [stdout]     |
[INFO] [stdout] 411 |     pub updateAvailable: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `update_available`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `lastSeen` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:414:9
[INFO] [stdout]     |
[INFO] [stdout] 414 |     pub lastSeen: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `last_seen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `keyExpiryDisabled` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:415:9
[INFO] [stdout]     |
[INFO] [stdout] 415 |     pub keyExpiryDisabled: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `key_expiry_disabled`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `isExternal` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:418:9
[INFO] [stdout]     |
[INFO] [stdout] 418 |     pub isExternal: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: convert the identifier to snake case: `is_external`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `machineKey` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:419:9
[INFO] [stdout]     |
[INFO] [stdout] 419 |     pub machineKey: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: convert the identifier to snake case: `machine_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `nodeKey` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:420:9
[INFO] [stdout]     |
[INFO] [stdout] 420 |     pub nodeKey: Option<String>,
[INFO] [stdout]     |         ^^^^^^^ help: convert the identifier to snake case: `node_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `blocksIncomingConnections` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:421:9
[INFO] [stdout]     |
[INFO] [stdout] 421 |     pub blocksIncomingConnections: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `blocks_incoming_connections`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `enabledRoutes` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:422:9
[INFO] [stdout]     |
[INFO] [stdout] 422 |     pub enabledRoutes: Option<Vec<String>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `enabled_routes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `advertisedRoutes` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:423:9
[INFO] [stdout]     |
[INFO] [stdout] 423 |     pub advertisedRoutes: Option<Vec<String>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `advertised_routes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `clientConnectivity` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:424:9
[INFO] [stdout]     |
[INFO] [stdout] 424 |     pub clientConnectivity: Option<ClientConnectivity>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_connectivity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tailnetLockError` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:426:9
[INFO] [stdout]     |
[INFO] [stdout] 426 |     pub tailnetLockError: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tailnet_lock_error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tailnetLockKey` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:427:9
[INFO] [stdout]     |
[INFO] [stdout] 427 |     pub tailnetLockKey: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tailnet_lock_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `postureIdentity` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:428:9
[INFO] [stdout]     |
[INFO] [stdout] 428 |     pub postureIdentity: Option<PostureIdentity>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `posture_identity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `mappingVariesByDestIP` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:436:9
[INFO] [stdout]     |
[INFO] [stdout] 436 |     pub mappingVariesByDestIP: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `mapping_varies_by_dest_ip`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `clientSupports` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:437:9
[INFO] [stdout]     |
[INFO] [stdout] 437 |     pub clientSupports: Option<ClientSupports>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_supports`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `latencyMs` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:444:9
[INFO] [stdout]     |
[INFO] [stdout] 444 |     pub latencyMs: Option<f64>,
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `latency_ms`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `hairPinning` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:450:9
[INFO] [stdout]     |
[INFO] [stdout] 450 |     pub hairPinning: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^ help: convert the identifier to snake case: `hair_pinning`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `serialNumbers` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:461:9
[INFO] [stdout]     |
[INFO] [stdout] 461 |     pub serialNumbers: Option<Vec<String>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `serial_numbers`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error`
[INFO] [stdout]  --> src/lib.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use anyhow::{anyhow, Error, Result};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::WaitFor`
[INFO] [stdout]  --> src/lib.rs:7:22
[INFO] [stdout]   |
[INFO] [stdout] 7 | use testcontainers::{core::WaitFor, runners::AsyncRunner, GenericImage, ImageExt};
[INFO] [stdout]   |                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `expirySeconds` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:325:9
[INFO] [stdout]     |
[INFO] [stdout] 325 |     pub expirySeconds: Option<u64>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `expiry_seconds`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `userId` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:373:9
[INFO] [stdout]     |
[INFO] [stdout] 373 |     pub userId: Option<String>,
[INFO] [stdout]     |         ^^^^^^ help: convert the identifier to snake case: `user_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `nodeId` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:406:9
[INFO] [stdout]     |
[INFO] [stdout] 406 |     pub nodeId: Option<String>,
[INFO] [stdout]     |         ^^^^^^ help: convert the identifier to snake case: `node_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `clientVersion` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:410:9
[INFO] [stdout]     |
[INFO] [stdout] 410 |     pub clientVersion: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_version`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `updateAvailable` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:411:9
[INFO] [stdout]     |
[INFO] [stdout] 411 |     pub updateAvailable: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `update_available`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `lastSeen` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:414:9
[INFO] [stdout]     |
[INFO] [stdout] 414 |     pub lastSeen: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `last_seen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `keyExpiryDisabled` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:415:9
[INFO] [stdout]     |
[INFO] [stdout] 415 |     pub keyExpiryDisabled: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `key_expiry_disabled`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `isExternal` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:418:9
[INFO] [stdout]     |
[INFO] [stdout] 418 |     pub isExternal: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: convert the identifier to snake case: `is_external`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `machineKey` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:419:9
[INFO] [stdout]     |
[INFO] [stdout] 419 |     pub machineKey: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: convert the identifier to snake case: `machine_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `nodeKey` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:420:9
[INFO] [stdout]     |
[INFO] [stdout] 420 |     pub nodeKey: Option<String>,
[INFO] [stdout]     |         ^^^^^^^ help: convert the identifier to snake case: `node_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `blocksIncomingConnections` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:421:9
[INFO] [stdout]     |
[INFO] [stdout] 421 |     pub blocksIncomingConnections: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `blocks_incoming_connections`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `enabledRoutes` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:422:9
[INFO] [stdout]     |
[INFO] [stdout] 422 |     pub enabledRoutes: Option<Vec<String>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `enabled_routes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `advertisedRoutes` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:423:9
[INFO] [stdout]     |
[INFO] [stdout] 423 |     pub advertisedRoutes: Option<Vec<String>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `advertised_routes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `clientConnectivity` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:424:9
[INFO] [stdout]     |
[INFO] [stdout] 424 |     pub clientConnectivity: Option<ClientConnectivity>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_connectivity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tailnetLockError` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:426:9
[INFO] [stdout]     |
[INFO] [stdout] 426 |     pub tailnetLockError: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tailnet_lock_error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tailnetLockKey` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:427:9
[INFO] [stdout]     |
[INFO] [stdout] 427 |     pub tailnetLockKey: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tailnet_lock_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `postureIdentity` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:428:9
[INFO] [stdout]     |
[INFO] [stdout] 428 |     pub postureIdentity: Option<PostureIdentity>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `posture_identity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `mappingVariesByDestIP` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:436:9
[INFO] [stdout]     |
[INFO] [stdout] 436 |     pub mappingVariesByDestIP: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `mapping_varies_by_dest_ip`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `clientSupports` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:437:9
[INFO] [stdout]     |
[INFO] [stdout] 437 |     pub clientSupports: Option<ClientSupports>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_supports`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `latencyMs` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:444:9
[INFO] [stdout]     |
[INFO] [stdout] 444 |     pub latencyMs: Option<f64>,
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `latency_ms`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `hairPinning` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:450:9
[INFO] [stdout]     |
[INFO] [stdout] 450 |     pub hairPinning: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^ help: convert the identifier to snake case: `hair_pinning`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `serialNumbers` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:461:9
[INFO] [stdout]     |
[INFO] [stdout] 461 |     pub serialNumbers: Option<Vec<String>>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `serial_numbers`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 10.29s
[INFO] running `Command { std: "docker" "inspect" "9bb45b2518745b1c8ec35c1b16d0b0aa48118935a7d034f31f0be44c45752148", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9bb45b2518745b1c8ec35c1b16d0b0aa48118935a7d034f31f0be44c45752148", kill_on_drop: false }`
[INFO] [stdout] 9bb45b2518745b1c8ec35c1b16d0b0aa48118935a7d034f31f0be44c45752148
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] ae2de627e39adc06eec5679f73c9c544739698121f9fa6d656aad926c1eae6df
[INFO] running `Command { std: "docker" "start" "-a" "ae2de627e39adc06eec5679f73c9c544739698121f9fa6d656aad926c1eae6df", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `Error`
[INFO] [stderr]  --> src/lib.rs:1:22
[INFO] [stderr]   |
[INFO] [stderr] 1 | use anyhow::{anyhow, Error, Result};
[INFO] [stderr]   |                      ^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `testcontainers::core::ExecCommand`
[INFO] [stderr]  --> src/lib.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use testcontainers::core::ExecCommand;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `GenericImage`, `ImageExt`, `core::WaitFor`, and `runners::AsyncRunner`
[INFO] [stderr]  --> src/lib.rs:7:22
[INFO] [stderr]   |
[INFO] [stderr] 7 | use testcontainers::{core::WaitFor, runners::AsyncRunner, GenericImage, ImageExt};
[INFO] [stderr]   |                      ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `expirySeconds` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:325:9
[INFO] [stderr]     |
[INFO] [stderr] 325 |     pub expirySeconds: Option<u64>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `expiry_seconds`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `userId` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:373:9
[INFO] [stderr]     |
[INFO] [stderr] 373 |     pub userId: Option<String>,
[INFO] [stderr]     |         ^^^^^^ help: convert the identifier to snake case: `user_id`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `nodeId` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:406:9
[INFO] [stderr]     |
[INFO] [stderr] 406 |     pub nodeId: Option<String>,
[INFO] [stderr]     |         ^^^^^^ help: convert the identifier to snake case: `node_id`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `clientVersion` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:410:9
[INFO] [stderr]     |
[INFO] [stderr] 410 |     pub clientVersion: Option<String>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_version`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `updateAvailable` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:411:9
[INFO] [stderr]     |
[INFO] [stderr] 411 |     pub updateAvailable: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `update_available`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `lastSeen` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:414:9
[INFO] [stderr]     |
[INFO] [stderr] 414 |     pub lastSeen: Option<String>,
[INFO] [stderr]     |         ^^^^^^^^ help: convert the identifier to snake case: `last_seen`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `keyExpiryDisabled` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:415:9
[INFO] [stderr]     |
[INFO] [stderr] 415 |     pub keyExpiryDisabled: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `key_expiry_disabled`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `isExternal` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:418:9
[INFO] [stderr]     |
[INFO] [stderr] 418 |     pub isExternal: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^^^ help: convert the identifier to snake case: `is_external`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `machineKey` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:419:9
[INFO] [stderr]     |
[INFO] [stderr] 419 |     pub machineKey: Option<String>,
[INFO] [stderr]     |         ^^^^^^^^^^ help: convert the identifier to snake case: `machine_key`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `nodeKey` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:420:9
[INFO] [stderr]     |
[INFO] [stderr] 420 |     pub nodeKey: Option<String>,
[INFO] [stderr]     |         ^^^^^^^ help: convert the identifier to snake case: `node_key`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `blocksIncomingConnections` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:421:9
[INFO] [stderr]     |
[INFO] [stderr] 421 |     pub blocksIncomingConnections: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `blocks_incoming_connections`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `enabledRoutes` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:422:9
[INFO] [stderr]     |
[INFO] [stderr] 422 |     pub enabledRoutes: Option<Vec<String>>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `enabled_routes`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `advertisedRoutes` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:423:9
[INFO] [stderr]     |
[INFO] [stderr] 423 |     pub advertisedRoutes: Option<Vec<String>>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `advertised_routes`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `clientConnectivity` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:424:9
[INFO] [stderr]     |
[INFO] [stderr] 424 |     pub clientConnectivity: Option<ClientConnectivity>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_connectivity`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tailnetLockError` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:426:9
[INFO] [stderr]     |
[INFO] [stderr] 426 |     pub tailnetLockError: Option<String>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tailnet_lock_error`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `tailnetLockKey` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:427:9
[INFO] [stderr]     |
[INFO] [stderr] 427 |     pub tailnetLockKey: Option<String>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tailnet_lock_key`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `postureIdentity` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:428:9
[INFO] [stderr]     |
[INFO] [stderr] 428 |     pub postureIdentity: Option<PostureIdentity>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `posture_identity`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `mappingVariesByDestIP` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:436:9
[INFO] [stderr]     |
[INFO] [stderr] 436 |     pub mappingVariesByDestIP: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `mapping_varies_by_dest_ip`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `clientSupports` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:437:9
[INFO] [stderr]     |
[INFO] [stderr] 437 |     pub clientSupports: Option<ClientSupports>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `client_supports`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `latencyMs` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:444:9
[INFO] [stderr]     |
[INFO] [stderr] 444 |     pub latencyMs: Option<f64>,
[INFO] [stderr]     |         ^^^^^^^^^ help: convert the identifier to snake case: `latency_ms`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `hairPinning` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:450:9
[INFO] [stderr]     |
[INFO] [stderr] 450 |     pub hairPinning: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^^^^ help: convert the identifier to snake case: `hair_pinning`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `serialNumbers` should have a snake case name
[INFO] [stderr]    --> src/lib.rs:461:9
[INFO] [stderr]     |
[INFO] [stderr] 461 |     pub serialNumbers: Option<Vec<String>>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `serial_numbers`
[INFO] [stderr] 
[INFO] [stderr] warning: `tailscale-client` (lib) generated 25 warnings (run `cargo fix --lib -p tailscale-client` to apply 3 suggestions)
[INFO] [stderr] warning: unused import: `core::WaitFor`
[INFO] [stderr]  --> src/lib.rs:7:22
[INFO] [stderr]   |
[INFO] [stderr] 7 | use testcontainers::{core::WaitFor, runners::AsyncRunner, GenericImage, ImageExt};
[INFO] [stderr]   |                      ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `tailscale-client` (lib test) generated 24 warnings (23 duplicates) (run `cargo fix --lib -p tailscale-client --tests` to apply 1 suggestion)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.31s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/tailscale_client-df8e95d90ab1e233)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test test_tailscale_normal_in_docker ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- test_tailscale_normal_in_docker stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'test_tailscale_normal_in_docker' (16) panicked at src/lib.rs:467:52:
[INFO] [stdout] Please set TAILSCALE_API_KEY env var.: NotPresent
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x57429de8ad92 - std[3b51380354919863]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x57429de8ad92 - std[3b51380354919863]::backtrace_rs::backtrace::trace_unsynchronized::<std[3b51380354919863]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x57429de8ad92 - std[3b51380354919863]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x57429de8ad92 - <<std[3b51380354919863]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[27de1724e4349be2]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x57429dea342a - <core[27de1724e4349be2]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x57429dea342a - core[27de1724e4349be2]::fmt::write
[INFO] [stdout]    6:     0x57429de908f6 - std[3b51380354919863]::io::default_write_fmt::<alloc[a57f19327c0ad893]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x57429de908f6 - <alloc[a57f19327c0ad893]::vec::Vec<u8> as std[3b51380354919863]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x57429de6682f - <std[3b51380354919863]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x57429de6682f - std[3b51380354919863]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x57429de81cd9 - std[3b51380354919863]::panicking::default_hook
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x57429d3891ee - <alloc[a57f19327c0ad893]::boxed::Box<dyn for<'a, 'b> core[27de1724e4349be2]::ops::function::Fn<(&'a std[3b51380354919863]::panic::PanicHookInfo<'b>,), Output = ()> + core[27de1724e4349be2]::marker::Sync + core[27de1724e4349be2]::marker::Send> as core[27de1724e4349be2]::ops::function::Fn<(&std[3b51380354919863]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x57429d3891ee - test[182b2e79ecd7bbd9]::test_main_with_exit_callback::<test[182b2e79ecd7bbd9]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x57429de81f42 - <alloc[a57f19327c0ad893]::boxed::Box<dyn for<'a, 'b> core[27de1724e4349be2]::ops::function::Fn<(&'a std[3b51380354919863]::panic::PanicHookInfo<'b>,), Output = ()> + core[27de1724e4349be2]::marker::Sync + core[27de1724e4349be2]::marker::Send> as core[27de1724e4349be2]::ops::function::Fn<(&std[3b51380354919863]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x57429de81f42 - std[3b51380354919863]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x57429de668e8 - std[3b51380354919863]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x57429de5b399 - std[3b51380354919863]::sys::backtrace::__rust_end_short_backtrace::<std[3b51380354919863]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x57429de679fd - __rustc[d79c0ace40940972]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x57429dea3bec - core[27de1724e4349be2]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x57429dea3962 - core[27de1724e4349be2]::result::unwrap_failed
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/result.rs:1867:5
[INFO] [stdout]   20:     0x57429d32842e - <core[27de1724e4349be2]::result::Result<alloc[a57f19327c0ad893]::string::String, std[3b51380354919863]::env::VarError>>::expect
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/result.rs:1185:23
[INFO] [stdout]   21:     0x57429d291d2f - tailscale_client[ae843cb2e20b97cc]::test_tailscale_normal_in_docker::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/lib.rs:467:52
[INFO] [stdout]   22:     0x57429d345395 - <core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>> as core[27de1724e4349be2]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x57429d34540d - <core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>> as core[27de1724e4349be2]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x57429d327f6d - <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:753:70
[INFO] [stdout]   25:     0x57429d327e4c - tokio[7808be3a4dd82b2f]::task::coop::with_budget::<core[27de1724e4349be2]::task::poll::Poll<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>, <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/task/coop/mod.rs:167:5
[INFO] [stdout]   26:     0x57429d327e4c - tokio[7808be3a4dd82b2f]::task::coop::budget::<core[27de1724e4349be2]::task::poll::Poll<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>, <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/task/coop/mod.rs:133:5
[INFO] [stdout]   27:     0x57429d327e4c - <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:753:25
[INFO] [stdout]   28:     0x57429d31c82a - <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::Context>::enter::<core[27de1724e4349be2]::task::poll::Poll<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>, <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:442:19
[INFO] [stdout]   29:     0x57429d32663d - <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:752:44
[INFO] [stdout]   30:     0x57429d3258eb - <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:840:68
[INFO] [stdout]   31:     0x57429d1f3aaa - <tokio[7808be3a4dd82b2f]::runtime::context::scoped::Scoped<tokio[7808be3a4dd82b2f]::runtime::scheduler::Context>>::set::<<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>::{closure#0}, (alloc[a57f19327c0ad893]::boxed::Box<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::Core>, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>)>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x57429d2ea7fa - tokio[7808be3a4dd82b2f]::runtime::context::set_scheduler::<(alloc[a57f19327c0ad893]::boxed::Box<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::Core>, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>), <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context.rs:176:38
[INFO] [stdout]   33:     0x57429d2194e6 - <std[3b51380354919863]::thread::local::LocalKey<tokio[7808be3a4dd82b2f]::runtime::context::Context>>::try_with::<tokio[7808be3a4dd82b2f]::runtime::context::set_scheduler<(alloc[a57f19327c0ad893]::boxed::Box<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::Core>, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>), <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>::{closure#0}>::{closure#0}, (alloc[a57f19327c0ad893]::boxed::Box<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::Core>, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>)>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/thread/local.rs:513:12
[INFO] [stdout]   34:     0x57429d218efc - <std[3b51380354919863]::thread::local::LocalKey<tokio[7808be3a4dd82b2f]::runtime::context::Context>>::with::<tokio[7808be3a4dd82b2f]::runtime::context::set_scheduler<(alloc[a57f19327c0ad893]::boxed::Box<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::Core>, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>), <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>::{closure#0}>::{closure#0}, (alloc[a57f19327c0ad893]::boxed::Box<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::Core>, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>)>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/thread/local.rs:477:20
[INFO] [stdout]   35:     0x57429d2e5b91 - tokio[7808be3a4dd82b2f]::runtime::context::set_scheduler::<(alloc[a57f19327c0ad893]::boxed::Box<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::Core>, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>), <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context.rs:176:17
[INFO] [stdout]   36:     0x57429d320389 - <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>::{closure#0}, core[27de1724e4349be2]::option::Option<core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:840:27
[INFO] [stdout]   37:     0x57429d3206b6 - <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[27de1724e4349be2]::pin::Pin<&mut core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:740:24
[INFO] [stdout]   38:     0x57429d325319 - <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   39:     0x57429d249153 - tokio[7808be3a4dd82b2f]::runtime::context::runtime::enter_runtime::<<tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CurrentThread>::block_on<core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>::{closure#0}, core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x57429d31c2a1 - <tokio[7808be3a4dd82b2f]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   41:     0x57429d29e9ef - <tokio[7808be3a4dd82b2f]::runtime::runtime::Runtime>::block_on_inner::<core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/runtime.rs:368:52
[INFO] [stdout]   42:     0x57429d29ebd5 - <tokio[7808be3a4dd82b2f]::runtime::runtime::Runtime>::block_on::<core[27de1724e4349be2]::pin::Pin<&mut dyn core[27de1724e4349be2]::future::future::Future<Output = core[27de1724e4349be2]::result::Result<(), anyhow[647cbb8c0dc34888]::Error>>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/runtime.rs:342:18
[INFO] [stdout]   43:     0x57429d29937d - tailscale_client[ae843cb2e20b97cc]::test_tailscale_normal_in_docker
[INFO] [stdout]                                at /opt/rustwide/workdir/src/lib.rs:546:7
[INFO] [stdout]   44:     0x57429d291b27 - tailscale_client[ae843cb2e20b97cc]::test_tailscale_normal_in_docker::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/lib.rs:465:47
[INFO] [stdout]   45:     0x57429d1d5496 - <tailscale_client[ae843cb2e20b97cc]::test_tailscale_normal_in_docker::{closure#0} as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x57429d37d59b - <fn() -> core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String> as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x57429d37d59b - test[182b2e79ecd7bbd9]::__rust_begin_short_backtrace::<core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String>, fn() -> core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:663:18
[INFO] [stdout]   48:     0x57429d389dfa - test[182b2e79ecd7bbd9]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:686:74
[INFO] [stdout]   49:     0x57429d389dfa - <core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<test[182b2e79ecd7bbd9]::run_test_in_process::{closure#0}> as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   50:     0x57429d389dfa - std[3b51380354919863]::panicking::catch_unwind::do_call::<core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<test[182b2e79ecd7bbd9]::run_test_in_process::{closure#0}>, core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:581:40
[INFO] [stdout]   51:     0x57429d389dfa - std[3b51380354919863]::panicking::catch_unwind::<core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String>, core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<test[182b2e79ecd7bbd9]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:544:19
[INFO] [stdout]   52:     0x57429d389dfa - std[3b51380354919863]::panic::catch_unwind::<core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<test[182b2e79ecd7bbd9]::run_test_in_process::{closure#0}>, core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panic.rs:359:14
[INFO] [stdout]   53:     0x57429d389dfa - test[182b2e79ecd7bbd9]::run_test_in_process
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:686:27
[INFO] [stdout]   54:     0x57429d389dfa - test[182b2e79ecd7bbd9]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:607:43
[INFO] [stdout]   55:     0x57429d3853a4 - test[182b2e79ecd7bbd9]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:637:41
[INFO] [stdout]   56:     0x57429d3853a4 - std[3b51380354919863]::sys::backtrace::__rust_begin_short_backtrace::<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   57:     0x57429d38c8f2 - std[3b51380354919863]::thread::lifecycle::spawn_unchecked::<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   58:     0x57429d38c8f2 - <core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<std[3b51380354919863]::thread::lifecycle::spawn_unchecked<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   59:     0x57429d38c8f2 - std[3b51380354919863]::panicking::catch_unwind::do_call::<core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<std[3b51380354919863]::thread::lifecycle::spawn_unchecked<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:581:40
[INFO] [stdout]   60:     0x57429d38c8f2 - std[3b51380354919863]::panicking::catch_unwind::<(), core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<std[3b51380354919863]::thread::lifecycle::spawn_unchecked<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:544:19
[INFO] [stdout]   61:     0x57429d38c8f2 - std[3b51380354919863]::panic::catch_unwind::<core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<std[3b51380354919863]::thread::lifecycle::spawn_unchecked<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panic.rs:359:14
[INFO] [stdout]   62:     0x57429d38c8f2 - std[3b51380354919863]::thread::lifecycle::spawn_unchecked::<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   63:     0x57429d38c8f2 - <std[3b51380354919863]::thread::lifecycle::spawn_unchecked<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1} as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   64:     0x57429de89eff - <alloc[a57f19327c0ad893]::boxed::Box<dyn core[27de1724e4349be2]::ops::function::FnOnce<(), Output = ()> + core[27de1724e4349be2]::marker::Send> as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   65:     0x57429de89eff - <std[3b51380354919863]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   66:     0x74e0b3cf5aa4 - <unknown>
[INFO] [stdout]   67:     0x74e0b3d82a64 - clone
[INFO] [stdout]   68:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     test_tailscale_normal_in_docker
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.11s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "ae2de627e39adc06eec5679f73c9c544739698121f9fa6d656aad926c1eae6df", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ae2de627e39adc06eec5679f73c9c544739698121f9fa6d656aad926c1eae6df", kill_on_drop: false }`
[INFO] [stdout] ae2de627e39adc06eec5679f73c9c544739698121f9fa6d656aad926c1eae6df
