shlink-web-client/test/utils/dates/DateRangeRow.test.tsx

35 lines
1.2 KiB
TypeScript
Raw Normal View History

import { screen } from '@testing-library/react';
import { DateRangeRow } from '../../../src/utils/dates/DateRangeRow';
import { renderWithEvents } from '../../__helpers__/setUpTest';
2020-01-14 20:20:27 +01:00
describe('<DateRangeRow />', () => {
2023-05-27 11:57:26 +02:00
const onEndDateChange = vi.fn();
const onStartDateChange = vi.fn();
const setUp = () => renderWithEvents(
<DateRangeRow onEndDateChange={onEndDateChange} onStartDateChange={onStartDateChange} />,
);
2020-01-14 20:20:27 +01:00
2023-05-27 11:57:26 +02:00
afterEach(vi.clearAllMocks);
2020-01-14 20:20:27 +01:00
it('renders two date inputs', () => {
setUp();
expect(screen.getAllByRole('textbox')).toHaveLength(2);
2020-01-14 20:20:27 +01:00
});
it('invokes start date callback when change event is triggered on first input', async () => {
const { user } = setUp();
2020-01-14 20:20:27 +01:00
expect(onStartDateChange).not.toHaveBeenCalled();
await user.type(screen.getByPlaceholderText('Since...'), '2020-05-05');
2020-01-14 20:20:27 +01:00
expect(onStartDateChange).toHaveBeenCalled();
});
it('invokes end date callback when change event is triggered on second input', async () => {
const { user } = setUp();
2020-01-14 20:20:27 +01:00
expect(onEndDateChange).not.toHaveBeenCalled();
await user.type(screen.getByPlaceholderText('Until...'), '2022-05-05');
2020-01-14 20:20:27 +01:00
expect(onEndDateChange).toHaveBeenCalled();
});
});