最近参与的项目进入集中测试阶段了,可怜各位测试小姐姐还要手动输入各种数据,真是不能忍啊。这种时候就需要我们程序猿出场了,使用各种高科技来拯救小姐姐吧。
用python版的selenium来实现一个简单的自动化程序很简单,具体selenium的使用教程也不用赘述了,官网文档描述的很清楚了,附上链接供大家参考Selenium 浏览器自动化项目。
言归正传,该项目名为AutoTest 可配置自动化测试工具使用,python+selenium实现的可配置自动化测试工具,只要稍微了解HTML及相关查询器的知识,就可以通过书写测试流程文件来完成测试流程定制,表单自动填写,按钮点击,流程截图,键盘事件,浏览器缓存操作等功能,目前仅支持Chrome, IE浏览器。
启动方法
-
开发环境运行
- 本地环境请预先安装好python3.8,下载项目到本地任意文件夹,使用pip安装pipenv包,使用vscode加载项目后,在控制台输入
pipenv shell
建立独立开发环境,然后输入pipenv install
完成项目所需包安装。 - 本地添加如下lauch.json启动文件
{ "version": "0.2.0", "configurations": [ { "name": "Python: Current File", "type": "python", "request": "launch", "program": "${workspaceFolder}/autotest.py", "console": "integratedTerminal" } ] }
- 点击F5即可启动本项目。
- 本地环境请预先安装好python3.8,下载项目到本地任意文件夹,使用pip安装pipenv包,使用vscode加载项目后,在控制台输入
-
exe文件运行
- 在完成开发环境配置后,可以通过项目中提供的run.bat文件来生成exe可执行文件来启动项目。
使用说明
-
相关配置文件
- autotest.yaml 项目全局配置文件,配置诸如默认启动浏览器,是否使用代理等。
- logger.yaml 日志配置文件,配置日志等级及输出类型
- const.yaml 常量定义,在自定义测试流程时使用
-
流程文件定义说明
- 流程文件是json格式文件,所有文件都必须放到项目根目录下的flowdata文件夹下,文件名取名任意,前缀为cmn_XXXX.json的文件将做为通用流程文件,提供给其他流程文件使用,不会直接加载到项目可执行流程文件中。
- 如下代码所示,每一个键值对代表一个操作步骤,字典键无具体意义,可作为操作提示备注信息,type指定操作类型,这里的open是指的打开具体网址操作,targeturl表示目标网址,option表示当前操作后的一些额外动作,例如此处的
{ "type": "wait", "params": 5}
为停顿5秒。{ "打开简书": { "type": "open", "targeturl": "https://www.jianshu.com/", "option": { "type": "wait", "params": 5} } }
-
type包括以下类型
-
open 打开指定网址。
- 必要属性:targeturl指定目标网站地址;
- 可选属性:
- option指定当前操作完成后的一些额外操作,包括refresh刷新页面,wait停顿,close关闭浏览器,switch切换窗口,screenshot截图;
- doafter指定完成操作后的子操作,语法和父节点一致。
-
read 读取指定mock数据文件。
- 必要属性:
- findmethod指定页面元素使用的选择器,包括ID,XPATH,LINK_TEXT,PARTIAL_LINK_TEXT,NAME,TAG_NAME,CLASS_NAME,CSS_SELECTOR;
- targeturl指定读取目标mock文件地址。mock文件作为流程中需要使用的共通数据文件,统一放置在mockdata文件夹中,mock文件格式也为json格式,其中的字典键对应与findmethod相匹配的查询表达式。
- 可选属性:option,doafter。
- 必要属性:
-
click 处理页面元素单击操作。
- 必要属性:findmethod,target指定与findmethod相匹配的查询表达式;
- 可选属性:
- count指定点击次数,默认为1次;
- index通过指定索引值从匹配元素集中找到对应元素
- option;
- doafter。
-
dbclick 处理页面元素双击操作。
- 必要属性:findmethod,target;
- 可选属性:option,doafter。
-
alert 弹出对话框确认操作。系统中有时在点击关键按钮时会出现相关操作确认提示框,通过配置该节点默认确认进入下一节点。
- 可选属性:option,doafter。
-
copy 将匹配值复制到剪贴板中,以备后续使用。
- 必要属性:
- 通过指定findmethod,target组合,可以复制页面指定元素值到剪贴板中;
- 通过指定itemval,可以复制其对应值到剪贴板中,itemval支持设置常量值,如copy操作配置在某循环中,也可通过指定format来完成动态值设置。
- 可选属性:option,doafter。
- 必要属性:
-
paste 将剪贴板值设置给页面指定元素。
- 必要属性:findmethod,target;
- 可选属性:option,doafter
-
for 循环操作。
- 必要属性:
- 通过指定startidx,endidx组合,完成指定范围的索引循环,其当前索引值可作为动态值提供给循环体内子节点使用;
- 通过指定findmethod,target组合,完成对页面匹配元素集的循环操作,当前元素值可提供给循环体内子节点使用。当循环体内click子节点未指定元素时,会使用循环中的当前元素进行单击操作。
- flow定义了循环体要处理的子节点集合。
- 可选属性:option,doafter
- 必要属性:
-
cache 设置浏览器缓存。
- 必要属性:
- cachekey指定浏览器缓存键;
- itemval指定缓存键对应的值。
- 可选属性:option,doafter
- 必要属性:
-
setval 区别于read多项目读取,该操作为对页面单项目的值设定,主要用于设置上传文件,动态值设定等。
- 必要属性:findmethod,target, itemval;
- 可选属性:option,doafter
-
flowfile 加载共通流程模板文件。
- 必要属性:targeturl;
- 可选属性:option,doafter
-
keyboard 键盘操作。多用于点击键盘PAGE_DOWN事件完成页面滚动等,不支持键盘键组合。
- 必要属性:
- 通过指定findmethod,target组合,在指定页面元素上施加对应键盘操作。
- itemval指定键盘键值;
- 可选属性:option,doafter
- 必要属性:
-
open 打开指定网址。
- 其他属性说明
-
option包括无参命令,有参命令,也可以通过数组形式包括多个命令。
- 无参命令:
-
{"option":"refresh"}
刷新浏览器 -
{"option":"close"}
关闭浏览器 -
{"option":"screenshot"}
当前显示窗口截屏
-
- 有参命令
-
{"option": { "type": "wait", "params": 5} }
执行等待,等待时间由params参数指定。多用于解决页面加载缓慢问题。 -
{"option": { "type": "switch", "params": "new"} }
切换到新开窗口;{"option": { "type": "switch", "params": "origin"} }
关闭新窗口后,切换回原始窗口 - 截取页面全屏,params指定参数数组,第一个参数为页面中需要处理的漂浮元素,xpath指定查询元素方式,当前支持id=xxx,class=yyy, tag=zzz等3种方式,display_page表示漂浮元素要显示的位置,一般情况下漂浮元素如简书的头需要显示在截屏的首页则设置为first,如简书的返回顶部按钮需要显示在截屏的尾页则设置为last,截取全屏功能仅通过Chrome测试;第二个参数为指定是否需要预先加载完页面,例如简书首页文章列表随着滚动加载,如需要截取全屏则需要设置为True,反之对于一次性加载的页面则设置为False。
{ "type": "screenshot", "params": [ [ { "xpath":"tag=nav", "display_page":"first"}, { "xpath":"class=side-tool", "display_page":"last"} ], "True" ] }
-
- 无参命令:
-
option包括无参命令,有参命令,也可以通过数组形式包括多个命令。
- bat文件说明
- run.bat 执行后会在项目根目录生成dist文件夹,里面包含了项目可执行程序exe等相关文件。执行打包前,请先进入pipenv所创建的独立环境后,再请执行命令pip install pyinstaller安装对应包。
- zip.bat 使用windows自带压缩软件,压缩浏览器代理插件用的压缩文件,使用前请先修改proxy文件下的代理配置文件background.js,直接cmd中进入项目目录输入zip命令执行。
简书点赞流程文件解析
{
"打开简书": {
"type": "open",
"targeturl": "https://www.jianshu.com/",
"option": { "type": "wait", "params": 5}
},
"添加cookie": {
"type": "cache",
"cachekey": "remember_user_token",
"itemval": "输入账户登陆后的token值",
"option": ["refresh", {
"type": "wait",
"params": 5
}, {
"type": "screenshot",
"params": [
[
{ "xpath":"tag=nav", "display_page":"first"},
{ "xpath":"class=side-tool", "display_page":"last"}
],
"True"
]
}]
},
"循环点击文章列表": {
"type": "for",
"findmethod": "CSS_SELECTOR",
"target": "#list-container>ul.note-list>li>div.content>a.title",
"flow": {
"打开文章": {
"type": "click",
"option": {
"type": "switch",
"params": "new"
}
},
"文章点赞": {
"type": "click",
"findmethod": "CLASS_NAME",
"target": "_2VdqdF",
"index": 0,
"option": {
"type": "switch",
"params": "origin"
}
}
}
}
}
该流程文件包含了3个节点,第一个节点表示打开简书网站;第二个节点操作缓存,简书网站在你登陆以后会在浏览器缓存的remember_user_token中记录你的token值,通过手动添加该缓存即可自动登陆,同时在添加完缓存后,需要按序执行额外的一些操作,刷新浏览器让登陆状态生效,截取文章列表全屏(此处另一个目的是为了加载完全部文章以备后续点赞用);第三个节点通过CSS_SELECTOR选择器,查找所有文章列表,并循环该列表完成后续点赞操作。子节点打开文章,由于没有指定查找匹配元素方式,则默认会点击循环当前元素即当前文章,额外操作中完成切换到新窗口,子节点文章点赞则完成单击点赞按钮后,在额外操作中关掉当前窗口并切换回主窗口。
下面是程序运行后的启动界面,选中流程文件,点击启动即可。
被拯救的小姐姐很满意,奖励了一根鸡腿。