react-day-picker
Version:
Customizable Date Picker for React
47 lines (39 loc) • 1.32 kB
text/typescript
import { RenderResult } from '@testing-library/react-hooks';
import { DayPickerProps } from 'DayPicker';
import { customRenderHook } from 'test/render';
import { useModifiers } from 'contexts/Modifiers';
import { DayModifiers, InternalModifier, Modifiers } from 'types/Modifiers';
let renderResult: RenderResult<Modifiers>;
function setup(dayPickerProps: DayPickerProps) {
const { result } = customRenderHook(() => useModifiers(), dayPickerProps);
renderResult = result;
}
const internalModifiers = Object.values(InternalModifier);
describe('when rendered with custom modifiers', () => {
const modifier = new Date(2018, 11, 12);
const dayModifiers: DayModifiers = {
foo: modifier,
today: modifier,
outside: modifier,
disabled: modifier,
selected: modifier,
hidden: modifier,
range_start: modifier,
range_end: modifier,
range_middle: modifier
};
beforeEach(() => {
setup({ modifiers: dayModifiers });
});
test('should return the custom modifiers', () => {
expect(renderResult.current.foo).toEqual([dayModifiers.foo]);
});
test.each(internalModifiers)(
'should override the %s internal modifier',
(internalModifier) => {
expect(renderResult.current[internalModifier]).toEqual([
dayModifiers[internalModifier]
]);
}
);
});