メインコンテンツにスキップ

ページオブジェクトモデル

はじめに

大規模なテストスイートは、作成とメンテナンスの容易さを最適化するために構造化できます。ページオブジェクトモデルは、テストスイートを構造化するためのそのようなアプローチの1つです。

ページオブジェクトは、Webアプリケーションの一部を表します。EコマースWebアプリケーションには、ホームページ、リスティングページ、チェックアウトページがあるかもしれません。それらのそれぞれは、ページオブジェクトモデルで表すことができます。

ページオブジェクトは、アプリケーションに合った高レベルのAPIを作成することで作成を簡素化し、要素セレクターを1か所にまとめて重複を避けるための再利用可能なコードを作成することでメンテナンスを簡素化します

実装

ページオブジェクトモデルは、PlaywrightのPageをラップします。

models/SearchPage.java
package models;

import com.microsoft.playwright;

public class SearchPage {
private final Page page;
private final Locator searchTermInput;

public SearchPage(Page page) {
this.page = page;
this.searchTermInput = page.locator("[aria-label='Enter your search term']");
}

public void navigate() {
page.navigate("https://bing.com");
}

public void search(String text) {
searchTermInput.fill(text);
searchTermInput.press("Enter");
}
}

ページオブジェクトは、テスト内で使用できます。

import models.SearchPage;
import com.microsoft.playwright.*;
// ...

// In the test
Page page = browser.newPage();
SearchPage searchPage = new SearchPage(page);
searchPage.navigate();
searchPage.search("search query");