1

我正在为带有 selenium webdriver 的单页 webapp 开发一个 Java 框架,使用以下模式:PageObject、SlowLoadableComponent(责任链)、PageFactory、HaveExpectedControls(每个页面都知道它应该包含哪些元素并通过 .getExpectedControls 返回它们)

所以我创建和使用我的页面,例如:

LoginPage loginPage = new LoginPage(driver, "http://mywebapp.com");
mainPage MainPage = new MainPage(driver, loginPage, "password"); 
mainPage.get();  //this method checks whether page .isLoaded(), if not - calls its .load() method and finally assert it .isLoaded()
for (WebElement element: mainPage.getExpectedControls()) {
    assertTrue(element.isDisplayed);
}

我目前的目标是:测试用户在浏览我的网络应用程序时可以执行的所有“路径”。

一切都很容易,直到我进入网页,在我的 webapp 层次结构中“更深”......

我的页面可以表示如下

------------
|Login Page|
------------
->
|------------------------------
|LogoutLink
|---------------------------------
|mode: _ standart _ expert|  __________________
|-------------------------| |SystemSettingsTab1|SystemSettingsTab2|SystemSettingsTab3
|*MainPage menu item      | |                   ----------------------------------------
|*SomeOther menu item     | |                                                           |
|...                      | |                                                           |
|*System menu item      >->
|** Settings sub item    >-> 
|...                      | |
|** OneMore sub item      | |

这里有一些“规则”可以得到更多解释:

First you get Login Page
  Then (if loged in) you allways get 'MainPage menu item' (and 'standard' mode checked)
    You allways see (so can click only what you see):
      - only that sub-menu-items that are inside 'current' menu item page
      - only that sub-menu-items-tabs that are:
        - inside current sub-menu-item
        - is correspondent to the current mode ('expert' mode allows more tabs)
    Once clicked on any 'item' you allways get its first 'child item'
    Then whatever you do you can:
      - logout
      - switch to any 'item' which you can see (check correspondent section above):
        i.e.: 
        - switch to any other menu-item page by clicking on it
        - switch to any of sub-menu-items of the current menu-item:
            there is a special case for 'the first sub-menu-item':
              you can get it by:
                - clicking on its sub-menu-item link
                - on its parent menu-item 
        - switch to any of sub-menu-item-tabs of current sub-menu-item
            there is a special case for 'the first sub-menu-item-tab':
              you can get it by:
                - clicking on its sub-menu-item-tab link
                - on its parent sub-menu-item
                - on its parent menu-item 

问题: 如何设计:

  • 我所有页面的类层次结构?

  • 我可以在测试中浏览它们的方式?(尤其包括特殊情况,我可以通过几个链接获得一些页面)

4

1 回答 1

0

我认为以下将是一个简单有效的解决方案,

  1. 具有导航(或单击)其他菜单项和注销的方法的主页类。
  2. 带有子菜单项方法的每个菜单项的类,扩展主页面类
于 2013-08-21T09:37:06.673 回答