Time will tell.
前言
本文就Python Selenium自动化测试实践中所需要的POM设计模式进行分享。
基于python selenium2开始UI级自动化测试并不是多么艰巨的任务。只需要定位到元素,执行对应的操作即可。下面l来看一个简单的脚本实现百度搜索。
from selenium import webdriver
import time
driver = webdriver.Firefox()
driver.implicitly_wait(30)
# 启动浏览器,访问百度
driver.get("http://www.baidu.com")
# 定位 百度搜索框,并输入selenium
driver.find_element_by_id("kw").send_keys("selenium")
# 定位 百度一下 按钮并单击进行搜索
driver.find_element_by_id("su").click()
time.sleep(5)driver.quit()
从上述代码来看,我们所能做的就是定位到元素,然后进行键盘输入或鼠标动作。就一个小程序,维护起来看起来是很容易。但随着时间的迁移,测试套件将持续增长,脚本也将变得越来越臃肿庞大。
如果变成我们需要维护10个页面,100个页面,甚至1000个呢?那页面元素的任何改变都会让我们的脚本维护变得繁琐复杂,而且变得耗时易出错。那怎么解决呢?
在自动化测试中,引入了Page Object Model(POM):页面对象模式来解决。POM能让我们的测试代码变得可读性更好,高可维护性,高复用性。
下图为非POM和POM对比图:
一、POM是什么
页面对象模型(POM)是一种设计模式,用来管理维护一组web元素集的对象库。
- 在POM下,应用程序的每一个页面都有一个对应的page class。
- 每一个page class维护着该web页的元素集和操作这些元素的方法。
- page class中的方法命名最好根据其对应的业务场景进行,例如通常登录后我们需要等待几秒中,我们可以这样命名该方法:waitingForLoginSuccess(