-
Notifications
You must be signed in to change notification settings - Fork 391
Description
We have several test projects that we run "dotnet publish" to create an artifact to be run on a different machine from the build machine and when doing this we would get assembly binding errors like:
System.IO.FileLoadException : Could not load file or assembly 'System.Threading.Tasks.Extensions, Version=4.2.0.1, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51' or one of its dependencies. The located assembly's manifest definition does not match the assembly reference. (Exception from HRESULT: 0x80131040)
I found that when the project was built with dotnet build, it would have the correct version of System.Threading.Tasks.Extensions but when dotnet publish was run on the project, the System.Threading.Tasks.Extensions would be replaced with an older version (Version 4.0.0.0).
I traced this down to a build target here:
That copies all the assemblies in the build\netstandard1.0 directory to the publish directory. I'm not sure why this is done but many of the assemblies in this directory are assemblies that the project itself might also have and this copy ends up resulting in older assemblies being copied into the directory and autogeneratebindingredirects will have created binding redirects for the original assemblies and thus the tests will fail when trying to load these assemblies.