我正在使用 C# 使用 selenium 和 specflow 创建自动化测试。今天我不得不将 Selenium.WebDriver 更新到 4.0.0-beta4 版本,因为日志记录功能在以前的版本中存在一个带有 AvailableLogTypes 属性的错误,它总是抛出空引用异常。更新到 selenium 4 后,又出现了另一个问题。构建工作正常,没有错误或警告,但是当我运行测试时,会引发以下异常:
Message:
System.TypeLoadException : Could not load type 'OpenQA.Selenium.Internal.IWrapsElement' from assembly 'WebDriver, Version=4.0.0.0, Culture=neutral, PublicKeyToken=null'.
Stack Trace:
DefaultPageObjectMemberDecorator.CreateProxyObject(Type memberType, IElementLocator locator, IEnumerable`1 bys, Boolean cache)
DefaultPageObjectMemberDecorator.Decorate(MemberInfo member, IElementLocator locator)
PageFactory.InitElements(Object page, IElementLocator locator, IPageObjectMemberDecorator decorator)
PageFactory.InitElements(Object page, IElementLocator locator)
PageFactory.InitElements(ISearchContext driver, Object page)
LoginPageElements.ctor(IWebDriver driver) line 12
PortalSharedPageSteps.CheckUIElementsOfLoginScreen() line 32
LoginPageTestSteps.CheckUIElementsOfLoginScreenStep() line 21
BindingInvoker.InvokeBinding(IBinding binding, IContextManager contextManager, Object[] arguments, ITestTracer testTracer, TimeSpan& duration)
TestExecutionEngine.ExecuteStepMatch(BindingMatch match, Object[] arguments, TimeSpan& duration)
TestExecutionEngine.ExecuteStep(IContextManager contextManager, StepInstance stepInstance)
TestExecutionEngine.OnAfterLastStep()
TestRunner.CollectScenarioErrors()
LoginPageTestFeature.ScenarioCleanup()
LoginPageTestFeature.LoginPageTest() line 9
来自 selenium 的官方发行说明:
根据https://github.com/SeleniumHQ/selenium/blob/master/dotnet/CHANGELOG中的 v4.0.0a1 将 IWrapsDriver 和 IWrapsElement 从 OpenQA.Selenium.Internal 命名空间移动到 OpenQA.Selenium 命名空间。这应该是否-op 适用于绝大多数用户,只需要重新编译代码,因为这两个接口都具有基本命名空间中的返回类型,这意味着用户可能已经在其源代码中具有根命名空间的“使用”语句。如果错误遇到,更改代码中的命名空间并重建应该可以解决错误。”
我仔细检查了所有出现的 OpenQA.Selenium.Internal 命名空间,发现这个命名空间甚至没有在我的代码中使用。所以我认为一切都会好起来的,但没有......
后来我发现如果我删除 DotNetSeleniumExtras.PageObjects nuget 包,一切正常。这很好,但我需要这个包能够使用 PageFactory.InitElements() 进行页面对象初始化,并使用 FindsBy 属性绑定 UI 元素。我检查了 DotNetSeleniumExtras.PageObjects 包,它也使用了 selenium 4。
你有什么想法如何解决这个问题?如果您需要查看源代码,请告诉我(它非常广泛,所以我不想让这篇文章变得臃肿)