【发布时间】:2015-08-19 16:45:48
【问题描述】:
我们有 Visual Studio 2015 Enterprise RTM 和一个针对 beta 6 DNX SDK 编译的 MVC6 WebAPI 预览项目。
现在我们想在我们的 TFS 2013 服务器上构建这个项目。不幸的是,构建失败是因为(我们认为)beta 6 软件包没有恢复:
无法解析依赖 Microsoft.AspNet.Mvc 6.0.0-beta6
无法解决依赖 Microsoft.AspNet.Server.IIS 1.0.0-beta6
无法解决依赖 Microsoft.AspNet.Server.WebListener 1.0.0-beta6
无法解决依赖项 Microsoft.AspNet.StaticFiles 1.0.0-beta6
无法解析依赖 System.IdentityModel.Tokens 5.0.0-beta6-207211625
无法解析依赖 Microsoft.AspNet.Authentication.OAuthBearer 1.0.0-beta6
我们甚至没有在构建日志中看到任何 NuGet 包还原尝试。
考虑以下步骤来重现:
我们在构建服务器上安装了 Visual Studio 2015 Enterprise RTM(我们需要完整的 Visual Studio,因为我们在单元测试中使用了伪造品),作为构建代理登录并配置了 Visual Studio 的 TFS 源代码控制设置,确保选中自动 NuGet 还原,确保安装了 Visual Studio beta 6 SDK 工具并安装了 beta 6 DNX(一个 la 'dnvm upgrade' 命令)。
接下来,我们使用 TfvcTemplate.12.xaml 模板在 TFS 中创建了一个新版本,并在 Advanced->MSBuild 参数上指定了“/p:VisualStudioVersion=14.0”开关,如 this article 中指定的那样。=14.0 p>
最后,当我们对构建进行排队时,构建失败并显示以下日志:
Build started 8/19/2015 8:51:09 AM.
1>Project "C:\Builds\12\FunProjects\SPAFoundation\src\SPAFoundation.sln" on node 1 (default targets).
1>ValidateSolutionConfiguration:
Building solution configuration "Release|Any CPU".
1>Project "C:\Builds\12\FunProjects\SPAFoundation\src\SPAFoundation.sln" (1) is building "C:\Builds\12\FunProjects\SPAFoundation\src\src\API\API.xproj" (2) on node 1 (default targets).
2>PrepareForBuild:
Creating directory "..\..\artifacts\obj\API\Release\".
PreComputeCompileTypeScript:
C:\Program Files (x86)\Microsoft SDKs\TypeScript\1.5\tsc.exe --noEmitOnError COMPUTE_PATHS_ONLY
CompileTypeScript:
C:\Program Files (x86)\Microsoft SDKs\TypeScript\1.5\tsc.exe --noEmitOnError
CoreCompile:
C:\Users\svctfsserver\.dnx\runtimes\dnx-clr-win-x86.1.0.0-beta6\bin\dnx.exe --appbase "C:\Builds\12\FunProjects\SPAFoundation\src\src\API" "C:\Users\svctfsserver\.dnx\runtimes\dnx-clr-win-x86.1.0.0-beta6\bin\lib\Microsoft.Framework.PackageManager\Microsoft.Framework.PackageManager.dll" pack "C:\Builds\12\FunProjects\SPAFoundation\src\src\API" --configuration Release --out "C:\Builds\12\FunProjects\SPAFoundation\bin"
Microsoft .NET Development Utility CLR-x86-1.0.0-beta6-12256
Building API for DNX,Version=v4.5.1
Using Project dependency API 1.0.0
Source: C:\Builds\12\FunProjects\SPAFoundation\src\src\API\project.json
Unable to resolve dependency Microsoft.AspNet.Mvc 6.0.0-beta6
Unable to resolve dependency Microsoft.AspNet.Server.IIS 1.0.0-beta6
Unable to resolve dependency Microsoft.AspNet.Server.WebListener 1.0.0-beta6
Unable to resolve dependency Microsoft.AspNet.StaticFiles 1.0.0-beta6
Unable to resolve dependency System.IdentityModel.Tokens 5.0.0-beta6-207211625
Unable to resolve dependency Microsoft.AspNet.Authentication.OAuthBearer 1.0.0-beta6
Unable to resolve dependency Serilog.Framework.Logging 1.0.0-beta-43
Unable to resolve dependency Unity 3.5.1404
.
.
.
C:\Builds\12\FunProjects\SPAFoundation\src\src\API\project.json(6,29): error : The dependency Microsoft.AspNet.Mvc >= 6.0.0-beta6 could not be resolved. [C:\Builds\12\FunProjects\SPAFoundation\src\src\API\API.xproj]
C:\Builds\12\FunProjects\SPAFoundation\src\src\API\project.json(7,36): error : The dependency Microsoft.AspNet.Server.IIS >= 1.0.0-beta6 could not be resolved. [C:\Builds\12\FunProjects\SPAFoundation\src\src\API\API.xproj]
C:\Builds\12\FunProjects\SPAFoundation\src\src\API\project.json(8,44): error : The dependency Microsoft.AspNet.Server.WebListener >= 1.0.0-beta6 could not be resolved. [C:\Builds\12\FunProjects\SPAFoundation\src\src\API\API.xproj]
C:\Builds\12\FunProjects\SPAFoundation\src\src\API\project.json(9,37): error : The dependency Microsoft.AspNet.StaticFiles >= 1.0.0-beta6 could not be resolved. [C:\Builds\12\FunProjects\SPAFoundation\src\src\API\API.xproj]
C:\Builds\12\FunProjects\SPAFoundation\src\src\API\project.json(10,36): error : The dependency System.IdentityModel.Tokens >= 5.0.0-beta6-207211625 could not be resolved. [C:\Builds\12\FunProjects\SPAFoundation\src\src\API\API.xproj]
C:\Builds\12\FunProjects\SPAFoundation\src\src\API\project.json(11,52): error : The dependency Microsoft.AspNet.Authentication.OAuthBearer >= 1.0.0-beta6 could not be resolved. [C:\Builds\12\FunProjects\SPAFoundation\src\src\API\API.xproj]
- 最后一个难题是我们可以使用构建代理凭据远程访问 TFS 服务器。在 Visual Studio 2015 Enterprise RTM 中打开项目并毫无问题地构建它。显然,这与 MSBuild 和 Visual Studio 之间的分离有关,但我们不了解其中的细微差别。
像往常一样,我确信我们错过了秘诀中的关键步骤,任何建议都将不胜感激。
【问题讨论】: