-
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 install overwrites linked modules with cached version #1214
Comments
This isn't specific to cached packages. I have a published package |
really need this |
this is breaking |
This applies even when you cd @my/local-dep
yarn link
cd ../../@my/main-project
yarn link @my/local-dep
yarn add lodash Even though I didn’t even explicitly do anything with This happens even if I specify It’s a particularly nasty problem because it overwrites my local working copy of $ yarn --version
0.16.1 |
I've noticed this issue as well. In my testing it seems to be limited to scoped modules, but that may not be true for everyone. My use case: Our team works in a monorepo. To get shared packages locally, the only way to have an efficient development process is to symlink them. Since we can't save symlinked installs to It's kind of a hack, but it works very well. However, npm shrinkwrap is so painful for us that switching to yarn is extremely advantageous, even if we have to work around a few warts due to early adoption. This issue is very bad for that above workflow though. Anytime yarn tries to install we run the risk of losing work. What exactly is the advantage of using the cache for local dependencies? Since they would never hit the network anyway, couldn't yarn just treat anything that's a |
I’d be much happier if Yarn just left linked dependencies alone—if it’s a symlink, either do nothing on the assumption that I want to work with it as a symlink, or if for some reason that can’t be done, issue an error and refuse to do anything. Even deleting the symlinks and replacing them with normal dependencies would be better—still a nuisance, but at least not as bad as the current behaviour.
IMHO, the preferred behaviour would be to leave symlinked directories alone, unless there’s a version mismatch, in which case error out with a descriptive message. |
What would be the advantage of this? Why not allow linked packages to be any version? I believe that's how NPM currently works. |
Having the same issue. It seems like it's replacing the linked module with the published version. As tho it's installing the package into the directory without realising it's a symlinked package. I don't think yarn's cache is the reason. |
I was able to get around this issue for time being by using |
This is very confusing behaviour of yarn, a big source of hassle, have you managed fix the logic behind it? I believe yarn should not check for cache when dealing with |
I've described inconsistent behaviour or yarn that leads to the issue: #1794 |
Btw in new 0.17.6 it seems that yarn doesn't replace content of simlinked folder (in node_modules) with version from cache, but installs new dependencies (that changed in linked package.json - which is nice) Can others confirm that this not an issue anymore? |
@whitecolor can confirm that with 0.17.6 the problem still persists. simlinked folder is having code overwritten by yarn. |
This is happening with a privately scoped npm repo ( |
@travisbloom right it seem to be true when you link scoped package, it works ok with not scoped symlinks (doesn't touch it). @wyze can you look in to it, to close issues with scoped packages? |
Scoped dependencies are nested one folder deeper than traditional dependencies, the possiblyExtraneous needed updating to work with the actual dependencies, not the entire scoped folder.
Scoped dependencies are nested one folder deeper than traditional dependencies, the possiblyExtraneous needed updating to work with the actual dependencies, not the entire scoped folder.
Just added a fix for this in #1970 |
Still an issue with 0.17.9 and a huge blocker for most of the scenarios involving npm/yarn link. |
+1, This is a big issue that caused us to lose uncommitted work from a linked repo. Would be good to get it fixed. |
Scoped dependencies are nested one folder deeper than traditional dependencies, the possiblyExtraneous needed updating to work with the actual dependencies, not the entire scoped folder.
Can confirm I don't get this issue in the latest version 0.19.1. |
Yep, this can probably be closed now |
I am still seeing this issue on yarn@0.22.0. I'm using 'lerna' so if I have packageA depending on packageB via a symlink and then run |
@AlastairTaft can you make a list of simple steps to reproduce? |
Simple reproduction with file: protocol.
yarn v0.22.0 |
@dalmaer and on the latest stable 23.2? |
We just landed a fix to file: dependencies on master.
Check out in 0.24 next week
…On 27 April 2017 at 15:09, Alex ***@***.***> wrote:
@dalmaer <https://github.com/dalmaer> and on the latest stable 23.2?
—
You are receiving this because you modified the open/close state.
Reply to this email directly, view it on GitHub
<#1214 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/ACBdWJx3UiG6uRUHgZeNqqGlsUyGyd2Pks5r0KGIgaJpZM4KaX2W>
.
|
This is still happening. I just opened #3288 to report the same behavior. Happens with 0.23.4. We're not using file protocol. Could possibly be related to scoped/private as that is where we're seeing it. |
Is there any workaround for this which I am not aware of? Needless to say, having your working copies constantly overwritten by cached content without you realizing it has a major impact on development. |
@oliversalzburg I advice to try this for development with local packages: https://github.com/whitecolor/yalc (it can make your life really easier) |
@whitecolor Awesome. Thanks a lot. I'll check it out. |
I'm still trying to confirm if this is what happened, but it appears that yarn overwrote local files across multiple files with cached symlinked versions. I'm using yarn |
@bestander Can you reopen this issue? It is not solved. I would really appreciate some feedback on this. |
@oliversalzburg please open a new one with a scenario how to reproduce it. |
@bestander I had already opened #3288, but I'm having a really hard time reproducing the issue in isolation. It happens multiple times every day in our main project tree though. It would be really nice to investigate this with someone who is more familiar with the code base and maybe give me some pointers on what to look for. |
I'm getting this issue on version 0.24.5.
steps to reproduce: cd path/to/a-dev-package |
Thanks, @danilo-drs, I've extracted this into a separate issue #3645 |
I believe this issue is not solved in v0.27.5. node here is 6.11 and npm 5.04. Steps (note: A is a dependency to B in package.json):
|
@stelf yarn takes into account what is in your package.json to keep consistency. So it actually doesn't take into account that you linked the module (there is no any notice about it, except symlink directory in node_modules ). There is |
This is still happening with yarn v1.2.1:
So this is the expected behavior? |
Still outstanding and needs to be fixed. When I run |
Looks like the original issue was fixed but there may be other cases when it is still relevant. |
Created new issue #4770 as requested. |
Do you want to request a feature or report a bug?
Bug
What is the current behavior?
Running
yarn install
for an app that has linked modules results in yarn copying its cached version of each module to the symlinked directory, overwriting the local copy in the process.If the current behavior is a bug, please provide the steps to reproduce.
I struggled to reproduce this from scratch, it's possible that it's down to a specific combination of factors with my setup. This involves local copies of private/scoped npm modules
yarn link
ed from an application, and referenced in package.json viafile:../xxx
. The version of the modules yarn has in its cache appears to be from when I first installed and ran it a few days ago (there have been numerous changes to the modules since), so it's possible the problem lies with its caching strategy as much as its installation strategy.One observation I've made is that the problem occurs even when using
yarn install --force
to supposedly bypass the cache.Happy to answer any questions and/or try anything to help pinpoint the problem.
What is the expected behavior?
yarn install should skip linked modules like npm intstall does. Performing the same steps above using npm install does not result in this problem.
Please mention your node.js, yarn and operating system version.
node v6.2.2
yarn v0.16.0
Mac OS X v10.10.5
The text was updated successfully, but these errors were encountered: