[INFO] fetching crate nettu_scheduler_domain 0.6.0... [INFO] testing nettu_scheduler_domain-0.6.0 against try#b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b for pr-145330-1 [INFO] extracting crate nettu_scheduler_domain 0.6.0 into /workspace/builds/worker-7-tc2/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-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate nettu_scheduler_domain 0.6.0 on toolchain b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "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" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "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" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "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-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 0c969b0abd35c6df4df0bb35ccadd51d5e987b0c7de4b369b0e0f0e8711c90b7 [INFO] running `Command { std: "docker" "start" "-a" "0c969b0abd35c6df4df0bb35ccadd51d5e987b0c7de4b369b0e0f0e8711c90b7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "0c969b0abd35c6df4df0bb35ccadd51d5e987b0c7de4b369b0e0f0e8711c90b7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "0c969b0abd35c6df4df0bb35ccadd51d5e987b0c7de4b369b0e0f0e8711c90b7", kill_on_drop: false }` [INFO] [stdout] 0c969b0abd35c6df4df0bb35ccadd51d5e987b0c7de4b369b0e0f0e8711c90b7 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] cbbc15fbac8a0e92ea15225134c135975677299ca39cbcf6b444745637693887 [INFO] running `Command { std: "docker" "start" "-a" "cbbc15fbac8a0e92ea15225134c135975677299ca39cbcf6b444745637693887", 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 num-integer v0.1.46 [INFO] [stderr] Compiling ring v0.16.20 [INFO] [stderr] Compiling spin v0.5.2 [INFO] [stderr] Compiling percent-encoding v2.3.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 thiserror v1.0.69 [INFO] [stderr] Compiling yoke v0.8.0 [INFO] [stderr] Compiling zerovec v0.11.4 [INFO] [stderr] Compiling zerotrie v0.2.2 [INFO] [stderr] Compiling tinystr v0.8.1 [INFO] [stderr] Compiling potential_utf v0.1.3 [INFO] [stderr] Compiling icu_collections v2.0.0 [INFO] [stderr] Compiling icu_locale_core v2.0.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling chrono v0.4.42 [INFO] [stderr] Compiling icu_provider v2.0.0 [INFO] [stderr] Compiling icu_properties v2.0.1 [INFO] [stderr] Compiling icu_normalizer v2.0.0 [INFO] [stderr] Compiling simple_asn1 v0.4.1 [INFO] [stderr] Compiling jsonwebtoken v7.2.0 [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 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 47.01s [INFO] running `Command { std: "docker" "inspect" "cbbc15fbac8a0e92ea15225134c135975677299ca39cbcf6b444745637693887", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cbbc15fbac8a0e92ea15225134c135975677299ca39cbcf6b444745637693887", kill_on_drop: false }` [INFO] [stdout] cbbc15fbac8a0e92ea15225134c135975677299ca39cbcf6b444745637693887 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] ee9849805fa29ae1dad581b86f825df3fb6e728c787b19fe01e1f646803bc12e [INFO] running `Command { std: "docker" "start" "-a" "ee9849805fa29ae1dad581b86f825df3fb6e728c787b19fe01e1f646803bc12e", 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.00s [INFO] running `Command { std: "docker" "inspect" "ee9849805fa29ae1dad581b86f825df3fb6e728c787b19fe01e1f646803bc12e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ee9849805fa29ae1dad581b86f825df3fb6e728c787b19fe01e1f646803bc12e", kill_on_drop: false }` [INFO] [stdout] ee9849805fa29ae1dad581b86f825df3fb6e728c787b19fe01e1f646803bc12e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] afbec07aef5fe5273d51de4fe28c7086ffa2849657b5c2e3d146a846a56798ab [INFO] running `Command { std: "docker" "start" "-a" "afbec07aef5fe5273d51de4fe28c7086ffa2849657b5c2e3d146a846a56798ab", 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: `nettu_scheduler_domain` (lib) generated 21 warnings (run `cargo fix --lib -p nettu_scheduler_domain` to apply 1 suggestion) [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 test) generated 25 warnings (21 duplicates) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.20s [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::generate_service_bookingslots_with_one_user_in_service ... ok [INFO] [stdout] test booking_slots::test::get_booking_slots_empty ... ok [INFO] [stdout] test booking_slots::test::get_booking_slots_from_many_events ... 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_2 ... 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_two_events ... ok [INFO] [stdout] test booking_slots::test::slot_that_crosses_end ... ok [INFO] [stdout] test booking_slots::test::slot_that_fits_right_at_end ... ok [INFO] [stdout] test date::test::it_accepts_valid_dates ... ok [INFO] [stdout] test booking_slots::test::slot_that_crosses_start ... ok [INFO] [stdout] test event::test::calendar_event_without_recurrence ... ok [INFO] [stdout] test event_instance::test::another_free_busy ... 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_instance::test::combining_events::overlap_without_extending ... ok [INFO] [stdout] test event::test::daily_calendar_event ... ok [INFO] [stdout] test event::test::allows_event_with_valid_recurrence ... 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::test::rejects_event_with_invalid_recurrence ... 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::compatible_events_test_3 ... ok [INFO] [stdout] test event_instance::test::compatible_events_test_4 ... 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 schedule::test::day_sanity_tests ... ok [INFO] [stdout] test schedule::test::it_computes_freebusy_for_schedule ... ok [INFO] [stdout] test event_instance::test::single_event ... 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_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_without_members ... 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 booking_slots::test::groups_bookingslots_by_date ... ok [INFO] [stdout] test shared::recurrence::test::serializes_weekday ... 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 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: 0x5b954bcf7a72 - std::backtrace_rs::backtrace::libunwind::trace::hc4a5f428cfb78751 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x5b954bcf7a72 - std::backtrace_rs::backtrace::trace_unsynchronized::h20e1095684b4c296 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x5b954bcf7a72 - std::sys::backtrace::_print_fmt::h461f2e3a8f6b29e2 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x5b954bcf7a72 - ::fmt::h4ee3a75aa71a2c45 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x5b954bd1b28f - core::fmt::rt::Argument::fmt::h6f1564705cd089af [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x5b954bd1b28f - core::fmt::write::h21ca93b65a7c281a [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x5b954bce36f3 - std::io::default_write_fmt::h6f3360f4711e9130 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x5b954bce36f3 - std::io::Write::write_fmt::hf4539125c0e0bc30 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x5b954bcf80c2 - std::sys::backtrace::BacktraceLock::print::h58d5d73f9e953cf1 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x5b954bce1bcc - std::panicking::default_hook::{{closure}}::h1457fbe47c9457d1 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x5b954bce1a44 - std::panicking::default_hook::hccb5e73b206c0830 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x5b954b9648fe - as core::ops::function::Fn>::call::h04940a86aa899793 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 12: 0x5b954b9648fe - test::test_main_with_exit_callback::{{closure}}::hca6cc295403b83e8 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x5b954bce2873 - as core::ops::function::Fn>::call::h9d85285925beb538 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 14: 0x5b954bce2873 - std::panicking::panic_with_hook::h3190ecc6229cdd29 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x5b954bcf7eca - std::panicking::panic_handler::{{closure}}::ha1f1b769bc2bb40c [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x5b954bcf7e29 - std::sys::backtrace::__rust_end_short_backtrace::h5f9cf66f19c2a172 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x5b954bce24cd - __rustc[a93bd50104b99ad4]::rust_begin_unwind [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x5b954bd22bc0 - core::panicking::panic_fmt::hc70c3c83f13c1375 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x5b954bd24116 - core::result::unwrap_failed::ha809bf80017a514a [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x5b954b8f0128 - core::result::Result::unwrap::h00b3589940bdb0e7 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x5b954b8f0128 - nettu_scheduler_domain::account::test::it_accepts_valid_public_key::h0e1577010ef072ab [INFO] [stdout] at /opt/rustwide/workdir/src/account.rs:140:78 [INFO] [stdout] 22: 0x5b954b8f0377 - nettu_scheduler_domain::account::test::it_accepts_valid_public_key::{{closure}}::hcf5f8c07e27b560d [INFO] [stdout] at /opt/rustwide/workdir/src/account.rs:139:37 [INFO] [stdout] 23: 0x5b954b8ff316 - core::ops::function::FnOnce::call_once::hbaa898d7cee61596 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x5b954b96597b - core::ops::function::FnOnce::call_once::h70d190c46966003b [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x5b954b96597b - test::__rust_begin_short_backtrace::hb077ccaabb17d2ec [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x5b954b9635e5 - test::run_test_in_process::{{closure}}::hd73eeb633a1507bd [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x5b954b9635e5 - as core::ops::function::FnOnce<()>>::call_once::h033c82756fc9d192 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x5b954b9635e5 - std::panicking::catch_unwind::do_call::h734b44e243d34585 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x5b954b9635e5 - std::panicking::catch_unwind::h5e85417122517fb1 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x5b954b9635e5 - std::panic::catch_unwind::h0900e58a82a7d188 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x5b954b9635e5 - test::run_test_in_process::h27721efd62ae77d0 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x5b954b9635e5 - test::run_test::{{closure}}::h8b1264838cc597aa [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x5b954b98a4f4 - test::run_test::{{closure}}::h6ecb96835e2eae4f [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x5b954b98a4f4 - std::sys::backtrace::__rust_begin_short_backtrace::h098f38ee82a820a7 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x5b954b97110a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h042592f748f5e369 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x5b954b97110a - as core::ops::function::FnOnce<()>>::call_once::h134fe7f3a2d9ec8d [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x5b954b97110a - std::panicking::catch_unwind::do_call::heb87d604f60aee16 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x5b954b97110a - std::panicking::catch_unwind::h2203a0f553b89fd7 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x5b954b97110a - std::panic::catch_unwind::h4d383e0b0e25d838 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x5b954b97110a - std::thread::Builder::spawn_unchecked_::{{closure}}::h76cbdd4635cfd58b [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x5b954b97110a - core::ops::function::FnOnce::call_once{{vtable.shim}}::he72e066680f5e267 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x5b954bcccc1f - as core::ops::function::FnOnce>::call_once::h1b9c6fea2cbefc68 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/alloc/src/boxed.rs:1971:9 [INFO] [stdout] 43: 0x5b954bcccc1f - std::sys::pal::unix::thread::Thread::new::thread_start::h92caa992bc760789 [INFO] [stdout] at /rustc/b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b/library/std/src/sys/pal/unix/thread.rs:107:17 [INFO] [stdout] 44: 0x767dc5a87aa4 - [INFO] [stdout] 45: 0x767dc5b14a34 - 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.07s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] running `Command { std: "docker" "inspect" "afbec07aef5fe5273d51de4fe28c7086ffa2849657b5c2e3d146a846a56798ab", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "afbec07aef5fe5273d51de4fe28c7086ffa2849657b5c2e3d146a846a56798ab", kill_on_drop: false }` [INFO] [stdout] afbec07aef5fe5273d51de4fe28c7086ffa2849657b5c2e3d146a846a56798ab