我们的主要产品组合中有超过 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 文件中缺少什么。
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 进行两次不同的调用。
这似乎不适用于 MSBuild 17.9 (VS2022) 的简单 .proj 文件 但是,我找到了一种解决方法,将
Sdk="Microsoft.NET.Sdk"
添加到 <Project/>
元素。
因此,PackageReference 项目现在可以通过 msbuild -restore
成功恢复