-
Notifications
You must be signed in to change notification settings - Fork 30.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
deps: upgrade npm to 4.0.1 #9284
Conversation
You must be joking. Users of v6 which just went into LTS are now (by default) stuck with an npm that may never receive any updates?? |
Is this intended to be a patch-level release on our end? We'd need to have some discussions about that and I'm not sure how likely we are to accept it as such. I realize you say |
@Fishrock123 #8977 (comment) is what specifically calls out that As far as I know this is a conversation that has happened in disconnected ways between multiple parties (I've had various versions of it, myself, with you, @thealphanerd, and @jasnell, for example, and I think some of y'all had also had your own conversations with @othiym23). It seems clear from your reaction that this was surprising, and I did not expect it to be. We're unlikely to be completely rigid on stuff, and yes, the conversation matters. Perhaps #8977 is the place to center the specifics about it. Communication about LTS issues has been a bit difficult as of later. |
Just curious, how could this be a minor bump if there's (even small) breaking changes in npm? |
I think handling this as a semver-major for now is the right thing to do until we can get a better sense of the impact of the changes. The only real impact that would have is that v7, v6 and v4 would each continue with npm3 for the foreseeable future. If there's no significant breakage, then we can revisit the decision later on. Doing a feature freeze on npm3 seems appropriate. I think the main concern we have is that we'll be able to keep getting security and critical issue updates for the npm3 line, at least through the lifetime of the v6 LTS or until if/when a decision is made to pull npm4 into the LTS lines. @zkat the concerning (and surprising) part of your original post above is the statement "might end up being our last npm@3 release". That would imply that we wouldn't be seeing any updates at all, even for security, but I don't believe that is what you intended. |
@jasnell oh. no. I didn't mean to imply that. That was purely meant to emphasize that we're treating it as a maintenance thing: our stance about making sure there is a version of npm that works reliably for Node's LTS hasn't changed. There are, of course, possible exceptions to this: if something fundamental involving major changes that were made in a later version is what's "broken", we won't fix it (example: we're not going to patch Please let me know if I can help clarify anything about |
Replaced by #9848 |
Checklist
make -j8 test
(UNIX), orvcbuild test nosign
(Windows) passesAffected core subsystem(s)
deps
Description of change
Hey y'all! #8977 was created a while back to track stuff surrounding this release, and I think it's a good decision to wait to do a minor bump later, rather than rush this release out in any way. Thanks a bunch for your patience!
As you can see, this is a semver-major bump for npm. That said, the actual impact of the release to the ecosystem is relatively small. Most certainly much smaller in impact than
npm@3
was. We're still sniffing out a couple of issues and might even put together an[email protected]
soon to iron that out beforenpm@4
becomeslatest
.THIS IS NOT A FINAL RELEASE -- as mentioned in #8977, this is a preview of
npm@4
so y'all can start testing and taking a look at changes and make sure everything looks good before considering including it with official node releases.One more note: With the release of
npm@4
, we've decided to move bothnpm@2
andnpm@3
to maintenance: that means we're unlikely to continue adding features to either of those, but will include critical patches, specially security patches, if something comes up. Regular bugfixes will not be done, as it's much better for our team to be able to focus on the latest release which we're standing behind. As far as Node Core is concerned, though,npm@2
continues what we consider to be a sort of LTS release for y'all's sake. Maintenance doesn't mean it's no longer maintained, and users should continue to have a working experience withnpm@2
untilnode@4
leaves LTS.[email protected]
, which I'll be downstreaming soon, might end up being our lastnpm@3
release.So without further ado,
npm@4
!Breaking Changes
npm search
rewritten to stream results, and no longer supports sorting.npm scripts
no longer prepend the path of the node executable used to run npm before running scripts. A--scripts-prepend-node-path
option has been added to configure this behavior. (/cc @addaleax)prepublish
has been deprecated, replaced byprepare
. AprepublishOnly
script has been temporarily added, which will only run onnpm publish
. NOTE: This change only affects users publishing new versions of their packages and developers installing through git and local deps. Registry installs should be (mostly) unaffected by this change.npm outdated
exits with exit code1
if it finds any outdated packages. (/cc @watilde)npm tag
has been removed after a deprecation cycle. Usenpm dist-tag
.npm-shrinkwrap.json
is considered a complete installation manifest except fordevDependencies
. This will affect certain projects that relied heavily on this feature, most notablyhapi
.devDependencies
are now included innpm-shrinkwrap.json
by default. This should make the transition tonpm@5
easier.Other Notable Changes
Npm-In-CI
- whether npm was run within a Continuous Integration environment.Npm-Scope
- the scope of the toplevel package this installation is for. For example, if you have a@node/foo
package, all dependency requests for that package will include@node
in the header, even if those dependencies themselves are not scoped or are for a different scope.Changelogs
v3.10.9
v4.0.0
v4.0.1
r: @Fishrock123
r: @addaleax
r: @jasnell