私は、数か月前から Selenium WebDriver インフラストラクチャを開発しているチームで働いていますが、テスト ケースとページ オブジェクトからドライバー オブジェクトにアクセスする方法に悩まされています。
テスト ケースでは、新しい WebDriver インスタンスを作成し、ブラウザーを開きます。この新しいインスタンスは、テスト ケース クラスに格納されます。
次に、テスト ケースはページ オブジェクトをインスタンス化します。Selenium の Page Object Patternに従って、これらのページ オブジェクトは WebDriver をコンストラクターのパラメーターとして受け取ります (ただし、私たちのバージョンではそれが最終的なものではないことに気付きました)。さまざまなページ オブジェクト メソッドは、ページ オブジェクトのコンストラクターで設定されたドライバーを使用して、そのメソッドが行うことを行います。ページ オブジェクト メソッドが新しいページ オブジェクトに移動すると、WebDriver がそれに渡されます。Selenium の例のように:
public class LoginPage {
private final WebDriver driver;
public LoginPage(WebDriver driver) {
this.driver = driver;
// Check that we're on the right page.
if (!"Login".equals(driver.getTitle())) {
// Alternatively, we could navigate to the login page, perhaps logging out first
throw new IllegalStateException("This is not the login page");
}
}
// Conceptually, the login page offers the user the service of being able to "log into"
// the application using a user name and password.
public HomePage loginAs(String username, String password) {
// This is the only place in the test code that "knows" how to enter these details
driver.findElement(By.id("username")).sendKeys(username);
driver.findElement(By.id("passwd")).sendKeys(password);
driver.findElement(By.id("login")).submit();
// Return a new page object representing the destination. Should the login page ever
// go somewhere else (for example, a legal disclaimer) then changing the method signature
// for this method will mean that all tests that rely on this behaviour won't compile.
return new HomePage(driver);
}
}
これにより、ページ オブジェクトからページ オブジェクトに渡さなければならないトーチのように、WebDriver インスタンスが一意で重要であるかのように見えます。コードのスタイルから、前回の操作で使用したドライバーと同じインスタンスを使用していることを常に確認する必要があると考えるようになりました。
しかし、ページ上に複数のページ オブジェクトがあり、ページ オブジェクト メソッドが次に作業する予定のページ オブジェクトを返さない状況では、この「トーチの通過」は複雑または不可能になります。画面上に 2 つのページ オブジェクトがあり、新しいページに切り替えたり、新しいページ オブジェクトを作成したりせずに、それらを交互に切り替える必要がある場合、同じ WebDriver インスタンスを操作するにはどうすればよいでしょうか?
このすべての混乱により、トーチの受け渡しは実際には必要ではない、またはおそらく起こっていないと信じるようになります (これらすべてのページオブジェクトは同じ WebDriver インスタンスへの参照を格納していますか?)。しかし、なぜそのパターンがセレンによる説明。
では、「トーチを渡す」ことについて心配する必要がありますか? または、他のページ オブジェクトがその間に同じ WebDriver の独自のバージョンで操作を実行したとしても、その WebDriver でインスタンス化されたページ オブジェクトは正常に動作しますか?
任意の時点で JVM ごとに複数の WebDriver を使用することはないため、WebDriver をすべての人がアクセスできるシングルトンにする方が簡単/良いでしょうか? そうすれば、コンストラクターで WebDriver を渡す必要はまったくありません。ご意見をお寄せいただきありがとうございます。