-import { hoursToMilliseconds, hoursToSeconds, isValid } from 'date-fns';
+import { hoursToMilliseconds, hoursToSeconds } from 'date-fns';
import { expect } from 'expect';
import { Constants } from '../../src/utils/Constants';
convertToDate,
convertToFloat,
convertToInt,
+ extractTimeSeriesValues,
formatDurationMilliSeconds,
formatDurationSeconds,
generateUUID,
isObject,
isUndefined,
isValidTime,
+ max,
+ min,
+ once,
roundTo,
secureRandom,
sleep,
it('Verify sleep()', async () => {
const start = performance.now();
await sleep(1000);
- const end = performance.now();
- expect(end - start).toBeGreaterThanOrEqual(1000);
+ const stop = performance.now();
+ expect(stop - start).toBeGreaterThanOrEqual(1000);
});
it('Verify formatDurationMilliSeconds()', () => {
it('Verify convertToDate()', () => {
expect(convertToDate(undefined)).toBe(undefined);
- expect(convertToDate(null)).toBe(null);
- expect(isValid(convertToDate(''))).toBe(false);
+ expect(() => convertToDate('')).toThrowError(new Error("Cannot convert to date: ''"));
+ expect(() => convertToDate('00:70:61')).toThrowError(
+ new Error("Cannot convert to date: '00:70:61'"),
+ );
expect(convertToDate(0)).toStrictEqual(new Date('1970-01-01T00:00:00.000Z'));
+ expect(convertToDate(-1)).toStrictEqual(new Date('1969-12-31T23:59:59.999Z'));
const dateStr = '2020-01-01T00:00:00.000Z';
let date = convertToDate(dateStr);
expect(date).toBeInstanceOf(Date);
expect(convertToInt(1.999)).toBe(1);
expect(() => {
convertToInt('NaN');
- }).toThrow('Cannot convert to integer: NaN');
+ }).toThrow("Cannot convert to integer: 'NaN'");
});
it('Verify convertToFloat()', () => {
expect(convertToFloat(1.999)).toBe(1.999);
expect(() => {
convertToFloat('NaN');
- }).toThrow('Cannot convert to float: NaN');
+ }).toThrow("Cannot convert to float: 'NaN'");
});
it('Verify convertToBoolean()', () => {
randomInteger = getRandomInteger(2, 1);
expect(randomInteger).toBeGreaterThanOrEqual(1);
expect(randomInteger).toBeLessThanOrEqual(2);
- const max = 2.2,
- min = 1.1;
- randomInteger = getRandomInteger(max, min);
- expect(randomInteger).toBeGreaterThanOrEqual(Math.ceil(min));
- expect(randomInteger).toBeLessThanOrEqual(Math.floor(max));
+ const maximum = 2.2,
+ minimum = 1.1;
+ randomInteger = getRandomInteger(maximum, minimum);
+ expect(randomInteger).toBeLessThanOrEqual(Math.floor(maximum));
+ expect(randomInteger).toBeGreaterThanOrEqual(Math.ceil(minimum));
});
it('Verify roundTo()', () => {
expect(randomFloat).toBeLessThanOrEqual(0);
});
+ it('Verify extractTimeSeriesValues()', () => {
+ expect(extractTimeSeriesValues([])).toEqual([]);
+ expect(extractTimeSeriesValues([{ timestamp: Date.now(), value: 1.1 }])).toEqual([1.1]);
+ expect(
+ extractTimeSeriesValues([
+ { timestamp: Date.now(), value: 1.1 },
+ { timestamp: Date.now(), value: 2.2 },
+ ]),
+ ).toEqual([1.1, 2.2]);
+ });
+
it('Verify isObject()', () => {
expect(isObject('test')).toBe(false);
expect(isObject(undefined)).toBe(false);
expect(isArraySorted<number>([1, 2, 3, 5, 4], (a, b) => a - b)).toBe(false);
expect(isArraySorted<number>([2, 1, 3, 4, 5], (a, b) => a - b)).toBe(false);
});
+
+ it('Verify once()', () => {
+ let called = 0;
+ const fn = () => ++called;
+ const onceFn = once(fn, this);
+ const result1 = onceFn();
+ expect(called).toBe(1);
+ expect(result1).toBe(1);
+ const result2 = onceFn();
+ expect(called).toBe(1);
+ expect(result2).toBe(1);
+ const result3 = onceFn();
+ expect(called).toBe(1);
+ expect(result3).toBe(1);
+ });
+
+ it('Verify min()', () => {
+ expect(min(0, 1)).toBe(0);
+ expect(min(1, 0)).toBe(0);
+ expect(min(0, -1)).toBe(-1);
+ expect(min(-1, 0)).toBe(-1);
+ });
+
+ it('Verify max()', () => {
+ expect(max(0, 1)).toBe(1);
+ expect(max(1, 0)).toBe(1);
+ expect(max(0, -1)).toBe(0);
+ expect(max(-1, 0)).toBe(0);
+ });
});