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开发也做了一些年头,也分享下自己看这个视频的感受,单论单个知识点课 ...
随机推荐
- tf.contrib.rnn.LSTMCell 里面参数的意义
num_units:LSTM cell中的单元数量,即隐藏层神经元数量.use_peepholes:布尔类型,设置为True则能够使用peephole连接cell_clip:可选参数,float类型, ...
- 安卓运行linux应用程序
安卓是可以运行linux应用程序的,安卓系统原来就基于Linux.但是安卓已经把linux改头换面了.具体方法是安装Termux软件,然后就可以运行pkg命令安装软件包了,希望可以帮助到大家.
- 华为Fusioncompute 6.5.1
V6.5.1VRM“gandalf”用户的默认密码为“IaaS@OS-CLOUD9!”.CNA“gandalf”用户的默认密码为“IaaS@OS-CLOUD8!”.普通模式:admin/LaaS@PO ...
- Matlab求微分方程的符号解1
一.常微分方程的求解 例1. 例2. 例3. 通常我们使用syms 和dsolve来求解: first: second:表示 third:如果有必要 功能函数diff可以完成一元或多元函数任意阶数的微 ...
- 最新 斗鱼java校招面经 (含整理过的面试题大全)
从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿.斗鱼等10家互联网公司的校招Offer,因为某些自身原因最终选择了斗鱼.6.7月主要是做系统复习.项目复盘.LeetCode ...
- 通过JS动态追加标签,以父评论子评论为例
以下代码前后端交互以Django模板语法为例 先来以伪代码来示意用法: HTML部分: JS动态插入部分代码: 运行之后我们来浏览器看检查打印的内容: 看插入前后打印结果我们可以得知 $title[0 ...
- python进程池 使用Queue实现计数功能
多进程中各个进程间相互隔离,进程间通信需要使用到通道. 多进程中使用Queue实现进程中通信 from multiprocessing import Process,Queue import time ...
- 【LOJ】#3097. 「SNOI2019」通信
LOJ#3097. 「SNOI2019」通信 费用流,有点玄妙 显然按照最小路径覆盖那题的建图思路,把一个点拆成两种点,一种是从这个点出去,标成\(x_{i}\),一种是输入到这个点,使得两条路径合成 ...
- Kubernetes---启动及退出动作
apiVersion: v1 kind: Pod metadata: name: lifecycle-demo spec: containers: - name:lifecycle-demo-cont ...
- review代码,需要做些什么???
有一种习惯,叫看代码找问题:有另一种习惯,叫不看代码很不习惯. 这,矛盾,处处不在! review代码(code diff升级)到底可以做些什么?该做些什么? 1.整体代码风格是否贴切已有框架的设计风 ...