注:该案例使用js编写。
1:安装:提供客户端和npm安装方式
客户端版在官网(appium.io)下载即可,npm安装方式为:npm install -g appium(中途可能会失败,多试几次。)。
启动方式:客户端版直接双击即可,命令版直接在Dos命令下输入appium即可启动成功。启动成功后可查询到版本号。版本号在Js中需要配置。
两者不同之处:客户端版多了一个inspector,该插件能够完美的解决对应用中元素通过xpath定位问题,但是描述起来相当困难,假如能够通过给
原始控件赋予一个id或者是name节能解决问题,我们何乐而不为之呢。
2:配置:需要配置Android虚拟机,用于测试程序(看文档)。
3:编写测试代码:为了简便,直接在官网下载官方案例(https://github.com/appium/sample-code),该案例包含了多种语言的案例,
下载下来。sample-code---->examples--->node即为我们要找的示例,在项目目录下使用npm install来下载安装项目运行需要的组件。
使用中能用到根目录下的helpers文件夹和根目录下的.js文件
(本测试中,为了简便起见,直接对官方例子android-simple进行了相应的修改)。
Helpers目录结构如下:
打开apps.Js进行修改如下:
打开caps.Js进行修改如下:
对android-simple.js修改如下:
本文具体实例为混编应用,所以首先获取其上下文(context),将其转换到webView模式,然后编写需要测试的事件。此处通过控件名来定位到某一具体元素,然后对其进行相应操作。
4:启动测试:1)运行服务器。2)开启appium(客户端或DOS命令行)。3)打开模拟器。4)测试代码的根目录下-->npm run xxx.js
5:采用yiewd调整代码格式:在项目目录中安装Yiewd(npm install yiewd),其次安装mocha(npm install -g mocha),然后修改相应代码,运行方式为:mocha -R spec -t 60000 --harmony test/es6/(例如:mocha test/apptest/mobileEng),可在项目的package.json中进行进一步的配置。
对于存在的两种测试,此处采用的是本地测试。