-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support for React 18 #509
Comments
This is how #507 looks so far: const {container} = render(<div>test</div>, {root: 'concurrent'})
expect(container).toHaveTextContent('test') There's no breaking change required so far. It's more about figuring out how to teach this (do we need to test differently? what scheduler implementations are useful for testing? etc). |
Yea well, that's another "obvious choice", but I don't think it's a correct approach. Sure it gives good choice that only some tests can run concurrently. However, it's too verbose in my opinion. I would love to have ability to say that the whole test file run in Concurrent mode. I am still convinced that using the environment variable is the best approach here. It's then possible to pick which test files will run concurrently and which not by having two sets of |
I mean we can always read the default from a environment variable (or you import your own renderer that does that). Your approach would put the restriction on you to have different test files for different react modes. Mine would have no such restriction. This becomes more obvious if you think about blocking vs concurrent roots. You might want to test them next to each other. I don't understand how this is different to, say, |
Ok, that would help for sure. What I am trying to avoid here is the need to refactor tests in the future when "Concurrent is normal". Even if it's "only" about removing some option, it can be fairly tedious. Some new projects might even want to opt-in and go full Concurrent from the start so having some "global" switch is certainly helpful. |
I'm not sure this is even possible or desired. We need to figure some things out ourselves first. This might depend on the scheduler you mocked for your test, or maybe you want to assert that some side-effect was scheduled with a certain priority etc. Again I don't think API discussions are very helpful at this moment. It's more about finding out how you may want to write test for concurrent react or if these "just work"™ |
I believe the React team had some opinions on how this should be approached. |
In my conversations with folks at React Conf, I think the best approach is for people to run their tests using concurrent mode if their app uses concurrent mode which makes a lot of sense to me. The least annoying way (for users) to do this is via config IMO. The config defaults could be determined by environment variables though. |
In theory, you shouldn't have to rewrite your tests for concurrent mode. You'll have to add a line of configuration reactjs/react.dev#2171 In practice, there will be some stuff that is different. (Like, useTransition will clearly behave differently across modes) Overall, I don't think this will be a big problem. We're keeping an eye open for any edge cases. |
So, is it adding a scheduler mock going to be the official way to test React from now on? jest.mock("scheduler", () => require("scheduler/unstable_mock")); If so, could that be embedded somehow into |
This is a bit concerning. Mocking modules isn't as trivial with other test runners. Jest might make this easier but locking react users into jest is not helpful especially since jest can't run in the browser. |
You can set up your browser build to alias the mock scheduler in place of the scheduler. I understand the concern that it's not trivial, but I expect it to be solved in tools-land. I experimented with mocha+karma (and some others, can't recollect) and it didn't seem hard. Taking a step back, consider then what our options could be -
react-testing-library's As a data point, FB runs all its tests with the mocked scheduler (for all modes). Works well, so far. |
I think we could auto-mock the scheduler for people like this: if (typeof jest !== 'undefined') {
try {
jest.mock('scheduler', () => require('scheduler/unstable_mock'))
} catch (e) {
// no scheduler mock here
}
} I don't see a big problem with that personally. And if people don't like it, they can import the Though, it occurs to me just now that this may not work properly based on how jest mocking works. If It may just be better to document that people should do this themselves in their setup file 🤔 |
React warns about a missing mock scheduler if you try do an act() for a concurrent mode update, so that should make it easy too. (The warning might be behind a feature flag, I’ll check) |
😞 doesn't seem great since it's set up you need 100% of the time. That's going down the "enzyme-adapter-react-16-3" path with required configuration. I'd almost want this to be something handled by the jest environment, e.g. a "jest-environment-react". |
I agree. I definitely want the experience for 99% of users to be as config-free as possible. This is why we did the auto-cleanup thing :) I'd love to hear suggestions. We need to test things out. |
@kentcdodds I don't think it would be a big deal to export a single file with that mocking in a similar fashion as cleanup was. It can be imported in Or modifying The "jest-environment-react" does sound interesting too, but it already requires a configuration change, so no real benefit and on the contrary, it can block out if people need other envs for some reason. Another alternative that comes to my mind is to tweak |
If the auto-mock doesn't work during import because the |
The problem isn't in our code, but in the developer user's code: import React from 'react' // <-- too late
import {render} from '@testing-library/react' |
Yeah, they could add "jest-environment-react" there so CRA users would get that out of the box with the zero-config Jest env. Everyone else could either install and use that env or use a setup file we provide (if needed). Would also need instructions for Mocha, etc. |
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
Let's hold off on concurrent mode support until React concurrent mode is closer. Luckily it's pretty easy to implement yourself if you want to via: import React from 'react'
import ReactDOM from 'react-dom'
import {screen} from '@testing-library/dom'
import {fireEvent} from '@testing-library/react'
const root = document.createElement('div')
document.body.appendChild(root)
const unmount = ReactDOM.createRoot(root).render(<YourThing />)
// do tests with screen and fireEvent
unmount()
document.body.innerHTML = '' That should get people going until concurrent mode is more real :) Thanks! |
Uhh, easy you say? So when we have a bunch of tests written in RTL we will be rewriting them just to test it out? It's not like I need it for my app, this is MobX we are talking about here which should probably be prepared sooner than Concurrent becomes stable. Why close this, can't you keep it open for tracking toward the future? |
Hi @FredyC, I'm trying to clean up issues which don't currently have any action items (that applies to this issue). We can open it up again (or another one) when we have something to do. As for "easy." You should be using your own render via custom utils as described in the docs: https://testing-library.com/docs/react-testing-library/setup#custom-render If you're doing that then it should be relatively trivial to swap things within that render. Either way, I don't want to ship support for experimental features in general and when there's a reasonable workaround that makes me even less interested in doing so. |
I personally think that for now a custom render paired with a |
I think the recent announcement qualifies: https://reactjs.org/blog/2021/06/08/the-plan-for-react-18.html |
To test integration with React 18 please install To opt-out, set When using Please understand React 18 is currently an alpha and thereore any behavior is subject to change. We try to ensure compatibility with the latest React 18 version. If you encounter any issues with React 18 please open a new issue. |
I came here after running the included default test for a create-react-app project and seeing the following error:
I'm trying to figure out what the current guidance is on this as I would have guessed that the issue would have been sorted out since September 2021. Could anybody give some guidance? |
Hi @jpierson-at-riis. Thanks for writing this one :) Thanks to @eps1lon for the hard work on V13 to support React 18 🥳 |
This is the PR for CRA if someone's interested: |
I upgraded with |
Hi @afroguy16, thanks for reaching out. |
I am a bit confused. Is my assessment correct that you dropped support for React 17 in the latest version? The 'Support for React 18' confuses me as it suggests it an addition |
Check the release notes: /~https://github.com/testing-library/react-testing-library/releases/tag/v13.0.0 |
Yeah, I was reading it. I was getting confused about:
Somehow read it as being able to opt-out of the React 18 support 🤦♀️ Time to take some time off lol |
I have tested v13.0.0 in my repository and it seems that the test fails when it tries to query/find Components inside of Suspense. |
So it seems like this error remains unsolved? |
I couldn't find any guide in this regard on official documentation. Should we still wait for some update or what? |
Hi @ahangarha, what documentation are you specifically referring to? RTL version 13 was released with support for React 18, all you need to do is to upgrade the version you're using. |
Thank you @MatanBobi. I updated and now it is working well. Thanks |
quick question @eps1lon: while react-testing-library/src/pure.js Lines 235 to 238 in 73ee9ba
would it be okay to contribute this? I'm not entirely sure which of the other |
@TkDodo I think that makes sense |
npm install --save graphql graphql.macroconst network = 118; // Atom (SLIP-44) const request = connector._formatRequest({ connector |
Describe the feature you'd like:
It's probably premature, given experimental nature of Concurrent mode. but I might as we start the discussion.
Perhaps I am misunderstanding something, but I think it would be useful if tests would run in Concurrent mode to mimic real app behavior as close as possible.
At this point, it's probably about replacing
ReactDOM.render
withReactDOM.createRoot
.The question is how to make it in a compatible way so people can decide which version to use without polluting actual test files with it.
Suggested implementation:
Probably the most obvious choice is exposing function
renderConcurrent
which would be fine for the experimental phase. However, given that Concurrent will most likely become a "new normal" eventually, it would be kinda weird to have that in tests.Perhaps the env variable might be better approach ultimately. It's easy to switch and doesn't need to pollute actual test files with it.
Describe alternatives you've considered:
Publishing major version when Concurrent mode is official and stable and keep rolling in that direction only. An obvious drawback is that people would need to stick to the previous major as long as they are testing against code that doesn't support Concurrent mode.
The text was updated successfully, but these errors were encountered: