MSBuild还原目标 - MSB4057:项目中不存在目标“还原”

时间:2017-11-15 17:15:57

标签: c# msbuild nuget-package-restore .net-4.6.2 msbuild-target

我们的主要产品组合中有超过20个解决方案(超过880个项目),我们有一套复杂的构建脚本,但是我们正在尝试从msbuild管道中自动恢复nuget包。目前,这是通过手动调用nuget来恢复软件包来完成的。

根据https://docs.microsoft.com/en-us/nuget/schema/msbuild-targets,我应该可以运行此命令并进行恢复运行:

# works
& $script:msBuildPath $solutionName /t:build /v:q /clp:ErrorsOnly /nologo /p:...
# doesn't works
& $script:msBuildPath $solutionName /t:restore,build /v:q /clp:ErrorsOnly /nologo /p:...

但是,当我向上面添加restore,时会抛出错误

MSB4057: The target "restore" does not exist in the project

我从哪里开始研究以了解为什么找不到这个目标?我们主要使用的是VS 2015和.NET 4.6.2,所以VS2017的任何特定内容都不适合我在这个时候。

如果我省略了/v:q/clp:ErrorsOnly标记,我会得到这个(稍微清理过的解决方案/项目名称和路径)

PS Z:\git\company> build c
building Common\Common.sln
Build started 11/15/2017 11:08:54 AM.
     1>Project "Z:\git\company\Common\Common.sln" on node 1 (restore;build target(s)).
     1>ValidateSolutionConfiguration:
         Building solution configuration "DEBUG|Any CPU".
     1>Z:\git\company\Common\Common.sln.metaproj : error MSB4057: The target "restore" does not exist in the project. [Z:\git\company\Common\Common.sln]
     1>Done Building Project "Z:\git\company\Common\Common.sln" (restore;build target(s)) -- FAILED.

Build FAILED.

       "Z:\git\company\Common\Common.sln" (restore;build target) (1) ->
         Z:\git\company\Common\Common.sln.metaproj : error MSB4057: The target "restore" does not exist in the project. [Z:\git\company\Common\Common.sln]

    0 Warning(s)
    1 Error(s)

Time Elapsed 00:00:00.03
runBuildPackage :  ... failed
At Z:\git\company\psincludes\buildFunctions.ps1:11 char:5
+     runBuildPackage "Common\Common.sln"
+     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (:) [Write-Error], WriteErrorException
    + FullyQualifiedErrorId : Microsoft.PowerShell.Commands.WriteErrorException,runBuildPackage


msbuild failed
At Z:\git\company\psincludes\buildInternals.ps1:63 char:21
+                     throw "msbuild failed";
+                     ~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : OperationStopped: (msbuild failed:String) [], RuntimeException
    + FullyQualifiedErrorId : msbuild failed
  

我意识到其中一些是我们的内部工具,我只是觉得不需要模糊那部分。

根据“互联网”,这应该只是“免费”作为构建过程的一部分,我不确定我们在csproj文件中缺少什么。

1 个答案:

答案 0 :(得分:9)

msbuild集成的NuGet功能在NuGet 4.0+中与MSBuild 15一起提供,这意味着仅在VS 2017中。不支持VS 2015的恢复目标。

VS 2017 / NuGet 4中的集成恢复仅适用于使用新PackageReference样式引用NuGet包的项目。它不适用于使用packages.config的项目。这种引用包的新方法是ASP.NET Core(.NET Framework / .NET Core),.NET Core和.NET Standard项目的默认选项。通过在NuGet属性中首次安装之前选择样式(Tools-> Options-> NuGet),可以选择加入所有其他项目类型。

请注意,调用/t:Restore,Build不是调用此目标的好方法,因为还原可能会生成或更改msbuild然后不重新加载的文件。 MSBuild 15.5(VS 2017的即将更新)引入了一个/restore选项,它将调用恢复目标,然后清除之前无法清除的所有缓存并按要求执行正常构建。在15.5之前,最好对msbuild进行两次不同的调用。