PO模型
一,po模型介绍
在自动化中,selenium自动化测试中有一个名字经常被提及pageobject(思想与面向对象的特征相同),通常PO模型可以大大提高测试用例的维护效率
优点:重用,业务和对象分离,代码结构清晰,方便代码维护
二,PO的核心要素
1,在PO模式中抽离封装集成一个BasePage类,该基类应该拥有应该实现webdriver实例的属性
2,每一个page都继承BasePage,通过driver来管理本page中元素,将page中的操作封装成一个个方法
3,TestCase继承unittest.Testcase类,并依赖page类,从而实现相应的测试步骤
三,代码分析
不同的运行脚本环境,游览器不同:驱动webdriver.Firefox()
可以剥离
请求地址的变化(生产环境和测试环境): url = http : // www.baidu.com可以剥离
操作元素时,常常要等待元素加载完成方可进行操作:可以把webdriver提供的find_element * 方法封装,在元素操作前,先判断元素是否可以操作
实际测试场景中,可能有多个测试场景,如果每个测试场景都需要维护url, 游览器驱动, 元素定位等, 效率会非常低
因此基于以上分析,是否可以设计一个所有测试界面(selenium本身是B / S系统开展测试)的基类,来维护公共的方法,此处定义名字为BasePage.py, 用于存放页面公共方法及webdriver原有方法二次封装等
四,PO模式的优点
1:PO提供了一种业务流程与页面元素操作分离的模式,这使得测试代码变得更加清晰
2:页面对象与用例分离,使得我们更好的复用对象
3:可复用的页面方法代码会变得更加优化
4:更加有效的命令方式使得我们更加清晰的知道方法所操作的UI元素
五,总结
PO设计模式中的BasePage基类对应案例中的BasePage.py文件
PO模式中的pages中的案例显示Search.py
PO模式设计中TestCase对应案例中的TestCase.py