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 进行两次不同的调用。
我们的主要产品组合(超过 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 进行两次不同的调用。