说我有一个使用两个不同类中包含的步骤的方案。他们两个都有没有相同的IWebDriver
实例句柄而无需通过ScenarioContext.Current["webdriverVariableName"]
的方法?
太丑了。有没有更清洁的方法?
我本来要创建一个具有public static IWebDriver
属性的类,该类在每种情况的开始都会被分配,以便我的所有步骤都可以引用它,但是当我开始运行它们时,我认为这种方法不起作用并行,因为每种情况都将覆盖全局驱动程序。
Specflow提供了依赖注入机制,因此您可以在步骤中注入Web驱动程序实例。
请参见https://github.com/techtalk/SpecFlow/wiki/Context-Injection
请参阅“高级选项”部分。
我刚刚开始使用Specflow,但这似乎起作用;
创建一个使用IObjectContainer作为构造函数并具有BeforScenario方法的类来创建WebDriver实例;
[Binding]
public class WebDriverSupport
{
private readonly IObjectContainer _objectContainer;
public WebDriverSupport(IObjectContainer objectContainer)
{
_objectContainer = objectContainer;
}
[BeforeScenario]
public void InitializeWebDriver()
{
var webDriver = DriverFactory.CreateDriver();
_objectContainer.RegisterInstanceAs<RemoteWebDriver>(webDriver);
}
}
[使用带有RemoteWebDriver的构造函数创建步骤类;
[Binding]
public class POCSteps
{
private readonly IdlWebDriver _driver;
public POCSteps(IdlWebDriver driver)
{
_driver = driver;
}
}
您的步骤现在将可以访问完全实例化的WebDriver对象
我的测试目前可以在多线程Webdriver实例上正常运行,正在使用基本步骤定义类来保存驱动程序实例。所有步骤定义都继承自此,因此驱动程序可用于所有步骤。]
namespace Project.StepDefinitions
{
[Binding]
public class BaseStepDefinitions
{
private const string CurrentPageKey = "Current.Page";
public static IWebDriver Driver { get; set; }
protected LogonPageModel LogonPage
{
get { return (LogonPageModel)ScenarioContext.Current[CurrentPageKey]; }
set { ScenarioContext.Current[CurrentPageKey] = value; }
}
protected RegisterPageModel RegisterPage
{
get { return (RegisterPageModel)ScenarioContext.Current[CurrentPageKey]; }
set { ScenarioContext.Current[CurrentPageKey] = value; }
}
}
}
//////////////
namespace SpecDriver.StepDefinitions
{
[Binding]
public class LoginSteps : BaseStepDefinitions
{
[Given(@"I navigate to the homepage")]
public void GivenINavigateToTheHomepage()
{
Driver.Navigate().GoToUrl(SettingsManager.BaseUrl);
}
}
}
etc etc ...
只需使用返回驱动程序的静态属性创建一个新的分离的类:
static class DriverProvider
{
private static IWebDriver _driver;
public static IWebDriver Driver
{
get
{
if (_driver == null)
{
_driver = new ChromeDriver();
_driver.Manage().Timeouts().ImplicitWait = TimeSpan.FromSeconds(40);
_driver.Manage().Window.Maximize();
}
return _driver;
}
}
}
每次您都需要对驱动程序做一些事情,只需以这种方式调用它:
SomeMethod(DriverProvider.Driver);
//
IWebelement e = DriverProvider.Driver.FindElement(By.XPath("you_XPath"));
e.Click();
// etc etc etc