MSBuild 恢复目标 - MSB4057:项目中不存在目标“恢复”

问题描述 投票:0回答:2

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

根据https://learn.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 文件中缺少什么。

c# msbuild nuget-package-restore .net-4.6.2 msbuild-target
2个回答
22
投票

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 属性(工具 -> 选项 -> NuGet)中选择样式,可以选择加入所有其他项目类型。

请注意,调用

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


0
投票

这似乎不适用于 MSBuild 17.9 (VS2022) 的简单 .proj 文件 但是,我找到了一种解决方法,将

Sdk="Microsoft.NET.Sdk"
添加到
<Project/>
元素。 因此,PackageReference 项目现在可以通过
msbuild -restore

成功恢复
© www.soinside.com 2019 - 2024. All rights reserved.