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

  


  

posted @ 2021-03-09 17:02  测试——小白  阅读(246)  评论(0编辑  收藏  举报