利用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定位,实现页面整体封装
相关推荐
艾莉丝努力练剑11 小时前
【Linux网络】Linux 网络编程入门:UDP Socket 编程(上)
linux·运维·服务器·网络·c++·udp
代码中介商11 小时前
Linux多线程编程完全指南:线程同步、互斥锁与生产者消费者模型
linux·运维·服务器
学不会pwn不改名11 小时前
【ArchLinux】如何制服国产免驱网卡
linux·运维·网络
一只小bit11 小时前
Docker 存储卷:本地文件与容器内部文件建立绑定关系
运维·docker·容器
可视化运维管理爱好者12 小时前
rg完整中文操作指南
linux·运维·服务器·ai
寒山独见君~12 小时前
自动化-消息推送Server酱3,APP推送
运维·数据库·python·自动化·通知
都在酒里12 小时前
在公共服务器上构建 RK3588 SDK 的纯净 Docker 方案
运维·服务器·docker
计算机安禾12 小时前
【Linux从入门到精通】第46篇:SELinux与AppArmor——Linux的安全增强模块
linux·运维·安全
TBrL7UtdTELTTdut4BAL12 小时前
F7015TV3 光猫 Telnet 命令配置 DHCP 服务器
运维·服务器·网络
海兰12 小时前
将 Cursor 连接到生产日志:通过 Elastic MCP 服务器
运维·服务器·elasticsearch