diff options
author | Sebastian <sebasjm@gmail.com> | 2021-08-23 16:46:06 -0300 |
---|---|---|
committer | Sebastian <sebasjm@gmail.com> | 2021-08-23 16:48:30 -0300 |
commit | 38acabfa6089ab8ac469c12b5f55022fb96935e5 (patch) | |
tree | 453dbf70000cc5e338b06201af1eaca8343f8f73 /date-fns/src/eachWeekendOfInterval/test.ts | |
parent | f26125e039143b92dc0d84e7775f508ab0cdcaa8 (diff) | |
download | node-vendor-38acabfa6089ab8ac469c12b5f55022fb96935e5.tar.gz node-vendor-38acabfa6089ab8ac469c12b5f55022fb96935e5.tar.bz2 node-vendor-38acabfa6089ab8ac469c12b5f55022fb96935e5.zip |
Diffstat (limited to 'date-fns/src/eachWeekendOfInterval/test.ts')
-rw-r--r-- | date-fns/src/eachWeekendOfInterval/test.ts | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/date-fns/src/eachWeekendOfInterval/test.ts b/date-fns/src/eachWeekendOfInterval/test.ts new file mode 100644 index 0000000..75df655 --- /dev/null +++ b/date-fns/src/eachWeekendOfInterval/test.ts @@ -0,0 +1,67 @@ +// @flow +/* eslint-env mocha */ + +import assert from 'assert' +import eachWeekendOfInterval from '.' + +describe('eachWeekendOfInterval', function () { + it('returns all weekends within the interval', function () { + const result = eachWeekendOfInterval({ + start: new Date(2018, 8 /* Sept */, 17), + end: new Date(2018, 8 /* Sept */, 30) + }) + assert.deepEqual(result, [ + new Date(2018, 8 /* Sept */, 22), + new Date(2018, 8 /* Sept */, 23), + new Date(2018, 8 /* Sept */, 29), + new Date(2018, 8 /* Sept */, 30) + ]) + }) + + it('returns all weekends within the interval when starting on a weekend', function () { + const result = eachWeekendOfInterval({ + start: new Date(2018, 8 /* Sept */, 22), + end: new Date(2018, 8 /* Sept */, 30) + }) + assert.deepEqual(result, [ + new Date(2018, 8 /* Sept */, 22), + new Date(2018, 8 /* Sept */, 23), + new Date(2018, 8 /* Sept */, 29), + new Date(2018, 8 /* Sept */, 30) + ]) + }) + + it('throws `RangeError` invalid interval start date is used', function () { + // $ExpectedMistake + const block = eachWeekendOfInterval.bind(null, { + start: new Date(NaN), + end: new Date(2019, 11 /* Dec */, 31) + }) + assert.throws(block, RangeError) + }) + + it('throws `RangeError` invalid interval end date is used', function () { + // $ExpectedMistake + const block = eachWeekendOfInterval.bind(null, { + start: new Date(2019, 0 /* Jan */, 1), + end: new Date(NaN) + }) + assert.throws(block, RangeError) + }) + + it('throws TypeError exception if passed less than 1 argument', function () { + assert.throws(eachWeekendOfInterval, TypeError) + }) + + it('throws `RangeError` if start of an interval is after its end', function () { + const block = eachWeekendOfInterval.bind( + null, + // $ExpectedMistake + { + start: new Date(2018, 8 /* Sept */, 25), + end: new Date(2018, 8 /* Sept */, 6) + } + ) + assert.throws(block, RangeError) + }) +}) |