From c8a8fa2bbef7f4596e2b96fbd593e20217a41982 Mon Sep 17 00:00:00 2001 From: Joshua Jacobowitz <31038284+joshuajaco@users.noreply.github.com> Date: Sat, 14 Oct 2023 23:07:55 +0200 Subject: [PATCH] Fix Interval.splitAt datetime sorting (#1524) --- src/interval.js | 2 +- test/interval/many.test.js | 18 ++++++++++++++++++ 2 files changed, 19 insertions(+), 1 deletion(-) diff --git a/src/interval.js b/src/interval.js index 594bf2c7b..9df385584 100644 --- a/src/interval.js +++ b/src/interval.js @@ -320,7 +320,7 @@ export default class Interval { const sorted = dateTimes .map(friendlyDateTime) .filter((d) => this.contains(d)) - .sort(), + .sort((a, b) => a.toMillis() - b.toMillis()), results = []; let { s } = this, i = 0; diff --git a/test/interval/many.test.js b/test/interval/many.test.js index d02b67a15..8bcbec186 100644 --- a/test/interval/many.test.js +++ b/test/interval/many.test.js @@ -301,6 +301,24 @@ test("Interval#splitAt ignores times outside the interval", () => { expect(oneAfterOneDuring[1]).toEqual(todayFrom(11, 13)); }); +test("Interval#splitAt handles DST shifts", () => { + const zone = "Europe/Berlin"; + const dayStart = DateTime.fromISO("2023-10-29T00:00:00+02:00", { zone }); + const dayEnd = DateTime.fromISO("2023-10-30T00:00:00+01:00", { zone }); + const dstShiftStart = DateTime.fromISO("2023-10-29T02:00:00+02:00", { zone }); + const dstShiftEnd = DateTime.fromISO("2023-10-29T02:00:00+01:00", { zone }); + + const splitByDSTStartAndEnd = Interval.fromDateTimes(dayStart, dayEnd) + .splitAt(dstShiftStart, dstShiftEnd) + .map((i) => i.toISO()); + + expect(splitByDSTStartAndEnd).toEqual([ + "2023-10-29T00:00:00.000+02:00/2023-10-29T02:00:00.000+02:00", + "2023-10-29T02:00:00.000+02:00/2023-10-29T02:00:00.000+01:00", + "2023-10-29T02:00:00.000+01:00/2023-10-30T00:00:00.000+01:00", + ]); +}); + //------- // #splitBy() //-------