-
-
Notifications
You must be signed in to change notification settings - Fork 2k
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
Incorrect dependency version for React needed for React Native 0.43 #893
Comments
There are no react versions greater than 15, yet. |
@ljharb Care to elaborate? |
Alphas aren't releases; enzyme doesn't tend to support React alphas. Since React 16 is only in alpha, React Native shouldn't be requiring it in a non-alpha release. |
That may be true, but that's not how they manage compatibility between React and React Native. Depending on the alpha is intentional. Still, it doesn't change that enzyme incorrectly identifies react major versions > 15 as 0.13-0.14. |
I agree that the error message is unhelpful; the best we could do to improve it is determine that you're using React > 15, and throw immediately. |
Any ETA on supporting react 16? It would help us make sure MobX supports React 16 when it is released :) |
It has been a month and a half since Enzyme has become incompatible with the latest stable React Native releases. The final React 16.0.0 is several months ahead (at least). |
This is a bug with react-native. An alpha should not be depended upon; and if it's stable enough to depend upon, it shouldn't be an alpha. Please feel free to file a bug on react-native and/or react. |
I apologize for this. I know it is frustrating, but unfortunately React 16 is a big change (basically a rewrite), and there’s a chicken and egg problem here. React Native is tightly coupled to React, but unlike React DOM, has a much faster breaking change release cycle (a month rather than a year). As a result, while we’re able to batch all ReactDOM breaking changes in yearly releases, we can’t really do the same for React Native. We have to dogfood 16 in order to fix issues in it, and we can’t let the open source version of RN diverge from an internal version because there’s so much more surface area, and a separate open source version would immediately go stale. For this reason, RN uses an “alpha” version of the Whether or not Enzyme is willing to support The matter is also complicated by the fact that |
I guess I'd expect an RN that depends on a react alpha to be an alpha itself - npm maintains 2 versions at once (4, and 5 alpha), for example, so I don't see why RN couldn't do the same. Server rendering is a pretty important use case for enzyme - |
My impression is it just would not very practical, as it would effectively make all future releases of RN “alphas” for a few months even though they’re more stable than previous versions. React itself is such a tiny part of React Native Perhaps this is something you could discuss with @yungsters. |
Doesn't seem like this issue is going to be resolved anytime soon. |
Issue is still there with latest and greatest RN releases :( |
I entirely agree with pushing back against FB/React/RN's confusing abuse of the "alpha" label—3rd party lib/tool support for RN in general is shockingly chaotic, and I think this cavalier attitude to release labeling and discipline is no small part of it—however they've shown no signs of changing their bizarre behavior, so it appears that any lib/tool that wishes to support RN ought to accept it or drop that support (publicly and as loudly as possible if you do, please). This ongoing clash of pushing-insane-release-labeling versus firmly-insisting-on-sane-release-labeling is just making life difficult for developers (users) of RN and related projects. In short, Facebook's entirely at fault for labeling their releases in a way that breaks convention, harms communication, erodes confidence/trust, and is generally and obviously poor practice for a bunch of good reasons, but having so many of the tools/libs that "support" RN always be several versions behind (and not always the same number of versions behind) RN stable really sucks for those of us trying to use it, regardless of whose fault it is. |
I think calling it "abuse" is a bit too much given that React team literally spends months of effort on things that don't matter to Facebook but are significant to the open source community. Yes, this particular case is unfortunate, and I'm open to suggestions on how we can make this better. What would you suggest we do instead? |
It's not a bit too much to call the use of [EDIT] As for suggestions, my preference would be that tools that support RN consider any dependencies that RN calls stable to be stable regardless of the stability-signifying labels those dependencies have chosen for themselves, or else prominently and persistently announce refusal to support RN releases with apparently-unstable dependencies, so that hopefully authors of things like e.g. Microsoft/Typescript's getting started with RN guide will catch on and include disclaimers about this weirdness alongside recommendations of tools like Enzyme, and maybe React/RN will change either their stability-signifying conventions or dependency inclusion behaviors so that they make more sense. |
The React team does amazing things, and I'm very glad Facebook and the React team are doing them - but that very statement, I think, represents the problem: that things being significant to the open source community don't automatically make them matter to Facebook as a whole. In this situation, I think the only path for now is to wait on #1007; after which, I hope both the React and React Native teams will ensure that any release includes an enzyme adapter that is compatible with it. I think that any other tooling that has issues will probably need to develop their own adapter pattern. |
I don't think this is relevant any more now that we're on v3 - a React Native enzyme adapter should address these issues. |
React Native 0.43 has a peer dependency on React 16.0.0-alpha.6, but react-compat doesn't check for major versions greater than 15.
This has the lovely effect of having the app compile and run successfully, but all the tests fail because it enzyme resolves to [email protected].
It looks like this should be fairly straightforward. I could probably draft a PR tomorrow if need be.
Here's the full error:
The text was updated successfully, but these errors were encountered: