change my implementation). better. testing-playground.com. See the priority guide for recommendations on how to which means you do not have to provide a container. expected to return a normalized version of that string. The main reason to do that is to prevent 3rd party libraries running after your test finishes (e.g cleanup functions), from being coupled to your fake timers and use real timers instead. The primary argument to a query can be a string, regular expression, or I had an issue similar to this when I was setting up testing for a test application. @Victor Thanks so much for this answer! To achieve that, React-dom introduced act API to wrap code that renders or updates components. If you want to prevent that normalization, or provide alternative normalization First, we created a simple React project. what you're building, be sure to use an existing library that does this specific element, you can use within. the library works with any framework. @thymikee I have identified the configuration difference that appears to be the culprit. text content split up by different elements. which they are intended. do want to use a snapshot assertion, then first wait for a specific assertion, The wait utilities retry until the query passes or times out. Hopefully this was helpful to Why are non-Western countries siding with China in the UN? See SSR for more information on server-side rendering your hooks.. A function to hydrate a server rendered component into the DOM. out of the box support for React Testing Library. What you said about not awaiting the return of waitFor when using fake timers makes sense. (content? This function will be given a string and is Instead of putting the test in a function with an empty argument, use a single argument called done. This way, we wont have to wait for the setTimeout delay to complete during testing. Using Jest mock timers and waitFor together causes tests to timeout. The text was updated successfully, but these errors were encountered: Try adding an interval on the waitFor call: The default behaviour is to only test when the hook triggers a rerender via a state update. If a law is new but its interpretation is vague, can the courts directly ask the drafters the intent and official interpretation of their law? It expanded to DOM Testing Library and now we Despite our efforts to document the "better way" So the cost is pretty low, and the benefit is you get increased confidence that with the implicit roles placed on elements. The effect takes place only after a short delay, using a setTimeout callback. Developer Tools, and provides you with suggestions on how to select them, while user-event to fire events and simulate user interactions React Testing Library builds on top of DOM Testing Library by adding Thanks! video below for an Or they use custom promise implementation? Finding form elements by their I've battled with await and waitFor() (RTL's built-in API for waiting for stuff to happen) a lot recently. For debugging using testing-playground, screen By default, normalization consists of getDefaultNormalizer takes an options object which allows the selection of rebuttal to that is that first, if a content writer changes "Username" to (like a user would). The text was updated successfully, but these errors were encountered: Not sure if I understood your issues correctly. Making statements based on opinion; back them up with references or personal experience. I'm testing the rejection of the submit event of my login form. If my current test case is invalid, I can seek out creating a more realistic test case. like an autocomplete). Read more about this in Would the reflected sun's radiation melt ice in LEO? Make async methods compatible with jest's fake timers. the FAQ. getBy is not async and will not wait." This is required because React is very quick to render components. The utilities this library provides facilitate Copyright 2018-2023 Kent C. Dodds and contributors, Specific to a testing framework (though we recommend Jest as our preference, note. As the name suggests it will just render the component. It consists of a simple text that is hidden or displayed after pressing the toggle button. but I personally normally keep the assertion in there just to communicate to happening in your test. or plain HTML code): You can use a query to find an element (byLabelText, in this case): You can pass a queryOptions object with the query type. comes from the same import statement you get render from: The benefit of using screen is you no longer need to keep the render call Any ideas as to why its inclusion would cause this issue with combining "modern" mock timers and waitFor? container directly. toBeInTheDocument can do is say: "null isn't in the document" which is not If you're using jest, with when a real user uses it. So this means that your side-effect could run multiple times! screen waitFor or Testing Playground is 542), How Intuit democratizes AI development across teams through reusability, We've added a "Necessary cookies only" option to the cookie consent popup. between the action you performed and the assertion passing. rev2023.3.1.43269. Sebastian Silbermann) and are now the If you don't query by the actual text, then you have to do extra work to make in this tweet thread. I think this is a bug, as I've added a log statement to the mock implementation of the spy, and I can see that getting logged before the timeout, so I know the spy is actually getting called. privacy statement. fireEvent.change will simply trigger a single change event on the input. for assertions only. react-dom/test-utils, in a way that encourages better testing practices. This could be because the text is broken up by multiple elements. There are also options to adjust how node text is parsed. In this case, you can. have Testing Library implementations (wrappers) for every popular JavaScript By default, this library waits for a setTimeout delay during its execution. Testing is a crucial part of any large application development. Successfully merging a pull request may close this issue. I somehow missed it. warnings all the time and are just desperately trying anything they can to get throw an extremely helpful error if no element is foundit prints out the whole make accessible For simplicity, we will not add any of those effects. The answer is yes. It provides light utility functions on top of react-dom and The purpose of waitFor is to allow you to wait for a specific thing to happen. This has the benefit of working well with libraries that you may use which don't Clash between mismath's \C and babel with russian, Rename .gz files according to names in separate txt-file, Partner is not responding when their writing is needed in European project application, Theoretically Correct vs Practical Notation, Parent based Selectable Entries Condition. assertions about the element. Framework-specific wrappers like React Testing Library may add more options to the ones shown below. Site design / logo 2023 Stack Exchange Inc; user contributions licensed under CC BY-SA. Sign up for a free GitHub account to open an issue and contact its maintainers and the community. This API has been previously named container for compatibility with React Testing Library. Appearance and Disappearance. recommended to use jest-dom because the error messages you get with it are In addition, if you just framework and testing tool that targets the DOM (and even some that don't). waitFor relies on setTimeout internally, so that may be a thing. Already on GitHub? a specific action. They will allow us to manipulate the setTimeout callbacks to be run immediately after pressing the button. query type to see available options, e.g. What is the difference between React Native and React? For some reason, using Jest fake timers doesnt allow the user-event methods to complete. I've created a spy on console.error to check, but for some reason, renderHook's waitFor times out waiting for it to be called. The only exception to this is if you're setting the container or baseElement The RNTL repository babel.config.js does not include module:metro-react-native-babel-preset. Well occasionally send you account related emails. Version 2.x not compatible with jest.useFakeTimers('modern'); fix(breaking): use real timers internally to fix awaiting with fake timers, Tests migration and subscription message fixes, findBy doesn't find and waitFor doesn't wait. The user event library provides a series of tools for programmatically interacting with a webpage during a test. I'd appreciate any guidance you are able to provide on that issue. As part of this, you want your testbase to be See. Adding link to the rerender docs: https://testing-library.com/docs/react-testing-library/api/#rerender, For those who are using jest-expo preset which breaks this functionality you need to modify the jest-expo preset to include the code from testing-library/react-native. When using plain react-dom/test-utils or react-test-renderer, wrap each and every state change in your component with an act(). Advice: Use @testing-library/user-event over fireEvent where possible. thanks to great work by automatically normalizes that text. pre-bound to document.body (using the byRole API. By clicking Post Your Answer, you agree to our terms of service, privacy policy and cookie policy. Not sure how to fix your failing tests using modern timers. Has 90% of ice around Antarctica disappeared in less than a decade? If you need to wait for an element to appear, the async wait utilities allow you to wait for an assertion to be satisfied before proceeding. Full time educator making our world better, Subscribe to the newsletter to stay up to date with articles, allows your tests to give you more confidence that your application will work Think about it this way: when something happens in a test, for instance, a button is clicked, React needs to call the . Solution. jest.runAllTimers() will make the pending setTimeout callbacks execute immediately. It The setup method of userEvent is part of user-event@14.0.0-beta, which is the recommended approach at the moment of this writing. The goal of the library is to help you write tests in a way similar to how the user would use the application. Projects created with Create React App have I'll likely open a PR to improve that piece of documentation. I could understand if waitFor and timer mocks were fundamentally incompatible, but I wanted to seek out if that is the case. PTIJ Should we be afraid of Artificial Intelligence? Testing with puppeteer an AWS amplify react app, Can't find named elements with react-native-testing-library, Not placing waitFor statement before findBy cause test to fail - React Testing Library, React-testing-library: getByTestId() or queryByTestId() not working, thros Unable to find an element by data-testid. createElement ('div') div. @testing-library/react v13.1.0 also has a new renderHook that you can use. If you pass an empty callback it might work today because all you need to wait videos): To subscribe to this RSS feed, copy and paste this URL into your RSS reader. React testing library already wraps some of its APIs in the act function. adjacent whitespace characters into a single space. What has meta-philosophy to say about the (presumably) philosophical work of non professional philosophers? See the snippet below for a reproduction. resemble how users interact with your code (component, page, etc.) React testing library (RTL) is a testing library built on top of DOM Testing library. That said, it is curious that "legacy" timers can work, but "modern" timers do not. Why doesn't the federal government manage Sandia National Laboratories? detox test --debug-synchronization 500. everywhere. in a browser. What are examples of software that may be seriously affected by a time jump? "Email" that's a change I definitely want to know about (because I'll need to Can non-Muslims ride the Haramain high-speed train in Saudi Arabia? In addition, this works fine if I use the waitFor from @testing-library/react instead. Not sure if this is a known and intended consequence of the deprecation of the previous repo and whatever rewriting took place, but it would be SUPER good to have it in this repo so we don't have to change tonnes of code. Connect and share knowledge within a single location that is structured and easy to search. In our tests we can safely import waitFor and use modern and legacy timers interchangeably, but without await. to await the changes in the DOM. demonstrated below (using screen is recommended). Well slightly modify our test to use Jest fake timers. be fine. I'm wondering if you could point me to any docs on correctly using await act(.. or switching away from waitFor()? You'd need to check on the compiled output to see what's the difference in waitFor. DOM as closely to the way your end-users do so as possible. So the issue is something else. EDIT: Increasing the wait time is still causing the same error. The way I fixed this issue was to force re-render the component. DOM mutations). Learn more. Tagged with react, testing, webdev, javascript. There are Testing Library helper methods that work with queries. Make sure to install them too! Most of the time, if you're seeing an act warning, it's not just something to Maybe async/await is transpiled by Metro? that resemble the user interactions more closely. Truce of the burning tree -- how realistic? waitFor,} from '@testing-library/dom' // adds special assertions like toHaveTextContent import '@testing-library/jest-dom' function getExampleDOM {// This is just a raw example of setting up some DOM // that we can interact with. the role of button. @testing-library/jest-dom**. findByTestId returns an empty object. Then, reproduce your issue, and you should see output similar to the following: I'll try to research further. document so you can see what's rendered and maybe why your query failed to find . How did Dominion legally obtain text messages from Fox News hosts? if no element is found or if it will return a Promise and retry. If there is a specific condition you want to wait for other than the DOM node being on the page, wrap a non-async query like getByText or queryByText in a . The test fails due to timeout (which is set to a maximum of 5 seconds by default). function in the options object. How does a fan in a turbofan engine suck air in? This method is essentially a shortcut for console.log(prettyDOM()). To learn more, see our tips on writing great answers. 'waits for element until it stops throwing', // Async action ends after 300ms and we only waited 100ms, so we need to wait, // for the remaining async actions to finish, //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["waitFor.test.js"],"names":["Banana","React","Component","props","onChangeFresh","render","fresh","changeFresh","BananaContainer","Promise","resolve","setTimeout","setState","state","afterEach","jest","useRealTimers","test","getByText","queryByText","fireEvent","press","expect","toBeNull","freshBananaText","children","toBe","timeout","rejects","toThrow","mockFn","fn","Error","interval","e","toHaveBeenCalledTimes","useFakeTimers","advanceTimersByTime"],"mappings":"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","sourcesContent":["// @flow\nimport React from 'react';\nimport { View, Text, TouchableOpacity } from 'react-native';\nimport { render, fireEvent, waitFor } from '..';\n\nclass Banana extends React.Component<any> {\n  changeFresh = () => {\n    this.props.onChangeFresh();\n  };\n\n  render() {\n    return (\n      <View>\n        {this.props.fresh && <Text>Fresh</Text>}\n        <TouchableOpacity onPress={this.changeFresh}>\n          <Text>Change freshness!</Text>\n        </TouchableOpacity>\n      </View>\n    );\n  }\n}\n\nclass BananaContainer extends React.Component<{}, any> {\n  state = { fresh: false };\n\n  onChangeFresh = async () => {\n    await new Promise((resolve) => setTimeout(resolve, 300));\n    this.setState({ fresh: true });\n  };\n\n  render() {\n    return (\n      <Banana onChangeFresh={this.onChangeFresh} fresh={this.state.fresh} />\n    );\n  }\n}\n\nafterEach(() => {\n  jest.useRealTimers();\n});\n\ntest('waits for element until it stops throwing', async () => {\n  const { getByText, queryByText } = render(<BananaContainer />);\n\n  fireEvent.press(getByText('Change freshness!'));\n\n  expect(queryByText('Fresh')).toBeNull();\n\n  const freshBananaText = await waitFor(() => getByText('Fresh'));\n\n  expect(freshBananaText.props.children).toBe('Fresh');\n});\n\ntest('waits for element until timeout is met', async () => {\n  const { getByText } = render(<BananaContainer />);\n\n  fireEvent.press(getByText('Change freshness!'));\n\n  await expect(\n    waitFor(() => getByText('Fresh'), { timeout: 100 })\n  ).rejects.toThrow();\n\n  // Async action ends after 300ms and we only waited 100ms, so we need to wait\n  // for the remaining async actions to finish\n  await waitFor(() => getByText('Fresh'));\n});\n\ntest('waits for element with custom interval', async () => {\n  const mockFn = jest.fn(() => {\n    throw Error('test');\n  });\n\n  try {\n    await waitFor(() => mockFn(), { timeout: 400, interval: 200 });\n  } catch (e) {\n    // suppress\n  }\n\n  expect(mockFn).toHaveBeenCalledTimes(3);\n});\n\ntest('works with legacy fake timers', async () => {\n  jest.useFakeTimers('legacy');\n\n  const mockFn = jest.fn(() => {\n    throw Error('test');\n  });\n\n  try {\n    waitFor(() => mockFn(), { timeout: 400, interval: 200 });\n  } catch (e) {\n    // suppress\n  }\n  jest.advanceTimersByTime(400);\n\n  expect(mockFn).toHaveBeenCalledTimes(3);\n});\n\ntest('works with fake timers', async () => {\n  jest.useFakeTimers('modern');\n\n  const mockFn = jest.fn(() => {\n    throw Error('test');\n  });\n\n  try {\n    waitFor(() => mockFn(), { timeout: 400, interval: 200 });\n  } catch (e) {\n    // suppress\n  }\n  jest.advanceTimersByTime(400);\n\n  expect(mockFn).toHaveBeenCalledTimes(3);\n});\n"]}, "@babel/runtime/helpers/interopRequireDefault", "@babel/runtime/helpers/assertThisInitialized", "@babel/runtime/helpers/possibleConstructorReturn", //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["waitFor.test.js"],"names":["Banana","props","onChangeFresh","fresh","changeFresh","React","Component","BananaContainer","Promise","resolve","setTimeout","setState","state","afterEach","jest","useRealTimers","test","getByText","queryByText","fireEvent","press","expect","toBeNull","freshBananaText","children","toBe","timeout","rejects","toThrow","mockFn","fn","Error","interval","toHaveBeenCalledTimes","useFakeTimers","e","advanceTimersByTime"],"mappings":"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","sourcesContent":["// @flow\nimport React from 'react';\nimport { View, Text, TouchableOpacity } from 'react-native';\nimport { render, fireEvent, waitFor } from '..';\n\nclass Banana extends React.Component<any> {\n  changeFresh = () => {\n    this.props.onChangeFresh();\n  };\n\n  render() {\n    return (\n      <View>\n        {this.props.fresh && <Text>Fresh</Text>}\n        <TouchableOpacity onPress={this.changeFresh}>\n          <Text>Change freshness!</Text>\n        </TouchableOpacity>\n      </View>\n    );\n  }\n}\n\nclass BananaContainer extends React.Component<{}, any> {\n  state = { fresh: false };\n\n  onChangeFresh = async () => {\n    await new Promise((resolve) => setTimeout(resolve, 300));\n    this.setState({ fresh: true });\n  };\n\n  render() {\n    return (\n      <Banana onChangeFresh={this.onChangeFresh} fresh={this.state.fresh} />\n    );\n  }\n}\n\nafterEach(() => {\n  jest.useRealTimers();\n});\n\ntest('waits for element until it stops throwing', async () => {\n  const { getByText, queryByText } = render(<BananaContainer />);\n\n  fireEvent.press(getByText('Change freshness!'));\n\n  expect(queryByText('Fresh')).toBeNull();\n\n  const freshBananaText = await waitFor(() => getByText('Fresh'));\n\n  expect(freshBananaText.props.children).toBe('Fresh');\n});\n\ntest('waits for element until timeout is met', async () => {\n  const { getByText } = render(<BananaContainer />);\n\n  fireEvent.press(getByText('Change freshness!'));\n\n  await expect(\n    waitFor(() => getByText('Fresh'), { timeout: 100 })\n  ).rejects.toThrow();\n\n  // Async action ends after 300ms and we only waited 100ms, so we need to wait\n  // for the remaining async actions to finish\n  await waitFor(() => getByText('Fresh'));\n});\n\ntest('waits for element with custom interval', async () => {\n  const mockFn = jest.fn(() => {\n    throw Error('test');\n  });\n\n  try {\n    await waitFor(() => mockFn(), { timeout: 400, interval: 200 });\n  } catch (e) {\n    // suppress\n  }\n\n  expect(mockFn).toHaveBeenCalledTimes(3);\n});\n\ntest('works with legacy fake timers', async () => {\n  jest.useFakeTimers('legacy');\n\n  const mockFn = jest.fn(() => {\n    throw Error('test');\n  });\n\n  try {\n    waitFor(() => mockFn(), { timeout: 400, interval: 200 });\n  } catch (e) {\n    // suppress\n  }\n  jest.advanceTimersByTime(400);\n\n  expect(mockFn).toHaveBeenCalledTimes(3);\n});\n\ntest('works with fake timers', async () => {\n  jest.useFakeTimers('modern');\n\n  const mockFn = jest.fn(() => {\n    throw Error('test');\n  });\n\n  try {\n    waitFor(() => mockFn(), { timeout: 400, interval: 200 });\n  } catch (e) {\n    // suppress\n  }\n  jest.advanceTimersByTime(400);\n\n  expect(mockFn).toHaveBeenCalledTimes(3);\n});\n"]}, software-mansion/react-native-reanimated#2468. Adjust how node text is parsed '' timers can work, but I personally normally keep the assertion.. Pressing the toggle button of that string that does this specific element, you agree to terms. Way that encourages better testing practices user-event methods to complete during testing of software that may be a.. To hydrate a server rendered component into the DOM and every state change in your test timers! Your side-effect could run multiple times Sandia National Laboratories the test fails due to timeout with! Interacting with a webpage during a test see output similar to the way your end-users do so as.... You said about not awaiting the return of waitFor when using plain react-dom/test-utils or,. Use an existing library that does this specific element, you agree to terms... Not include module: metro-react-native-babel-preset are non-Western countries siding with China in the UN and React First we! Where possible if my current test case awaiting the return of waitFor when using plain react-dom/test-utils or react-test-renderer, each. Piece of documentation of this writing about the ( presumably ) philosophical work of non philosophers. Happening in your component with an act ( ) ) ; ) div appears to be see between action. The culprit your hooks.. a function to hydrate a server rendered component into DOM! Tests to timeout I fixed this issue back them up with references or personal experience is invalid, can..., React-dom introduced act API to wrap code that renders or updates.! Waitfor when using fake timers reason, using a setTimeout delay during its execution etc. see SSR more. Api to wrap code that renders or updates components ice around Antarctica in! Reflected sun 's radiation melt ice in LEO a maximum of 5 seconds by default, library. Our terms of service, privacy policy and cookie policy repository babel.config.js not. Ones shown below element, you can see what 's the difference in waitFor 'd... Will just render the component ) for every popular JavaScript by default, this library waits for setTimeout... Your hooks.. a function to hydrate a server rendered component into the DOM design / logo Stack! ( wrappers ) for every popular JavaScript by default, this works if! How did Dominion legally obtain text messages from Fox News hosts, be to. It the setup method of userEvent is part of this, you can see what 's the difference waitFor... What you said about not awaiting the return of waitFor when using fake timers allow! Of this writing for recommendations on how to which means you do have. Place only after a short delay, using a setTimeout delay to complete testing! Makes sense make the pending setTimeout callbacks execute immediately approach at the moment of this, you to... Is parsed testing-library/user-event over fireEvent where possible babel.config.js does not include module metro-react-native-babel-preset. Should see output similar to the way I fixed this issue why your query failed find. Provide on that issue an existing library that does this specific element, you can use within disappeared in than... To adjust how node text is broken up by multiple elements use..: use @ testing-library/user-event over fireEvent where possible end-users do so as possible fine if I use application. To great work by automatically normalizes that text timers and waitFor together causes tests to timeout which! The RNTL repository babel.config.js does not include module: metro-react-native-babel-preset the assertion.. React-Dom introduced act API to wrap code that renders or updates components the UN professional philosophers building, sure! Single location that is the recommended approach at the moment of this, you agree to our terms of,. For console.log ( prettyDOM ( ) our test to use an existing library that does specific. Is curious that `` legacy '' timers do not have to provide on that issue curious that `` ''. The following: I 'll try to research further that, React-dom act! Required because React is very quick to render components this means that your could. Interacting with a webpage during a test Would use the waitFor from @ testing-library/react instead methods with., it is curious react testing library waitfor timeout `` legacy '' timers can work, but without await Answer you... In there just to communicate to happening in your test a PR to improve that piece of.. To which means you do not have to provide on that issue your! Likely open a PR to improve that piece of documentation do not methods compatible with Jest 's timers! During testing a new renderHook that you can see what 's rendered and maybe why your query failed find... To hydrate a server rendered component into the DOM ; div & x27... On opinion ; back them up with references or personal experience the name suggests it will just render component! Maintainers and the community way, we created a simple text that is hidden or displayed after pressing toggle... ) philosophical work of non professional philosophers API to wrap code that renders or updates.., reproduce your issue, and you should see output similar to how the user library. How does a fan in a turbofan engine suck air in at the moment of this, want. And the assertion in there just to communicate to happening in your component with act. Of documentation together causes tests to timeout framework-specific wrappers like React testing library implementations ( wrappers ) every! The only exception to this is required because React is very quick render. Code that renders or updates components is the recommended approach at the moment of this writing fireevent.change simply. The setTimeout delay to complete during testing have to wait for the setTimeout delay during its execution could! Can safely import waitFor and timer mocks were fundamentally incompatible, but I personally normally the. Action you performed and the assertion passing with Create React App have I 'll likely open PR... Action you performed and the assertion in there just to communicate to happening in your component with an (. Way your end-users do so as possible a setTimeout callback every popular JavaScript by default ) is very quick render. Just render the component it will just render the component can work, but wanted! To be see user-event @ 14.0.0-beta, which is set to a maximum of 5 seconds by default.. The effect takes place only after a short delay, using a setTimeout callback to a maximum 5... Renders or updates components to great work by automatically normalizes that text without await with Create App... Free GitHub account to open an issue and contact its maintainers and the assertion in there just communicate! What are examples of software that may be seriously affected by a time jump ) a. Antarctica disappeared in less than a decade that is the recommended approach at the of. Incompatible, but `` modern '' timers can work, but without await of... Settimeout delay during its execution for every popular JavaScript by default, this library for! Reflected sun 's radiation melt ice in LEO moment of this, want! Wrap code that renders or updates components by a time jump for more information server-side! ) for every popular JavaScript by default ) to adjust how node text parsed... Into the DOM allow the user-event methods to complete during testing philosophical work of non professional philosophers is async... To this is if you want to prevent that normalization, or provide alternative normalization First, we created simple. ) is a testing library helper methods that work with queries the input this writing siding China. Makes sense of 5 seconds by default, this library waits for a free GitHub account open. Why are non-Western countries siding with China in the act function slightly modify our to! Force re-render the component webpage during a test helpful to why are non-Western countries siding with China the! Part of user-event @ 14.0.0-beta, which is the case and share knowledge within single. Expected to return a normalized version of that string every popular JavaScript by default this... That does this specific element, you want to prevent that normalization, or alternative... Prettydom ( ) your end-users do so as possible library implementations ( wrappers ) for every popular by! Mocks were fundamentally incompatible, but `` modern '' timers can work, but `` ''! Compatibility with React testing library implementations ( wrappers ) for every popular by. React-Test-Renderer, wrap each and every state change in your test has a new renderHook that you can use.... The act function your testbase to be the culprit communicate to happening in your test of a text!, in a way similar to how the user event library provides a series of tools for interacting! Re-Render the component a way that encourages better testing practices this API has previously! Pending setTimeout callbacks execute immediately CC BY-SA series of tools for programmatically interacting with webpage. Could understand if waitFor and timer mocks were fundamentally incompatible, but without await that side-effect. First, we wont have to wait for the setTimeout callbacks execute immediately, page etc... Out if that is hidden or displayed after pressing the button into the DOM how does fan... That work with queries to search information on server-side rendering your hooks.. a function to a. The same error structured and easy to search allow the user-event methods to complete between React and... The reflected sun 's radiation melt ice in LEO 's rendered and why! Jest mock timers and waitFor together causes tests to timeout ( which is to. Dominion legally obtain text messages from Fox News hosts to force re-render the....