From f9b59579d3d22170aa8abce752e3f7d150763b7b Mon Sep 17 00:00:00 2001 From: Jonathan Keam Date: Thu, 31 Jan 2019 10:46:42 -0500 Subject: [PATCH] catch range errors when dates are invalid and instead return boolean indicating validity (#1577) --- src/date_utils.js | 17 +++++++++++-- test/date_utils_test.js | 55 ++++++++++++++++++++++++++++++++++++++++- 2 files changed, 69 insertions(+), 3 deletions(-) diff --git a/src/date_utils.js b/src/date_utils.js index 99c5eca12..fcb6d45f8 100644 --- a/src/date_utils.js +++ b/src/date_utils.js @@ -224,7 +224,13 @@ export function isSameDay(date1, date2) { } export function isDayInRange(day, startDate, endDate) { - return isWithinInterval(day, { start: startDate, end: endDate }); + let valid; + try { + valid = isWithinInterval(day, { start: startDate, end: endDate }); + } catch (err) { + valid = false; + } + return valid; } // *** Diffing *** @@ -326,7 +332,14 @@ export function isTimeInDisabledRange(time, { minTime, maxTime }) { setMinutes(base, getMinutes(maxTime)), getHours(maxTime) ); - return !isWithinInterval(baseTime, { start: min, end: max }); + + let valid; + try { + valid = !isWithinInterval(baseTime, { start: min, end: max }); + } catch (err) { + valid = false; + } + return valid; } export function monthDisabledBefore(day, { minDate, includeDates } = {}) { diff --git a/test/date_utils_test.js b/test/date_utils_test.js index 431e96f56..82ee789ad 100644 --- a/test/date_utils_test.js +++ b/test/date_utils_test.js @@ -10,8 +10,12 @@ import { monthDisabledBefore, monthDisabledAfter, getEffectiveMinDate, - getEffectiveMaxDate + getEffectiveMaxDate, + isTimeInDisabledRange, + isDayInRange } from "../src/date_utils"; +import setMinutes from "date-fns/setMinutes"; +import setHours from "date-fns/setHours"; describe("date_utils", function() { describe("isSameDay", function() { @@ -245,4 +249,53 @@ describe("date_utils", function() { assert(isEqual(getEffectiveMaxDate({ maxDate, includeDates }), date1)); }); }); + + describe("isTimeInDisabledRange", () => { + it("should tell if time is in disabled range", () => { + const date = newDate("2016-03-15"); + const time = setHours(setMinutes(date, 30), 1); + const minTime = setHours(setMinutes(date, 30), 0); + const maxTime = setHours(setMinutes(date, 30), 5); + expect(isTimeInDisabledRange(time, { minTime, maxTime })).to.be.false; + }); + + it("should tell if time is not in disabled range", () => { + const date = newDate("2016-03-15"); + const time = setHours(setMinutes(date, 30), 0); + const minTime = setHours(setMinutes(date, 30), 1); + const maxTime = setHours(setMinutes(date, 30), 5); + expect(isTimeInDisabledRange(time, { minTime, maxTime })).to.be.true; + }); + + it("should not throw an exception if max time is before min time", () => { + const date = newDate("2016-03-15"); + const time = setHours(setMinutes(date, 30), 10); + const minTime = setHours(setMinutes(date, 30), 5); + const maxTime = setHours(setMinutes(date, 30), 0); + expect(isTimeInDisabledRange(time, { minTime, maxTime })).to.be.false; + }); + }); + + describe("isDayInRange", () => { + it("should tell if day is in range", () => { + const day = newDate("2016-02-15"); + const startDate = newDate("2016-02-01"); + const endDate = newDate("2016-03-15"); + expect(isDayInRange(day, startDate, endDate)).to.be.true; + }); + + it("should tell if day is not in range", () => { + const day = newDate("2016-07-15"); + const startDate = newDate("2016-02-15"); + const endDate = newDate("2016-03-15"); + expect(isDayInRange(day, startDate, endDate)).to.be.false; + }); + + it("should not throw exception if end date is before start date", () => { + const day = newDate("2016-02-01"); + const startDate = newDate("2016-02-15"); + const endDate = newDate("2016-01-15"); + expect(isDayInRange(day, startDate, endDate)).to.be.false; + }); + }); });