使用 .NET Core 2.0 + .Net Standard 2.0 的 Team Build Nuget 恢复失败
Team Build Nuget restore failure with .NET Core 2.0 + .Net Standard 2.0
我有一个 VS2017 解决方案,其中包含一个引用 .NET Standard 2.0 class 库的 .NET Core 2.0 控制台项目,以及许多其他 NuGet 包。该解决方案在我的开发机器上构建良好。
当我尝试 运行 使用 NuGet 4.0.0 或 4.1.0 在 TFS 构建服务器上恢复 NuGet 时,出现以下错误:
Package (mypackagename) 1.0.0 is not compatible with netcoreapp2.0 (.NETCoreApp,Version=v2.0). Package (mypackagename) 1.0.0 supports:
- net35 (.NETFramework,Version=v3.5)
- netstandard2.0 (.NETStandard,Version=v2.0)
此错误消息与中描述的类似,因此我尝试了那里建议的解决方案,即使用 NuGet 4.3.0 或更高版本。我已经尝试了从 4.3.0 到 4.6.2 的所有发布版本,这次我从 NuGet 恢复中得到以下错误:
2018-04-17T15:45:15.2611952Z Value cannot be null.
2018-04-17T15:45:15.2611952Z Parameter name: key
2018-04-17T15:45:15.2611952Z System.ArgumentNullException: Value cannot be null.
2018-04-17T15:45:15.2611952Z Parameter name: key
2018-04-17T15:45:15.2611952Z at System.Collections.Concurrent.ConcurrentDictionary`2.GetOrAdd(TKey key, Func`2 valueFactory)
2018-04-17T15:45:15.2611952Z at NuGet.Commands.RestoreCommandProvidersCache.GetOrCreate(String globalPackagesPath, IReadOnlyList`1 fallbackPackagesPaths, IReadOnlyList`1 sources, SourceCacheContext cacheContext, ILogger log)
2018-04-17T15:45:15.2611952Z at NuGet.Commands.DependencyGraphSpecRequestProvider.Create(String projectNameToRestore, ExternalProjectReference project, HashSet`1 projectReferenceClosure, RestoreArgs restoreArgs, DependencyGraphSpec projectDgSpec)
2018-04-17T15:45:15.2611952Z at NuGet.Commands.DependencyGraphSpecRequestProvider.GetRequestsFromItems(RestoreArgs restoreContext, DependencyGraphSpec dgFile)
2018-04-17T15:45:15.2611952Z at NuGet.Commands.DependencyGraphSpecRequestProvider.CreateRequests(RestoreArgs restoreContext)
2018-04-17T15:45:15.2611952Z at NuGet.Commands.RestoreRunner.<CreatePreLoadedRequests>d__11.MoveNext()
2018-04-17T15:45:15.2611952Z --- End of stack trace from previous location where exception was thrown ---
关于如何使它正常工作有什么建议吗?
我通过在我的 Team Build 的 "Get Sources" 任务中设置 "Clean = True" 解决了这个问题。
完成此操作后,我可以使用最新版本的 NuGet (4.6.2),它不再抛出上述 ArgumentNullException。
我怀疑 NuGet 中存在一个错误,它会被之前版本遗留下来的文件弄糊涂。
我有一个 VS2017 解决方案,其中包含一个引用 .NET Standard 2.0 class 库的 .NET Core 2.0 控制台项目,以及许多其他 NuGet 包。该解决方案在我的开发机器上构建良好。
当我尝试 运行 使用 NuGet 4.0.0 或 4.1.0 在 TFS 构建服务器上恢复 NuGet 时,出现以下错误:
Package (mypackagename) 1.0.0 is not compatible with netcoreapp2.0 (.NETCoreApp,Version=v2.0). Package (mypackagename) 1.0.0 supports:
- net35 (.NETFramework,Version=v3.5)
- netstandard2.0 (.NETStandard,Version=v2.0)
此错误消息与
2018-04-17T15:45:15.2611952Z Value cannot be null.
2018-04-17T15:45:15.2611952Z Parameter name: key
2018-04-17T15:45:15.2611952Z System.ArgumentNullException: Value cannot be null.
2018-04-17T15:45:15.2611952Z Parameter name: key
2018-04-17T15:45:15.2611952Z at System.Collections.Concurrent.ConcurrentDictionary`2.GetOrAdd(TKey key, Func`2 valueFactory)
2018-04-17T15:45:15.2611952Z at NuGet.Commands.RestoreCommandProvidersCache.GetOrCreate(String globalPackagesPath, IReadOnlyList`1 fallbackPackagesPaths, IReadOnlyList`1 sources, SourceCacheContext cacheContext, ILogger log)
2018-04-17T15:45:15.2611952Z at NuGet.Commands.DependencyGraphSpecRequestProvider.Create(String projectNameToRestore, ExternalProjectReference project, HashSet`1 projectReferenceClosure, RestoreArgs restoreArgs, DependencyGraphSpec projectDgSpec)
2018-04-17T15:45:15.2611952Z at NuGet.Commands.DependencyGraphSpecRequestProvider.GetRequestsFromItems(RestoreArgs restoreContext, DependencyGraphSpec dgFile)
2018-04-17T15:45:15.2611952Z at NuGet.Commands.DependencyGraphSpecRequestProvider.CreateRequests(RestoreArgs restoreContext)
2018-04-17T15:45:15.2611952Z at NuGet.Commands.RestoreRunner.<CreatePreLoadedRequests>d__11.MoveNext()
2018-04-17T15:45:15.2611952Z --- End of stack trace from previous location where exception was thrown ---
关于如何使它正常工作有什么建议吗?
我通过在我的 Team Build 的 "Get Sources" 任务中设置 "Clean = True" 解决了这个问题。
完成此操作后,我可以使用最新版本的 NuGet (4.6.2),它不再抛出上述 ArgumentNullException。
我怀疑 NuGet 中存在一个错误,它会被之前版本遗留下来的文件弄糊涂。