-
Notifications
You must be signed in to change notification settings - Fork 2.7k
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
yarn upgrade [pkg@tag] does not upgrade dist-tag version #2788
Comments
Does anyone have a setup where they can easily retest this on Yarn 1.2.1? If not, I can publish a dummy package to NPM and unpublish it later, just wanted to avoid adding a garbage package to NPM... |
Easily might be the wrong term (need to republish new package versions) - but can probably test this tonight with our private repo. |
Checked it in private repo — dependency is updated correctly, but package.json stays untouched. Is it intended? |
@Hypnosphi yes the current implementation of Any objections to closing this issue? |
Quite late to the party, but I can confirm this works as expected now. Yarn now also supports the Unfortunately our NPM workflow can still not be built with yarn as we're now affected by #4632 😢 |
Do you want to request a feature or report a bug?
bug
What is the current behavior?
When using a dist-tag dependency in the
package.json
, (example usingkw-util@bump
),yarn add
will install the version the tag currently points to and add it toyarn.lock
.Now when a new version is published to the repo and the tag is updated to point to the new version,
yarn outdated <package-name>
will correctly reflect that and show the new dependency:Note that the
package.json
did not change here, only the dist-tag in the repo moved to a new version.Running
yarn upgrade [package@tag]
now does NOT upgrade the package to the new version:Yarn outdated still gives the same output:
Note: there is a range of other open issues about install picking the wrong versions for dist-tags, including implicit
latest
tag, e.g. #2648, #1690, #2154.Note 2: running
yarn upgrade
(all packages) will indeed upgrade the package to the version the tag is pointing to - but since our use case is about updating upstream internal modules, we need to be able to do this for individual packages, without having to upgrade external/public packages.Ideally it should be possible to provide a list of packages to upgrade, too (we currently have 17 internal modules, which need to be upgraded after every upstream build...). The CLI actually accepts that, but since it doesn't work and the documentation only mentions a single package (see https://yarnpkg.com/en/docs/cli/upgrade#toc-yarn-upgrade-package-tag), I'm not sure if the CLI is lazy or actually supports upgrading several named packages in one go.
If the current behavior is a bug, please provide the steps to reproduce.
failure requires publishing a new version for an existing dist-tag, so no simple test-case possible.
What is the expected behavior?
upgrade package version to the version currently being pointed to by a dist-tag, when running
yarn upgrade [package@tag]
Please mention your node.js, yarn and operating system version.
The text was updated successfully, but these errors were encountered: