sptt

sptt是移动端UI自动化测试的一种解决方案,全称为special tool of test。sptt提供了一套测试解决方案,并使用命令行完成相关操作,最终可集成在各种后续的流程中。

sptt内部整合了第三方测试框架-appium,由appium层抹平iOS和android环境下的测试差异,同时sptt又针对appium的相关接口做了二次开发层面上的优化,封装了可直接使用的操作接口,并提供了开发和调试相关功能,方便使用。

关于规范介绍,请看

sptt规范介绍

关于如何开发atom实例,请看

如何开发sptt工程的原子操作

安装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”中,记录了测试用例集合运行的总时间、每个测试用例执行时间以及运行结果,对使用者更人性化。

移动端测试方案--sptt的更多相关文章

  1. Memory及其controller芯片整体测试方案(下篇)

    {  第三部分  }  DDR总线的设计.调试和验证  在计算机架构中,DDR作为程序运算的动态存储器,面对如高性能计算.图形计算.移动计算.工业应用等领域的要求,发展出DDR4,以及用于图形计算的G ...

  2. Java 服务端监控方案(四. Java 篇)

    http://jerrypeng.me/2014/08/08/server-side-java-monitoring-java/ 这个漫长的系列文章今天要迎来最后一篇了,也是真正与 Java 有关的部 ...

  3. 脚手架vue-cli系列五:基于Nightwatch的端到端测试环境

    不同公司和组织之间的测试效率迥异.在这个富交互和响应式处理随处可见的时代,很多组织都使用敏捷的方式来开发应用,因此测试自动化也成为软件项目的必备部分.测试自动化意味着使用软件工具来反复运行项目中的测试 ...

  4. 有了这套flexible.js 移动端自适应方案,你就能在移动端的来去自如, (*^__^*)

    flexible.js 移动端自适应方案 一,flexible.js 的使用方式: github地址:https://github.com/amfe/lib-flexible 官方文档地址:https ...

  5. APP端测试,常见功能测试点汇总

    除去每个产品和版本不同的业务需求以及功能,针对于大多数的APP的共同点和移动设备的特性,本文总结了一些APP功能测试中经常遇见,需要考虑到的测试点以共参考 一.安装和卸载 应用的安装和卸载在任何一款A ...

  6. finereport普通报表的移动端自适应方案

    移动端报表呈现,首先要求的是页面随手机屏幕大小自动放缩(自适应),下面给出一个普通报表中的finereport移动端自适应方案,适用于finereport 7.1之前的版本. 首先,了解一下当前我们可 ...

  7. 从Google开源RE2库学习到的C++测试方案

    最近因为科研需求,一直在研究Google的开源RE2库(正则表达式识别库),库源码体积庞大,用C++写的,对于我这个以前专供Java的人来说真的是一件很痛苦的事,每天只能啃一点点.今天研究了下里面用到 ...

  8. web端测试和移动端测试的区别小记

    转:http://qa.blog.163.com/blog/static/19014700220157128345318/ 之前一直参与web端的测试,最近一个项目加入了移动端,本人有幸参与了移动端的 ...

  9. Android MediaCodec硬编兼容性测试方案

    作者:阿宝 更新:2016-08-15 来源:彩色世界(https://blog.hz601.org/2016/08/15/android-mediacodec-hardcode-compatibil ...

随机推荐

  1. Android中使用开源框架citypickerview实现省市区三级联动选择

    1.概述 记得之前做商城项目,需要在地址选择中实现省市区三级联动,方便用户快速的填写地址,当时使用的是一个叫做android-wheel 的开源控件,当时感觉非常好用,唯一麻烦的是需要自己整理并解析省 ...

  2. KMP算法的优化与详解

    文章开头,我首先抄录一些阮一峰先生关于KMP算法的一些讲解. 下面,我用自己的语言,试图写一篇比较好懂的 KMP 算法解释. 1. 首先,字符串"BBC ABCDAB ABCDABCDABD ...

  3. 2017年的golang、python、php、c++、c、java、Nodejs性能对比(golang python php c++ java Nodejs Performance)

    2017年的golang.python.php.c++.c.java.Nodejs性能对比 本人在PHP/C++/Go/Py时,突发奇想,想把最近主流的编程语言性能作个简单的比较, 至于怎么比,还是不 ...

  4. Ajax页面的加载数据与删除

    1.数据库找一张表: 颜色表2.主页面主页面的代码用到tbody:TBODY作用是:可以控制表格分行下载,从而提高下载速度.(网页的打开是先表格的的内容全部下载完毕后,才显示出来,分行下载可以先显示部 ...

  5. python pytesser 的安装

      安装包: 需要安装的包主要有两个: PIL 和 pytesser . PIL模块的安装不多说 pytesser 模块的安装: 下载后得到 "pytesser_v0.0.1.zip&quo ...

  6. 3403: [Usaco2009 Open]Cow Line 直线上的牛

    3403: [Usaco2009 Open]Cow Line 直线上的牛 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 71  Solved: 62[S ...

  7. DOM的内部插入和外部插入

    /*****************返回值都是最前面调用这个方法的元素 ***************** */ //这是外部插入 $("div").insertBefore($( ...

  8. 对Vue.js $watch方法的理解

    博主最近对着vue.js的官方教程在自学vue.js,博主自幼愚钝,在教程中真的是好多点都不太理解,接下来要说的这个$watch方法就是其中一个不太理解的点了.咱们先来看一下对于$watch方法在vu ...

  9. php文件基本操作与文件管理功能

    文件的基本操作 先来看一下PHP文件基础操作,请看强大注释 <body> <?php var_dump(filetype("./img/11.png")); // ...

  10. 为什么用IP无法访问网站,域名可以访问?

    我们访问网站都是通过域名进行访问的,偶尔会使用网站IP进行访问,如学校通常使用IP登录教务处,但很多的时候我们无法通过ip进行访问其他网站,这就涉及到服务器的问题了. 网站都是依托在服务器上面的,而服 ...