利用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定位,实现页面整体封装
相关推荐
ZZH1120KQ几秒前
Linux账号和权限管理
linux·运维
@Liu_GuoXing7 分钟前
Registry和docker有什么关系?
运维·docker·容器·registry
水水沝淼㵘25 分钟前
嵌入式开发学习日志(linux系统编程--系统编程之 进程间通信IPC)Day32
linux·运维·学习
IT小饕餮32 分钟前
linux登陆硬件检测脚本
linux·运维·服务器
YGGP41 分钟前
【结构型模式】代理模式
设计模式
Dxy12393102161 小时前
DrissionPage 性能优化实战指南:让网页自动化效率飞升
运维·爬虫·python·性能优化·自动化
It's Q1 小时前
从测试角度看待CI/CD,敏捷开发
ci/cd·自动化·敏捷流程
碎梦归途2 小时前
Linux 软件安装方式全解(适用于 CentOS/RHEL 系统)
linux·运维·centos
啃火龙果的兔子2 小时前
CentOS 7.9 安装 宝塔面板
linux·运维·centos
半导体守望者3 小时前
英福康INFICON VGC501, VGC502, VGC503 单通道、双通道和三通道测量装置
经验分享·笔记·功能测试·自动化·制造