Макет функции по умолчанию DayJs вместе с ее связанными методами
Я пытаюсь издеваться над функцией по умолчанию dayjs() с определенной датой и временем, а также хочу издеваться над ее вложенными методами, т.е. utc () и. Добавить()
Вот что я пробовал до сих пор:
abc.ts:
getEarliestDate() {
const {
minHour,
maxHour
} = operatingHours;
const earliestDateTime = dayjs().add(sla + 1, 'minute');
const earliestDateTimeUTC = earliestDateTime.utc();
return dayjs().add(121, 'minute').format('YYYY-MM-DD HH:mm');
}
abc.test.ts:
import { abc } from '../../src/common/serviceFactory';
import dayjs from 'dayjs';
jest.mock('dayjs', () =>
jest.fn((...args) => jest.requireActual('dayjs')(args.filter((arg) => arg).length > 0 ? args : '2020-08-12')),
);
jest.mock('dayjs', () => ({
default: jest.requireActual('dayjs')(`2020-08-18 12:00:00`),
extend: jest.fn(),
utc: jest.fn((...args) => {
const dayjs = jest.requireActual('dayjs');
dayjs.extend(jest.requireActual('dayjs/plugin/utc'));
return dayjs.utc(args.filter((arg) => arg).length > 0 ? args : '12:00:00').startOf('day');
}),
add: jest.requireActual('dayjs')(`2020-08-18 12:00:00`),
}));
describe('getEarliestDate Function', () => {
it('should return earliest date response', () => {
const earliestDate = abc.getEarliestDate();
expect(earliestDate).toMatch(dayjs().add(121, 'minute').format('YYYY-MM-DD HH:mm'));
});
Но получив это: TypeError: dayjs_1.default is not a function
Любая помощь / предложение приветствуются.
3 ответа
MockDate отлично подходит для этого, не требуется сложного кода для имитации.
https://www.npmjs.com/package/mockdate
import MockDate from 'mockdate'
import dayjs from 'dayjs'
MockDate.set('2000-11-22')
console.log(dayjs.format())
// >>> 2000-11-22T00:00:00Z
Не забудьте очистить макет после теста с помощью:
MockDate.reset();
Для базовых операций с dayjs работает этот код:
jest.mock('dayjs', () => jest.fn((...args) => jest.requireActual('dayjs')(args.filter((arg) => arg).length > 0 ? args : '2020-08-12')),);
Когда '2020-08-12' - это дата, которую вы хотите высмеять.
Я думаю проблема в том default
функция макета модуля должна быть функцией, а не результатом возврата dayjs()
. Тогда попробуйте следующее:
jest.mock('dayjs', () => ({
default: jest.fn((...args) => {
const yourDay = jest.requireActual('dayjs')(args.filter((arg) => arg).length > 0 ? args : '2020-08-11');
// Mock add function
yourDay.add = jest.fn(() => jest.requireActual('dayjs')(`2020-08-10 12:00:00`));
// more mock
return yourDay;
})
}));
Также удалите другой макет, поскольку он заменит:
jest.mock('dayjs', () => ({
default: jest.requireActual('dayjs')(`2020-08-18 12:00:00`),
extend: jest.fn(),
// ...
}));
Другое решение, вы можете изменить и оставить свой первый макет неизменным:
jest.mock('dayjs', () =>
jest.fn((...args) => jest.requireActual('dayjs')(args.filter((arg) => arg).length > 0 ? args : '2020-08-12')),
);
Единственное, что вам нужно сделать, это включить опцию esModuleInterop
в вашем tsconfig.json
так как эта опция добавит default
функция для вас автоматически:
{
"compilerOptions": {
// ...
"esModuleInterop": true,
},
}