[INFO] fetching crate baltic-id 0.0.2... [INFO] testing baltic-id-0.0.2 against try#c2e32f1c9652b13ed99608599c1e855462f421f3 for pr-146098-7 [INFO] extracting crate baltic-id 0.0.2 into /workspace/builds/worker-2-tc2/source [INFO] started tweaking crates.io crate baltic-id 0.0.2 [INFO] finished tweaking crates.io crate baltic-id 0.0.2 [INFO] tweaked toml for crates.io crate baltic-id 0.0.2 written to /workspace/builds/worker-2-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate baltic-id 0.0.2 on toolchain c2e32f1c9652b13ed99608599c1e855462f421f3 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 220 packages to latest compatible versions [INFO] [stderr] Adding base64 v0.21.7 (available: v0.22.1) [INFO] [stderr] Adding rand v0.8.5 (available: v0.9.2) [INFO] [stderr] Adding reqwest v0.11.27 (available: v0.12.24) [INFO] [stderr] Adding strum v0.24.1 (available: v0.27.2) [INFO] [stderr] Adding thiserror v1.0.69 (available: v2.0.17) [INFO] [stderr] Adding x509-parser v0.15.1 (available: v0.18.0) [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] efc3a4b764fe834ee15afef091c65a32b2d8497df8829d2dc4323836c7d3c52f [INFO] running `Command { std: "docker" "start" "-a" "efc3a4b764fe834ee15afef091c65a32b2d8497df8829d2dc4323836c7d3c52f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "efc3a4b764fe834ee15afef091c65a32b2d8497df8829d2dc4323836c7d3c52f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "efc3a4b764fe834ee15afef091c65a32b2d8497df8829d2dc4323836c7d3c52f", kill_on_drop: false }` [INFO] [stdout] efc3a4b764fe834ee15afef091c65a32b2d8497df8829d2dc4323836c7d3c52f [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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 6e6807e320e92f3fb84dd345244dbc3db67891b2c4a66020f2e1307228af0784 [INFO] running `Command { std: "docker" "start" "-a" "6e6807e320e92f3fb84dd345244dbc3db67891b2c4a66020f2e1307228af0784", kill_on_drop: false }` [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling syn v2.0.110 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling lock_api v0.4.14 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling time-macros v0.2.24 [INFO] [stderr] Compiling nom v7.1.3 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling tracing v0.1.41 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling asn1-rs-derive v0.4.0 [INFO] [stderr] Compiling asn1-rs-impl v0.1.0 [INFO] [stderr] Compiling getrandom v0.2.16 [INFO] [stderr] Compiling oid-registry v0.6.1 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling num-integer v0.1.46 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling heck v0.4.1 [INFO] [stderr] Compiling time v0.3.44 [INFO] [stderr] Compiling anyhow v1.0.100 [INFO] [stderr] Compiling num-bigint v0.4.6 [INFO] [stderr] Compiling strum_macros v0.24.3 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling serde_json v1.0.145 [INFO] [stderr] Compiling rusticata-macros v4.1.0 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling encoding_rs v0.8.35 [INFO] [stderr] Compiling data-encoding v2.9.0 [INFO] [stderr] Compiling iana-time-zone v0.1.64 [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling strum v0.24.1 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling regex v1.12.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling tokio v1.48.0 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling asn1-rs v0.5.2 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling der-parser v8.2.0 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling x509-parser v0.15.1 [INFO] [stderr] Compiling icu_properties v2.1.1 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling chrono v0.4.42 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling url v2.5.7 [INFO] [stderr] Compiling tokio-util v0.7.17 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling h2 v0.3.27 [INFO] [stderr] Compiling hyper v0.14.32 [INFO] [stderr] Compiling hyper-tls v0.5.0 [INFO] [stderr] Compiling reqwest v0.11.27 [INFO] [stderr] Compiling baltic-id v0.0.2 (/opt/rustwide/workdir) [INFO] [stdout] warning: use of deprecated associated function `chrono::NaiveDateTime::from_timestamp_opt`: use `DateTime::from_timestamp` instead [INFO] [stdout] --> src/smart_id/utils/certificate_attributes.rs:16:45 [INFO] [stdout] | [INFO] [stdout] 16 | let naive_datetime = NaiveDateTime::from_timestamp_opt(timestamp, 0).unwrap(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated associated function `chrono::DateTime::::from_utc`: Use TimeZone::from_utc_datetime() or DateTime::from_naive_utc_and_offset instead [INFO] [stdout] --> src/smart_id/utils/certificate_attributes.rs:17:41 [INFO] [stdout] | [INFO] [stdout] 17 | let datetime = DateTime::::from_utc(naive_datetime, Utc); [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/smart_id/models.rs:388:13 [INFO] [stdout] | [INFO] [stdout] 388 | _ => panic!("Unsupported hash type: {}", hash_type), [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/smart_id/models.rs:388:13 [INFO] [stdout] | [INFO] [stdout] 383 | HashType::Md5 => MessageDigest::md5(), [INFO] [stdout] | ------------- matches some of the same values [INFO] [stdout] 384 | HashType::Sha1 => MessageDigest::sha1(), [INFO] [stdout] | -------------- matches some of the same values [INFO] [stdout] 385 | HashType::Sha256 => MessageDigest::sha256(), [INFO] [stdout] | ---------------- matches some of the same values [INFO] [stdout] 386 | HashType::Sha384 => MessageDigest::sha384(), [INFO] [stdout] | ---------------- matches some of the same values [INFO] [stdout] 387 | HashType::Sha512 => MessageDigest::sha512(), [INFO] [stdout] 388 | _ => panic!("Unsupported hash type: {}", hash_type), [INFO] [stdout] | ^ ...and 1 other patterns collectively make this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/smart_id/mod.rs:365:17 [INFO] [stdout] | [INFO] [stdout] 365 | _ => Err(TechnicalError( [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/smart_id/mod.rs:365:17 [INFO] [stdout] | [INFO] [stdout] 340 | SessionEndResultCode::UserRefused => Err(UserRefusedException), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 341 | SessionEndResultCode::Timeout => Err(SessionTimeoutException), [INFO] [stdout] | ----------------------------- matches some of the same values [INFO] [stdout] 342 | SessionEndResultCode::DocumentUnusable => Err(DocumentUnusableException), [INFO] [stdout] | -------------------------------------- matches some of the same values [INFO] [stdout] 343 | SessionEndResultCode::RequiredInteractionNotSupportedByApp => { [INFO] [stdout] | ---------------------------------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 365 | _ => Err(TechnicalError( [INFO] [stdout] | ^ ...and 7 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `ssl_keys` is never read [INFO] [stdout] --> src/smart_id/mod.rs:26:5 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct SmartIdClient { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 26 | ssl_keys: Vec, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `authenticate` is never used [INFO] [stdout] --> src/smart_id/mod.rs:125:14 [INFO] [stdout] | [INFO] [stdout] 40 | impl SmartIdClient { [INFO] [stdout] | ------------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 125 | async fn authenticate( [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AuthenticationResponseValidator` is never constructed [INFO] [stdout] --> src/smart_id/authentication_response_validator.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 21 | pub struct AuthenticationResponseValidator { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/smart_id/authentication_response_validator.rs:26:12 [INFO] [stdout] | [INFO] [stdout] 25 | impl AuthenticationResponseValidator { [INFO] [stdout] | ------------------------------------ associated items in this implementation [INFO] [stdout] 26 | pub fn new(resources_location: Option<&str>) -> Result { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 39 | pub fn validate( [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 82 | fn validate_authentication_response( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 104 | fn verify_response_end_result( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 111 | fn verify_signature( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 124 | fn verify_certificate_expiry( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 133 | fn verify_certificate_level( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 143 | fn construct_authentication_identity( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 181 | fn initialize_trusted_ca_certificates_from_resources( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 198 | fn is_certificate_trusted(&self, certificate: String) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 215 | fn get_date_of_birth( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/smart_id/models.rs:83:5 [INFO] [stdout] | [INFO] [stdout] 82 | pub struct AuthenticationCertificateExtensions { [INFO] [stdout] | ----------------------------------- fields in this struct [INFO] [stdout] 83 | basic_constraints: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 84 | key_usage: String, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 85 | certificate_policies: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 86 | subject_key_identifier: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 87 | qc_statements: String, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 88 | authority_key_identifier: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 89 | authority_info_access: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 90 | extended_key_usage: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 91 | subject_alt_name: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/smart_id/models.rs:353:48 [INFO] [stdout] | [INFO] [stdout] 353 | pub fn parse_x509_certificate(certificate: &[u8]) -> Result { [INFO] [stdout] | ^^^^^ ^^^^^^^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 353 | pub fn parse_x509_certificate(certificate: &[u8]) -> Result, anyhow::Error> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 41s [INFO] running `Command { std: "docker" "inspect" "6e6807e320e92f3fb84dd345244dbc3db67891b2c4a66020f2e1307228af0784", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6e6807e320e92f3fb84dd345244dbc3db67891b2c4a66020f2e1307228af0784", kill_on_drop: false }` [INFO] [stdout] 6e6807e320e92f3fb84dd345244dbc3db67891b2c4a66020f2e1307228af0784 [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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 3b528d68d8a8c9b538ced5984e65b96fc0da985e9299bad5c6fca9b7d8ed9fb7 [INFO] running `Command { std: "docker" "start" "-a" "3b528d68d8a8c9b538ced5984e65b96fc0da985e9299bad5c6fca9b7d8ed9fb7", kill_on_drop: false }` [INFO] [stderr] Compiling baltic-id v0.0.2 (/opt/rustwide/workdir) [INFO] [stdout] warning: use of deprecated associated function `chrono::NaiveDateTime::from_timestamp_opt`: use `DateTime::from_timestamp` instead [INFO] [stdout] --> src/smart_id/utils/certificate_attributes.rs:16:45 [INFO] [stdout] | [INFO] [stdout] 16 | let naive_datetime = NaiveDateTime::from_timestamp_opt(timestamp, 0).unwrap(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated associated function `chrono::DateTime::::from_utc`: Use TimeZone::from_utc_datetime() or DateTime::from_naive_utc_and_offset instead [INFO] [stdout] --> src/smart_id/utils/certificate_attributes.rs:17:41 [INFO] [stdout] | [INFO] [stdout] 17 | let datetime = DateTime::::from_utc(naive_datetime, Utc); [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/smart_id/models.rs:388:13 [INFO] [stdout] | [INFO] [stdout] 388 | _ => panic!("Unsupported hash type: {}", hash_type), [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/smart_id/models.rs:388:13 [INFO] [stdout] | [INFO] [stdout] 383 | HashType::Md5 => MessageDigest::md5(), [INFO] [stdout] | ------------- matches some of the same values [INFO] [stdout] 384 | HashType::Sha1 => MessageDigest::sha1(), [INFO] [stdout] | -------------- matches some of the same values [INFO] [stdout] 385 | HashType::Sha256 => MessageDigest::sha256(), [INFO] [stdout] | ---------------- matches some of the same values [INFO] [stdout] 386 | HashType::Sha384 => MessageDigest::sha384(), [INFO] [stdout] | ---------------- matches some of the same values [INFO] [stdout] 387 | HashType::Sha512 => MessageDigest::sha512(), [INFO] [stdout] 388 | _ => panic!("Unsupported hash type: {}", hash_type), [INFO] [stdout] | ^ ...and 1 other patterns collectively make this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/smart_id/mod.rs:365:17 [INFO] [stdout] | [INFO] [stdout] 365 | _ => Err(TechnicalError( [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/smart_id/mod.rs:365:17 [INFO] [stdout] | [INFO] [stdout] 340 | SessionEndResultCode::UserRefused => Err(UserRefusedException), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 341 | SessionEndResultCode::Timeout => Err(SessionTimeoutException), [INFO] [stdout] | ----------------------------- matches some of the same values [INFO] [stdout] 342 | SessionEndResultCode::DocumentUnusable => Err(DocumentUnusableException), [INFO] [stdout] | -------------------------------------- matches some of the same values [INFO] [stdout] 343 | SessionEndResultCode::RequiredInteractionNotSupportedByApp => { [INFO] [stdout] | ---------------------------------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 365 | _ => Err(TechnicalError( [INFO] [stdout] | ^ ...and 7 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `ssl_keys` is never read [INFO] [stdout] --> src/smart_id/mod.rs:26:5 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct SmartIdClient { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 26 | ssl_keys: Vec, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `authenticate` is never used [INFO] [stdout] --> src/smart_id/mod.rs:125:14 [INFO] [stdout] | [INFO] [stdout] 40 | impl SmartIdClient { [INFO] [stdout] | ------------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 125 | async fn authenticate( [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AuthenticationResponseValidator` is never constructed [INFO] [stdout] --> src/smart_id/authentication_response_validator.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 21 | pub struct AuthenticationResponseValidator { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/smart_id/authentication_response_validator.rs:26:12 [INFO] [stdout] | [INFO] [stdout] 25 | impl AuthenticationResponseValidator { [INFO] [stdout] | ------------------------------------ associated items in this implementation [INFO] [stdout] 26 | pub fn new(resources_location: Option<&str>) -> Result { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 39 | pub fn validate( [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 82 | fn validate_authentication_response( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 104 | fn verify_response_end_result( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 111 | fn verify_signature( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 124 | fn verify_certificate_expiry( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 133 | fn verify_certificate_level( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 143 | fn construct_authentication_identity( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 181 | fn initialize_trusted_ca_certificates_from_resources( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 198 | fn is_certificate_trusted(&self, certificate: String) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 215 | fn get_date_of_birth( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/smart_id/models.rs:83:5 [INFO] [stdout] | [INFO] [stdout] 82 | pub struct AuthenticationCertificateExtensions { [INFO] [stdout] | ----------------------------------- fields in this struct [INFO] [stdout] 83 | basic_constraints: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 84 | key_usage: String, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 85 | certificate_policies: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 86 | subject_key_identifier: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 87 | qc_statements: String, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 88 | authority_key_identifier: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 89 | authority_info_access: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 90 | extended_key_usage: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 91 | subject_alt_name: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/smart_id/models.rs:353:48 [INFO] [stdout] | [INFO] [stdout] 353 | pub fn parse_x509_certificate(certificate: &[u8]) -> Result { [INFO] [stdout] | ^^^^^ ^^^^^^^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 353 | pub fn parse_x509_certificate(certificate: &[u8]) -> Result, anyhow::Error> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 2.23s [INFO] running `Command { std: "docker" "inspect" "3b528d68d8a8c9b538ced5984e65b96fc0da985e9299bad5c6fca9b7d8ed9fb7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "3b528d68d8a8c9b538ced5984e65b96fc0da985e9299bad5c6fca9b7d8ed9fb7", kill_on_drop: false }` [INFO] [stdout] 3b528d68d8a8c9b538ced5984e65b96fc0da985e9299bad5c6fca9b7d8ed9fb7 [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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 2ac5c3cabfdce7bddc88d3a781282277b6dbbc035639230eada9c1294372c1be [INFO] running `Command { std: "docker" "start" "-a" "2ac5c3cabfdce7bddc88d3a781282277b6dbbc035639230eada9c1294372c1be", kill_on_drop: false }` [INFO] [stderr] warning: use of deprecated associated function `chrono::NaiveDateTime::from_timestamp_opt`: use `DateTime::from_timestamp` instead [INFO] [stderr] --> src/smart_id/utils/certificate_attributes.rs:16:45 [INFO] [stderr] | [INFO] [stderr] 16 | let naive_datetime = NaiveDateTime::from_timestamp_opt(timestamp, 0).unwrap(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated associated function `chrono::DateTime::::from_utc`: Use TimeZone::from_utc_datetime() or DateTime::from_naive_utc_and_offset instead [INFO] [stderr] --> src/smart_id/utils/certificate_attributes.rs:17:41 [INFO] [stderr] | [INFO] [stderr] 17 | let datetime = DateTime::::from_utc(naive_datetime, Utc); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/smart_id/models.rs:388:13 [INFO] [stderr] | [INFO] [stderr] 388 | _ => panic!("Unsupported hash type: {}", hash_type), [INFO] [stderr] | ^ no value can reach this [INFO] [stderr] | [INFO] [stderr] note: multiple earlier patterns match some of the same values [INFO] [stderr] --> src/smart_id/models.rs:388:13 [INFO] [stderr] | [INFO] [stderr] 383 | HashType::Md5 => MessageDigest::md5(), [INFO] [stderr] | ------------- matches some of the same values [INFO] [stderr] 384 | HashType::Sha1 => MessageDigest::sha1(), [INFO] [stderr] | -------------- matches some of the same values [INFO] [stderr] 385 | HashType::Sha256 => MessageDigest::sha256(), [INFO] [stderr] | ---------------- matches some of the same values [INFO] [stderr] 386 | HashType::Sha384 => MessageDigest::sha384(), [INFO] [stderr] | ---------------- matches some of the same values [INFO] [stderr] 387 | HashType::Sha512 => MessageDigest::sha512(), [INFO] [stderr] 388 | _ => panic!("Unsupported hash type: {}", hash_type), [INFO] [stderr] | ^ ...and 1 other patterns collectively make this unreachable [INFO] [stderr] = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/smart_id/mod.rs:365:17 [INFO] [stderr] | [INFO] [stderr] 365 | _ => Err(TechnicalError( [INFO] [stderr] | ^ no value can reach this [INFO] [stderr] | [INFO] [stderr] note: multiple earlier patterns match some of the same values [INFO] [stderr] --> src/smart_id/mod.rs:365:17 [INFO] [stderr] | [INFO] [stderr] 340 | SessionEndResultCode::UserRefused => Err(UserRefusedException), [INFO] [stderr] | --------------------------------- matches some of the same values [INFO] [stderr] 341 | SessionEndResultCode::Timeout => Err(SessionTimeoutException), [INFO] [stderr] | ----------------------------- matches some of the same values [INFO] [stderr] 342 | SessionEndResultCode::DocumentUnusable => Err(DocumentUnusableException), [INFO] [stderr] | -------------------------------------- matches some of the same values [INFO] [stderr] 343 | SessionEndResultCode::RequiredInteractionNotSupportedByApp => { [INFO] [stderr] | ---------------------------------------------------------- matches some of the same values [INFO] [stderr] ... [INFO] [stderr] 365 | _ => Err(TechnicalError( [INFO] [stderr] | ^ ...and 7 other patterns collectively make this unreachable [INFO] [stderr] [INFO] [stderr] warning: field `ssl_keys` is never read [INFO] [stderr] --> src/smart_id/mod.rs:26:5 [INFO] [stderr] | [INFO] [stderr] 22 | pub struct SmartIdClient { [INFO] [stderr] | ------------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 26 | ssl_keys: Vec, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: method `authenticate` is never used [INFO] [stderr] --> src/smart_id/mod.rs:125:14 [INFO] [stderr] | [INFO] [stderr] 40 | impl SmartIdClient { [INFO] [stderr] | ------------------ method in this implementation [INFO] [stderr] ... [INFO] [stderr] 125 | async fn authenticate( [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `AuthenticationResponseValidator` is never constructed [INFO] [stderr] --> src/smart_id/authentication_response_validator.rs:21:12 [INFO] [stderr] | [INFO] [stderr] 21 | pub struct AuthenticationResponseValidator { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: multiple associated items are never used [INFO] [stderr] --> src/smart_id/authentication_response_validator.rs:26:12 [INFO] [stderr] | [INFO] [stderr] 25 | impl AuthenticationResponseValidator { [INFO] [stderr] | ------------------------------------ associated items in this implementation [INFO] [stderr] 26 | pub fn new(resources_location: Option<&str>) -> Result { [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 39 | pub fn validate( [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 82 | fn validate_authentication_response( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 104 | fn verify_response_end_result( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 111 | fn verify_signature( [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 124 | fn verify_certificate_expiry( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 133 | fn verify_certificate_level( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 143 | fn construct_authentication_identity( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 181 | fn initialize_trusted_ca_certificates_from_resources( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 198 | fn is_certificate_trusted(&self, certificate: String) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 215 | fn get_date_of_birth( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: multiple fields are never read [INFO] [stderr] --> src/smart_id/models.rs:83:5 [INFO] [stderr] | [INFO] [stderr] 82 | pub struct AuthenticationCertificateExtensions { [INFO] [stderr] | ----------------------------------- fields in this struct [INFO] [stderr] 83 | basic_constraints: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] 84 | key_usage: String, [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] 85 | certificate_policies: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 86 | subject_key_identifier: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 87 | qc_statements: String, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] 88 | authority_key_identifier: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 89 | authority_info_access: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 90 | extended_key_usage: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 91 | subject_alt_name: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stderr] --> src/smart_id/models.rs:353:48 [INFO] [stderr] | [INFO] [stderr] 353 | pub fn parse_x509_certificate(certificate: &[u8]) -> Result { [INFO] [stderr] | ^^^^^ ^^^^^^^^^^^^^^^ the same lifetime is hidden here [INFO] [stderr] | | [INFO] [stderr] | the lifetime is elided here [INFO] [stderr] | [INFO] [stderr] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stderr] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stderr] help: use `'_` for type paths [INFO] [stderr] | [INFO] [stderr] 353 | pub fn parse_x509_certificate(certificate: &[u8]) -> Result, anyhow::Error> { [INFO] [stderr] | ++++ [INFO] [stderr] [INFO] [stderr] warning: `baltic-id` (lib test) generated 10 warnings (run `cargo fix --lib -p baltic-id --tests` to apply 1 suggestion) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.29s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/baltic_id-a973fd95a41312c4) [INFO] [stdout] [INFO] [stdout] running 3 tests [INFO] [stdout] test smart_id::models::authentication_hash_tests::generate_random_hash_of_type_sha384 ... ok [INFO] [stdout] test smart_id::models::authentication_hash_tests::generate_random_hash_of_type_sha512 ... ok [INFO] [stdout] test smart_id::models::authentication_hash_tests::generate_random_hash_of_type_sha256 ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "2ac5c3cabfdce7bddc88d3a781282277b6dbbc035639230eada9c1294372c1be", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2ac5c3cabfdce7bddc88d3a781282277b6dbbc035639230eada9c1294372c1be", kill_on_drop: false }` [INFO] [stdout] 2ac5c3cabfdce7bddc88d3a781282277b6dbbc035639230eada9c1294372c1be