利用POM完成脚本分离实现企业级自动化(POM设计模式+页面的框架封装+测试报告截图)
项目-测试-手工测试
- 1.了解需求;
2.编写测试用例(开始)------功能测试组会去做的事情
3.执行测试用例------发送测试报告 - 企业架构:功能组-自动化-性能组
- 前置条件:web自动化必须是项目相对稳定的情况去进行投入自动化测试。
- 比较规范的公司业务:自动化工程师会根据我们对应功能测试用例去挑选一些核心业务流程去做自动化。
(优先级高的、业务的核心流程(根据项目各有不同)、对应的复杂度能够通过自动化实现)
重点:然后把挑选的用例用脚本的方式去进行描述。通过计算机进行自动取执行脚本。--如果说需要回归测试的话,相对会提高效率。
-
怎么把对应的case转成脚本?--WEB UI --selenium------元素定位、8种
-
很多重复的代码--如果是重复的代码-线性代码-面试过程当中(认定不会自动化)。
-
思路:线性代码-动作
1.打开浏览器
2.让浏览器打开对应的页面
3.操作页面元素及对应的操作(点击、输入、滚动、拖动...)(都是通过selenium去做的)
-
自动化测试相关的模型------POM
-
POM(Page Object Model)页面对象模型,是一种设计模式
-
建立文件夹存放页面,如何去定义页面:
1.一个页面一个对象 --class
2.这个页面有什么?(公共部分提取,再单独写)
这个页面能做什么?
3.定位方式:右击-检查-复制 XPATH
导入by包
4.目前知道谁?可以去运行了吗?所有页面操作都一样,如何不需要重复写
实现:继承。(所有的页面都可以看为一个子类)
1.写一个类--父类--(方法、属性)
2.只要对应的子类继承了父类
3.对应的子类就可以使用父类的方法和属性
-
find_element------依次传递
-
在python当中*代表进行解包,把对应的数据依此分割开。
如何继承?在对应类中写入父类名
4.调用,程序的入口
(完成了自动登录和退出)
- 总结:
1.page--class--一个class代表一个页面;
2.每个页面做的操作:有什么、能做什么?
3.每个页面做的操作都基本相同,所以我们可以写一个父类,对应的子类继承于他
4.所有的父类即可使用对应的方法
- 利用css定位,实现页面整体封装