Java&Selenium Web自动化测试框架理念
一、自动化测试含义
在自动化测试领域内流传着一个说法:单元测试才是自动化测试的核心,在自动化测试里,无论框架何等完美都不可能脱离单元测试,单元测试将会是自动化测试里最小的单位,把它看作单位一,若干个单位一组成了一个整体,它就成了自动化测试;
诸如Python的单元测试框架Unittest、Pytest;Java的单元测试框架TestNG、Junit都为自动化测试提供并承担了决定性的支持,如何做好单位一,是一个合格的自动化测试工程师所必备的技能。
二、结构说明

- Util:工具类包:包含操作浏览器的常规事件、键盘及鼠标事件的模拟、文件的解析等,不区分平台皆可使用的公共的工具类
- PageObject:页面对象包:以每一个页面为单位,封装该页面内所有需要控制的控件,通过页面控件的定位将其封装成对象,然后操作该对象实现自动化操作
- AppModules:公共应用模块包:在产品的业务流程中,常有中间过程,公共流程,例如登陆、例如导航,将其独立封装,而非在脚本中重复编写
- PropertyFiles:属性文件包:自动化框架必须实现的一点,页面元素独立,配置信息独立,从而达到更高的可维护性,页面的变动对整体代码影响降到最低
- TestScripts:测试脚本包:以TestNG作为支撑,单纯的测试脚本
- TestData:测试数据包:自动化框架必须实现的一点,测试数据独立,根据实际测试内容的需要可以将测试数据存放在文件里,可以是excel、yaml、json等,而Util包里提供解析测试数据文件的工具类实现对的读取写入,在测试数据量少的情况下,则可直接使用TestNG的DataProvider实现测试数据的组织形式
- Constants:常量包:用于定义一些配置信息如文件路径、SQL语句、连数据库信息等以供代码直接调用
注:每一款产品都有不同的特性,例如针对我们平台来说,它提供大量的服务及应用相关内容,这些内容并非单纯的UI自动化可测的,因此我们在Util里单独为服务验证提供方法用于验证Mysql、MongoDB、Redis、ElasticSearch、PostGreSQL、Neo4j、Kafka、RabbitMQ等服务在UI自动化执行后对服务可用性进行补充验证。
三、编码规则及样例
任何一家公司的自动化框架都应该有一定的规约,当自动化工程师进进出出团队,难免变法风格及相关工作存在一定的差异。
那么自动化团队的编码规约应该从哪写方面进行规范呢?
- 命名风格规约
- 常量定义规约
- 代码格式规约
- 控制语句规约
- 注释规约
- 元素定位规约
- 页面元素封装规约
- 自动化测试脚本规约
- 工具类封装规约
- 公用应用类封装规约
四、使用自动化测试框架的优势
为什么要使用自动化测试框架,实际上很多已经从事了自动化测试的人或者刚刚迈进门槛的人都会问这个问题。
明明一个文件就能编写用例并执行,为什么要费那么大力气弄框架,为什么要使用它?
我在从事了很多年自动化测试工作后一度非常厌倦,我们常常会吐槽的点大概就是:为什么PO又要对页面进行优化、为什么前端代码如此的不规范、为什么需求又变了等等
一个产品的自动化用例量可能有几千几万甚至更多,一旦页面发生变化就可能导致我们的用例因为定位不到页面元素而执行失败或者断言失败,如此我们修改自动化代码的代价就是不可估量的,代码的可维护性无法保障
同样的道理,测试输入,我们的测试数据也尽可能不要出现在测试代码中,从而方便维护和扩展
在一个产品内的思考:公共方法类的封装,例如一个产品的业务逻辑会出现很多公共的且绕不过去的部分,比如登陆、比如导航,我们不可能每个用例都去编写或复制一遍它,因此自动化框架也将这公共部分单独封装以供调用
再有一个很重要的考虑层面是,我们决定做一个新的产品,也要上自动化测试,那么原有的自动化测试中是否有直接迁移的部分,以便我们新的团队不用从0做起
因此我们还要合理的封装一些通用的不依赖产品本身的API,例如鼠标操作、键盘操作、浏览器控制、文件解析、报告类、日志类等等
五、好的自动化框架什么样
其一 必须做到页面元素与实际测试代码分离
其二 必须做到测试数据与实际测试代码分离
其三 必须将公共方法独立封装不可依赖于产品
其四 必须尽可能封装产品内的公共模块以供调用
自动化测试框架的目标一定是为自动化测试工程师服务的,让他们能够快速构建测试代码,并且框架必须是松耦合的从而使它可维护可扩展
Java&Selenium Web自动化测试框架理念的更多相关文章
- Java+Selenium+Testng自动化测试学习(二)
Java+Selenium+TestNG自动化测试框架整合 1.简化代码 封装一个定位元素的类,类型为ElementLocation package com.test; import org.open ...
- 基于Selenium+Python的web自动化测试框架
一.什么是Selenium? Selenium是一个基于浏览器的自动化测试工具,它提供了一种跨平台.跨浏览器的端到端的web自动化解决方案.Selenium主要包括三部分:Selenium IDE.S ...
- web自动化 基于python+Selenium+PHP+Ftp实现的轻量级web自动化测试框架
基于python+Selenium+PHP+Ftp实现的轻量级web自动化测试框架 by:授客 QQ:1033553122 博客:http://blog.sina.com.cn/ishou ...
- Windows环境搭建Web自动化测试框架Watir
Windows环境搭建Web自动化测试框架Watir 一.前言 Web自动化测试一直是一个比较迫切的问题,对于现在web开发的敏捷开发,却没有相对应的敏捷测试,故开此主题,一边研究,一边将We ...
- Web 自动化测试框架 sweetest 介绍
项目开源: https://github.com/tonglei100/sweetest 文章转载:https://segmentfault.com/a/1190000011612061 介绍 swe ...
- Web自动化测试框架改进
Web自动化测试框架(WebTestFramework)是基于Selenium框架且采用PageObject设计模式进行二次开发形成的框架. 一.适用范围:传统Web功能自动化测试.H5功能自动化测试 ...
- Web自动化测试框架-PO模式
Web自动化测试框架(WebTestFramework)是基于Selenium框架且采用PageObject设计模式进行二次开发形成的框架. 一.适用范围:传统Web功能自动化测试.H5功能自动化测试 ...
- selenium3与Python3实战 web自动化测试框架 ☝☝☝
selenium3与Python3实战 web自动化测试框架 selenium3与Python3实战 web自动化测试框架 学习 教程 一.环境搭建 1.selenium环境搭建 Client: py ...
- selenium3与Python3实战 web自动化测试框架✍✍✍
selenium3与Python3实战 web自动化测试框架 整个课程都看完了,这个课程的分享可以往下看,下面有链接,之前做java开发也做了一些年头,也分享下自己看这个视频的感受,单论单个知识点课 ...
随机推荐
- 《剑指offer》Q01-12 (牛客10.11)
目录 T1 二维部分有序数组查找 ☆ T2 字符串字符不等长替换 - 从后往前 T3 返回链表的反序 vector T4 重建二叉树 T5 两个栈模拟队列 T6 旋转数组中的最小元素 - 二分或暴力 ...
- 【VS开发】fopen 文本文件与二进制文件区别
在学习C语言文件操作后,我们都会知道打开文件的函数是fopen,也知道它的第二个参数是 标志字符串.其中,如果字符串中出现'b',则表明是以打开二进制(binary)文件,否则是打开文本文件. 那么什 ...
- 启动Nginx 出现 nginx: [emerg] unknown directive "锘?user" 错误
出现这种情况 一般是修改配置文件 nginx.conf 造成的 如果你修改文件后出现 那基本上就是这个原因 启动不了 重新打开 改为UTF-8 无BOM编码
- EXCEL 查找某个字符在字符串中最后一次出现的位置
在EXCEL文档里想从很长的文件路径中取得文件名,[数据]→[分列]是个不错的选择,但用函数会显得更高大上一些. 首先,需要获取最后一个"\"所在的位置. 方法1: FIND(&q ...
- LINUX添加新的用户账号并赋予root权限
一:添加新的用户账号使用 useradd 命令 语法: useradd 选项 用户名 示例: # 添加用户,设定登录目录:useradd -d /home/admin -m a ...
- 小菜鸟之SSM框架
# SSM框架 # **什么是框架** 就是模板,将一些基础性的程序和代码由框架模板提供,然后程序员补充和业务需求相关的代码. # **ssm框架组成** s: springMvc 子框架 代替ser ...
- Linux 下安装 redis5.0
1.redis 安装 wget http://download.redis.io/rele... tar -zxvf redis-5.0.5.tar.gz cd redis-5.0.5.tar.gz ...
- (六)Java秒杀项目之接口优化
一.Redis预减库存减少数据库访问 思路:减少数据库访问 1.系统初始化,把商品库存数量加载到Redis 2.收到请求,Redis预减库存,库存不足,直接返回,否则进入3 3.请求入队,立即返回排队 ...
- C++多线程基础学习笔记(十)
一.Windows临界区的基本用法 CRITICAL_SECTION my_winsc; //定义一个Windows的临界区,相当于一个mutex变量 InitializeC ...
- vs code 更改快捷键
选择左下角设置图标,快捷键方式 文件列表修改,搜 list 文件tree list.focusUp -> ctrl+p