[INFO] fetching crate turbomcp-auth 3.1.1...
[INFO] testing turbomcp-auth-3.1.1 against beta-2026-04-21 for beta-1.96-2
[INFO] extracting crate turbomcp-auth 3.1.1 into /workspace/builds/worker-2-tc2/source
[INFO] started tweaking crates.io crate turbomcp-auth 3.1.1
[INFO] removed 0 missing examples
[INFO] removed 0 missing tests
[INFO] finished tweaking crates.io crate turbomcp-auth 3.1.1
[INFO] tweaked toml for crates.io crate turbomcp-auth 3.1.1 written to /workspace/builds/worker-2-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate turbomcp-auth 3.1.1 on toolchain beta-2026-04-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate turbomcp-auth 3.1.1 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 3d8edbc8d5acf5501ff178997fb689d1adb1516be00e8c88683c8181fbeb63f1
[INFO] running `Command { std: "docker" "start" "-a" "3d8edbc8d5acf5501ff178997fb689d1adb1516be00e8c88683c8181fbeb63f1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "3d8edbc8d5acf5501ff178997fb689d1adb1516be00e8c88683c8181fbeb63f1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3d8edbc8d5acf5501ff178997fb689d1adb1516be00e8c88683c8181fbeb63f1", kill_on_drop: false }`
[INFO] [stdout] 3d8edbc8d5acf5501ff178997fb689d1adb1516be00e8c88683c8181fbeb63f1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2410b6d04b9fbd38df79653c50870a234cd1a6cfa716f58e7322989088641805
[INFO] running `Command { std: "docker" "start" "-a" "2410b6d04b9fbd38df79653c50870a234cd1a6cfa716f58e7322989088641805", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling dunce v1.0.5
[INFO] [stderr]    Compiling fs_extra v1.3.0
[INFO] [stderr]    Compiling zerocopy v0.8.40
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling aws-lc-rs v1.16.3
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling socket2 v0.6.3
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling zerocopy-derive v0.8.40
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling untrusted v0.7.1
[INFO] [stderr]    Compiling simd-adler32 v0.3.8
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling rustls v0.23.38
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling brotli-decompressor v5.0.0
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling cc v1.2.56
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling compression-core v0.4.31
[INFO] [stderr]    Compiling ref-cast v1.0.25
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]    Compiling getrandom v0.4.2
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling ref-cast-impl v1.0.25
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling flate2 v1.1.9
[INFO] [stderr]    Compiling tokio v1.50.0
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling simdutf8 v0.1.5
[INFO] [stderr]    Compiling bitflags v2.11.0
[INFO] [stderr]    Compiling time-macros v0.2.27
[INFO] [stderr]    Compiling event-listener v5.4.1
[INFO] [stderr]    Compiling rand_core v0.9.5
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling float-cmp v0.10.0
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling portable-atomic v1.13.1
[INFO] [stderr]    Compiling rustls-native-certs v0.8.3
[INFO] [stderr]    Compiling num-bigint v0.4.6
[INFO] [stderr]    Compiling event-listener-strategy v0.5.4
[INFO] [stderr]    Compiling crossbeam-deque v0.8.6
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling brotli v8.0.2
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling cmake v0.1.57
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling sonic-simd v0.1.3
[INFO] [stderr]    Compiling sonic-number v0.1.1
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling async-lock v3.4.2
[INFO] [stderr]    Compiling crossbeam v0.8.4
[INFO] [stderr]    Compiling arc-swap v1.8.2
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling pem v3.0.6
[INFO] [stderr]    Compiling tagptr v0.2.0
[INFO] [stderr]    Compiling arrayref v0.3.9
[INFO] [stderr]    Compiling arrayvec v0.7.6
[INFO] [stderr]    Compiling time v0.3.47
[INFO] [stderr]    Compiling signature v2.2.0
[INFO] [stderr]    Compiling aws-lc-sys v0.40.0
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling blake3 v1.8.3
[INFO] [stderr]    Compiling futures-executor v0.3.32
[INFO] [stderr]    Compiling constant_time_eq v0.4.2
[INFO] [stderr]    Compiling futures v0.3.32
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling uuid v1.22.0
[INFO] [stderr]    Compiling serde_path_to_error v0.1.20
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling halfbrown v0.4.0
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling turbomcp-types v3.1.1
[INFO] [stderr]    Compiling compact_str v0.9.0
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling faststr v0.2.34
[INFO] [stderr]    Compiling serde_with_macros v3.18.0
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling value-trait v0.12.1
[INFO] [stderr]    Compiling secrecy v0.10.3
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling dashmap v6.1.0
[INFO] [stderr]    Compiling moka v0.12.14
[INFO] [stderr]    Compiling simple_asn1 v0.6.4
[INFO] [stderr]    Compiling simd-json v0.17.0
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling compression-codecs v0.4.37
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling serde_with v3.18.0
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling half v2.7.1
[INFO] [stderr]    Compiling sonic-rs v0.5.7
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling async-compression v0.4.41
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling ciborium-ll v0.2.2
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling ciborium v0.2.2
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling turbomcp-core v3.1.1
[INFO] [stderr]    Compiling turbomcp-protocol v3.1.1
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling rustls-webpki v0.103.12
[INFO] [stderr]    Compiling jsonwebtoken v10.3.0
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling rustls-platform-verifier v0.6.2
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling reqwest v0.13.2
[INFO] [stderr]    Compiling oauth2 v5.0.0
[INFO] [stderr]    Compiling turbomcp-auth v3.1.1 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 41s
[INFO] running `Command { std: "docker" "inspect" "2410b6d04b9fbd38df79653c50870a234cd1a6cfa716f58e7322989088641805", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2410b6d04b9fbd38df79653c50870a234cd1a6cfa716f58e7322989088641805", kill_on_drop: false }`
[INFO] [stdout] 2410b6d04b9fbd38df79653c50870a234cd1a6cfa716f58e7322989088641805
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7955884b03959c62d6bd88840be4c53822a64cacbe702c2fe15e6b062d311a15
[INFO] running `Command { std: "docker" "start" "-a" "7955884b03959c62d6bd88840be4c53822a64cacbe702c2fe15e6b062d311a15", kill_on_drop: false }`
[INFO] [stderr]    Compiling tokio v1.50.0
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling float-cmp v0.10.0
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling tempfile v3.26.0
[INFO] [stderr]    Compiling wait-timeout v0.2.1
[INFO] [stderr]    Compiling num_cpus v1.17.0
[INFO] [stderr]    Compiling bit-vec v0.8.0
[INFO] [stderr]    Compiling quick-error v1.2.3
[INFO] [stderr]    Compiling rand_xorshift v0.4.0
[INFO] [stderr]    Compiling assert-json-diff v2.0.2
[INFO] [stderr]    Compiling unarray v0.1.4
[INFO] [stderr]    Compiling bit-set v0.8.0
[INFO] [stderr]    Compiling value-trait v0.12.1
[INFO] [stderr]    Compiling rusty-fork v0.3.1
[INFO] [stderr]    Compiling proptest v1.10.0
[INFO] [stderr]    Compiling num-bigint v0.4.6
[INFO] [stderr]    Compiling simd-json v0.17.0
[INFO] [stderr]    Compiling simple_asn1 v0.6.4
[INFO] [stderr]    Compiling jsonwebtoken v10.3.0
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling async-compression v0.4.41
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]    Compiling deadpool v0.12.3
[INFO] [stderr]    Compiling tokio-test v0.4.5
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling turbomcp-core v3.1.1
[INFO] [stderr]    Compiling turbomcp-protocol v3.1.1
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling wiremock v0.6.5
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling reqwest v0.13.2
[INFO] [stderr]    Compiling oauth2 v5.0.0
[INFO] [stderr]    Compiling turbomcp-auth v3.1.1 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 54.26s
[INFO] running `Command { std: "docker" "inspect" "7955884b03959c62d6bd88840be4c53822a64cacbe702c2fe15e6b062d311a15", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7955884b03959c62d6bd88840be4c53822a64cacbe702c2fe15e6b062d311a15", kill_on_drop: false }`
[INFO] [stdout] 7955884b03959c62d6bd88840be4c53822a64cacbe702c2fe15e6b062d311a15
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 03b6af0a94a23d8c878dc7dac80ed57deef79193edd38e7787662a43cae1e3e8
[INFO] running `Command { std: "docker" "start" "-a" "03b6af0a94a23d8c878dc7dac80ed57deef79193edd38e7787662a43cae1e3e8", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.42s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/turbomcp_auth-e76c718827238031)
[INFO] [stdout] 
[INFO] [stdout] running 121 tests
[INFO] [stdout] test api_key_validation::tests::test_validate_empty_keys ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_short_keys_rejected ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_multiple_keys_empty_list ... ok
[INFO] [stdout] test api_key_validation::tests::test_blake3_hash_consistency ... ok
[INFO] [stdout] test api_key_validation::tests::test_blake3_hash_collision_resistance ... ok
[INFO] [stdout] test audit::tests::test_audit_logger_creation ... ok
[INFO] [stdout] test audit::tests::test_identifier_hashing ... ok
[INFO] [stdout] test audit::tests::test_ip_redaction ... ok
[INFO] [stdout] test audit::tests::test_privacy_focused_logger ... ok
[INFO] [stdout] test auth_metrics::tests::test_init_auth_metrics ... ok
[INFO] [stdout] test audit::tests::test_event_serialization ... ok
[INFO] [stdout] test audit::tests::test_audit_record_serialization ... ok
[INFO] [stdout] test auth_metrics::tests::test_no_op_functions_without_metrics ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_prefix_mismatch ... ok
[INFO] [stdout] test api_key_validation::tests::test_special_characters ... ok
[INFO] [stdout] test api_key_validation::tests::test_long_keys ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_suffix_mismatch ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_incorrect_key ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_multiple_keys_first_match ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_correct_key ... ok
[INFO] [stdout] test context::tests::test_builder_full ... ok
[INFO] [stdout] test context::tests::test_builder_minimal ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_multiple_keys_middle_match ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_multiple_keys_no_match ... ok
[INFO] [stdout] test api_key_validation::tests::test_unicode_keys ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_multiple_keys_last_match ... ok
[INFO] [stdout] test api_key_validation::tests::test_validate_case_sensitive ... ok
[INFO] [stdout] test context::tests::test_has_any_role ... ok
[INFO] [stdout] test context::tests::test_has_all_roles ... ok
[INFO] [stdout] test context::tests::test_has_permission ... ok
[INFO] [stdout] test context::tests::test_has_scope ... ok
[INFO] [stdout] test context::tests::test_is_expired ... ok
[INFO] [stdout] test context::tests::test_has_role ... ok
[INFO] [stdout] test context::tests::test_validation_audience ... ok
[INFO] [stdout] test context::tests::test_validation_expired ... ok
[INFO] [stdout] test context::tests::test_metadata ... ok
[INFO] [stdout] test context::tests::test_validation_not_yet_valid ... ok
[INFO] [stdout] test introspection::tests::test_introspection_response_inactive ... ok
[INFO] [stdout] test introspection::tests::test_introspection_response_active ... ok
[INFO] [stdout] test introspection::tests::test_introspection_response_full ... ok
[INFO] [stdout] test jwt::jwks::tests::test_cached_jwks_validity ... ok
[INFO] [stdout] test jwt::jwks::tests::test_cached_jwks_expired ... ok
[INFO] [stdout] test context::tests::test_jwt_serialization ... ok
[INFO] [stdout] test jwt::validator::tests::test_multi_issuer_validator_creation ... ok
[INFO] [stdout] test manager::tests::test_api_key_provider ... ok
[INFO] [stdout] test manager::tests::test_auth_manager ... ok
[INFO] [stdout] test oauth2::dcr::tests::test_dcr_builder_mcp_client ... ok
[INFO] [stdout] test oauth2::dcr::tests::test_dcr_builder_native_client ... ok
[INFO] [stdout] test oauth2::dcr::tests::test_registration_response_deserialization ... ok
[INFO] [stdout] test manager::tests::test_oauth2_pkce_integration ... ok
[INFO] [stdout] test manager::tests::test_oauth2_config ... ok
[INFO] [stdout] test oauth2::http_client::tests::test_error_display ... ok
[INFO] [stdout] test oauth2::resource::tests::test_fragment_rejected ... ok
[INFO] [stdout] test oauth2::resource::tests::test_http_non_localhost_rejected ... ok
[INFO] [stdout] test oauth2::resource::tests::test_invalid_scheme_rejected ... ok
[INFO] [stdout] test oauth2::resource::tests::test_localhost_http_allowed ... ok
[INFO] [stdout] test oauth2::resource::tests::test_missing_host_rejected ... ok
[INFO] [stdout] test oauth2::resource::tests::test_port_handling ... ok
[INFO] [stdout] test oauth2::resource::tests::test_mcp_examples ... ok
[INFO] [stdout] test oauth2::resource::tests::test_query_parameters_removed ... ok
[INFO] [stdout] test oauth2::resource::tests::test_uri_normalization ... ok
[INFO] [stdout] test oauth2::resource::tests::test_trailing_slash_removal ... ok
[INFO] [stdout] test oauth2::resource::tests::test_valid_https_uri ... ok
[INFO] [stdout] test oauth2::validation::tests::test_fragment_not_allowed ... ok
[INFO] [stdout] test oauth2::validation::tests::test_invalid_scheme ... ok
[INFO] [stdout] test oauth2::validation::tests::test_missing_host ... ok
[INFO] [stdout] test oauth2::validation::tests::test_non_canonical_uppercase_host ... ok
[INFO] [stdout] test oauth2::validation::tests::test_non_canonical_uppercase_scheme ... ok
[INFO] [stdout] test oauth2::validation::tests::test_oauth_state_validation_empty_expected ... ok
[INFO] [stdout] test oauth2::validation::tests::test_oauth_state_validation_case_sensitive ... ok
[INFO] [stdout] test oauth2::validation::tests::test_oauth_state_validation_empty_received ... ok
[INFO] [stdout] test oauth2::validation::tests::test_oauth_state_validation_mismatch ... ok
[INFO] [stdout] test oauth2::validation::tests::test_oauth_state_validation_success ... ok
[INFO] [stdout] test oauth2::validation::tests::test_valid_http_uri ... ok
[INFO] [stdout] test oauth2::validation::tests::test_valid_https_uri ... ok
[INFO] [stdout] test rate_limit::tests::test_get_usage ... ok
[INFO] [stdout] test rate_limit::tests::test_rate_limit_key_creation ... ok
[INFO] [stdout] test rate_limit::tests::test_rate_limiter_allows_burst ... ok
[INFO] [stdout] test rate_limit::tests::test_rate_limiter_allows_under_limit ... ok
[INFO] [stdout] test rate_limit::tests::test_rate_limiter_blocks_over_limit ... ok
[INFO] [stdout] test rate_limit::tests::test_rate_limiter_different_keys ... ok
[INFO] [stdout] test api_key_validation::tests::test_timing_attack_resistance ... ok
[INFO] [stdout] test rate_limit::tests::test_rate_limiter_disabled ... ok
[INFO] [stdout] test rate_limit::tests::test_rate_limiter_for_auth ... ok
[INFO] [stdout] test server::tests::test_audience_validation_case_insensitive ... ok
[INFO] [stdout] test rate_limit::tests::test_rate_limiter_reset ... ok
[INFO] [stdout] test server::tests::test_audience_validation_exact_match ... ok
[INFO] [stdout] test server::tests::test_audience_validation_default_ports ... ok
[INFO] [stdout] test server::tests::test_audience_validation_port_mismatch ... ok
[INFO] [stdout] test server::tests::test_audience_validation_path_significant ... ok
[INFO] [stdout] test server::tests::test_audience_validation_trailing_slash ... ok
[INFO] [stdout] test server::tests::test_bearer_token_extraction ... ok
[INFO] [stdout] test server::tests::test_bearer_token_extraction_case_insensitive ... ok
[INFO] [stdout] test server::tests::test_bearer_token_extraction_invalid_format ... ok
[INFO] [stdout] test server::tests::test_metadata_builder ... ok
[INFO] [stdout] test server::tests::test_normalize_resource_uri ... ok
[INFO] [stdout] test server::tests::test_www_authenticate_builder ... ok
[INFO] [stdout] test server::tests::test_unauthorized_response ... ok
[INFO] [stdout] test ssrf::tests::test_custom_policy_builder ... ok
[INFO] [stdout] test ssrf::tests::test_default_policy_allows_public_ip ... ok
[INFO] [stdout] test ssrf::tests::test_default_policy_blocks_cloud_metadata ... ok
[INFO] [stdout] test ssrf::tests::test_default_policy_blocks_localhost ... ok
[INFO] [stdout] test ssrf::tests::test_default_policy_blocks_private_networks ... ok
[INFO] [stdout] test ssrf::tests::test_ip_allowlist ... ok
[INFO] [stdout] test ssrf::tests::test_ipv6_unique_local_blocked ... ok
[INFO] [stdout] test ssrf::tests::test_link_local_blocked ... ok
[INFO] [stdout] test ssrf::tests::test_url_validation_requires_https ... ok
[INFO] [stdout] test introspection::tests::test_introspection_client_creation ... ok
[INFO] [stdout] test jwt::validator::tests::test_multi_issuer_validator_add_issuer ... ok
[INFO] [stdout] test jwt::validator::tests::test_jwt_validator_creation_with_jwks_uri ... ok
[INFO] [stdout] test oauth2::http_client::tests::test_client_creation ... ok
[INFO] [stdout] test oauth2::http_client::tests::test_default ... ok
[INFO] [stdout] test jwt::jwks::tests::test_jwks_cache_creation ... ok
[INFO] [stdout] test oauth2::dcr::tests::test_dcr_client_creation ... ok
[INFO] [stdout] test jwt::validator::tests::test_jwt_validator_custom_clock_skew ... ok
[INFO] [stdout] test jwt::validator::tests::test_jwt_validator_custom_algorithms ... ok
[INFO] [stdout] test jwt::jwks::tests::test_jwks_client_with_custom_ttl ... ok
[INFO] [stdout] test jwt::jwks::tests::test_jwks_client_creation ... ok
[INFO] [stdout] test jwt::jwks::tests::test_clear_cache ... ok
[INFO] [stdout] test providers::oauth2::tests::test_oauth2_provider_creation ... ok
[INFO] [stdout] test jwt::jwks::tests::test_jwks_cache_different_issuers ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 121 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.34s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/dpop_integration.rs (/opt/rustwide/target/debug/deps/dpop_integration-af99303ddb2e378c)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stderr]      Running tests/jwks_caching_robustness.rs (/opt/rustwide/target/debug/deps/jwks_caching_robustness-2ce41def49aa5452)
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 10 tests
[INFO] [stdout] test common::tests::test_current_timestamp ... ok
[INFO] [stdout] test common::tests::test_sha256_hash ... ok
[INFO] [stdout] test common::tests::test_mock_server_startup ... ok
[INFO] [stdout] test test_concurrent_jwks_cache_access ... ok
[INFO] [stdout] test test_cache_invalidation_on_signature_failure ... ok
[INFO] [stdout] test test_jwks_cache_hit_rate_performance ... ok
[INFO] [stdout] test test_key_rotation_with_grace_period ... ok
[INFO] [stdout] test test_jwks_cache_control_headers ... ok
[INFO] [stdout] test test_jwks_fallback_to_cache_on_endpoint_failure ... ok
[INFO] [stdout] test test_jwks_cache_ttl_refresh has been running for over 60 seconds
[INFO] [stdout] test test_jwks_cache_ttl_refresh ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 10 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 61.10s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/jwt_validation_edge_cases.rs (/opt/rustwide/target/debug/deps/jwt_validation_edge_cases-da18d66ae20b7f9c)
[INFO] [stdout] 
[INFO] [stdout] running 13 tests
[INFO] [stdout] test common::tests::test_current_timestamp ... ok
[INFO] [stdout] test common::tests::test_sha256_hash ... ok
[INFO] [stdout] test common::tests::test_mock_server_startup ... ok
[INFO] [stdout] test test_algorithm_mismatch ... ok
[INFO] [stdout] test test_nbf_claim_validation ... ok
[INFO] [stdout] test test_issuer_validation ... ok
[INFO] [stdout] test test_jwt_expiration_boundary ... ok
[INFO] [stdout] test test_audience_claim_variations ... ok
[INFO] [stdout] test test_clock_skew_tolerance ... ok
[INFO] [stdout] test test_far_future_expiration ... ok
[INFO] [stdout] test test_missing_expiration ... ok
[INFO] [stdout] test test_missing_required_claims ... ok
[INFO] [stdout] test test_expired_token ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 13 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/multi_provider_scenarios.rs (/opt/rustwide/target/debug/deps/multi_provider_scenarios-8c56099217ada496)
[INFO] [stdout] 
[INFO] [stdout] running 16 tests
[INFO] [stdout] test common::tests::test_sha256_hash ... ok
[INFO] [stdout] test common::tests::test_current_timestamp ... ok
[INFO] [stdout] test test_per_provider_rate_limiting ... ok
[INFO] [stdout] test test_issuer_specific_validation_rules ... ok
[INFO] [stdout] test common::tests::test_mock_server_startup ... ok
[INFO] [stdout] test test_all_new_providers_oauth2_1_features ... ok
[INFO] [stdout] test test_okta_enterprise_oauth2_1_support ... ok
[INFO] [stdout] test test_keycloak_oidc_provider_oauth2_1_support ... ok
[INFO] [stdout] test test_provider_specific_error_formats ... ok
[INFO] [stdout] test test_cross_provider_token_isolation ... ok
[INFO] [stdout] test test_per_provider_jwks_configuration ... ok
[INFO] [stdout] test test_apple_signin_oauth2_1_support ... ok
[INFO] [stdout] test test_auth0_identity_platform_oauth2_1_support ... ok
[INFO] [stdout] test test_concurrent_jwks_fetching_multi_provider ... ok
[INFO] [stdout] test test_provider_failover ... ok
[INFO] [stdout] test test_concurrent_multi_provider_authentication ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 16 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.49s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/oauth2_flow_integration.rs (/opt/rustwide/target/debug/deps/oauth2_flow_integration-2f66b5f31f812c0c)
[INFO] [stdout] 
[INFO] [stdout] running 11 tests
[INFO] [stdout] test common::tests::test_sha256_hash ... ok
[INFO] [stdout] test common::tests::test_current_timestamp ... ok
[INFO] [stdout] test common::tests::test_mock_server_startup ... ok
[INFO] [stdout] test test_oauth2_refresh_token_flow ... ok
[INFO] [stdout] test test_oauth2_client_credentials_flow ... ok
[INFO] [stdout] test test_oauth2_scope_handling ... ok
[INFO] [stdout] test test_oauth2_token_exchange_invalid_code ... ok
[INFO] [stdout] test test_oauth2_missing_required_parameters ... ok
[INFO] [stdout] test test_oauth2_authorization_redirect ... ok
[INFO] [stdout] test test_oauth2_token_exchange_success ... ok
[INFO] [stdout] test test_oauth2_pkce_code_challenge_validation ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 11 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.44s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/security_attack_scenarios.rs (/opt/rustwide/target/debug/deps/security_attack_scenarios-a226cfa8b69a09f7)
[INFO] [stdout] 
[INFO] [stdout] running 11 tests
[INFO] [stdout] test common::tests::test_current_timestamp ... ok
[INFO] [stdout] test test_reject_jwk_injection_in_access_token ... ok
[INFO] [stdout] test test_token_type_confusion_attack ... ok
[INFO] [stdout] test common::tests::test_sha256_hash ... ok
[INFO] [stdout] test test_jsonwebtoken_rejects_none_algorithm ... ok
[INFO] [stdout] test test_replay_attack_prevention_with_jti ... ok
[INFO] [stdout] test common::tests::test_mock_server_startup ... ok
[INFO] [stdout] test test_scope_escalation_prevention ... ok
[INFO] [stdout] test test_pkce_downgrade_attack_prevention ... ok
[INFO] [stdout] test test_redirect_uri_validation ... ok
[INFO] [stdout] test test_authorization_code_single_use ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 11 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.26s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/token_lifecycle.rs (/opt/rustwide/target/debug/deps/token_lifecycle-34caeb01c49a9ff9)
[INFO] [stdout] 
[INFO] [stdout] running 9 tests
[INFO] [stdout] test common::tests::test_current_timestamp ... ok
[INFO] [stdout] test common::tests::test_sha256_hash ... ok
[INFO] [stdout] test common::tests::test_mock_server_startup ... ok
[INFO] [stdout] test test_token_revocation_rfc7009 ... ok
[INFO] [stdout] test test_token_lifetime_best_practices ... ok
[INFO] [stdout] test test_refresh_token_rotation_grace_period ... ok
[INFO] [stdout] test test_automatic_token_refresh_before_expiration ... ok
[INFO] [stdout] test test_revocation_propagates_to_access_tokens ... ok
[INFO] [stdout] test test_refresh_token_rotation_single_use ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 9 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.39s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests turbomcp_auth
[INFO] [stdout] 
[INFO] [stdout] running 45 tests
[INFO] [stdout] test src/auth_metrics.rs - auth_metrics (line 15) ... ignored
[INFO] [stdout] test src/context.rs - context::AuthContext (line 77) ... ignored
[INFO] [stdout] test src/context.rs - context::AuthContext::get_metadata (line 421) ... ignored
[INFO] [stdout] test src/context.rs - context::AuthContext::to_jwt_claims (line 264) ... ignored
[INFO] [stdout] test src/context.rs - context::AuthContextBuilder (line 547) ... ignored
[INFO] [stdout] test src/introspection.rs - introspection::IntrospectionClient (line 121) - compile ... ok
[INFO] [stdout] test src/introspection.rs - introspection::IntrospectionClient::introspect (line 228) - compile ... ok
[INFO] [stdout] test src/introspection.rs - introspection::IntrospectionClient::is_token_active (line 299) - compile ... ok
[INFO] [stdout] test src/jwt/jwks.rs - jwt::jwks::JwksCache (line 328) - compile ... ok
[INFO] [stdout] test src/api_key_validation.rs - api_key_validation::validate_api_key_multiple (line 150) ... ok
[INFO] [stdout] test src/api_key_validation.rs - api_key_validation (line 28) ... ok
[INFO] [stdout] test src/jwt/jwks.rs - jwt::jwks::JwksClient (line 51) - compile ... ok
[INFO] [stdout] test src/jwt/validator.rs - jwt::validator::JwtValidator (line 60) - compile ... ok
[INFO] [stdout] test src/jwt/validator.rs - jwt::validator::JwtValidator::new (line 229) - compile ... ok
[INFO] [stdout] test src/jwt/validator.rs - jwt::validator::JwtValidator::validate (line 411) - compile ... ok
[INFO] [stdout] test src/oauth2/client.rs - oauth2::client::OAuth2Client::authorization_code_flow (line 419) ... ignored
[INFO] [stdout] test src/oauth2/client.rs - oauth2::client::OAuth2Client::refresh_access_token (line 512) ... ignored
[INFO] [stdout] test src/oauth2/client.rs - oauth2::client::OAuth2Client::revoke_token (line 601) ... ignored
[INFO] [stdout] test src/audit.rs - audit (line 28) ... ok
[INFO] [stdout] test src/api_key_validation.rs - api_key_validation::validate_api_key (line 92) ... ok
[INFO] [stdout] test src/introspection.rs - introspection (line 15) - compile ... ok
[INFO] [stdout] test src/jwt/validator.rs - jwt::validator::MultiIssuerValidator (line 569) - compile ... ok
[INFO] [stdout] test src/jwt/validator.rs - jwt::validator::MultiIssuerValidator::add_issuer (line 612) - compile ... ok
[INFO] [stdout] test src/manager.rs - manager::AuthManager::validate_token (line 183) - compile ... ok
[INFO] [stdout] test src/oauth2/dcr.rs - oauth2::dcr (line 21) - compile ... ok
[INFO] [stdout] test src/oauth2/dcr.rs - oauth2::dcr::DcrClient (line 174) - compile ... ok
[INFO] [stdout] test src/oauth2/dcr.rs - oauth2::dcr::DcrBuilder (line 387) ... ok
[INFO] [stdout] test src/lib.rs - (line 37) ... ok
[INFO] [stdout] test src/oauth2/validation.rs - oauth2::validation::validate_oauth_state (line 108) ... ignored
[INFO] [stdout] test src/manager.rs - manager (line 13) - compile ... ok
[INFO] [stdout] test src/oauth2/dcr.rs - oauth2::dcr::DcrClient::register (line 259) - compile ... ok
[INFO] [stdout] test src/manager.rs - manager::AuthManager::authenticate (line 110) - compile ... ok
[INFO] [stdout] test src/oauth2/dcr.rs - oauth2::dcr::DcrClient::update (line 305) - compile ... ok
[INFO] [stdout] test src/rate_limit.rs - rate_limit (line 24) - compile ... ok
[INFO] [stdout] test src/server.rs - server::BearerTokenValidator::extract_from_header (line 181) - compile ... ok
[INFO] [stdout] test src/ssrf.rs - ssrf (line 30) ... ignored
[INFO] [stdout] test src/ssrf.rs - ssrf::SsrfValidator::create_pinned_client (line 569) ... ignored
[INFO] [stdout] test src/ssrf.rs - ssrf::SsrfValidator::fetch (line 668) ... ignored
[INFO] [stdout] test src/server.rs - server::validate_audience (line 265) ... ok
[INFO] [stdout] test src/oauth2/resource.rs - oauth2::resource::validate_resource_uri (line 57) ... ok
[INFO] [stdout] test src/rate_limit.rs - rate_limit (line 54) ... ok
[INFO] [stdout] test src/jwt/jwks.rs - jwt::jwks::JwksClient::new (line 98) ... ok
[INFO] [stdout] test src/jwt/validator.rs - jwt::validator::JwtValidator::with_jwks_uri (line 308) ... ok
[INFO] [stdout] test src/introspection.rs - introspection::IntrospectionClient::new (line 182) ... ok
[INFO] [stdout] test src/oauth2/dcr.rs - oauth2::dcr::DcrClient::new (line 217) ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 33 passed; 0 failed; 12 ignored; 0 measured; 0 filtered out; finished in 0.18s
[INFO] [stdout] 
[INFO] [stdout] all doctests ran in 4.07s; merged doctests compilation took 3.81s
[INFO] running `Command { std: "docker" "inspect" "03b6af0a94a23d8c878dc7dac80ed57deef79193edd38e7787662a43cae1e3e8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "03b6af0a94a23d8c878dc7dac80ed57deef79193edd38e7787662a43cae1e3e8", kill_on_drop: false }`
[INFO] [stdout] 03b6af0a94a23d8c878dc7dac80ed57deef79193edd38e7787662a43cae1e3e8
