visual-studio-2019 - SpecFlow:打开功能文件会导致 NullReferenceException
问题描述
几周后,我突然在 Visual Studio 2019(专业版)中遇到了 SpecFlow 扩展的问题。它突然停止工作。首先我认为是因为 VS 的更新,但我的其他同事正在使用相同(最新)版本的 VS,并且 SpecFlow 对他们有效。
我遇到的问题是:
- SpecFlow 没有设置菜单(工具 - 选项 - SpecFlow)
- 打开功能文件时出现 NullReferenceException(请参阅帖子末尾的活动日志条目)
- 打开功能文件时没有语法突出显示
- 没有上下文菜单
测试资源管理器仍在发现测试,我仍然可以运行它们,但不能从功能文件中运行(也不能调试步骤)。
扩展程序已正确安装并启用(据我所知)。已经尝试了以下但没有成功:
- 卸载并安装 SpecFlow for Visual Studio 2019 扩展
- 卸载 SpecFlow 并安装 Devroom
- 卸载 Visual Studio 2019 并重新安装
你们中的任何人对可能导致这种情况的原因有任何想法吗?
活动日志条目
<entry>
<record>806</record>
<time>2021/02/09 09:25:56.786</time>
<type>Error</type>
<source>Editor or Editor Extension</source>
<description>System.NullReferenceException: Object reference not set to an instance of an object.

at TechTalk.SpecFlow.VsIntegration.LanguageService.ProjectScopeFactory.<.ctor>b__9_0() in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\LanguageService\ProjectScopeFactory.cs:line 52

at TechTalk.SpecFlow.VsIntegration.Implementation.Utils.SynchInitializedInstance`1.EnsureInitialized()

at TechTalk.SpecFlow.VsIntegration.LanguageService.ProjectScopeFactory.<.ctor>b__9_2(Project project) in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\LanguageService\ProjectScopeFactory.cs:line 64

at TechTalk.SpecFlow.VsIntegration.Implementation.Utils.SynchronizedResultCache`3.GetOrCreate(TSource source)

at TechTalk.SpecFlow.VsIntegration.LanguageService.ProjectScopeFactory.GetProjectScope(Project project) in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\LanguageService\ProjectScopeFactory.cs:line 76

at TechTalk.SpecFlow.VsIntegration.LanguageService.GherkinLanguageServiceFactory.CreateLanguageService(ITextBuffer textBuffer) in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\LanguageService\GherkinLanguageServiceFactory.cs:line 51

at TechTalk.SpecFlow.VsIntegration.LanguageService.GherkinLanguageServiceFactory.<>c__DisplayClass7_0.<GetLanguageService>b__0() in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\LanguageService\GherkinLanguageServiceFactory.cs:line 43

at TechTalk.SpecFlow.VsIntegration.LanguageService.GherkinBufferServiceManager.<>c__DisplayClass3_0`1.<GetOrCreate>b__0() in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\LanguageService\GherkinBufferServiceManager.cs:line 32

at Microsoft.VisualStudio.Utilities.PropertyCollection.GetOrCreateSingletonProperty[T](Object key, Func`1 creator)

at TechTalk.SpecFlow.VsIntegration.LanguageService.GherkinBufferServiceManager.GetOrCreate[TService](ITextBuffer textBuffer, Func`1 creator) in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\LanguageService\GherkinBufferServiceManager.cs:line 29

at TechTalk.SpecFlow.VsIntegration.LanguageService.GherkinLanguageServiceFactory.GetLanguageService(ITextBuffer textBuffer) in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\LanguageService\GherkinLanguageServiceFactory.cs:line 43

at TechTalk.SpecFlow.VsIntegration.GherkinFileEditor.GherkinFileClassifierProvider.<>c__DisplayClass3_0.<GetClassifier>b__0() in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\GherkinFileEditor\GherkinFileClassifierProvider.cs:line 31

at TechTalk.SpecFlow.VsIntegration.LanguageService.GherkinBufferServiceManager.<>c__DisplayClass3_0`1.<GetOrCreate>b__0() in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\LanguageService\GherkinBufferServiceManager.cs:line 32

at Microsoft.VisualStudio.Utilities.PropertyCollection.GetOrCreateSingletonProperty[T](Object key, Func`1 creator)

at TechTalk.SpecFlow.VsIntegration.LanguageService.GherkinBufferServiceManager.GetOrCreate[TService](ITextBuffer textBuffer, Func`1 creator) in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\LanguageService\GherkinBufferServiceManager.cs:line 29

at TechTalk.SpecFlow.VsIntegration.GherkinFileEditor.GherkinFileClassifierProvider.GetClassifier(ITextBuffer buffer) in D:\a\1\s\TechTalk.SpecFlow.VSIXShared\GherkinFileEditor\GherkinFileClassifierProvider.cs:line 30

at Microsoft.VisualStudio.Text.Classification.Implementation.ClassifierTaggerProvider.<>c__DisplayClass12_0`1.<CreateTagger>b__0(IClassifierProvider provider)

at Microsoft.VisualStudio.Text.Utilities.GuardedOperations.InvokeEligibleFactories[TExtensionInstance,TExtensionFactory,TMetadataView](IEnumerable`1 lazyFactories, Func`2 getter, IContentType dataContentType, IContentTypeRegistryService contentTypeRegistryService, Object errorSource)
--- End of stack trace from previous location where exception was thrown ---

at Microsoft.VisualStudio.Telemetry.WindowsErrorReporting.WatsonReport.GetClrWatsonExceptionInfo(Exception exceptionObject)
</description>
</entry>
编辑:运行 VS 修复后,我可以看到“清除 MEF 组件缓存”扩展的菜单选项。不幸的是,使用它并没有让我进一步使用 SpecFlow 扩展(仍然是同样的问题)。
解决方案
这看起来像 Visual Studio 的 MEF 缓存有问题。
一个简单的清洁方法是Clear MEF Component Cache
Mads Kristensen 的扩展。可以在此处的市场上找到它:https ://marketplace.visualstudio.com/items?itemName=MadsKristensen.ClearMEFComponentCache
安装它并在重新启动 VS 后,执行菜单中的命令:
之后,再次重新启动 VS,SpecFlow VS 扩展应该再次工作。
推荐阅读
- php - Laravel - 在验证字段中显示自定义错误
- google-cloud-platform - Google Cloud Functions - 部署挂起 5-10 分钟,然后给出错误“部署失败:操作中断”
- javascript - React Native console.error 版本不匹配
- c# - 如何使用 CSOM 检索 SharePoint 共享链接
- tensorflow - Keras 说我的 cuda 驱动程序不兼容,但它们实际上是兼容版本
- python - 编辑用于将十进制数转换为二进制的 Python 代码
- c# - 如何使用 ASP.NET Core MVC 中的下拉列表中的值填充表
- android - Android App,Firebase 初始化成功,但网站仍然失败
- java - 对象列表的 Spring @NotNull 验证约束未显示所需的元素名称
- sql - 如何调整 Oracle SQL 查询