Ошибка запуска NUnit в MSBuild после обновления - System.IO.FileLoadException: не удалось загрузить файл или сборку nunit.framework

Недавно я обновил свое решение до Visual Studio 2013 и обновил ссылки на NUnit 2.6.3 в тестовых библиотеках с версии 2.6.2. В Visual Studio все работает нормально, но мои сценарии MSBuild, управляющие системой развертывания, полностью заблокированы.

Файлы сборки находятся в каталоге сборки, который содержит папку MSBuild с файлами MSBuild.Community.Targets, на которые есть ссылки, и каталог NUnit, содержащий nunit-console.exe и различные зависимые файлы. Я также обновил их до 2.6.3.

Я просто получаю эту ошибку ...

«System.IO.FileLoadException: не удалось загрузить файл или сборку» nunit.framework, Version = 2.6.0.12051, Culture = нейтральный, PublicKeyToken = 96d09a1eb7f44a77 или одна из его зависимостей. Определение манифеста обнаруженной сборки не соответствует ссылке на сборку. (Исключение из HRESULT: 0x80131040) '

Я вообще этого не понимаю - раньше это работало нормально, и весь код ссылался на 2.6.2, поэтому я понятия не имею, откуда взялось 2.6.0 и как я говорю ему искать 2.6.3 (что является прямо там!!)

Вот мой файл сборки (если это поможет) ...

<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="DeployAndPackage" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
  <!-- IMPORTS -->
  <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
  <Import Project="$(MSBuildProjectDirectory)\MSBuild\MSBuild.Community.Tasks.targets" />
  <UsingTask TaskName="TransformXml" AssemblyFile="$(MSBuildExtensionsPath)\Microsoft\VisualStudio\v10.0\Web\Microsoft.Web.Publishing.Tasks.dll"/>
  <!-- PROPERTIES -->
  <PropertyGroup Label="BuildOptions">
    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
    <Platform Condition=" '$(Platform)' == '' ">Any CPU</Platform>
    <OutputPath Condition=" '$(OutputPath)' == '' ">bin\</OutputPath>
    <ProjectConfiguration Condition=" '$(Configuration)' == '' ">Debug</ProjectConfiguration>
    <ProjectConfiguration Condition=" '$(Configuration)' == 'Test' ">Debug</ProjectConfiguration>
    <ProjectConfiguration Condition=" '$(Configuration)' == 'Staging' ">Release</ProjectConfiguration>
    <ProjectConfiguration Condition=" '$(Configuration)' == 'Live' ">Release</ProjectConfiguration>
  </PropertyGroup>
  <PropertyGroup Label="DirectoryPaths">
    <RootDir>$(MSBuildProjectDirectory)\..\</RootDir>
    <TestsDir>$(RootDir)Tests\</TestsDir>
    <DatabaseDir>$(RootDir)SiansPlan.Database\</DatabaseDir>
    <RelativePackageDir>$(RootDir)pkg\</RelativePackageDir>
    <Solution>$(RootDir)SiansPlan.sln</Solution>
    <SP_Auth>$(RootDir)SiansPlan.Authentication\SiansPlan.Authentication.csproj</SP_Auth>
    <SP_Database>$(DatabaseDir)SiansPlan.Database.sqlproj</SP_Database>
    <SP_Entities>$(RootDir)SiansPlan.Entities\SiansPlan.Entities.csproj</SP_Entities>
    <SP_Domain>$(RootDir)SiansPlan.Domain\SiansPlan.Domain.csproj</SP_Domain>
    <SP_Providers>$(RootDir)SiansPlan.Providers\SiansPlan.Providers.csproj</SP_Providers>
    <SP_ApiDir>$(RootDir)SiansPlan.Api\</SP_ApiDir>
    <SP_Api>$(SP_ApiDir)SiansPlan.Api.csproj</SP_Api>
    <SP_Web>$(RootDir)SiansPlan.Web\SiansPlan.Web.csproj</SP_Web>
    <SP_SpaDir>$(RootDir)SiansPlan.Spa\</SP_SpaDir>
    <SP_Spa>$(SP_SpaDir)SiansPlan.Spa.csproj</SP_Spa>
    <SP_Test_Support>$(TestsDir)SiansPlan.TestSupport\SiansPlan.TestSupport.csproj</SP_Test_Support>
    <SP_Entities_Tests>$(TestsDir)SiansPlan.Entities.Tests\SiansPlan.Entities.Tests.csproj</SP_Entities_Tests>
    <SP_Auth_Tests>$(TestsDir)SiansPlan.Authentication.Tests\SiansPlan.Authentication.Tests.csproj</SP_Auth_Tests>
    <SP_Domain_Tests>$(TestsDir)SiansPlan.Domain.Tests\SiansPlan.Domain.Tests.csproj</SP_Domain_Tests>
    <SP_Api_Tests>$(TestsDir)SiansPlan.Api.Tests\SiansPlan.Api.Tests.csproj</SP_Api_Tests>
  </PropertyGroup>
  <PropertyGroup Label="Globals">
    <ProjectGuid>2ae13924-f2dd-48b1-9acb-755e0ee2b0d1</ProjectGuid>
  </PropertyGroup>
  <!-- BUILD -->
  <Target Name="Compile">
    <MSBuild Projects="$(SP_Auth)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Database)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Entities)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Domain)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Providers)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Api)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Web)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Spa)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Test_Support)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Entities_Tests)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Auth_Tests)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Domain_Tests)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
    <MSBuild Projects="$(SP_Api_Tests)" Targets="Rebuild" Properties="Configuration=$(ProjectConfiguration);Platform=$(Platform);OutputPath=bin\" />
  </Target>
  <!-- TEST -->
  <Target Name="RunTests" DependsOnTargets="Compile">
    <CreateItem Include="$(RootDir)Tests\*.Tests\bin\*.Tests.dll">
      <Output TaskParameter="Include" ItemName="TestAssemblies" />
    </CreateItem>
    <NUnit Assemblies="@(TestAssemblies)" ToolPath="$(MSBuildProjectDirectory)\NUnit" DisableShadowCopy="true" />
  </Target>
  <!-- TRANSFORM -->
  <Target Name="Transform">
    <TransformXml Source="$(SP_ApiDir)\Web.config"
                  Transform="$(SP_ApiDir)\Web.$(Configuration).config"
                  Destination="$(SP_ApiDir)\Web.transformed.config"
                  StackTrace="False" />
    <TransformXml Source="$(SP_SpaDir)\Web.config"
                  Transform="$(SP_SpaDir)\Web.$(Configuration).config"
                  Destination="$(SP_SpaDir)\Web.transformed.config"
                  StackTrace="False" />
  </Target>
  <!-- DEPLOY & PACKAGE -->
  <Target Name="DeployAndPackage" DependsOnTargets="RunTests">
    <CallTarget Targets="Transform"/>
    <ItemGroup>
      <SqlFiles Include="$(DatabaseDir)Upgrades\*.sql" />
    </ItemGroup>
    <RemoveDir Directories="$(RelativePackageDir)" />
    <MakeDir Directories="$(RelativePackageDir)" />
    <MakeDir Directories="$(RelativePackageDir)sql\" />
    <Copy SourceFiles="@(SqlFiles)" DestinationFolder="$(RootDir)pkg\sql" />
  </Target>
</Project>

Полный вывод части сборки RunTests ...

RunTests:

C: \ Development \ Clients \ SiansPlan \ source \ build \ NUnit \ nunit-console.exe / nologo / noshadow C: \ Development \ Clients \ SiansPlan \ source \ build .. \ Tests \ SiansPlan.Api.Tests \ bin \ SiansPlan .Api.Tests.dll C: \ Development \ Clients \ SiansPlan \ source \ build .. \ Tests \ SiansPlan.Api.Tests \ bin \ SiansPlan.Domain.Tests.dll C: \ Development \ Clients \ SiansPlan \ source \ build .. \ Tests \ SiansPlan.Authentication.Tests \ bin \ SiansPlan.Authentication.Tests.dll C: \ Development \ Clients \ SiansPlan \ source \ build .. \ Tests \ SiansPlan.Domain.Tests \ bin \ SiansPlan.Domain.Tests .dll C: \ Development \ Clients \ SiansPlan \ source \ build .. \ Tests \ SiansPlan.Entities.Tests \ bin \ SiansPlan.Entities.Tests.dll C: \ Development \ Clients \ SiansPlan \ source \ build .. \ Tests \ SiansPlan.Logging.Tests \ bin \ SiansPlan.Domain.Tests.dll C: \ Development \ Clients \ SiansPlan \ source \ build .. \ Tests \ SiansPlan.Logging.Tests \ bin \ SiansPlan.Logging.Tests.dll Модель процесса: Default DomainUsage: Multiple Execution Runtime: net-4.5 Необработанное исключение: System.IO.FileLoadExc Вариант: не удалось загрузить файл или сборку nunit.framework, Version = 2.6.0.12051, Culture = нейтральный, PublicKeyToken = 96d09a1eb7f44a77 или одну из его зависимостей. Определение манифеста обнаруженной сборки не соответствует ссылке на сборку. (Исключение из HRESULT: 0x80131040)
Имя файла: 'nunit.framework, Version = 2.6.0.12051, Culture = нейтральный, PublicKeyToken = 96d09a1eb7f44a77'

Любые идеи будут приветствоваться, так как я бьюсь головой о стол. Я попросил своего настольного медведя, мою резиновую утку и Soundwave, и, честно говоря, ни один из них не принес особого толку!


person Keith Jackson    schedule 17.04.2014    source источник
comment
Я только что попытался запустить команду непосредственно в командной строке, и у меня такая же проблема: использую ли я экземпляр nunit-console.exe в моем каталоге сборки или устанавливаю локально на машине, они оба падают, не имея возможности найти nunit 2.6.0 ...   -  person Keith Jackson    schedule 17.04.2014


Ответы (1)


Непонятный ответ на непонятную проблему. Кажется, у меня была старая библиотека, которая зависала (Domain.Tests in Logging была чем-то вроде раздачи), из-за которой она падала.

cleanfail

person Keith Jackson    schedule 17.04.2014