做过web自动化测试的同学,对Page object设计模式应该不陌生。
Page object库应该根据以下目标开发:
-
Page object应该易于使用
-
清晰的结构
-
PageObjects 对于页面对象
-
PageModules对于页面内容
-
-
只写测试,而不是基础。
-
在可能的情况下防止样板代码。
-
不需要自己管理浏览器。
-
在运行时选择浏览器,而不是在类级别。
-
不需要直接接触selenium。
这只是一种设计模式,只要遵循它有思想,不借助第三方库,我们一样可以实现这种设计模式。
创建baidu_page.py
文件,实现page层封装。
class BasePage:"""基础Page"""def __init__(self, driver):self.driver = driverdef 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"""@propertydef search_box(self):return self.id_("kw")@propertydef search_button(self):return self.xpath("//*[@id='su']")
我们本质上要将元素的定位和元素的操作分开,page层用来定义元素的定位。
接下来创建,test_baidu.py
文件,用来实现自动化测试。
from selenium import webdriver
from baidu_page import BaiduPagedr = 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, PageElementclass BaiduPage(PageObject):search_box = PageElement(css='#kw')search_button = PageElement(id_='su')
是的,就这么简单,专注于元素的定位的编写,几乎没有多月的东西。而且还可以添加超时时间哦!
from page_objects import PageObject, PageElementclass BaiduPage(PageObject):search_box = PageElement(css='#kw', time_out=2)search_button = PageElement(id_='su', time_out=10)
这样再也不用写恶心的显式等待了,是不是很爽!?
定位一组元素也是非常简单的说。
from page_objects import PageElementsclass BaiduPage(PageObject):……# 百度搜索结果search_result = PageElements(xpath="//div/h3/a")
啥? 项目地址? 别急!别急!
GitHub地址:
GitHub - SeldomQA/poium: Page Objects design pattern test library, support selenium、appium、playwright, etc
原项目已经不再维护,我阅读了原项目代码,虽然只有100多行,但设计非常精妙。可惜缺少元素的等待,这将有助于定位元素的稳定性,所以,在原有项目的基础上增加的该功能。
下载安装:
$ python setup.py install
通过pip命令安装:
$ pip install -i https://testpypi.python.org/pypi selenium-page-objects