AppCrawler自动遍历测试

AppCrawler 是由 seveniruby开源的一个自动遍历测试工具,谷歌有一个叫App Crawler 的遍历工具。AppCrawler具有很大的灵活性,可以自由控制测试页面,控件类型,测试深度等,且支持Android和IOS应用测试。

AppCrawler开源地址:https://github.com/seveniruby/AppCrawler

appcrawler基于appium开发,底层引擎还引用了 adb、 macaca、 selenium

AppCrawler安装

AppCrawler工具以jar包方式发布,下载地址:https://pan.baidu.com/s/1dE0JDCH

appcrawler 2.4.0

  • java8

  • appium 1.8.x

../_images/appcrawler.png

AppCrawler运行

  • 启动 appium server

  • 启动模拟器或者连接真机

  • 开始自动遍历

  • appcrawler --capability

  • "appPackage=com.xueqiu.android,appActivity=.view.WelcomeActivity Alias"

使用AppCrawler前需要启动appium server,然后启动模拟器或者连接真机。运行 java -jar appcrawler.jar 查看帮助。

D:\testing_tools\appcrawler>java -jar appcrawler-2.4.0-jar-with-dependencies.jar

----------------
AppCrawler 2.4.0 [霍格沃兹测试学院特别纪念版]
Appium 1.8.1 Java8 tested
app爬虫, 用于自动遍历测试. 支持Android和iOS, 支持真机和模拟器
项目地址: https://github.com/seveniruby/AppCrawler
移动测试技术交流: https://testerhome.com
联络作者: seveniruby@testerhome.com (思寒)
致谢: 晓光 泉龙 杨榕 恒温 mikezhou yaming116 沐木

--------------------------------


Usage: appcrawler [options]

  -a, --app <value>        Android或者iOS的文件地址, 可以是网络地址, 赋值给appium的app选项
  -e, --encoding <value>   set encoding, such as UTF-8 GBK
  -c, --conf <value>       配置文件地址
  -p, --platform <value>   平台类型android或者ios, 默认会根据app后缀名自动判断
  -t, --maxTime <value>    最大运行时间. 单位为秒. 超过此值会退出. 默认最长运行3个小时
  -u, --appium <value>     appium的url地址
  -o, --output <value>     遍历结果的保存目录. 里面会存放遍历生成的截图, 思维导图和日志
  --capability k1=v1,k2=v2...
                           appium capability选项, 这个参数会覆盖-c指定的配置模板参数, 用于在模板配置之上的参数微调
  -r, --report <value>     输出html和xml报告
  --template <value>       输出代码模板
  --master <value>         master的diff.yml文件地址
  --candidate <value>      candidate环境的diff.yml文件
  --diff                   执行diff对比
  -vv, --verbose           是否展示更多debug信息
  --demo                   生成demo配置文件学习使用方法
  --help
示例
appcrawler -a xueqiu.apk
appcrawler -a xueqiu.apk --capability noReset=true
appcrawler -c conf/xueqiu.json -p android -o result/
appcrawler -c xueqiu.json --capability udid=[你的udid] -a Snowball.app
appcrawler -c xueqiu.json -a Snowball.app -u 4730
appcrawler -c xueqiu.json -a Snowball.app -u http://127.0.0.1:4730/wd/hub

#生成demo例子
appcrawler --demo

#启动已经安装过的app
appcrawler --capability "appPackage=com.xueqiu.android,appActivity=.view.WelcomeActivityAlias"

#从已经结束的结果中重新生成报告
appcrawler --report result/

#新老版本对比
appcrawler --candidate result/ --master pre/ --report ./

生成样板配置示例

运行 java -jar appcrawler.jar --demo 会在当前目录下生成一个demo.yml文件。

通过编辑demo.yml文件实现app自动遍历的灵活定制。

D:\testing_tools\appcrawler>java -jar appcrawler-2.4.0-jar-with-dependencies.jar --demo
2020-11-18 20:47:04 INFO [AppCrawler$.86.main]
----------------
AppCrawler 2.4.0 [霍格沃兹测试学院特别纪念版]
Appium 1.8.1 Java8 tested
app爬虫, 用于自动遍历测试. 支持Android和iOS, 支持真机和模拟器
项目地址: https://github.com/seveniruby/AppCrawler
移动测试技术交流: https://testerhome.com
联络作者: seveniruby@testerhome.com (思寒)
致谢: 晓光 泉龙 杨榕 恒温 mikezhou yaming116 沐木

--------------------------------


2020-11-18 20:47:05 INFO [AppCrawler$.223.parseParams] use default appium address 4723
2020-11-18 20:47:05 INFO [AppCrawler$.230.parseParams] appium address = Some(http://127.0.0.1:4723/wd/hub)
2020-11-18 20:47:05 INFO [AppCrawler$.242.parseParams] result directory = 20201118204701
2020-11-18 20:47:07 INFO [AppCrawler$.286.parseParams] you can read D:\testing_tools\appcrawler\demo.yml for demo

../_images/appcrawler_demo.png

执行参数与配置文件

  • capability设置:与 appium完全一致

    appPackage: "com. xueqiu.android"
    appActivity: ".view.WelcomeActivityAlias"
    app:
    appium: "http: //127.0.0.1:4723/wd/hub"
    noReset: true
    automationName: uiautomator2
    dontStopAppOnReset: true
    

    ../_images/appcrawler_capability.png- testcase:用于启动app后的基础测试用例

  • selectedList:设定遍历范围

  • triggerActions:特定条件触发执行动作

  • 执行参数比配置文件优先级别高

    java -jar <appcrawler.jar路径> -c example.yml --capability appPackage=com.xueqiu.android,appActivity=.view.WelcomeActivityAlias -o /tmp/xueqiu/
    

testcase

testcase的完整形态

  • given:所有的先决条件

  • when:先决条件成立后的行为

  • then:断言集合

testcase的简写形态

  • xpath:对应when里的 xpath

  • action:对应when的 action

../_images/appcrawler_testcase.png

action

  • back 后退

  • backApp 回退到当前的app默认等价于back行为 可定制

  • monkey 随机事件

  • xxx()执行代码

    • Thread.sleep(3000)

    • driver.swipe(0.9, 0.5,0.1,0.5)

  • click

  • longTap

../_images/appcrawler_action.png

自动遍历定制

  • selectedList:需要被遍历的元素范围

  • firstList:优先被点击

  • lastList:最后被点击

  • tagLimitMax:同祖先(同类型)的元素最多点击多少次

  • backButton:当所有元素都被点击后默认后退控件定位

  • blackList:黑名单

  • maxDepth:遍历的最大深度

触发器

triggerActions:

  • 动作触发特定次数

  • 通常用于处理弹框:关闭弹框

    • xpath:指定具体按钮

    • action:动作

    • times:规则的使用次数

../_images/appcrawler_trigger.png

自动遍历测试过程

  1. 信息的获取:

    • 把当前app的界面dump为xml结构

  2. 获取待遍历元素

    • 遍历范围 selectedList

    • 过滤黑名单 小控件 不可见控件 blackList

    • 重排控件顺序 firstList lastList

    • 跳过已点击+跳过限制点击的控件tagLimit

    • 根据匹配的规则执行 action

  3. 循环上面的步骤

网页报告

java -jar appcrawler-2.4.0-jar-with-dependencies.jar -c demo1.yml

自动遍历执行完成后,当前目录会生成测试报告index.html ../_images/appcrawler_report.png打开index.html文件 ../_images/appcrawler_report2.png