[INFO] fetching crate nettu_scheduler_domain 0.6.0... [INFO] testing nettu_scheduler_domain-0.6.0 against master#350d0ef0ec0493e6d21cfb265cb8211a0e74d766 for pr-145330-1 [INFO] extracting crate nettu_scheduler_domain 0.6.0 into /workspace/builds/worker-7-tc1/source [INFO] started tweaking crates.io crate nettu_scheduler_domain 0.6.0 [INFO] finished tweaking crates.io crate nettu_scheduler_domain 0.6.0 [INFO] tweaked toml for crates.io crate nettu_scheduler_domain 0.6.0 written to /workspace/builds/worker-7-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate nettu_scheduler_domain 0.6.0 on toolchain 350d0ef0ec0493e6d21cfb265cb8211a0e74d766 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "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" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 104 packages to latest compatible versions [INFO] [stderr] Adding chrono-tz v0.5.3 (available: v0.10.4) [INFO] [stderr] Adding itertools v0.10.5 (available: v0.14.0) [INFO] [stderr] Adding jsonwebtoken v7.2.0 (available: v10.0.0) [INFO] [stderr] Adding rand v0.8.5 (available: v0.9.2) [INFO] [stderr] Adding rrule v0.5.9 (available: v0.14.0) [INFO] [stderr] Adding thiserror v1.0.69 (available: v2.0.17) [INFO] [stderr] Adding uuid v0.8.2 (available: v1.18.1) [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded nettu_scheduler_utils v0.6.0 [INFO] [stderr] Downloaded rrule v0.5.9 [INFO] [stderr] Downloaded parse-zoneinfo v0.3.1 [INFO] [stderr] Downloaded chrono-tz v0.5.3 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] e13b61da84bf32ce53fc43897630a8dcc1f9a5c3a15f7064de4f7abecde80102 [INFO] running `Command { std: "docker" "start" "-a" "e13b61da84bf32ce53fc43897630a8dcc1f9a5c3a15f7064de4f7abecde80102", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "e13b61da84bf32ce53fc43897630a8dcc1f9a5c3a15f7064de4f7abecde80102", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e13b61da84bf32ce53fc43897630a8dcc1f9a5c3a15f7064de4f7abecde80102", kill_on_drop: false }` [INFO] [stdout] e13b61da84bf32ce53fc43897630a8dcc1f9a5c3a15f7064de4f7abecde80102 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 4024a317af25311d05719e66144e450be031c6b68651860a7fbbf00fa1a2ef5c [INFO] running `Command { std: "docker" "start" "-a" "4024a317af25311d05719e66144e450be031c6b68651860a7fbbf00fa1a2ef5c", kill_on_drop: false }` [INFO] [stderr] Compiling syn v2.0.106 [INFO] [stderr] Compiling parse-zoneinfo v0.3.1 [INFO] [stderr] Compiling num-bigint v0.2.6 [INFO] [stderr] Compiling ring v0.16.20 [INFO] [stderr] Compiling num-integer v0.1.46 [INFO] [stderr] Compiling percent-encoding v2.3.2 [INFO] [stderr] Compiling spin v0.5.2 [INFO] [stderr] Compiling untrusted v0.7.1 [INFO] [stderr] Compiling pem v0.8.3 [INFO] [stderr] Compiling serde_json v1.0.145 [INFO] [stderr] Compiling form_urlencoded v1.2.2 [INFO] [stderr] Compiling base64 v0.12.3 [INFO] [stderr] Compiling nettu_scheduler_utils v0.6.0 [INFO] [stderr] Compiling uuid v0.8.2 [INFO] [stderr] Compiling chrono-tz v0.5.3 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.0 [INFO] [stderr] Compiling zerovec-derive v0.11.1 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.0 [INFO] [stderr] Compiling zerovec v0.11.4 [INFO] [stderr] Compiling zerotrie v0.2.2 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling tinystr v0.8.1 [INFO] [stderr] Compiling potential_utf v0.1.3 [INFO] [stderr] Compiling icu_locale_core v2.0.0 [INFO] [stderr] Compiling icu_collections v2.0.0 [INFO] [stderr] Compiling icu_provider v2.0.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling icu_normalizer v2.0.0 [INFO] [stderr] Compiling icu_properties v2.0.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 simple_asn1 v0.4.1 [INFO] [stderr] Compiling jsonwebtoken v7.2.0 [INFO] [stderr] Compiling rrule v0.5.9 [INFO] [stderr] Compiling nettu_scheduler_domain v0.6.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime` instead [INFO] [stdout] --> src/schedule.rs:295:38 [INFO] [stdout] | [INFO] [stdout] 295 | pub fn date(&self, tzid: &Tz) -> Date { [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/booking_slots.rs:76:29 [INFO] [stdout] | [INFO] [stdout] 76 | let first_date = tz.timestamp_millis(slots[0].start); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/booking_slots.rs:81:48 [INFO] [stdout] | [INFO] [stdout] 81 | let current_date = format_date(&tz.timestamp_millis(current_date.start)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/booking_slots.rs:213:25 [INFO] [stdout] | [INFO] [stdout] 213 | let start_date = tz.ymd( [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stdout] --> src/booking_slots.rs:218:31 [INFO] [stdout] | [INFO] [stdout] 218 | let start_ts = start_date.and_hms(0, 0, 0).timestamp_millis(); [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/booking_slots.rs:219:23 [INFO] [stdout] | [INFO] [stdout] 219 | let end_date = tz.ymd(parsed_end_date.0, parsed_end_date.1, parsed_end_date.2); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stdout] --> src/booking_slots.rs:220:27 [INFO] [stdout] | [INFO] [stdout] 220 | let end_ts = end_date.and_hms(0, 0, 0).timestamp_millis() + 1000 * 60 * 60 * 24; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/event.rs:120:35 [INFO] [stdout] | [INFO] [stdout] 120 | let exdate = tzid.timestamp_millis(*exdate); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::datetime_from_str`: use `DateTime::parse_from_str` or `NaiveDateTime::parse_from_str` with `and_utc()` or `and_local_timezone()` instead [INFO] [stdout] --> src/providers/outlook.rs:26:14 [INFO] [stdout] | [INFO] [stdout] 26 | .datetime_from_str( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stdout] --> src/providers/outlook.rs:35:37 [INFO] [stdout] | [INFO] [stdout] 35 | .unwrap_or_else(|_| UTC.timestamp(0, 0)) [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:47:38 [INFO] [stdout] | [INFO] [stdout] 47 | let min_date = self.timezone.ymd(now.year(), now.month(), now.day()) - Duration::days(2); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:48:38 [INFO] [stdout] | [INFO] [stdout] 48 | let max_date = self.timezone.ymd(min_date.year() + 5, 1, 1); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:131:25 [INFO] [stdout] | [INFO] [stdout] 131 | let date = tzid.ymd(day.year, day.month, day.day); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:296:14 [INFO] [stdout] | [INFO] [stdout] 296 | tzid.ymd(self.year, self.month, self.day) [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/schedule.rs:324:35 [INFO] [stdout] | [INFO] [stdout] 324 | let start = self.timezone.timestamp_millis(timespan.start()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/schedule.rs:325:33 [INFO] [stdout] | [INFO] [stdout] 325 | let end = self.timezone.timestamp_millis(timespan.end()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stdout] --> src/shared/recurrence.rs:84:50 [INFO] [stdout] | [INFO] [stdout] 84 | let until = self.until.map(|ts| timezone.timestamp(ts as i64 / 1000, 0)); [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stdout] --> src/shared/recurrence.rs:86:32 [INFO] [stdout] | [INFO] [stdout] 86 | let dtstart = timezone.timestamp(start_ts / 1000, 0); [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/timespan.rs:31:12 [INFO] [stdout] | [INFO] [stdout] 31 | tz.timestamp_millis(timestamp_millis) [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/account.rs:64:29 [INFO] [stdout] | [INFO] [stdout] 64 | if let Some(mut webhook_settings) = self.webhook.as_mut() { [INFO] [stdout] | ----^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `InvalidTimeSpanError` is never constructed [INFO] [stdout] --> src/timespan.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 51 | pub struct InvalidTimeSpanError(i64, i64); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 48.85s [INFO] running `Command { std: "docker" "inspect" "4024a317af25311d05719e66144e450be031c6b68651860a7fbbf00fa1a2ef5c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4024a317af25311d05719e66144e450be031c6b68651860a7fbbf00fa1a2ef5c", kill_on_drop: false }` [INFO] [stdout] 4024a317af25311d05719e66144e450be031c6b68651860a7fbbf00fa1a2ef5c [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] fdb73e9f74df1d0ca7f0b036c7cbd4aeeb00c2d22ce0e1386d4b19a36fe25db7 [INFO] running `Command { std: "docker" "start" "-a" "fdb73e9f74df1d0ca7f0b036c7cbd4aeeb00c2d22ce0e1386d4b19a36fe25db7", kill_on_drop: false }` [INFO] [stderr] Compiling nettu_scheduler_domain v0.6.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime` instead [INFO] [stdout] --> src/schedule.rs:295:38 [INFO] [stdout] | [INFO] [stdout] 295 | pub fn date(&self, tzid: &Tz) -> Date { [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/booking_slots.rs:76:29 [INFO] [stdout] | [INFO] [stdout] 76 | let first_date = tz.timestamp_millis(slots[0].start); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/booking_slots.rs:81:48 [INFO] [stdout] | [INFO] [stdout] 81 | let current_date = format_date(&tz.timestamp_millis(current_date.start)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/booking_slots.rs:213:25 [INFO] [stdout] | [INFO] [stdout] 213 | let start_date = tz.ymd( [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stdout] --> src/booking_slots.rs:218:31 [INFO] [stdout] | [INFO] [stdout] 218 | let start_ts = start_date.and_hms(0, 0, 0).timestamp_millis(); [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/booking_slots.rs:219:23 [INFO] [stdout] | [INFO] [stdout] 219 | let end_date = tz.ymd(parsed_end_date.0, parsed_end_date.1, parsed_end_date.2); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stdout] --> src/booking_slots.rs:220:27 [INFO] [stdout] | [INFO] [stdout] 220 | let end_ts = end_date.and_hms(0, 0, 0).timestamp_millis() + 1000 * 60 * 60 * 24; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/event.rs:120:35 [INFO] [stdout] | [INFO] [stdout] 120 | let exdate = tzid.timestamp_millis(*exdate); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::datetime_from_str`: use `DateTime::parse_from_str` or `NaiveDateTime::parse_from_str` with `and_utc()` or `and_local_timezone()` instead [INFO] [stdout] --> src/providers/outlook.rs:26:14 [INFO] [stdout] | [INFO] [stdout] 26 | .datetime_from_str( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stdout] --> src/providers/outlook.rs:35:37 [INFO] [stdout] | [INFO] [stdout] 35 | .unwrap_or_else(|_| UTC.timestamp(0, 0)) [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:47:38 [INFO] [stdout] | [INFO] [stdout] 47 | let min_date = self.timezone.ymd(now.year(), now.month(), now.day()) - Duration::days(2); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:48:38 [INFO] [stdout] | [INFO] [stdout] 48 | let max_date = self.timezone.ymd(min_date.year() + 5, 1, 1); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:131:25 [INFO] [stdout] | [INFO] [stdout] 131 | let date = tzid.ymd(day.year, day.month, day.day); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:296:14 [INFO] [stdout] | [INFO] [stdout] 296 | tzid.ymd(self.year, self.month, self.day) [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/schedule.rs:324:35 [INFO] [stdout] | [INFO] [stdout] 324 | let start = self.timezone.timestamp_millis(timespan.start()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/schedule.rs:325:33 [INFO] [stdout] | [INFO] [stdout] 325 | let end = self.timezone.timestamp_millis(timespan.end()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stdout] --> src/shared/recurrence.rs:84:50 [INFO] [stdout] | [INFO] [stdout] 84 | let until = self.until.map(|ts| timezone.timestamp(ts as i64 / 1000, 0)); [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stdout] --> src/shared/recurrence.rs:86:32 [INFO] [stdout] | [INFO] [stdout] 86 | let dtstart = timezone.timestamp(start_ts / 1000, 0); [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/timespan.rs:31:12 [INFO] [stdout] | [INFO] [stdout] 31 | tz.timestamp_millis(timestamp_millis) [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/account.rs:64:29 [INFO] [stdout] | [INFO] [stdout] 64 | if let Some(mut webhook_settings) = self.webhook.as_mut() { [INFO] [stdout] | ----^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `InvalidTimeSpanError` is never constructed [INFO] [stdout] --> src/timespan.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 51 | pub struct InvalidTimeSpanError(i64, i64); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime` instead [INFO] [stdout] --> src/schedule.rs:295:38 [INFO] [stdout] | [INFO] [stdout] 295 | pub fn date(&self, tzid: &Tz) -> Date { [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/booking_slots.rs:76:29 [INFO] [stdout] | [INFO] [stdout] 76 | let first_date = tz.timestamp_millis(slots[0].start); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/booking_slots.rs:81:48 [INFO] [stdout] | [INFO] [stdout] 81 | let current_date = format_date(&tz.timestamp_millis(current_date.start)); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/booking_slots.rs:213:25 [INFO] [stdout] | [INFO] [stdout] 213 | let start_date = tz.ymd( [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stdout] --> src/booking_slots.rs:218:31 [INFO] [stdout] | [INFO] [stdout] 218 | let start_ts = start_date.and_hms(0, 0, 0).timestamp_millis(); [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/booking_slots.rs:219:23 [INFO] [stdout] | [INFO] [stdout] 219 | let end_date = tz.ymd(parsed_end_date.0, parsed_end_date.1, parsed_end_date.2); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stdout] --> src/booking_slots.rs:220:27 [INFO] [stdout] | [INFO] [stdout] 220 | let end_ts = end_date.and_hms(0, 0, 0).timestamp_millis() + 1000 * 60 * 60 * 24; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/event.rs:120:35 [INFO] [stdout] | [INFO] [stdout] 120 | let exdate = tzid.timestamp_millis(*exdate); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/event.rs:249:29 [INFO] [stdout] | [INFO] [stdout] 249 | until: Some(Utc.ymd(2150, 1, 1).and_hms(0, 0, 0).timestamp_millis() as isize), // too big until [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stdout] --> src/event.rs:249:45 [INFO] [stdout] | [INFO] [stdout] 249 | until: Some(Utc.ymd(2150, 1, 1).and_hms(0, 0, 0).timestamp_millis() as isize), // too big until [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::datetime_from_str`: use `DateTime::parse_from_str` or `NaiveDateTime::parse_from_str` with `and_utc()` or `and_local_timezone()` instead [INFO] [stdout] --> src/providers/outlook.rs:26:14 [INFO] [stdout] | [INFO] [stdout] 26 | .datetime_from_str( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stdout] --> src/providers/outlook.rs:35:37 [INFO] [stdout] | [INFO] [stdout] 35 | .unwrap_or_else(|_| UTC.timestamp(0, 0)) [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:47:38 [INFO] [stdout] | [INFO] [stdout] 47 | let min_date = self.timezone.ymd(now.year(), now.month(), now.day()) - Duration::days(2); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:48:38 [INFO] [stdout] | [INFO] [stdout] 48 | let max_date = self.timezone.ymd(min_date.year() + 5, 1, 1); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:131:25 [INFO] [stdout] | [INFO] [stdout] 131 | let date = tzid.ymd(day.year, day.month, day.day); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:296:14 [INFO] [stdout] | [INFO] [stdout] 296 | tzid.ymd(self.year, self.month, self.day) [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/schedule.rs:324:35 [INFO] [stdout] | [INFO] [stdout] 324 | let start = self.timezone.timestamp_millis(timespan.start()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/schedule.rs:325:33 [INFO] [stdout] | [INFO] [stdout] 325 | let end = self.timezone.timestamp_millis(timespan.end()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stdout] --> src/schedule.rs:644:28 [INFO] [stdout] | [INFO] [stdout] 644 | let noon_utc = Utc.ymd(2021, 4, 1).and_hms(0, 0, 0).timestamp_millis(); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stdout] --> src/schedule.rs:644:44 [INFO] [stdout] | [INFO] [stdout] 644 | let noon_utc = Utc.ymd(2021, 4, 1).and_hms(0, 0, 0).timestamp_millis(); [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stdout] --> src/shared/recurrence.rs:84:50 [INFO] [stdout] | [INFO] [stdout] 84 | let until = self.until.map(|ts| timezone.timestamp(ts as i64 / 1000, 0)); [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stdout] --> src/shared/recurrence.rs:86:32 [INFO] [stdout] | [INFO] [stdout] 86 | let dtstart = timezone.timestamp(start_ts / 1000, 0); [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stdout] --> src/timespan.rs:31:12 [INFO] [stdout] | [INFO] [stdout] 31 | tz.timestamp_millis(timestamp_millis) [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/account.rs:64:29 [INFO] [stdout] | [INFO] [stdout] 64 | if let Some(mut webhook_settings) = self.webhook.as_mut() { [INFO] [stdout] | ----^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `InvalidTimeSpanError` is never constructed [INFO] [stdout] --> src/timespan.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 51 | pub struct InvalidTimeSpanError(i64, i64); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 4.18s [INFO] running `Command { std: "docker" "inspect" "fdb73e9f74df1d0ca7f0b036c7cbd4aeeb00c2d22ce0e1386d4b19a36fe25db7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "fdb73e9f74df1d0ca7f0b036c7cbd4aeeb00c2d22ce0e1386d4b19a36fe25db7", kill_on_drop: false }` [INFO] [stdout] fdb73e9f74df1d0ca7f0b036c7cbd4aeeb00c2d22ce0e1386d4b19a36fe25db7 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 61aadc5627b3a8ec33ecd7069deef8ecf6b77ad7a0a575f3061ca8621d98ece3 [INFO] running `Command { std: "docker" "start" "-a" "61aadc5627b3a8ec33ecd7069deef8ecf6b77ad7a0a575f3061ca8621d98ece3", kill_on_drop: false }` [INFO] [stderr] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime` instead [INFO] [stderr] --> src/schedule.rs:295:38 [INFO] [stderr] | [INFO] [stderr] 295 | pub fn date(&self, tzid: &Tz) -> Date { [INFO] [stderr] | ^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stderr] --> src/booking_slots.rs:76:29 [INFO] [stderr] | [INFO] [stderr] 76 | let first_date = tz.timestamp_millis(slots[0].start); [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stderr] --> src/booking_slots.rs:81:48 [INFO] [stderr] | [INFO] [stderr] 81 | let current_date = format_date(&tz.timestamp_millis(current_date.start)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stderr] --> src/booking_slots.rs:213:25 [INFO] [stderr] | [INFO] [stderr] 213 | let start_date = tz.ymd( [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stderr] --> src/booking_slots.rs:218:31 [INFO] [stderr] | [INFO] [stderr] 218 | let start_ts = start_date.and_hms(0, 0, 0).timestamp_millis(); [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stderr] --> src/booking_slots.rs:219:23 [INFO] [stderr] | [INFO] [stderr] 219 | let end_date = tz.ymd(parsed_end_date.0, parsed_end_date.1, parsed_end_date.2); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stderr] --> src/booking_slots.rs:220:27 [INFO] [stderr] | [INFO] [stderr] 220 | let end_ts = end_date.and_hms(0, 0, 0).timestamp_millis() + 1000 * 60 * 60 * 24; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stderr] --> src/event.rs:120:35 [INFO] [stderr] | [INFO] [stderr] 120 | let exdate = tzid.timestamp_millis(*exdate); [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::datetime_from_str`: use `DateTime::parse_from_str` or `NaiveDateTime::parse_from_str` with `and_utc()` or `and_local_timezone()` instead [INFO] [stderr] --> src/providers/outlook.rs:26:14 [INFO] [stderr] | [INFO] [stderr] 26 | .datetime_from_str( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stderr] --> src/providers/outlook.rs:35:37 [INFO] [stderr] | [INFO] [stderr] 35 | .unwrap_or_else(|_| UTC.timestamp(0, 0)) [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stderr] --> src/schedule.rs:47:38 [INFO] [stderr] | [INFO] [stderr] 47 | let min_date = self.timezone.ymd(now.year(), now.month(), now.day()) - Duration::days(2); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stderr] --> src/schedule.rs:48:38 [INFO] [stderr] | [INFO] [stderr] 48 | let max_date = self.timezone.ymd(min_date.year() + 5, 1, 1); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stderr] --> src/schedule.rs:131:25 [INFO] [stderr] | [INFO] [stderr] 131 | let date = tzid.ymd(day.year, day.month, day.day); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stderr] --> src/schedule.rs:296:14 [INFO] [stderr] | [INFO] [stderr] 296 | tzid.ymd(self.year, self.month, self.day) [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stderr] --> src/schedule.rs:324:35 [INFO] [stderr] | [INFO] [stderr] 324 | let start = self.timezone.timestamp_millis(timespan.start()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stderr] --> src/schedule.rs:325:33 [INFO] [stderr] | [INFO] [stderr] 325 | let end = self.timezone.timestamp_millis(timespan.end()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stderr] --> src/shared/recurrence.rs:84:50 [INFO] [stderr] | [INFO] [stderr] 84 | let until = self.until.map(|ts| timezone.timestamp(ts as i64 / 1000, 0)); [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::timestamp`: use `timestamp_opt()` instead [INFO] [stderr] --> src/shared/recurrence.rs:86:32 [INFO] [stderr] | [INFO] [stderr] 86 | let dtstart = timezone.timestamp(start_ts / 1000, 0); [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::timestamp_millis`: use `timestamp_millis_opt()` instead [INFO] [stderr] --> src/timespan.rs:31:12 [INFO] [stderr] | [INFO] [stderr] 31 | tz.timestamp_millis(timestamp_millis) [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/account.rs:64:29 [INFO] [stderr] | [INFO] [stderr] 64 | if let Some(mut webhook_settings) = self.webhook.as_mut() { [INFO] [stderr] | ----^^^^^^^^^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct `InvalidTimeSpanError` is never constructed [INFO] [stderr] --> src/timespan.rs:51:12 [INFO] [stderr] | [INFO] [stderr] 51 | pub struct InvalidTimeSpanError(i64, i64); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stderr] --> src/event.rs:249:29 [INFO] [stderr] | [INFO] [stderr] 249 | until: Some(Utc.ymd(2150, 1, 1).and_hms(0, 0, 0).timestamp_millis() as isize), // too big until [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stderr] --> src/event.rs:249:45 [INFO] [stderr] | [INFO] [stderr] 249 | until: Some(Utc.ymd(2150, 1, 1).and_hms(0, 0, 0).timestamp_millis() as isize), // too big until [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead [INFO] [stderr] --> src/schedule.rs:644:28 [INFO] [stderr] | [INFO] [stderr] 644 | let noon_utc = Utc.ymd(2021, 4, 1).and_hms(0, 0, 0).timestamp_millis(); [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated method `chrono::Date::::and_hms`: Use and_hms_opt() instead [INFO] [stderr] --> src/schedule.rs:644:44 [INFO] [stderr] | [INFO] [stderr] 644 | let noon_utc = Utc.ymd(2021, 4, 1).and_hms(0, 0, 0).timestamp_millis(); [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `nettu_scheduler_domain` (lib) generated 21 warnings (run `cargo fix --lib -p nettu_scheduler_domain` to apply 1 suggestion) [INFO] [stderr] warning: `nettu_scheduler_domain` (lib test) generated 25 warnings (21 duplicates) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.19s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/nettu_scheduler_domain-2b4637a768b8cc69) [INFO] [stdout] [INFO] [stdout] running 55 tests [INFO] [stdout] test account::test::it_creates_account ... ok [INFO] [stdout] test booking_slots::test::generate_service_bookingslots_with_two_users_in_service ... ok [INFO] [stdout] test booking_slots::test::get_booking_slots_from_many_events ... ok [INFO] [stdout] test booking_slots::test::generate_service_bookingslots_with_one_user_in_service ... ok [INFO] [stdout] test booking_slots::test::get_booking_slots_from_one_event_1 ... ok [INFO] [stdout] test booking_slots::test::get_booking_slots_from_one_event_3 ... ok [INFO] [stdout] test booking_slots::test::get_booking_slots_from_one_event_2 ... ok [INFO] [stdout] test booking_slots::test::slot_that_crosses_end ... ok [INFO] [stdout] test booking_slots::test::slot_that_crosses_start ... ok [INFO] [stdout] test booking_slots::test::slot_that_fits_right_at_end ... ok [INFO] [stdout] test booking_slots::test::get_booking_slots_empty ... ok [INFO] [stdout] test event::test::calendar_event_without_recurrence ... ok [INFO] [stdout] test event::test::allows_event_with_valid_recurrence ... ok [INFO] [stdout] test date::test::it_accepts_valid_dates ... ok [INFO] [stdout] test event::test::rejects_event_with_invalid_recurrence ... ok [INFO] [stdout] test event_instance::test::combining_events::no_overlap ... ok [INFO] [stdout] test event_instance::test::combining_events::overlap_with_extending ... ok [INFO] [stdout] test event::test::daily_calendar_event ... ok [INFO] [stdout] test event_instance::test::combining_events::overlap_without_extending ... ok [INFO] [stdout] test event_instance::test::combining_events::remove_busy_from_free_complete_overlap ... ok [INFO] [stdout] test event_instance::test::combining_events::remove_busy_from_free_complete_partial_split_in_1 ... ok [INFO] [stdout] test event_instance::test::combining_events::remove_busy_from_free_complete_partial_split_in_2 ... ok [INFO] [stdout] test event_instance::test::combining_events::remove_busy_from_free_no_overlap ... ok [INFO] [stdout] test event_instance::test::compatible_events_test_1 ... ok [INFO] [stdout] test event_instance::test::compatible_events_test_2 ... ok [INFO] [stdout] test event_instance::test::another_free_busy ... ok [INFO] [stdout] test event_instance::test::compatible_events_test_4 ... ok [INFO] [stdout] test event_instance::test::compatible_events_test_3 ... ok [INFO] [stdout] test event_instance::test::compatible_events_test_5 ... ok [INFO] [stdout] test event_instance::test::compatible_events_test_6 ... ok [INFO] [stdout] test event_instance::test::no_free_event ... ok [INFO] [stdout] test event_instance::test::remove_busy_from_free_test_1 ... ok [INFO] [stdout] test event_instance::test::remove_busy_from_free_test_2 ... ok [INFO] [stdout] test event_instance::test::removes_all_after ... ok [INFO] [stdout] test event_instance::test::removes_all_before ... ok [INFO] [stdout] test event_instance::test::simple_freebusy ... ok [INFO] [stdout] test event_instance::test::single_event ... ok [INFO] [stdout] test schedule::test::day_sanity_tests ... ok [INFO] [stdout] test schedule::test::it_computes_freebusy_for_schedule ... ok [INFO] [stdout] test schedule::test::it_parses_intervals_for_rule ... ok [INFO] [stdout] test schedule::test::schedule_freebusy ... ok [INFO] [stdout] test schedule::test::schedule_freebusy_2 ... ok [INFO] [stdout] test scheduling::round_robin::tests::round_robin_availability_assignment ... ok [INFO] [stdout] test scheduling::round_robin::tests::round_robin_availability_assignment_2 ... ok [INFO] [stdout] test scheduling::round_robin::tests::round_robin_availability_assignment_without_members ... ok [INFO] [stdout] test booking_slots::test::get_booking_slots_from_two_events ... ok [INFO] [stdout] test scheduling::round_robin::tests::round_robin_eq_distribution_assignment_without_members ... ok [INFO] [stdout] test shared::recurrence::test::parses_invalid_weekday_str_correctly ... ok [INFO] [stdout] test shared::recurrence::test::parses_valid_weekday_str_correctly ... ok [INFO] [stdout] test scheduling::round_robin::tests::round_robin_eq_distribution_assignment ... ok [INFO] [stdout] test shared::recurrence::test::serializes_weekday ... ok [INFO] [stdout] test booking_slots::test::groups_bookingslots_by_date ... ok [INFO] [stdout] test account::test::it_accepts_valid_public_key ... FAILED [INFO] [stdout] test date::test::it_rejects_invalid_dates ... ok [INFO] [stdout] test account::test::it_rejects_invalid_public_key ... ok [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- account::test::it_accepts_valid_public_key stdout ---- [INFO] [stdout] [INFO] [stdout] thread 'account::test::it_accepts_valid_public_key' (17) panicked at src/account.rs:140:78: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: Os { code: 2, kind: NotFound, message: "No such file or directory" } [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x56c5bac30272 - std::backtrace_rs::backtrace::libunwind::trace::h0fb8082ca5562a61 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x56c5bac30272 - std::backtrace_rs::backtrace::trace_unsynchronized::hfaa258994374a3cd [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x56c5bac30272 - std::sys::backtrace::_print_fmt::h11496fe34963a885 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x56c5bac30272 - ::fmt::hff1a9408d012ee89 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x56c5bac545ef - core::fmt::rt::Argument::fmt::hf11195b61445f5d1 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x56c5bac545ef - core::fmt::write::h2f1fc679f228cc52 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x56c5bac1bc13 - std::io::default_write_fmt::h12bd533187bc883d [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x56c5bac1bc13 - std::io::Write::write_fmt::h926a1fdfdcb90065 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x56c5bac300c2 - std::sys::backtrace::BacktraceLock::print::h28bfdbcac6d3828b [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x56c5bac1a37c - std::panicking::default_hook::{{closure}}::h1f968e3a24b0e3b4 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x56c5bac1a1f9 - std::panicking::default_hook::h43da101644971931 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x56c5ba89638e - as core::ops::function::Fn>::call::h4b2012949041da5d [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 12: 0x56c5ba89638e - test::test_main_with_exit_callback::{{closure}}::h53c9154cdc260357 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x56c5bac1a983 - as core::ops::function::Fn>::call::h911f2e3e7e84b764 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 14: 0x56c5bac1a983 - std::panicking::panic_with_hook::hb4e916c3e65eccec [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x56c5bac2fc4a - std::panicking::panic_handler::{{closure}}::hbff715d0475cf1bd [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x56c5bac2fba9 - std::sys::backtrace::__rust_end_short_backtrace::hd6f43484e45a4955 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x56c5bac1afad - __rustc[b29d3319de9a3146]::rust_begin_unwind [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x56c5bac5b1d0 - core::panicking::panic_fmt::h5f8d281875be5ff1 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x56c5bac5c3e6 - core::result::unwrap_failed::hbb243a6a8b53218d [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x56c5ba8298c8 - core::result::Result::unwrap::h4bc40d841b904fa8 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x56c5ba8298c8 - nettu_scheduler_domain::account::test::it_accepts_valid_public_key::h824cb11b5ce7afff [INFO] [stdout] at /opt/rustwide/workdir/src/account.rs:140:78 [INFO] [stdout] 22: 0x56c5ba829a57 - nettu_scheduler_domain::account::test::it_accepts_valid_public_key::{{closure}}::hffe1b6c84ba2eabd [INFO] [stdout] at /opt/rustwide/workdir/src/account.rs:139:37 [INFO] [stdout] 23: 0x56c5ba839606 - core::ops::function::FnOnce::call_once::he79b5541b83a4867 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x56c5ba89b8cb - core::ops::function::FnOnce::call_once::haf4e03bb51ef1351 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x56c5ba89b8cb - test::__rust_begin_short_backtrace::h50f5566ee84f2f21 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x56c5ba89eac5 - test::run_test_in_process::{{closure}}::heb3733b71d876eca [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x56c5ba89eac5 - as core::ops::function::FnOnce<()>>::call_once::he2fe41e1b161faa9 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x56c5ba89eac5 - std::panicking::catch_unwind::do_call::h00aa383d8fd97a09 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x56c5ba89eac5 - std::panicking::catch_unwind::he482e1914bc21641 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x56c5ba89eac5 - std::panic::catch_unwind::h86ac9705098f4f22 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x56c5ba89eac5 - test::run_test_in_process::h636a992821e3c6aa [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x56c5ba89eac5 - test::run_test::{{closure}}::he454cc9a192df79f [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x56c5ba8c4474 - test::run_test::{{closure}}::haec47455908dff86 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x56c5ba8c4474 - std::sys::backtrace::__rust_begin_short_backtrace::h230785972524cdc1 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x56c5ba8ab08a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::haa5a562db4cde838 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x56c5ba8ab08a - as core::ops::function::FnOnce<()>>::call_once::h89254f37a55d0a87 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x56c5ba8ab08a - std::panicking::catch_unwind::do_call::h499f5a462f019d9d [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x56c5ba8ab08a - std::panicking::catch_unwind::h6736fbbb1a264383 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x56c5ba8ab08a - std::panic::catch_unwind::h49ea7bdd1cbee572 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x56c5ba8ab08a - std::thread::Builder::spawn_unchecked_::{{closure}}::h653dfa62acf32f5a [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x56c5ba8ab08a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h82582a626a045a45 [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x56c5bac04ebf - as core::ops::function::FnOnce>::call_once::h4ab26c07513156cc [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/alloc/src/boxed.rs:1971:9 [INFO] [stdout] 43: 0x56c5bac04ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h66ff1bba185a50cf [INFO] [stdout] at /rustc/350d0ef0ec0493e6d21cfb265cb8211a0e74d766/library/std/src/sys/pal/unix/thread.rs:107:17 [INFO] [stdout] 44: 0x7bb917db4aa4 - [INFO] [stdout] 45: 0x7bb917e41a34 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] account::test::it_accepts_valid_public_key [INFO] [stdout] [INFO] [stdout] test result: FAILED. 54 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.15s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] running `Command { std: "docker" "inspect" "61aadc5627b3a8ec33ecd7069deef8ecf6b77ad7a0a575f3061ca8621d98ece3", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "61aadc5627b3a8ec33ecd7069deef8ecf6b77ad7a0a575f3061ca8621d98ece3", kill_on_drop: false }` [INFO] [stdout] 61aadc5627b3a8ec33ecd7069deef8ecf6b77ad7a0a575f3061ca8621d98ece3