-
-
Notifications
You must be signed in to change notification settings - Fork 482
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
The newest version of glob and rimraf now is not supported for node 14 #596
Comments
If you are using an EOL node version as old as node 14, you must pin your dependencies. Your package manager should already be filtering out versions with a mismatched engines requirement, doesn't that work? |
NPM, at least, will log a nice warning but proceed with installation of the incompatible version and give you a successful exit code. Nothing in most build pipelines, for example, is going to stop or flag a failure here, which could certainly cause people some surprising problems! This also poses a problem for libraries that depend on glob, since it implicitly raises their Node.js minimum requirements without any changes on their part (in fact, I’m glad I just happened to be scrutinizing this update — for other, abnormal reasons — since this is exactly the position I was about to be in). I certainly thought this was pretty surprising in a patch release and I’d generally agree with @wghule that this is a breaking change for some people. At the very least, it deserves a callout in the changelog. |
npm should prioritize an engine match over a version that has an engine conflict. It only warns if it has to choose a version with an engines conflict, or throws if |
Well, I can only say that I tried it and, in practice, it installed an incompatible version. (On Node.js 16, required |
Maybe the code you’re pointing to is different in versions of NPM that are compatible with Node.js 16? I don’t know all the details of NPM’s own complex tree of dependencies across versions and, FWIW, I don’t feel like it is worth digging to understand what might be going wrong on a version of NPM for a version of Node.js that is probably no longer supported. I think the bigger issue is just that, in practice, at least one dependency manager (and probably others?) don’t automatically solve this issue for users the way you are expecting it to. |
I think it is correct to change the baseline version of nodejs, but the best practice is to release a major version to do this, because many other npm packages rely on your dependencies and use the semantic version specification. Now you have upgraded the baseline version of node through the patch version, which has caused problems for many upstream dependencies. Because many of our projects still rely on node 16 and are not ready to upgrade to version 18, I think this change is a break change. So see if you can release a new patch to restore the baseline version support of node, and then change the baseline of node version by upgrading the major version, so that we can upgrade to node 18 when we are ready. |
isaacs/node-glob#596 同作者多个基础 npm 包使用 patch 版本升级 node 版本依赖,导致固定 node 版本的使用者受阻。
I am getting this as well error glob@10.4.3: The engine "node" is incompatible with this module. Expected version ">=18". Got "16.20.1" |
And please make the older version of glob、jackspeak、lru-cache、rimraf and so on still work,not deprecated,thanks。It afffect many npm package and project。 |
This problem can be configured to set the package version |
did someone try to override version via package |
you also broke node 16 support! Make major version for this dude |
If we directly depend on these packages, it seems that we can solve it by locking the version, but there is such a situation:
In addition, some people may say that you can use yarn.lock or yarn resolutions to lock the version, but when |
We're also running into this issue with Node 16 at the moment. Please revert 8a69def and drop Node 16 support (if necessary) in a major release. Thank you! |
hi, I have temporary fix for my usecase comming from archiver@7.0.1 using yarn install in package.json I add : |
Yeah, this does not only affect |
… compatibility changes in dependencies (#12793) This PR fixes our broken Remix v1 @ Node 16 integration test. Over the weekend, the following transitive dependencies received minor and patch releases which removed support for EOL Node versions. - `glob` (isaacs/node-glob#596) - `lru-cache` (isaacs/node-lru-cache#340) - `jackspeack` (isaacs/jackspeak#13) IMO this, despite the dropped versions being EOL, is a breaking change and a major inconvenience for a lot of users. I added comments/opened issues with the request to revert the Node version drops and do it in a major version instead. We're by far not the only affected ones. As our tests show, at least everyone using Remix@1 on Node 16 will be broken by this. To fix, I added dependency resolutions, mostly scoped to specific packages that depend on one of the three packages. Global overrides for `glob` and `lru-cache` did not work because we have multiple dependencies depending on different major versions of said packages.
https://nodejs.org/en/blog/announcements/nodejs16-eol/ It's been EOL for 10 months. Pin your deps and only upgrade carefully if you are using EOL platform versions. |
The newest version of glob and rimraf now is not supported for node 14。if necessary,can you make major version upgrade?
The text was updated successfully, but these errors were encountered: