it-tools/src/tools/date-time-converter/date-time-converter.models.test.ts

181 lines
8 KiB
TypeScript
Raw Normal View History

import { describe, expect, test } from 'vitest';
import {
dateToExcelFormat,
excelFormatToDate,
isExcelFormat,
isISO8601DateTimeString,
isISO9075DateString,
isMongoObjectId,
isRFC3339DateString,
isRFC7231DateString,
isTimestamp,
isUTCDateString,
isUnixTimestamp,
} from './date-time-converter.models';
describe('date-time-converter models', () => {
describe('isISO8601DateTimeString', () => {
test('should return true for valid ISO 8601 date strings', () => {
expect(isISO8601DateTimeString('2021-01-01T00:00:00.000Z')).toBe(true);
expect(isISO8601DateTimeString('2023-04-12T14:56:00+01:00')).toBe(true);
expect(isISO8601DateTimeString('20230412T145600+0100')).toBe(true);
expect(isISO8601DateTimeString('20230412T145600Z')).toBe(true);
expect(isISO8601DateTimeString('2016-02-01')).toBe(true);
expect(isISO8601DateTimeString('2016')).toBe(true);
});
test('should return false for invalid ISO 8601 date strings', () => {
expect(isISO8601DateTimeString()).toBe(false);
expect(isISO8601DateTimeString('')).toBe(false);
expect(isISO8601DateTimeString('qsdqsd')).toBe(false);
expect(isISO8601DateTimeString('2016-02-01-')).toBe(false);
expect(isISO8601DateTimeString('2021-01-01T00:00:00.')).toBe(false);
});
});
describe('isISO9075DateString', () => {
test('should return true for valid ISO 9075 date strings', () => {
expect(isISO9075DateString('2022-01-01 12:00:00Z')).toBe(true);
expect(isISO9075DateString('2022-01-01 12:00:00.123456Z')).toBe(true);
expect(isISO9075DateString('2022-01-01 12:00:00+01:00')).toBe(true);
expect(isISO9075DateString('2022-01-01 12:00:00-05:00')).toBe(true);
});
test('should return false for invalid ISO 9075 date strings', () => {
expect(isISO9075DateString('2022/01/01T12:00:00Z')).toBe(false);
expect(isISO9075DateString('2022-01-01 12:00:00.123456789Z')).toBe(false);
expect(isISO9075DateString('2022-01-01 12:00:00+1:00')).toBe(false);
expect(isISO9075DateString('2022-01-01 12:00:00-05:')).toBe(false);
expect(isISO9075DateString('2022-01-01 12:00:00-05:00:00')).toBe(false);
expect(isISO9075DateString('2022-01-01')).toBe(false);
expect(isISO9075DateString('12:00:00Z')).toBe(false);
expect(isISO9075DateString('2022-01-01T12:00:00Zfoo')).toBe(false);
});
});
describe('isRFC3339DateString', () => {
test('should return true for valid RFC 3339 date strings', () => {
expect(isRFC3339DateString('2022-01-01T12:00:00Z')).toBe(true);
expect(isRFC3339DateString('2022-01-01T12:00:00.123456789Z')).toBe(true);
expect(isRFC3339DateString('2022-01-01T12:00:00.123456789+01:00')).toBe(true);
expect(isRFC3339DateString('2022-01-01T12:00:00-05:00')).toBe(true);
});
test('should return false for invalid RFC 3339 date strings', () => {
expect(isRFC3339DateString('2022/01/01T12:00:00Z')).toBe(false);
expect(isRFC3339DateString('2022-01-01T12:00:00.123456789+1:00')).toBe(false);
expect(isRFC3339DateString('2022-01-01T12:00:00-05:')).toBe(false);
expect(isRFC3339DateString('2022-01-01T12:00:00-05:00:00')).toBe(false);
expect(isRFC3339DateString('2022-01-01')).toBe(false);
expect(isRFC3339DateString('12:00:00Z')).toBe(false);
expect(isRFC3339DateString('2022-01-01T12:00:00Zfoo')).toBe(false);
});
});
describe('isRFC7231DateString', () => {
test('should return true for valid RFC 7231 date strings', () => {
expect(isRFC7231DateString('Sun, 06 Nov 1994 08:49:37 GMT')).toBe(true);
expect(isRFC7231DateString('Tue, 22 Apr 2014 07:00:00 GMT')).toBe(true);
});
test('should return false for invalid RFC 7231 date strings', () => {
expect(isRFC7231DateString('06 Nov 1994 08:49:37 GMT')).toBe(false);
expect(isRFC7231DateString('Sun, 06 Nov 94 08:49:37 GMT')).toBe(false);
expect(isRFC7231DateString('Sun, 06 Nov 1994 8:49:37 GMT')).toBe(false);
expect(isRFC7231DateString('Sun, 06 Nov 1994 08:49:37 GMT-0500')).toBe(false);
expect(isRFC7231DateString('Sun, 06 November 1994 08:49:37 GMT')).toBe(false);
expect(isRFC7231DateString('Sunday, 06 Nov 1994 08:49:37 GMT')).toBe(false);
expect(isRFC7231DateString('06 Nov 1994')).toBe(false);
});
});
describe('isUnixTimestamp', () => {
test('should return true for valid Unix timestamps', () => {
expect(isUnixTimestamp('1649789394')).toBe(true);
expect(isUnixTimestamp('1234567890')).toBe(true);
expect(isUnixTimestamp('0')).toBe(true);
});
test('should return false for invalid Unix timestamps', () => {
expect(isUnixTimestamp('foo')).toBe(false);
expect(isUnixTimestamp('')).toBe(false);
});
});
describe('isTimestamp', () => {
test('should return true for valid Unix timestamps in milliseconds', () => {
expect(isTimestamp('1649792026123')).toBe(true);
expect(isTimestamp('1234567890000')).toBe(true);
expect(isTimestamp('0')).toBe(true);
});
test('should return false for invalid Unix timestamps in milliseconds', () => {
expect(isTimestamp('foo')).toBe(false);
expect(isTimestamp('')).toBe(false);
});
});
describe('isUTCDateString', () => {
test('should return true for valid UTC date strings', () => {
expect(isUTCDateString('Sun, 06 Nov 1994 08:49:37 GMT')).toBe(true);
expect(isUTCDateString('Tue, 22 Apr 2014 07:00:00 GMT')).toBe(true);
});
test('should return false for invalid UTC date strings', () => {
expect(isUTCDateString('06 Nov 1994 08:49:37 GMT')).toBe(false);
expect(isUTCDateString('16497920261')).toBe(false);
expect(isUTCDateString('foo')).toBe(false);
expect(isUTCDateString('')).toBe(false);
});
});
describe('isMongoObjectId', () => {
test('should return true for valid Mongo ObjectIds', () => {
expect(isMongoObjectId('507f1f77bcf86cd799439011')).toBe(true);
expect(isMongoObjectId('507f1f77bcf86cd799439012')).toBe(true);
});
test('should return false for invalid Mongo ObjectIds', () => {
expect(isMongoObjectId('507f1f77bcf86cd79943901')).toBe(false);
expect(isMongoObjectId('507f1f77bcf86cd79943901z')).toBe(false);
expect(isMongoObjectId('foo')).toBe(false);
expect(isMongoObjectId('')).toBe(false);
});
});
describe('isExcelFormat', () => {
test('an Excel format string is a floating number that can be negative', () => {
expect(isExcelFormat('0')).toBe(true);
expect(isExcelFormat('1')).toBe(true);
expect(isExcelFormat('1.1')).toBe(true);
expect(isExcelFormat('-1.1')).toBe(true);
expect(isExcelFormat('-1')).toBe(true);
expect(isExcelFormat('')).toBe(false);
expect(isExcelFormat('foo')).toBe(false);
expect(isExcelFormat('1.1.1')).toBe(false);
});
});
describe('dateToExcelFormat', () => {
test('a date in Excel format is the number of days since 01/01/1900', () => {
expect(dateToExcelFormat(new Date('2016-05-20T00:00:00.000Z'))).toBe('42510');
expect(dateToExcelFormat(new Date('2016-05-20T12:00:00.000Z'))).toBe('42510.5');
expect(dateToExcelFormat(new Date('2023-10-31T09:26:06.421Z'))).toBe('45230.39312987268');
expect(dateToExcelFormat(new Date('1970-01-01T00:00:00.000Z'))).toBe('25569');
expect(dateToExcelFormat(new Date('1800-01-01T00:00:00.000Z'))).toBe('-36522');
});
});
describe('excelFormatToDate', () => {
test('a date in Excel format is the number of days since 01/01/1900', () => {
expect(excelFormatToDate('0')).toEqual(new Date('1899-12-30T00:00:00.000Z'));
expect(excelFormatToDate('1')).toEqual(new Date('1899-12-31T00:00:00.000Z'));
expect(excelFormatToDate('2')).toEqual(new Date('1900-01-01T00:00:00.000Z'));
expect(excelFormatToDate('4242.4242')).toEqual(new Date('1911-08-12T10:10:50.880Z'));
expect(excelFormatToDate('42738.22626859954')).toEqual(new Date('2017-01-03T05:25:49.607Z'));
expect(excelFormatToDate('-1000')).toEqual(new Date('1897-04-04T00:00:00.000Z'));
});
});
});