.Net 2015 References with yellow triangle for Nuget packages on portable libraries

38,575

Solution 1

I figured out what the problem was!

As mentioned to @Gusman I had my warning switch off. Once I turned them on, I got the following displayed for my portable projects:

Warning: IDE0006 - Error encountered while loading the project. Some project
features, such as full solution analysis for the failed project and projects
that depend on it, have been disabled

and it provided a link to this article Diagnosing Project System Build Errors

After following the instructions provided and inspecting the numerous files ending in designtime.log, I noticed that all of them had a FAIL referring to a Nuget package but as mentioned, I had removed all of them from my various project, so I went to re-check the .csproj from one of them and this is when I spotted the problem(s)!

There are actually 2 problems:

  1. The Microsoft.BCL.Build reference for Nuget does not get remove properly!!

  2. When re-adding Microsoft.BCL.Build Nuget package, it does not set the path correctly in the .csproj

Below is an example of the fault:

<Import Project="..\..\..\packages\Microsoft.Bcl.Build.1.0.21
       \build\Microsoft.Bcl.Build.targets" Condition="Exists
       ('..\..\..\packages\Microsoft.Bcl.Build.1.0.21
       \build\Microsoft.Bcl.Build.targets')" />
<Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild">
    <PropertyGroup>
      <ErrorText>This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them.  For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}.</ErrorText>
    </PropertyGroup>
    <Error Condition="!Exists('..\packages\Microsoft.Bcl.Build.1.0.21\build\
        Microsoft.Bcl.Build.targets')" Text="$([System.String]::Format
        ('$(ErrorText)', '..\packages\Microsoft.Bcl.Build.1.0.21
        \build\Microsoft.Bcl.Build.targets'))" />
    <Error Condition="!Exists('..\..\..\packages\Microsoft.Bcl.Build.1.0.21\build\
        Microsoft.Bcl.Build.targets')" Text="$([System.String]::Format
        ('$(ErrorText)', '..\..\..\packages\Microsoft.Bcl.Build.1.0.21\
        build\Microsoft.Bcl.Build.targets'))" />
</Target>

As you can see the first line i.e. <Import Project="..\..\..\packages\Microsoft.Bcl.Build.1.0.21> should not be there and yet it appears to remain in the project even though Microsoft.BCL.Build has been removed.

If you need it leave it and fix the second entry as this is what I did. As you can see there are two entries checking for the Microsoft.BCL.Build Nuget package. In my case, I simply removed the first one:

`<Error Condition="!Exists('..\packages\`

and kept this one:

`<Error Condition="!Exists('..\..\..\packages\`

Once I finished editing the .csproj, I reloaded the project in my solution and not only was the Microsoft.BCL.Build issue resolved, it also resolved all the other Nuget dependencies that were marked with the yellow triangle.

Wasted most of my day on this, but hopefully this will help others.

Solution 2

If you've received no output errors during install and there are no Warnings on build/rebuild. Simply:

  1. Restart Visual Studio

Solution 3

I faced the same issue on a solution in vs2017 with 2 projects for framework DotNetCoreApp 1.1. All my packages showed the exclamation sign/yellow triangles. Once i ran vs2017 as an administrator, it was resolved.

Solution 4

I had a same issue when I cloned a project to my laptop from GitHub. There are yellow triangles displaying on my EntityFramework and AspNet.Identity as well. What I did to solve the issue in my case was to remove the packages folder (which contains Nuget packages) and restore packages once I opened the project. As a result, those warnings were switched off after I restarted VS2017.

Solution 5

You could check my answer on relative topic here, because the answer of this topic it's a dangerous way to do things specially if you have a project on Production ambient: https://stackoverflow.com/a/59704420/7969733

Just for documentation purpose for new person with this issue try this and you will rememberme :D

If you go to: Tools > NuGet Administrator > Configurations. and you have "Allow nuget...." and "automatically check...." cheked.

The only thing than you have to do is click con the button "Clear All NuGet Cache(s)"

That's it, you don't have to edit manual thinks than can be dangerous, believe me, I use to need to done some of the steps than describe here a lot of time, and try more than 5 steps of the oficial microsoft documentation for that issue you could check it here: https://docs.microsoft.com/es-es/nuget/consume-packages/package-restore#restore-packages-automatically-using-visual-studio

But just cleaning the cache solve all the problems

Share:
38,575
Thierry
Author by

Thierry

Updated on January 13, 2020

Comments

  • Thierry
    Thierry over 4 years

    I know the question has been asked before but none of the suggested resolutions are working for me so I'm going to ask it again and hopefully get new suggestions. Some of the articles I've read:

    VS .Net References with yellow triangle Why do I get a warning icon when I add a reference to an MEF plugin project? The exclamation mark in the yellow triangle icon (inside Solution Explorer)

    My 5 portable libraries are definitely all targeting the same frameworks (I've checked and re-checked as this was one of the suggestions!):

    • .NET Framework 4.5
    • ASP.NET Core 1.0
    • Windows Phone 8
    • Windows Phone 8.1
    • Windows Phone Silverlight 8
    • Xamarin.Android
    • Xamarin.iOS
    • Xamarin.iOS (classic)

    What I've tried/done so far:

    • Remove Nuget package references manually from all projects.
    • Check each .csproj and made sure that the references were indeed removed.
    • Delete the packages folder in the root of my solution
    • Tried to re-installed all packages via the console manager. No error yet yellow triangle is still displayed.
    • Tried to re-installed all packages via the Nuget manager. No error yet yellow triangle is still displayed.

    Here is the section of one of my portable class library:

    <ItemGroup>
        <Reference Include="crypto">
          <HintPath>..\..\..\packages\Portable.BouncyCastle.1.8.1\lib\portable-
            net4+sl5+wp8+win8+wpa81+MonoTouch10+MonoAndroid10+xamarinmac20+xamarinios10
            \crypto.dll
          </HintPath>
      <Private>True</Private>
    </Reference>
    <Reference Include="Newtonsoft.Json">
      <HintPath>..\..\..\packages\Newtonsoft.Json.8.0.3\lib\portable-
          net40+sl5+wp80+win8+wpa81\Newtonsoft.Json.dll
      </HintPath>
      <Private>True</Private>
    </Reference>
    <Reference Include="System.Net.Http">
      <HintPath>..\..\..\packages\Microsoft.Net.Http.2.2.29\lib\portable-
          net40+sl4+win8+wp71+wpa81\System.Net.Http.dll
      </HintPath>
      <Private>True</Private>
    </Reference>
    <Reference Include="System.Net.Http.Extensions">
      <HintPath>..\..\..\packages\Microsoft.Net.Http.2.2.29\lib\portable-
          net40+sl4+win8+wp71+wpa81\System.Net.Http.Extensions.dll
      </HintPath>
      <Private>True</Private>
    </Reference>
    <Reference Include="System.Net.Http.Primitives">
      <HintPath>..\..\..\packages\Microsoft.Net.Http.2.2.29\lib\portable-
          net40+sl4+win8+wp71+wpa81\System.Net.Http.Primitives.dll
      </HintPath>
      <Private>True</Private>
    </Reference>
    

    My physcial project path is:

    C:\xxxx\xxxxxx\xxxxx-xxxxxxx

    so taking bouncycastle as an example and based on the above, I assume the full path would look like this:

    C:\xxxx\xxxxxx\xxxxx-xxxxxxx\packages\Portable.BouncyCastle.1.8.1\lib\portable-net4+sl5+wp8+win8+wpa81+MonoTouch10+MonoAndroid10+xamarinmac20+xamarinios10\crypto.dll

    This seems to be a problem only on my portable libraries as I've re-install all the Nuget packages on my uwp solution and they all worked as expected. The frustrating part is that my project which is still located in it's original location is working perfectly well. I've uninstalled the packages and re-installed them and everything is 100% working as expected.

    Has anyone got any other suggestions?

  • nh43de
    nh43de almost 7 years
    Long story short, check your project file and make sure there's nothing that holding up the build. Mine had a lingering Antlr runtime requirement that had been removed.
  • Rikon
    Rikon over 6 years
    you're fricken kidding me... I had been chasing core 1.0 issues down all afternoon and when I restarted VS, all my refs came in just fine...
  • pim
    pim over 6 years
    @Rikon sorry to hear about your luck! can't count the numbers of times I've been in the same boat... couple habits I've gotten myself into recently is closing tabs and environments somewhat frequently. Prevents head scratchers like this and I find my machine runs a little better.
  • Juan Carlos
    Juan Carlos over 6 years
    What year is this? And yes, sometimes this works. Means the project is not mature enough..
  • Sergi0
    Sergi0 over 6 years
    just helped me with BuildBundlerMinifier package
  • adamgede
    adamgede over 6 years
    @Sergi0 Same. And also JwtBearer... restarting the ide worked. I love my Chrome Tabs and apps, @pimbrouwers! Please don't take them away! :-(
  • pim
    pim over 6 years
    @adamgede So glad to hear this helped you. I should've been more clear in my comments. When I say "tabs" I mean VS Tabs. When I say "environments" I mean the various instances of VS I have open.
  • Gustavo Baiocchi Costa
    Gustavo Baiocchi Costa almost 6 years
    This was the fix to my problem :P
  • Lunster
    Lunster almost 6 years
    This worked after ensuring all of my project's .NET Framework versions were the same, Nuget packages were reinstalled, and finally - after much head scratching, simply restarting Visual Studio. If you're using something like Resharper, clear the caches out too.
  • Heike
    Heike over 5 years
    Such a simple solution to an annoying problem.
  • Ben Sampica
    Ben Sampica about 5 years
    How does this work?! Agh, so annoying - but thank you so much for this.
  • pim
    pim about 5 years
    @BenSampica it's really frustrating. If you look at the output window, you might get more insights as to what might be failing. It also might be that restarting VS resets the symbol cache (though this is a complete guess).
  • Prisoner ZERO
    Prisoner ZERO almost 5 years
    Ya know...after 20 years of Visual Studio...you would think "little things" like this would be worked-out (by now)