Page Objects是一種設計模式,用來將頁面上的對象進行模塊化。通過消除重復的對象,建立起一個抽象基類,從而使得你在開發(fā)瀏覽器自動化測試腳本時有更好的維護性和更強的健壯性。
Page Objects可以從兩個方面來看待:
從測試開發(fā)人員的角度來看, 一個Page Object可以看作一個服務。
從開發(fā)人員的角度來看, 一個Page Object可以看作良好結構的頁面對象。
對于Page Objects來說,一定要理解,它是提供一個服務的對象,而不用更詳細的研究它的方法以及結構的細節(jié)。
我們來舉一個簡單的例子,比如一個Web Mail的收件頁面, 我們可以把它想象成一個服務,能夠提供寫信,讀信,展示來信的主題等功能,對于我們測試來說,它這些功能是怎么實現(xiàn)的不是我們考慮的范圍。
對于Page Objects來說,返回值應該是其他的Page Objects,這意味著我們是在不同的Page Objects中進行數(shù)據(jù)交互。
我們用login page來做個例子
public class LoginPage {
public HomePage loginAs(String username, String password) {
// ... 成功的login
}
public LoginPage loginAsExpectingError(String username, String password) {
// ...失敗的login
}
public String getErrorMessage() {
// 判斷一下錯誤的內(nèi)容
}
}
從上面我們可以看到,不但要考慮成功的login到下一個page,也得考慮失敗的login是轉入那個page,還是在page上顯示錯誤信息?紤]的都是page這個整體需要處理的行為。
另外,我們應該考慮的是,我們的測試應該是著重判斷page的狀態(tài),拿inbox舉例子:
public void testMessagesAreReadOrUnread() {
Inbox inbox = new Inbox(driver);
inbox.assertMessageWithSubjectIsUnread("I like cheese");
inbox.assertMessageWithSubjectIsNotUnread("I'm not fond of tofu");
}
我們的斷言,是放在page的狀態(tài)上,也可以這么寫:
public void testMessagesAreReadOrUnread() {
Inbox inbox = new Inbox(driver);
assertTrue(inbox.isMessageWithSubjectIsUnread("I like cheese"));
assertFalse(inbox.isMessageWithSubjectIsUnread("I'm not fond of tofu"));
}
當然,我們也要先通過webdriver來判斷我們所在的頁面是對的,或者說我們要操作的Page Object是已經(jīng)出現(xiàn)了
public class LoginPage {
private final WebDriver driver;
public LoginPage(WebDriver driver) {
this.driver = driver;
// 判斷我們在正確的頁面上
if (!"Login".equals(driver.getTitle())) {
//如果不在,那報錯
throw new IllegalStateException("This is not the login page");
}
}
// 理論上講,login Page Object能提供Login As的服務
public HomePage loginAs(String username, String password) {
// 在這里是的詳細操作步驟
driver.findElement(By.id("username")).sendKeys(username);
driver.findElement(By.id("passwd")).sendKeys(password);
driver.findElement(By.id("login")).submit();
//返回對象應該是一個新的Page Object
return new HomePage(driver);
}
}