2 - InstallationEdit this page on GitHub
Migrating from Yarn 1
We've been compiling helpful advice when porting over from Yarn 1 on the following Migration Guide. Give it a look and contribute to it if you see things that aren't covered yet! Make sure to consult the PnP Compatibility Table and enable the node-modules plugin if required!
Using a single package manager across your system has always been a problem. To be stable, installs need to be run with the same package manager version across environments, otherwise there's a risk we introduce accidental breaking changes between versions - after all, that's why the concept of lockfile was introduced in the first place! And with Yarn being in a sense your very first project dependency, it should make sense to "lock it" as well.
For this reason, Yarn 2 and later are meant to be managed on a by-project basis. Don't worry, little will change! Just make sure to first install the global Yarn binary that we will use to spawn the local ones:
npm install -g yarn
Once you've followed the instructions (running
yarn --version from your home directory should yield something like
1.22.0), go to the next section to see how to actually enable Yarn 2 on your project.
You've probably remarked the global Yarn is from the "Classic" line (1.x). This is expected! One extra perk of this system is that projects configured for Yarn 1 will keep using it instead of suddenly having to migrate to the 2.x configuration format. We wouldn't have had to do this if Yarn had been "project locked" from the beginning, but hindsight is 20/20 😉
- Install the Yarn global binary to its latest version:
npm install -g yarn
- Move into your project folder:
- Run the following:
yarn set version berry
"Berry" is the codename for all versions of Yarn from 2 onwards: 2.x, 3.x, etc. It's also the name of our repository!
- Commit new & updated files. See: Which files should be gitignored?
Should you later want to update Yarn to the latest version, just run:
yarn set version latest
Yarn will then download the most recent binary from our website, and install it in your projects. Don't forget to run a new install to update your artifacts, and to commit the results!
From time to time even the most recent releases aren't enough, and you then will want to try out the very latest master to check if a bug has been fixed. This has become very simple with Yarn 2! Just run the following command:
yarn set version from sources
Similarly, specific PRs can be installed using the
yarn set version from sources --branch 1211