💼 This rule is enabled in the following configs: angular
, dom
, marko
, react
, svelte
, vue
.
This rule aims to avoid the usage of side effects actions (fireEvent
, userEvent
or render
) inside waitFor
.
Since waitFor
is intended for things that have a non-deterministic amount of time between the action you performed and the assertion passing,
the callback can be called (or checked for errors) a non-deterministic number of times and frequency.
This will make your side-effect run multiple times.
Example of incorrect code for this rule:
await waitFor(() => {
fireEvent.keyDown(input, { key: 'ArrowDown' });
expect(b).toEqual('b');
});
// or
await waitFor(function() {
fireEvent.keyDown(input, { key: 'ArrowDown' });
expect(b).toEqual('b');
});
// or
await waitFor(() => {
userEvent.click(button);
expect(b).toEqual('b');
});
// or
await waitFor(function() {
userEvent.click(button);
expect(b).toEqual('b');
});
// or
await waitFor(() => {
render(<App />)
expect(b).toEqual('b');
});
// or
await waitFor(function() {
render(<App />)
expect(b).toEqual('b');
});
};
Examples of correct code for this rule:
fireEvent.keyDown(input, { key: 'ArrowDown' });
await waitFor(() => {
expect(b).toEqual('b');
});
// or
fireEvent.keyDown(input, { key: 'ArrowDown' });
await waitFor(function() {
expect(b).toEqual('b');
});
// or
userEvent.click(button);
await waitFor(() => {
expect(b).toEqual('b');
});
// or
userEvent.click(button);
await waitFor(function() {
expect(b).toEqual('b');
});
// or
userEvent.click(button);
waitFor(function() {
expect(b).toEqual('b');
}).then(() => {
// Outside of waitFor, e.g. inside a .then() side effects are allowed
fireEvent.click(button);
});
// or
render(<App />)
await waitFor(() => {
expect(b).toEqual('b');
});
// or
render(<App />)
await waitFor(function() {
expect(b).toEqual('b');
});
};