做过web自动化测试的同学,对Page object设计模式应该不陌生。

Page object库应该根据以下目标开发:
-     Page object应该易于使用 
-     清晰的结构 -         PageObjects 对于页面对象 
-         PageModules对于页面内容 
 
-         
-     只写测试,而不是基础。 
-     在可能的情况下防止样板代码。 
-     不需要自己管理浏览器。 
-     在运行时选择浏览器,而不是在类级别。 
-     不需要直接接触selenium。 
这只是一种设计模式,只要遵循它有思想,不借助第三方库,我们一样可以实现这种设计模式。
创建baidu_page.py 文件,实现page层封装。
 class BasePage:     """    基础Page    """    def __init__(self, driver):         self.driver = driver      def get(self, url):         self.driver.get(url)      def id_(self, id_):         return self.driver.find_element_by_id(id_)      def xpath(self, xpath):         return self.driver.find_element_by_xpath(xpath)   class BaiduPage(BasePage):     """    百度首页Page    """     @property    def search_box(self):         return self.id_("kw")      @property    def search_button(self):         return self.xpath("//*[@id='su']") 我们本质上要将元素的定位和元素的操作分开,page层用来定义元素的定位。
接下来创建,test_baidu.py文件,用来实现自动化测试。
from selenium import webdriver from baidu_page import BaiduPage  dr = webdriver.Chrome() page = BaiduPage(dr) page.get("https://www.baidu.com") page.search_box.send_keys("page object") page.search_button.click()  dr.close()这里你将看不到元素的定位,分层的好处就是,当元素的定位发生改变时,只需要维护好page层即可,对于测试用例来说不需要关心元素怎么定位,只要专心设计好用例即可。
可是,Page层的编写并不太简便,本质上它的作用只是定义一些元素的定位。那我告诉你,只需要4行代码也可以实现上面baidu_page.py的功能,你会不会太简单了?
from page_objects import PageObject, PageElement  class BaiduPage(PageObject):     search_box = PageElement(css='#kw')     search_button = PageElement(id_='su')是的,就这么简单,专注于元素的定位的编写,几乎没有多月的东西。而且还可以添加超时时间哦!
from page_objects import PageObject, PageElement  class BaiduPage(PageObject):     search_box = PageElement(css='#kw', time_out=2)     search_button = PageElement(id_='su', time_out=10)这样再也不用写恶心的显式等待了,是不是很爽!?
定位一组元素也是非常简单的说。
                        
                        
                    