MSBuild 还原目标 - MSB4057:目标 "restore" 在项目中不存在

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

我们的主要产品组合(超过 880 个项目)中有 20 多个解决方案,并且我们有一组运行良好的复杂构建脚本,但我们正在尝试从 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 标志,我会得到这个 (稍微清理 solution/project 名称和路径)

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

I realize some of this around is our internal tooling, I just didn't feel the need to obscure that part.

根据 "the internet" 这应该只是 "free" 作为构建过程的一部分,我不确定我们在此处的 csproj 文件中缺少什么。

MSBuild 集成的 NuGet 功能在 NuGet 4.0+ 中与 MSBuild 15 结合使用,这意味着仅在 VS 2017 中可用。不支持 VS 2015 的还原目标。

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

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