-
Notifications
You must be signed in to change notification settings - Fork 801
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
Add volta configuration for managing node versions #19705
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here are some suggested test cases for this PR.
Connection
- In-place connection with free plan
- In-place connection with paid plan
- In-place connection with product purchase
- Classic connection. Use Safari, or set a constant
JETPACK_SHOULD_NOT_USE_CONNECTION_IFRAME
to true - Disconnect/reconnect connection
- Secondary user connection
- Connection on multisite
Verify that the changes are compatible with the plugins that use the connection package.
- WooCommerce Payments
- Jetpack Boost
- Previous versions of Jetpack
If you think that suggestions should be improved please edit the configuration file here. You can also modify/add test-suites to be used in the configuration file.
Caution: This PR has changes that must be merged to WordPress.com |
Thank you for your PR! When contributing to Jetpack, we have a few suggestions that can help us test and review your patch:
This comment will be updated as you work on your PR and make changes. If you think that some of those checks are not needed for your PR, please explain why you think so. Thanks for cooperation 🤖 Once your PR is ready for review, check one last time that all required checks (other than "Required review") appearing at the bottom of this PR are passing or skipped. Jetpack plugin:
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That seems like an interesting tool! It's a bit of a pity that volta cannot rely on the existing engines
info though, that makes for a lot of duplication. Is there a way around that?
@@ -29,5 +29,8 @@ | |||
"engines": { | |||
"node": "^14.16.0", | |||
"yarn": "^1.3.2" | |||
}, | |||
"volta": { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't know if we'd want to extend here (and for the other packages), since the JITM package is also available standalone, in a situation where there is nothing to extend:
https://github.com/Automattic/jetpack-jitm/blob/master/package.json
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If nothing else, we could copy the configuration and use a script (run from precommit and CI) to ensure that the copies remain in sync and are in sync with .nvmrc. We could also verify that the "engines" are in sync everywhere too, and that the versions are compatible.
Or we could wait for volta to resolve volta-cli/volta#282 so we could just drop a .voltarc or whatever in the monorepo root.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't know if we'd want to extend here (and for the other packages), since the JITM package is also available standalone...
Makes sense! I'd forgotten about the mirror repos. I've updated the PR so that each package.json has the version info rather than extending the root, except for projects/plugins/jetpack/tests/e2e/package.json
, which now extends projects/plugins/jetpack/package.json
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We could also verify that the "engines" are in sync everywhere too, and that the versions [in .nvmrc versus package.json "engines.node"] are compatible.
FYI, I pushed #19748 to ensure that engines
in package.json is in sync everywhere, and #19750 to check that the version in .nvmrc
satisfies that called for by package.json.
Once those are merged, it should be straightforward to do the same for the volta blocks.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That seems like an interesting tool! It's a bit of a pity that volta cannot rely on the existing
engines
info though, that makes for a lot of duplication. Is there a way around that?
+1. I'm wary of adding a bunch of extra configuration for tools people may not actually use.
@@ -0,0 +1,4 @@ | |||
Significance: minor |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Seems not really "minor". It doesn't change the code at all, it's just configuring a dev tool.
Significance: minor | |
Significance: patch |
Same in your other changelog files.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Updated.
@anomiex That's totally a fair concern. Though I'd bet that this tool will become quite popular at a8c, particularly for WP.com developers, because we tend to interact with so many different product repos on a daily basis. When the node versions they use get out of sync (which seems to be frequently), it tends to cause problems, even with nvm configured properly. You can see one example of these troubles described here: 98-gh-Automattic/a8c-wp-env. Any one who's run into |
@jeherve Agreed! I don't see any way around this currently. It looks like there are a few different proposals in the works, e.g. volta-cli/volta#959. Discussions seem to be proceeding slowly, as it appears to me they're prioritizing a long-lasting, stable solution, that accounts for the variety of different ways of specifying node versions. |
As a note, I looked into it a bit and
Looking at 959, it sounds more like a way to easily pin a "supported" version of node vs just grabbing the latest LTS, which isn't ideal. I know traditionally Jetpack has aimed to update our |
On hold for now. Internal reference: p7H4VZ-31V-p2 In short, let's aim to upgrade to Node 16 first so everyone gets native Node binaries with Volta (reference) |
Volta hasn't implemented pnpm support yet: volta-cli/volta#737 |
I'll close this PR for now because of the lack of activity on this. We can always reopen in the future if needed, but it will need a rebase, so it may be easier to start a new PR at this point. |
Changes proposed in this Pull Request:
This adds a
volta
entries for all package.json files, pinning the node version for those using Volta.Some of the benefits over nvm include
nvm use
to select the correct node version.yarn
) are pinned correctly to the project version, without the need for usingnpx
.Volta can replace nvm, but those who wish to continuing using nvm can. As long as the project provides an .nvmrc file,
nvm use
overrides volta, in my testing.Related wp-calypso PR.
Jetpack product discussion
n/a
Does this pull request change what data or activity we track or use?
No
Testing instructions:
brew install volta
will do it on macOS with homebrew)volta list
, you should see the versions specified in package.json