Skip to content

Commit

Permalink
[test] Update tests with latest state of StrictMode compatibility
Browse files Browse the repository at this point in the history
  • Loading branch information
eps1lon committed Jun 30, 2021
1 parent 93aab64 commit 74bc5a6
Show file tree
Hide file tree
Showing 7 changed files with 70 additions and 45 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import * as React from 'react';
import { expect } from 'chai';
import { SinonFakeTimers, useFakeTimers } from 'sinon';
import { fireEvent, screen, describeConformanceV5 } from 'test/utils';
import CalendarPicker, { calendarPickerClasses as classes } from '@material-ui/lab/CalendarPicker';
import {
Expand All @@ -10,6 +11,15 @@ import {
} from '../internal/pickers/test-utils';

describe('<CalendarPicker />', () => {
let clock: SinonFakeTimers;
beforeEach(() => {
clock = useFakeTimers();
});
afterEach(() => {
clock.restore();
});

// StrictModeViolation: Uses StrictMode incompatible API of `react-transition-group`
const render = createPickerRender({ strict: false });

describeConformanceV5(<CalendarPicker date={adapterToUse.date()} onChange={() => {}} />, () => ({
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import * as React from 'react';
import { expect } from 'chai';
import { spy } from 'sinon';
import { SinonFakeTimers, spy, useFakeTimers } from 'sinon';
import TextField from '@material-ui/core/TextField';
import { TransitionProps } from '@material-ui/core/transitions';
import { act, fireEvent, screen, userEvent } from 'test/utils';
Expand Down Expand Up @@ -42,7 +42,14 @@ const UncontrolledOpenDesktopDatePicker = (({
}) as typeof DesktopDatePicker;

describe('<DesktopDatePicker />', () => {
const render = createPickerRender({ strict: false });
let clock: SinonFakeTimers;
beforeEach(() => {
clock = useFakeTimers();
});
afterEach(() => {
clock.restore();
});
const render = createPickerRender();

it('prop: components.OpenPickerIcon', () => {
function HomeIcon(props: SvgIconProps) {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import * as React from 'react';
import { expect } from 'chai';
import { spy } from 'sinon';
import { SinonFakeTimers, spy, useFakeTimers } from 'sinon';
import { act, describeConformance, screen, fireEvent, userEvent } from 'test/utils';
import { createTheme, ThemeProvider } from '@material-ui/core/styles';
import TextField, { TextFieldProps } from '@material-ui/core/TextField';
Expand All @@ -23,14 +23,14 @@ const defaultRangeRenderInput = (startProps: TextFieldProps, endProps: TextField
);

describe('<DesktopDateRangePicker />', () => {
const render = createPickerRender({ strict: false });

before(function beforeHook() {
if (!/jsdom/.test(window.navigator.userAgent)) {
// FIXME This test suite is extremely flaky in test:karma
this.skip();
}
let clock: SinonFakeTimers;
beforeEach(() => {
clock = useFakeTimers();
});
afterEach(() => {
clock.restore();
});
const render = createPickerRender();

describeConformance(
<DesktopDateRangePicker
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import * as React from 'react';
import { expect } from 'chai';
import { spy, useFakeTimers, SinonFakeTimers } from 'sinon';
import TextField from '@material-ui/core/TextField';
import { fireEvent, screen } from 'test/utils';
import { act, fireEvent, screen } from 'test/utils';
import PickersDay from '@material-ui/lab/PickersDay';
import CalendarPickerSkeleton from '@material-ui/lab/CalendarPickerSkeleton';
import MobileDatePicker from '@material-ui/lab/MobileDatePicker';
Expand All @@ -16,7 +16,14 @@ import {
} from '../internal/pickers/test-utils';

describe('<MobileDatePicker />', () => {
const render = createPickerRender({ strict: false });
let clock: SinonFakeTimers;
beforeEach(() => {
clock = useFakeTimers(new Date());
});
afterEach(() => {
clock.restore();
});
const render = createPickerRender();

it('Accepts date on `OK` button click', () => {
const onChangeMock = spy();
Expand Down Expand Up @@ -267,39 +274,29 @@ describe('<MobileDatePicker />', () => {
expect(screen.getByText('July')).toBeVisible();
});

describe('mock time', () => {
let clock: SinonFakeTimers;

beforeEach(() => {
clock = useFakeTimers(new Date());
});

afterEach(() => {
clock.restore();
});

it('prop `showTodayButton` – accept current date when "today" button is clicked', () => {
const onCloseMock = spy();
const handleChange = spy();
render(
<MobileDatePicker
renderInput={(params) => <TextField {...params} />}
showTodayButton
cancelText="stream"
onClose={onCloseMock}
onChange={handleChange}
value={adapterToUse.date('2018-01-01T00:00:00.000')}
DialogProps={{ TransitionComponent: FakeTransitionComponent }}
/>,
);
const start = adapterToUse.date();
fireEvent.click(screen.getByRole('textbox'));
it('prop `showTodayButton` – accept current date when "today" button is clicked', () => {
const onCloseMock = spy();
const handleChange = spy();
render(
<MobileDatePicker
renderInput={(params) => <TextField {...params} />}
showTodayButton
cancelText="stream"
onClose={onCloseMock}
onChange={handleChange}
value={adapterToUse.date('2018-01-01T00:00:00.000')}
DialogProps={{ TransitionComponent: FakeTransitionComponent }}
/>,
);
const start = adapterToUse.date();
fireEvent.click(screen.getByRole('textbox'));
act(() => {
clock.tick(10);
fireEvent.click(screen.getByText(/today/i));

expect(onCloseMock.callCount).to.equal(1);
expect(handleChange.callCount).to.equal(1);
expect(adapterToUse.getDiff(handleChange.args[0][0], start)).to.equal(10);
});
fireEvent.click(screen.getByText(/today/i));

expect(onCloseMock.callCount).to.equal(1);
expect(handleChange.callCount).to.equal(1);
expect(adapterToUse.getDiff(handleChange.args[0][0], start)).to.equal(10);
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ describe('<MobileDateTimePicker />', () => {
clock.restore();
});

// StrictModeViolation: Uses CalendarPicker
const render = createPickerRender({ strict: false });

it('opens dialog on textField click for Mobile mode', () => {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import * as React from 'react';
import { expect } from 'chai';
import { SinonFakeTimers, useFakeTimers } from 'sinon';
import TextField from '@material-ui/core/TextField';
import { fireEvent, screen } from 'test/utils';
import StaticDatePicker from '@material-ui/lab/StaticDatePicker';
Expand All @@ -11,7 +12,15 @@ import {
} from '../internal/pickers/test-utils';

describe('<StaticDatePicker />', () => {
const render = createPickerRender({ strict: false });
let clock: SinonFakeTimers;
beforeEach(() => {
clock = useFakeTimers();
});
afterEach(() => {
clock.restore();
});

const render = createPickerRender();

it('render proper month', () => {
render(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import StylesProvider from '../StylesProvider';
import ThemeProvider from '../ThemeProvider';

describe('makeStyles', () => {
// StrictModeViolation: uses `useSynchronousEffect`
const mount = createMount({ strict: null });

/**
Expand Down

0 comments on commit 74bc5a6

Please sign in to comment.