Yarn 3.1 🎃👻 Corepack, ESM, pnpm, Optional Packages ...
Maël Nison
Posted on October 25, 2021
Welcome to the release notes for Yarn 3.1! We're quite excited by this release, as it brings various improvements that we've all been looking forward to. Let's dig into that!
As always, keep in mind those are only the highlights, the full changelog is much more comprehensive. And if you just happen to love reading our release posts, here are the past entries 👇
- Yarn 3.0 🚀🤖 Performances, ESBuild, Better Patches, ...
- Yarn 2.4 🎄🎁 Log Filters, Audits, Better Warnings, ...
- Yarn 2.3 🍦✨ Info Command, Detailed Options, Nohoist, ...
- Yarn 2.2 🚅🌟 Dedupe, Faster, Lighter, ...
- Yarn 2.1 🐱🏍 Git Workspaces, Focused Installs, Loose Mode, ...
Sponsoring
The Yarn org needs your help to make our work more sustainable! Please take a look at our OpenCollective and GitHub Sponsors pages for more details 😊
Table of content
- Node.js Corepack Integration
- ESM Support
- New Install Mode:
pnpm
- Conditional Packages
- Smart Changeset Filters
- New Workspace Syntax:
workspace:^
Improvements
Node.js Corepack Integration
Did you know that Yarn now ships with Node? This is done via the Node.js Corepack project, which includes both the Yarn and pnpm binaries as shims. By adding the packageManager
field to your package.json
, you can enforce the use of a specific package manager & package manager version in a completely transparent way:
{
"packageManager": "yarn@3.1.0"
}
Note that Corepack is available starting from Node.js 16.9, but is currently opt-in. Don't forget to run corepack enable
a single time to make sure the shims are globally installed!
We also improved in 3.1 the init
command to properly support Corepack: running yarn init -2
will now automatically setup a Yarn Modern project, setting its packageManager
field as required 💫
ESM Support
ESM has always been supported when using the node_modules
linker, since it's the same old install strategy that Node has always supported. However, with PnP taking ownership of the resolution pipeline, compatibility with ESM wasn't a given and had to be implemented using the Loader Hook API.
While the Loader Hook API isn't entirely stable yet, a large amount of work has been made lately and our team has been able to produce an initial experimental support for ESM modules. It should be enabled automatically if we detect that one of the packages in your dependency tree contains a "type": "module"
field, but you can enable or disable it manually through your settings:
pnpEnableEsmLoader: true
Being experimental, it's possible that some bugs may arise or that new Node releases bring some breaking changes around the API. Be sure to report issues on our bug tracker!
New Install Mode: pnpm
The pnpm package manager was one of the first tools to advocate for using symlinks when installing packages within the node_modules
folder. While we went another way with PnP, we decided that the implementation cost was low enough that it would be worth adding support for this symlink-based install strategy as well.
Starting from Yarn 3.1, you can try out symlink-based installs by adding the following setting to your .yarnrc.yml
file:
nodeLinker: pnpm
Conditional Packages
Esbuild and swc are two native packages that gained a lot of attention lately thanks to their impressive performances over their competitors. They recently revamped how their packages are built to avoid complex postinstall scripts, but did so in a way that was less efficient than before for Yarn projects.
Yarn 3.1 features a new optimization that kicks in when a package is listed as optionalDependencies
and lists os
and/or cpu
fields. When that happens, Yarn will skip fetching and installing those packages unless they match the current system parameters.
In case you need to manually configure a strict set of package architectures to support (for example like in a zero-install case, where you want to read from an immutable set of packages), you can use the supportedArchitectures
setting:
supportedArchitectures:
os: [linux, darwin]
cpu: [x64, arm64]
Smart Changeset Filters
The yarn workspaces foreach
and yarn workspaces list
commands now ships with brand new --since
flags. When set, those commands will only execute against the packages that changed when compared to the main branch (either main
or master
, depending on the branches in your repository).
This can come in handy if you wish to only run builds in some specific workspaces, or just get a list of the workspaces which changed for scripting purposes:
yarn workspaces foreach --since run eslint .
yarn workspaces list --since
The --since
flag also accepts an optional argument (--since=${commit-ish}
) to manually define a source from which the changes should be derived.
New Workspace Syntax: workspace:^
Workspaces supported a special syntax via workspace:*
, with those ranges being replaced at publish-time by exact ranges corresponding to the real version of the target workspace. However, if you wanted to use a caret instead of an exact range, you had to use the verbose workspace:^x.y.z
form, which Yarn updated repo-wide after each publish.
Yarn now supports workspace:^
and workspace:~
as well, making it much easier to cross-reference workspaces within a monorepo where most packages are intended to be published, by preventing a good amount of the merge conflicts that used to happen after Yarn updated the verbose ranges.
Additionally, as a special case, this syntax is now allowed in the peerDependencies
field as well:
{
"peerDependencies": {
"@my/other-package": "workspace:^"
}
}
Posted on October 25, 2021
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.