[INFO] fetching crate tailscale-client 0.1.5...
[INFO] testing tailscale-client-0.1.5 against 1.90.0 for beta-1.91-3
[INFO] extracting crate tailscale-client 0.1.5 into /workspace/builds/worker-4-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-4-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate tailscale-client 0.1.5 on toolchain 1.90.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "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" "+1.90.0" "generate-lockfile" "--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]      Locking 263 packages to latest compatible versions
[INFO] [stderr]       Adding testcontainers v0.23.3 (available: v0.25.0)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded parse-display-derive v0.9.1
[INFO] [stderr]   Downloaded testcontainers v0.23.3
[INFO] [stderr]   Downloaded docker_credential v1.3.2
[INFO] [stderr]   Downloaded tokio-tar v0.3.1
[INFO] [stderr]   Downloaded security-framework v3.5.1
[INFO] [stderr]   Downloaded structmeta-derive v0.3.0
[INFO] [stderr]   Downloaded structmeta v0.3.0
[INFO] [stderr]   Downloaded parse-display v0.9.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 9d95c42db841ca9333853e2ae5ca1d4c6ee24b60f198068ed3b58f93a8e8fcb9
[INFO] running `Command { std: "docker" "start" "-a" "9d95c42db841ca9333853e2ae5ca1d4c6ee24b60f198068ed3b58f93a8e8fcb9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "9d95c42db841ca9333853e2ae5ca1d4c6ee24b60f198068ed3b58f93a8e8fcb9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9d95c42db841ca9333853e2ae5ca1d4c6ee24b60f198068ed3b58f93a8e8fcb9", kill_on_drop: false }`
[INFO] [stdout] 9d95c42db841ca9333853e2ae5ca1d4c6ee24b60f198068ed3b58f93a8e8fcb9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 594690e9931e689b643fde07e5e02392b5993fed68f12dcfdb8310ff1bf83539
[INFO] running `Command { std: "docker" "start" "-a" "594690e9931e689b643fde07e5e02392b5993fed68f12dcfdb8310ff1bf83539", kill_on_drop: false }`
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling rustls-pki-types v1.12.0
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling rustls v0.23.32
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling rustix v1.1.2
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling structmeta-derive v0.3.0
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling regex-automata v0.4.11
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]    Compiling rustls-webpki v0.103.6
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]    Compiling serde_with_macros v3.14.1
[INFO] [stderr]    Compiling structmeta v0.3.0
[INFO] [stderr]    Compiling regex v1.11.3
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling serde_repr v0.1.20
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling home v0.5.11
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling serde_with v3.14.1
[INFO] [stderr]    Compiling xattr v1.6.1
[INFO] [stderr]    Compiling rustls-native-certs v0.8.1
[INFO] [stderr]    Compiling rustls-pemfile v2.2.0
[INFO] [stderr]    Compiling filetime v0.2.26
[INFO] [stderr]    Compiling docker_credential v1.3.2
[INFO] [stderr]    Compiling tokio-util v0.7.16
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling parse-display-derive v0.9.1
[INFO] [stderr]    Compiling h2 v0.4.12
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling tokio-tar v0.3.1
[INFO] [stderr]    Compiling tower-http v0.6.6
[INFO] [stderr]    Compiling bollard-stubs v1.47.1-rc.27.3.1
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling parse-display v0.9.1
[INFO] [stderr]    Compiling etcetera v0.8.0
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling hyper v1.7.0
[INFO] [stderr]    Compiling hyper-util v0.1.17
[INFO] [stderr]    Compiling hyperlocal v0.9.1
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling reqwest v0.12.23
[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)]` 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)]` 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 41s
[INFO] running `Command { std: "docker" "inspect" "594690e9931e689b643fde07e5e02392b5993fed68f12dcfdb8310ff1bf83539", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "594690e9931e689b643fde07e5e02392b5993fed68f12dcfdb8310ff1bf83539", kill_on_drop: false }`
[INFO] [stdout] 594690e9931e689b643fde07e5e02392b5993fed68f12dcfdb8310ff1bf83539
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 13a0be36dfb17f1b94e2cd26dfa30a3fbdb4cdd5489e841690b24aee05b6f32b
[INFO] running `Command { std: "docker" "start" "-a" "13a0be36dfb17f1b94e2cd26dfa30a3fbdb4cdd5489e841690b24aee05b6f32b", kill_on_drop: false }`
[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)]` 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] [stderr]    Compiling tailscale-client v0.1.5 (/opt/rustwide/workdir)
[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)]` 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)]` 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)]` 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 11.29s
[INFO] running `Command { std: "docker" "inspect" "13a0be36dfb17f1b94e2cd26dfa30a3fbdb4cdd5489e841690b24aee05b6f32b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "13a0be36dfb17f1b94e2cd26dfa30a3fbdb4cdd5489e841690b24aee05b6f32b", kill_on_drop: false }`
[INFO] [stdout] 13a0be36dfb17f1b94e2cd26dfa30a3fbdb4cdd5489e841690b24aee05b6f32b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 5bfb63f8be3efd9f07a077db37d0b5a5cb90d26e5c0fbe51e154beea17cdc300
[INFO] running `Command { std: "docker" "start" "-a" "5bfb63f8be3efd9f07a077db37d0b5a5cb90d26e5c0fbe51e154beea17cdc300", 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)]` 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)]` 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: 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) generated 25 warnings (run `cargo fix --lib -p tailscale-client` to apply 3 suggestions)
[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.27s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/tailscale_client-34c3934af47d775e)
[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' panicked at src/lib.rs:467:52:
[INFO] [stdout] Please set TAILSCALE_API_KEY env var.: NotPresent
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x61a71cee58f2 - std::backtrace_rs::backtrace::libunwind::trace::h2d45396358f41939
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x61a71cee58f2 - std::backtrace_rs::backtrace::trace_unsynchronized::hffcefc0b67f1d6e2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x61a71cee58f2 - std::sys::backtrace::_print_fmt::hd72f71d23b436b92
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x61a71cee58f2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::hdcfcb6d4c8489523
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x61a71cf100d3 - core::fmt::rt::Argument::fmt::h2c56b3114963061a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x61a71cf100d3 - core::fmt::write::h8a494366950f23bb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x61a71cee1443 - std::io::default_write_fmt::h7b8824096454f323
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x61a71cee1443 - std::io::Write::write_fmt::h4e71294925c334d0
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x61a71cee5742 - std::sys::backtrace::BacktraceLock::print::hb2a626a81e06b2dc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x61a71cee7259 - std::panicking::default_hook::{{closure}}::h4f78485264f12d10
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x61a71cee708e - std::panicking::default_hook::h2c66fc99e962531d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x61a71c3fa344 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hb6bd65493727d71a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x61a71c3fa344 - test::test_main_with_exit_callback::{{closure}}::h60217ec76a0ece4a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x61a71cee7d2e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h318e4efb8c1a5689
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x61a71cee7d2e - std::panicking::rust_panic_with_hook::h33ac55f64bbd807d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x61a71cee79fa - std::panicking::begin_panic_handler::{{closure}}::h30e7cb89678a57fe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:706:13
[INFO] [stdout]   16:     0x61a71cee5df9 - std::sys::backtrace::__rust_end_short_backtrace::hed60f27456c16ced
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x61a71cee768d - __rustc[de2ca18b4c54d5b8]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x61a71cf0df70 - core::panicking::panic_fmt::h62f63d096dd276af
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x61a71cf0e486 - core::result::unwrap_failed::h95bc3f5a607b2c95
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/result.rs:1765:5
[INFO] [stdout]   20:     0x61a71c24eeee - core::result::Result<T,E>::expect::hd5e076ed0813752e
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/result.rs:1119:23
[INFO] [stdout]   21:     0x61a71c35372c - tailscale_client::test_tailscale_normal_in_docker::{{closure}}::h0668d5f0203fbbe9
[INFO] [stdout]                                at /opt/rustwide/workdir/src/lib.rs:467:52
[INFO] [stdout]   22:     0x61a71c274b95 - <core::pin::Pin<P> as core::future::future::Future>::poll::h673bf9f5ad049fb7
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x61a71c274acd - <core::pin::Pin<P> as core::future::future::Future>::poll::h3dcaadd1a19f6946
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x61a71c2744dd - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::{{closure}}::hc8515a5a13b895c9
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:70
[INFO] [stdout]   25:     0x61a71c2743cc - tokio::task::coop::with_budget::h63ebf8a9e3223263
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:167:5
[INFO] [stdout]   26:     0x61a71c2743cc - tokio::task::coop::budget::h5edfcb1a4aa50b3a
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:133:5
[INFO] [stdout]   27:     0x61a71c2743cc - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::h750082fc23d5b2d0
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:25
[INFO] [stdout]   28:     0x61a71c27163a - tokio::runtime::scheduler::current_thread::Context::enter::h9c6661e9c420928b
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:432:19
[INFO] [stdout]   29:     0x61a71c27388d - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::hae193125c50efee2
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:741:44
[INFO] [stdout]   30:     0x61a71c272a7b - tokio::runtime::scheduler::current_thread::CoreGuard::enter::{{closure}}::hefd5eb3172e64c97
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:68
[INFO] [stdout]   31:     0x61a71c33637a - tokio::runtime::context::scoped::Scoped<T>::set::h0345a82250111e35
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x61a71c25221a - tokio::runtime::context::set_scheduler::{{closure}}::h46ab6a42f1bfcad7
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:38
[INFO] [stdout]   33:     0x61a71c249f46 - std::thread::local::LocalKey<T>::try_with::hf342ce3a4de809fb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/local.rs:315:12
[INFO] [stdout]   34:     0x61a71c247e3c - std::thread::local::LocalKey<T>::with::h5e068394a1e1125c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/local.rs:279:20
[INFO] [stdout]   35:     0x61a71c252171 - tokio::runtime::context::set_scheduler::h1f438f9f6d7905bd
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:17
[INFO] [stdout]   36:     0x61a71c272369 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::h4ec0498d59d3e14c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:27
[INFO] [stdout]   37:     0x61a71c272b02 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::h628d56da82d36820
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:729:24
[INFO] [stdout]   38:     0x61a71c26f819 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::{{closure}}::h1b332e33d1f578de
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   39:     0x61a71c2f1090 - tokio::runtime::context::runtime::enter_runtime::h7f18cb1fa0ac762c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x61a71c26f5c1 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::hbd8fcdda8803e5ae
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   41:     0x61a71c282cef - tokio::runtime::runtime::Runtime::block_on_inner::hdee8a62c3c23650c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:356:52
[INFO] [stdout]   42:     0x61a71c283015 - tokio::runtime::runtime::Runtime::block_on::hd3788c7f2c264e55
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:330:18
[INFO] [stdout]   43:     0x61a71c3534ad - tailscale_client::test_tailscale_normal_in_docker::h2320037190b94f89
[INFO] [stdout]                                at /opt/rustwide/workdir/src/lib.rs:546:7
[INFO] [stdout]   44:     0x61a71c353327 - tailscale_client::test_tailscale_normal_in_docker::{{closure}}::h7c4578b9340f6de5
[INFO] [stdout]                                at /opt/rustwide/workdir/src/lib.rs:465:47
[INFO] [stdout]   45:     0x61a71c1fa976 - core::ops::function::FnOnce::call_once::h730a91399d2686ce
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   46:     0x61a71c3ffbab - core::ops::function::FnOnce::call_once::h1f9474f1347fff52
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   47:     0x61a71c3ffbab - test::__rust_begin_short_backtrace::ha52ab26e77157f03
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:648:18
[INFO] [stdout]   48:     0x61a71c3fece5 - test::run_test_in_process::{{closure}}::h229c1a11a50b261f
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:74
[INFO] [stdout]   49:     0x61a71c3fece5 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h78821afbf97b39a9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   50:     0x61a71c3fece5 - std::panicking::catch_unwind::do_call::h53abf3ed5bd32ba3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   51:     0x61a71c3fece5 - std::panicking::catch_unwind::h6deb5fe1e91873c9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   52:     0x61a71c3fece5 - std::panic::catch_unwind::hea0829b6b565654b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   53:     0x61a71c3fece5 - test::run_test_in_process::hdc44dfecea3db21b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:27
[INFO] [stdout]   54:     0x61a71c3fece5 - test::run_test::{{closure}}::h0364ba59bf23f652
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:592:43
[INFO] [stdout]   55:     0x61a71c3c28e4 - test::run_test::{{closure}}::h32730b304eec05da
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:622:41
[INFO] [stdout]   56:     0x61a71c3c28e4 - std::sys::backtrace::__rust_begin_short_backtrace::h177cb952fc54ad2c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   57:     0x61a71c3c62ba - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h119d903520007597
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   58:     0x61a71c3c62ba - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hab88401d606702a6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   59:     0x61a71c3c62ba - std::panicking::catch_unwind::do_call::h163fe12cca9901c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   60:     0x61a71c3c62ba - std::panicking::catch_unwind::he81557d0e17cc1bc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   61:     0x61a71c3c62ba - std::panic::catch_unwind::hc2b8e79c20593955
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   62:     0x61a71c3c62ba - std::thread::Builder::spawn_unchecked_::{{closure}}::hfa6b4978e07815cc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   63:     0x61a71c3c62ba - core::ops::function::FnOnce::call_once{{vtable.shim}}::hddcd7484a13fd793
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   64:     0x61a71ceeb05f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h5924238c754de3b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   65:     0x61a71ceeb05f - std::sys::pal::unix::thread::Thread::new::thread_start::hb6e99e73da4d28f8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/pal/unix/thread.rs:107:17
[INFO] [stdout]   66:     0x7b66049a7aa4 - <unknown>
[INFO] [stdout]   67:     0x7b6604a34a34 - 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.14s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "5bfb63f8be3efd9f07a077db37d0b5a5cb90d26e5c0fbe51e154beea17cdc300", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5bfb63f8be3efd9f07a077db37d0b5a5cb90d26e5c0fbe51e154beea17cdc300", kill_on_drop: false }`
[INFO] [stdout] 5bfb63f8be3efd9f07a077db37d0b5a5cb90d26e5c0fbe51e154beea17cdc300
