一、什么是POM?
POM(Page Object Model)中文字母意思是,页面对象模型,POM是一种最近几年非常流行的自动化测试模型,或者思想,POM不是一个框架,就是一个解决问题的思想。采用POM的目的,是为了解决前端中UI变化频繁,从而造成测试自动化脚本维护的成本越来越大。
二、POM特点
1. 把web ui对象仓库从测试脚本分离,业务代码和测试脚本分离。
2. 每一个页面对应一个页面类,页面的元素写到这个页面类中。
3. 页面类主要包括该页面的元素定位,和和这些元素相关的业务操作代码封装的方法。
4. 代码复用,从而减少测试脚本代码量。
5. 层次清晰,同时支持多个编写自动化脚本开发,例如每个人写哪几个页面,不影响他人。
6. 建议页面类和业务逻辑方法都给一个有意义的名称,方便他人快速编写脚本和维护脚本。
三、POM目录结构
1、base 目录(公共方法的封装。单击、输入等)
2、data 目录(存放测试数据yaml文件)
3、config 目录(存放读取yaml文件的py文件)
4、page_object 目录 (脚本目录)
5、case 目录 (测试用例)
6、report 目录(测试报告生成目录)
四、示例
这里先讲前五个目录,report 目录后面结合测试报告一起讲。
1、base目录
一般是存放测试代码中都需要用到的公共方法,比如在UI自动化中,对webdriver对象的实例化以及需要用到的方法封装到一个base_page.py文件中,在其他文件中通过导包继承的方式实现类和方法的复用。
2、data目录与config 目录
datas 目录用来存放实现数据驱动时的各yaml文件,例如本人举例项目中,将登录账号密码写入yaml文件中,然后在测试用例中动读取态载入yaml文件中的数据,实现测试的数据驱动。
config 目录用于存放读取yaml文件的py文件
在用例目录会讲到用例传参
3、page_object 目录
在UI项目中,page目录内实现对各页面的封装,每个待测试的页面可以实现一个page,例如登录,可命名为login_page.py,达到见名知意的效果,也方便个人在其他文件中对该文件的导入复用以及后期维护,每个page文件中,实现对该页面中待操作的元素(ui层)以及各元素要实现的动作(操作层)的封装。
4、test_case 目录
cases 目录用来存放实际的测试用例,每个文件以test开头命名,对page中的文件进行测试步骤的实现。可以放多个page中的测试步骤。
最后创建一个run.py运行文件,用来运行测试用例。
再补充一下UI层与操作层的分离!
创建一个用于存放UI层的py文件以及一个操作层的py文件。
例如:
UI层:login_test.py
操作层:login_page.py
这里是登录页面所有的元素定位!这样做的好处是后续如果元素发生了改变,只需要去修改元素即可,不需要对其他地方做出修改!同时,改了这里,所有用到此元素的地方,都会发生改变!
示例:
接下来是操作层文件。
导包之后自定义调用名称来调用UI层文件的元素。
例如我这里自定义的是log