NUnit完成后,MSBuild挂起

Kar*_*und 5 msbuild nunit

我正在尝试使用NUnit设置一个MSBuild作为单元测试驱动程序,但是在NUnit完成后脚本会一直挂起.它似乎没有完成它的工作,让MSBuild继续工作.
我正在使用.NET 4.0并使用NUnit 2.5.8.
如果我手动或使用gui(VS2010或NUnit)运行测试,它可以正常工作,但在MSBuild调用时则不行.

我很感激任何寻找错误的帮助,或者只是想知道在哪里寻找答案.

手动命令如下所示:
C:\ ....> nunit \nunit-console.exe buildbinaries\YYYY.XXXX.Extractor.Test.IntegrationTest.dll /xml=nunit.xml

和缩写的MSBuild:

  <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />

  <!-- define folders for build output and reports -->
  <PropertyGroup>
    <BuildPath>buildbinaries\</BuildPath>
    <ReportPath>buildreports\</ReportPath>
    <ReleaseFolder>release_artefacts\</ReleaseFolder>
    <PublishFolder>c:\ZZZ Applications\published builds\</PublishFolder>
    <DeploymentFolder>\\seldclq99\ZZZ_Costanza_Dev$\</DeploymentFolder>
  </PropertyGroup>

  <PropertyGroup>
    <!-- specify assemblies that should be included in coverage report -->
    <NCoverAssemblyList>YYYY.XXXX.Extractor.Business.dll; YYYY.XXXX.Extractor.Common.dll YYYY.XXXX.Extractor.Configuration.dll YYYY.XXXX.Extractor.DAL.Access.dll YYYY.XXXX.Extractor.DAL.Facade.dll YYYY.XXXX.Extractor.Service.Contracts.dll YYYY.XXXX.Extractor.Service.dll YYYY.XXXX.Extractor.Service.Host.WebHost.dll YYYY.XXXX.Extractor.ServiceGateway.dll</NCoverAssemblyList>
  </PropertyGroup>

  <!-- define item group for deliverables -->
  <ItemGroup>
    <Binaries Include="$(BuildPath)/**/*.*" Exclude="$(BuildPath)nunit*" />
  </ItemGroup>

  <!--
  This is the default target that will be executed if MSBuild is not started
  with a specific target (this is decided by the DefaultTargets attribute in
  the root element of this XML document)
  -->
  <Target Name="BuildAndTest">
    <CallTarget Targets="SetupDirs" />
    <CallTarget Targets="Build" />
    <CallTarget Targets="UnitAndIntegrationTest" />
    <CallTarget Targets="FxCop" />
    <CallTarget Targets="CopyToReleaseFolder" />
  </Target>

  <!-- Setup folders used during the build -->
  <Target Name="SetupDirs">
    <RemoveDir Directories="$(ReportPath);$(BuildPath);$(ReleaseFolder)" ContinueOnError="true"/>
    <MakeDir Directories="$(ReportPath);$(BuildPath);$(ReleaseFolder);$(AssemblyVersionFolder)" ContinueOnError="true"/>
  </Target>

  <Target Name="Build">
    <!-- build the software using msbuild -->
    <!-- Build error in the Install build-->
    <MSBuild ContinueOnError="true" RebaseOutputs="false" Targets="Clean;Rebuild" Projects="YYYYXXXXExtractor.sln" Properties="Configuration=Release;OutDir=..\$(BuildPath)" />

  </Target>

  <!--Run the coverage stats-->
  <Target Name="UnitAndIntegrationTest">
      <Exec Command="nunit\nunit-console.exe buildbinaries\YYYY.XXXX.Extractor.Test.IntegrationTest.dll /xml=$(ReportPath)nunit.xml "/>
      <CallTarget Targets="UnitTest" />
  </Target>

  <Target Name="UnitTest">
      <Exec Command="nunit\nunit-console.exe buildbinaries\YYYY.XXXX.Extractor.Test.UnitTest.dll /xml=$(ReportPath)nunit.xml"/>
  </Target>

  <!-- Run FxCop  -->
  <!-- The ForceError.bat fires if the xml file is not found... aka an error was found -->
  <!-- The quiet command forces an Xml file ONLY if warnings or Errors are found -->
  <Target  Name="FxCop">
    <Exec  Command="..\tools\fxcop\FxCopCmd.exe /p:..\FxCopSettings.FxCop /o:$(ReportPath)fxcop.xml" />
    <Exec Condition="Exists('$(ReportPath)fxcop.xml')" Command="..\tools\fxcop\FX_Cop_Failed_Rule_Checks.bat" />

    <!--STATS: Run again but don't fail and this time run for all rules.-->
    <Exec  Command="..\tools\fxcop\FxCopCmd.exe /p:..\FxCopSettingsALLRULES.FxCop /o:$(ReportPath)fxCopAllRules.xml" />

  </Target >
Run Code Online (Sandbox Code Playgroud)

Iai*_*ell 2

自从升级到 .NET 4 以来,我注意到构建服务器上有类似的行为。MsBuild 似乎间歇性地挂在 NUnit、FxCop 或 Dotcover EXEC 命令上。如果您检查任务管理器,外部执行命令的进程(例如 Nunit.exe)仍然存在。如果您手动终止进程,MsBuild 会继续以愉快的方式运行 - 这远非理想!

这可能是最新版本的 MsBuild 中的错误吗?在 .NET 4 升级之前,我们的构建服务器运行得非常愉快。