研究Selenium + python 自动化测试有近两个月了,不能说非常熟练,起码对selenium自动化的执行有了深入的认识。
从最初无结构的代码,到类的使用,方法封装,从原始函数调用,到重定义函数。从变量驱动,到数据驱动,再到关键字驱动,一步一步的默默走向自动化框架的构建。虽然还有没有投入使用,只是写几个demo,就慢慢的发现了 selenium自动用例脚本,相似功能地方,代码基本都是一样的,界面元素换个查找方式,把原来的使用 xpath方式,改为使用 id 查找,需要对每个用例脚本都要改,虽然几个用例看不出什么工作量,但是重复findElement的代码,已经让我们感到了代码的笨重。如果某些定位发生了改变,我们就得贯穿整个测试代码进行调整元素定位,这样就会导致我们的脚本在后期,难以维护。
因此通过Page Object Model 我们可以创建更加健壮代码,并减少或者消除重复的测试代码,从而也能够提高代码的可读性,减少编写脚本的工作量。Page Object Model的实现,就是通过分离测试对象和测试脚本的抽象来实现的。
PO项目实战演示Demo源码:(源码会随着结构调整不断更新,但是整体结构不会变动)
Page Object Model 简称POM
下面通过一个实例演示POM的实现
在此之前,先看一个段比较普通的测试用例代码片段:
1 ....2 #测试用例
3 deftest_login_mail(self):4 driver =self.driver5 driver.get("http://mail.126.com")6 driver.find_element_by_id("idInput").clear()7 driver.find_element_by_id("idInput").send_keys("auto_tester")8 driver.find_element_by_id("pwdInput").clear()9 driver.find_element_by_id("pwdInput").send_keys("123456")10 driver.find_element_by_id("loginBtn").click()11 ....
这段脚本实现,是126邮箱登录功能的一个测试用例