利用POM完成脚本分离实现企业级自动化(POM设计模式+页面的框架封装+测试报告截图)

利用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定位,实现页面整体封装
相关推荐
❥ღ Komo·10 分钟前
Elasticsearch单机部署全指南
运维·jenkins
CHN悠远12 分钟前
debian13 安装钉钉后,钉钉无法运行问题的解决办法
linux·运维·服务器·钉钉·debian13
祎直向前14 分钟前
在Ubuntu中下载gcc
linux·运维·ubuntu
liu****21 分钟前
11.Linux进程信号(三)
linux·运维·服务器·数据结构·1024程序员节
shumeigang26 分钟前
nginx实用配置
运维·nginx
在未来等你1 小时前
AI Agent设计模式 Day 2:Plan-and-Execute模式:先规划后执行的智能策略
设计模式·llm·react·ai agent·plan-and-execute
fufu03111 小时前
俄罗斯方块
linux·运维·服务器
chen_note2 小时前
Kubernetes1.23版本搭建(三台机器)
运维·容器·kubernetes·云计算·kubepi
花落已飘2 小时前
openEuler WSL2容器化开发实战:Docker Desktop集成与应用部署
运维·docker·容器
betazhou3 小时前
基于Linux环境使用ogg19版本从oracle 19c ADG备库远程同步数据
linux·运维·oracle·goldengate·adg·远程抽取