移动端测试方案--sptt
sptt
sptt是移动端UI自动化测试的一种解决方案,全称为special tool of test。sptt提供了一套测试解决方案,并使用命令行完成相关操作,最终可集成在各种后续的流程中。
sptt内部整合了第三方测试框架-appium,由appium层抹平iOS和android环境下的测试差异,同时sptt又针对appium的相关接口做了二次开发层面上的优化,封装了可直接使用的操作接口,并提供了开发和调试相关功能,方便使用。
关于规范介绍,请看
关于如何开发atom实例,请看
安装sptt环境
为了测试的灵活性,sptt提供两种测试方式:
- 本地测试
- 云端测试
由于本地测试需要在本地环境部署相关的测试环境,因此在这里并不推荐测试人员使用本地测试。具体如何在本地部署环境请看官方文档。
首先,确保电脑上已经安装nodejs环境,并设置npm的仓库为公司的内部私有仓库:
npm config set registry http://npm.showjoy.net
然后,运行命令,安装sptt:
sudo npm install -g sptt
这样,sptt命令行安装完毕。
针对一个ios工程,在对应目录下运行云端测试:
sptt run -t ios --online 10.1.2.49
针对android工程,则有:
sptt run -t android --online 10.1.2.49
sptt命令使用
sptt提供了三个子命令:
sptt init
、
sptt run
和
sptt publish
"sptt init"用于初始化目录结构,并提供了相关模板。再创建一个新的sptt测试工程时,应该使用命令行进入当前目录,执行sptt init初始化目录;
“sptt run”执行测试用例,其中有多个选项:
“-t”指定运行测试用例的环境,可以取值“ios、android”;
“--online”指定云端测试主机的ip地址,如果不设置online则在本地环境运行测试用例;
“-n”指定执行具体名称的testcase文件,而不是执行默认的所有测试用例,如果要执行多个文件,必须使用**“,”**连接多个文件名。
sptt run -t ios --online 10.1.2.49 -n test1,test2,test3
//执行test1、test2和test3这3个测试用例集合
"sptt publish"用于发布ios的测试包(需要在在测试包所在目录下运行命令),android测试包的发布使用android包发布流程。需要注意的是,ios测试包是编译后的运行在模拟器上的.app文件,android则是.apk文件。
测试包的发布必须制定版本号,格式为x.x.x.
cd pwd(DaRenShop.app) // 切换到app文件所在的目录
sptt publish 0.0.5
示例
首先,从gitlab的testcase组中clone示例工程(https://github.com/royalrover/sptt-firstBlood);
pwd //out: /Users/showjoy/github
git clone http://git.showjoy.net/testcases/first-blood
cd /Users/showjoy/github/first-blood
其次,确保示例文件“ios/caps.json”中的app路径正确,默认引用的是我主机上的测试包;
最后,执行命令
sptt run -t ios --online 10.1.2.49
调试
sptt提供了调试功能,它分为两部分:
- 日志
- 截图
日志
其中,日志功能在macbook上有两个文件:命令行输出文件sptt.runtime.log和sptt内核-appium输出文件appium.log。
sptt.runtime.log输出的信息也就是命令行中输出的信息,它用来记录执行命令的所有输出;
appium.log记录云端或本地的appium服务器输出信息,当测试用例出错时,通过sptt.runtime.log文件不足以找出错误所在,这样可以通过查找appium.log来分析sptt与appium交互,并将相关的错误反映给开发者。
需要注意的是,在windows系统的cmd命令默认未提供相关功能,因此sptt并未提供appium.log文件。
截图
sptt在每次原子操作执行失败后保存当前视图快照,方便测试人员快速定位错误页面和步骤,集中重点debug。快照存放在工程的“out/snapshoot”目录中,图片的名称按照“name-content@name[action]{timer}.png”格式命名,透过名称可以了解当前元素的选择器和执行的操作及其时间,语义化调试。
结果分析
sptt运行完测试用例集合后,会生成相关报表。目前测试报表路径在“out/testcaseReport.html”中,记录了测试用例集合运行的总时间、每个测试用例执行时间以及运行结果,对使用者更人性化。
- pangrank算法--PageRank算法并行实现
- 刷爆朋友圈的 deepfakes 视频人物换脸是怎样炼成的?
- 干货 | ElasticSearch相关性打分机制
- FCN 的简单实现
- 2.运行一个demo
- ROWNUMBER() OVER( PARTITION BY COL1 ORDER BY COL2)/ ROWNUMBER() OVER( PARTITION BY COL1 ORDER BY CO
- 干货 | 前端常用的通信技术
- TP-LINK WR941N路由器研究
- ORA-01113问题的简单分析(r6笔记第3天)
- Tensorflow 中 learning rate decay 的奇技淫巧
- hive数据:名词解释
- 巧妙使用exchange partition的一个案例(r6笔记第1天)
- r与rjava
- 使用expect运行动态脚本(r6笔记第19天)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Qt编写安防视频监控系统32-onvif信息获取
- Qt编写安防视频监控系统33-onvif云台控制
- Qt编写安防视频监控系统34-onvif事件订阅
- Qt编写安防视频监控系统35-onvif抓拍图片
- Qt音视频开发1-vlc解码播放
- 【TBase开源版测评】分布式数据自动shard分片
- STL—mt19937
- 潘石屹用Python解决100个问题 | 字符类型统计
- 潘石屹用Python解决100个问题 | 分解质因数
- 使用Java Spring消费MySQL中的数据库存储过程
- 部署 Docker 及配置
- 【Spark on K8S】Spark里的k8s client
- 【每日一题】30. Substring with Concatenation of All Words
- MySQL选错索引导致的线上慢查询事故复盘
- 【Kubernetes】additionalPrinterColumns的配置