zoukankan      html  css  js  c++  java
  • [译]Selenium Python文档:六、页面对象

    本章是介绍页面对象设计模式的教程。一个页面对象代表了web应用用户接口的一片区域,你的测试代码将与之交互的。

    使用页面对象模式的好处:

    • 可以创建在多个测试样例中都可使用的可重用代码
    • 减少重复性代码
    • 如果用户接口发生改变,只需要字一个地方做出改动即可

    6.1 测试样例

    下面是一个测试样例,用于测试Pytohn.org网站的搜索功能,搜索一个单词,并确保能得到一些结果。

    import unittest
    from selenium import webdriver
    import page
    
    class PythonOrgSearch(unittest.TestCase):
        """A sample test class to show how page object works"""
    
        def setUp(self):
            self.driver = webdriver.Firefox()
            self.driver.get("http://www.python.org")
    
        def test_search_in_python_org(self):
            """
            Tests python.org search feature. Searches for the word "pycon" then verified that some results show up.
            Note that it does not look for any particular text in search results page. This test verifies that
            the results were not empty.
            """
    
            #Load the main page. In this case the home page of Python.org.
            main_page = page.MainPage(self.driver)
            #Checks if the word "Python" is in title
            assert main_page.is_title_matches(), "python.org title doesn't match."
            #Sets the text of search textbox to "pycon"
            main_page.search_text_element = "pycon"
            main_page.click_go_button()
            search_results_page = page.SearchResultsPage(self.driver)
            #Verifies that the results page is not empty
                assert search_results_page.is_results_found(), "No results found."
    
        def tearDown(self):
            self.driver.close()
    
    if __name__ == "__main__":
        unittest.main()
    

    6.2.页面对象类

    页面对象模式会为每一个web页面创建一个对象。按照这种技术就可以实现测试代码和技术实现的分层。

    page.py代码就像下面这样:

    from element import BasePageElement
    from locators import MainPageLocators
    
    class SearchTextElement(BasePageElement):
        """This class gets the search text from the specified locator"""
    
        #The locator for search box where search string is entered
        locator = 'q'
    
    
    class BasePage(object):
        """Base class to initialize the base page that will be called from all pages"""
    
        def __init__(self, driver):
            self.driver = driver
    
    
    class MainPage(BasePage):
        """Home page action methods come here. I.e. Python.org"""
    
        #Declares a variable that will contain the retrieved text
        search_text_element = SearchTextElement()
    
        def is_title_matches(self):
            """Verifies that the hardcoded text "Python" appears in page title"""
            return "Python" in self.driver.title
    
        def click_go_button(self):
            """Triggers the search"""
            element = self.driver.find_element(*MainPageLocators.GO_BUTTON)
            element.click()
    
    
    class SearchResultsPage(BasePage):
        """Search results page action methods come here"""
    
        def is_results_found(self):
            # Probably should search for this text in the specific page
            # element, but as for now it works fine
            return "No results found." not in self.driver.page_source
    

    6.3.页面元素

    element.py代码如下:

    from selenium.webdriver.support.ui import WebDriverWait
    
    
    class BasePageElement(object):
        """Base page class that is initialized on every page object class."""
    
        def __set__(self, obj, value):
            """Sets the text to the value supplied"""
            driver = obj.driver
            WebDriverWait(driver, 100).until(
                lambda driver: driver.find_element_by_name(self.locator))
            driver.find_element_by_name(self.locator).send_keys(value)
    
        def __get__(self, obj, owner):
            """Gets the text of the specified object"""
            driver = obj.driver
            WebDriverWait(driver, 100).until(
                lambda driver: driver.find_element_by_name(self.locator))
            element = driver.find_element_by_name(self.locator)
            return element.get_attribute("value")
    

    6.4.定位器

    一个实用的习惯是将定位器字符串从使用它的地方分离出来。在本例中,相同页面的定位器从属于相同的类。

    locators.py代码如下:

    from selenium.webdriver.common.by import By
    
    class MainPageLocators(object):
        """A class for main page locators. All main page locators should come here"""
        GO_BUTTON = (By.ID, 'submit')
    
    class SearchResultsPageLocators(object):
        """A class for search results locators. All search results locators should come here"""
        pass
    
  • 相关阅读:
    hashCode()相同,equals()也一定为true吗?
    什么是装箱?什么是拆箱?装箱和拆箱的执行过程?常见问题?
    LOJ114_k 大异或和_线性基
    BZOJ_4459_[Jsoi2013]丢番图_数学+分解质因数
    BZOJ_4184_shallot_线段树按时间分治维护线性基
    BZOJ_2844_albus就是要第一个出场_线性基
    BZOJ_3105_[cqoi2013]新Nim游戏_线性基+博弈论
    BZOJ_1195_[HNOI2006]最短母串_AC自动机+BFS+分层图
    BZOJ_3881_[Coci2015]Divljak_AC自动机+dfs序+树状数组
    BZOJ_1532_[POI2005]Kos-Dicing_二分+网络流
  • 原文地址:https://www.cnblogs.com/taceywong/p/6602772.html
Copyright © 2011-2022 走看看