AppCrawler自动遍历工具

前言

AppCrawler是一个基于自动遍历的app爬虫工具. 支持android和iOS, 支持真机和模拟器. 最大的特点是灵活性. 可通过配置来设定遍历的规则。
AppCrawler地址

环境准备

快速遍历

安装好环境后,可以执行以下命令, 命令参数介绍

# 查看帮助文档
java -jar appcrawler.jar
# 运行测试
java -jar appcrawler.jar -a xueqiu.apk

通过配置文件执行

配置文件可以帮助我们自定义遍历规则,和自定义测试用例。

  1. 生成配置文件
# 生成配置文件
java -jar appcrawler.jar --demo
  1. 配置文件内容
---
# 插件列表
pluginList: [] 
# 是否截图                                   
saveScreen: true  
# 报告的标题              
reportTitle: ""    
# 结果目录             
resultDir: "20190907185946"  
# 在执行操作后等待多少毫秒进行刷新     
waitLoading: 500               
waitLaunch: 6000
# 显示取消
showCancel: true
# 最大运行时间
maxTime: 10800
# 默认的最大深度                      
maxDepth: 10
# appium的capability通用配置
capability:
  noReset: "true"
  fullReset: "false"
  appium: "http://127.0.0.1:4723/wd/hub"
# 测试用例
testcase:
  name: "TesterHome AppCrawler"
  steps:
  - given: []
    when: null
    then: []
    xpath: "/*"
    action: "Thread.sleep(5000)"
    actions: []
    times: 0
# 默认遍历列表
selectedList:
- given: []
  when: null
  then: []
  xpath: "//*[contains(name(), 'Button')]"
  action: null
  actions: []
  times: 0
- given: []
  when: null
  then: []
  xpath: "//*[contains(name(), 'Text') and @clickable='true' and string-length(@text)<10]"
  action: null
  actions: []
  times: 0
- given: []
  when: null
  then: []
  xpath: "//*[@clickable='true']/*[contains(name(), 'Text') and string-length(@text)<10]"
  action: null
  actions: []
  times: 0
- given: []
  when: null
  then: []
  xpath: "//*[contains(name(), 'Image') and @clickable='true']"
  action: null
  actions: []
  times: 0
- given: []
  when: null
  then: []
  xpath: "//*[@clickable='true']/*[contains(name(), 'Image')]"
  action: null
  actions: []
  times: 0
- given: []
  when: null
  then: []
  xpath: "//*[contains(name(), 'Image') and @name!='']"
  action: null
  actions: []
  times: 0
- given: []
  when: null
  then: []
  xpath: "//*[contains(name(), 'Text') and @name!='' and string-length(@label)<10]"
  action: null
  actions: []
  times: 0
# 优先遍历元素
firstList: []
# 最后遍历列表
lastList:
- given: []
  when: null
  then: []
  xpath: "//*[@selected='true']/..//*"
  action: null
  actions: []
  times: 0
- given: []
  when: null
  then: []
  xpath: "//*[@selected='true']/../..//*"
  action: null
  actions: []
  times: 0
# 当所有元素都被点击后默认后退控件定位
backButton:
- given: []
  when: null
  then: []
  xpath: "Navigate up"
  action: null
  actions: []
  times: 0
# 特定条件触发执⾏动作的设置,通常⽤于处理弹框
triggerActions:
- given: []
  when: null
  then: []
  xpath: "share_comment_guide_btn"
  action: null
  actions: []
  times: 0
# 自动生成的xpath表达式里可以包含的匹配属性
xpathAttributes:
- "name"
- "label"
- "value"
- "resource-id"
- "content-desc"
- "instance"
- "text"
# 先按照深度depth排序,再按照list排序,最后按照selected排序。后排序是优先级别最高的
sortByAttribute:
- "depth"
- "list"
- "selected"
# 可选 default|android|id|xpath,默认状态会自动判断是否使用android定位或者ios定位
findBy: "default"
# 用来确定url的元素定位xpath 他的text会被取出当作url因素
defineUrl: []
# 设置一个起始url和maxDepth, 用来在遍历时候指定初始状态和遍历深度
baseUrl: []
# app白名单
appWhiteList: []
# url黑名单,用于排除某些页面 
urlBlackList: []
# url白名单
urlWhiteList: []
# 黑名单列表 匹配风格, 默认排除内容是2个数字以上的控件
blackList:
- given: []
  when: null
  then: []
  xpath: ".*[0-9]{2}.*"
  action: null
  actions: []
  times: 0
# 在重启session之前做的事情
beforeRestart: []
# 在执行action之前和之后默认执行的动作,比如等待
beforeElement:
- given: []
  when: null
  then: []
  xpath: "/*"
  action: "Thread.sleep(500)"
  actions: []
  times: 0
# 是否需要刷新或者滑动
afterElement: []
afterPage: []
# afterPage执行多少次后才不执行,比如连续滑动2次都没新元素即取消
afterPageMax: 2
# 同祖先(同类型)的元素最多点击多少次
tagLimitMax: 2
# 个别控件可例外
tagLimit:
- given: []
  when: null
  then: []
  xpath: "确定"
  action: null
  actions: []
  times: 1000
- given: []
  when: null
  then: []
  xpath: "取消"
  action: null
  actions: []
  times: 1000
- given: []
  when: null
  then: []
  xpath: "share_comment_guide_btn_name"
  action: null
  actions: []
  times: 1000
# 只需要写given与then即可
assertGlobal: []

配置文件介绍

配置文件的参数说明

如上的配置文件是完整形态,还支持简写形态,拿testcase举例
1. testcase

  • testcase的完整形态
    • given:所有的先决条件(先决条件通过xpath的方式进行匹配)
    • when:先决条件成⽴后的⾏为
    • then:断言集合
  • testcase的简写形态
    • xpath:对应when⾥的xpath
    • action:对应when的action

实例

testcase:
  name: "点击行情"  # 测试用例名称
  steps:
  - xpath: //*[contains(@resource-id, "tab_name") and @text="行情"]    #定位模式
    action: click  # 动作
    then:
    - //*[contains(@text,'雪球热股')]  # 断言

2. 定位模式 xpath
定位模式支持xpath定位、正则、迷糊匹配(注意:配置文件中的xpath定位模式别和appium的xpath搞混了,配置文件中的xpath只是一个参数,它支持appium的xpath的定位方法,并且还支持正则和模糊匹配)

  • xpath

    • //*[@resource-id=‘xxxx’]
    • //*[contains(@text, ‘密码’)]
  • 正则

    • ^确定$
    • ^.*输入密码
  • 包含

    • 密码
    • 输入

实例

blackList:
- xpath: ".*[0-9]{2}.*"
- xpath: "^雪球$"
- xpath: //*[@resource-id="com.xueqiu.android:id/action_search"]
- xpath: 雪

3. 动作支持 action

  • " " 只是截图记录
  • back 后退
  • backApp 回退到当前的app 默认等价于back⾏为 可定制
  • monkey 随机事件
  • xxx() 执⾏代码
    • Thread.sleep(3000)
    • driver.swipe(0.9, 0.5, 0.1, 0.5)
  • click
  • longTap
  • 非以上所有行为是输入 123 abcd

4. 动作次数 times

# 点击净买入10次
triggerActions:
- xpath: 净买入
   times: 10

实例自动遍历雪球app行情页面下的所有二级页面

  1. 安装模拟器,如mumu
  2. 安装雪球app
  3. 启动appium server
appium --session-override
  1. 生成配置文件
java -jar appcrawler-2.4.0-jar-with-dependencies.jar --demo
  1. 修改配置文件,另存为xueqiu.yml.(注意,保存为utf8编码)
---
pluginList: []
saveScreen: true
reportTitle: "遍历雪球行情页的所有二级页面"
resultDir: "20190907221950"
waitLoading: 500
waitLaunch: 6000
showCancel: true
maxTime: 10800
maxDepth: 1
capability:
  noReset: "true"
  fullReset: "false"
  appium: "http://127.0.0.1:4723/wd/hub"
  appPackage: com.xueqiu.android
  appActivity: .view.WelcomeActivityAlias
testcase:
  name: "点击行情"
  steps:
  - xpath: //*[contains(@resource-id, "tab_name") and @text="行情"]
    action: click
    then:
    - //*[contains(@text,'雪球热股')]
# 遍历雪球行情页
selectedList:
- xpath: "//*[contains(name(), 'Button')]"
- xpath: "//*[contains(name(), 'Text') and @clickable='true' and string-length(@text)<10]"
- xpath: "//*[@clickable='true']/*[contains(name(), 'Text') and string-length(@text)<10]"
- xpath: "//*[contains(name(), 'Image') and @clickable='true']"
- xpath: "//*[@clickable='true']/*[contains(name(), 'Image')]"
- xpath: "//*[contains(name(), 'Image') and @name!='']"
- xpath: "//*[contains(name(), 'Text') and @name!='' and string-length(@label)<10]"
firstList: []
lastList:
- xpath: "//*[@selected='true']/..//*"
- xpath: "//*[@selected='true']/../..//*"
backButton:
- xpath: "Navigate up"
triggerActions:
- xpath: "share_comment_guide_btn"
xpathAttributes:
- "name"
- "label"
- "value"
- "resource-id"
- "content-desc"
- "instance"
- "text"
sortByAttribute:
- "depth"
- "list"
- "selected"
findBy: "default"
defineUrl: []
baseUrl: []
appWhiteList: []
urlBlackList: []
urlWhiteList: []
# 添加黑名单元素,避免点击到其他地方
blackList:
- xpath: ".*[0-9]{2}.*"
- xpath: //*[contains(@resource-id, "tab_name") and @text="雪球"]
- xpath: //*[contains(@resource-id, "tab_name") and @text="自选"]
- xpath: //*[contains(@resource-id, "tab_name") and @text="关注"]
- xpath: //*[contains(@resource-id, "tab_name") and @text="交易"]
- xpath: //*[@resource-id="com.xueqiu.android:id/action_search"]
beforeRestart: []
beforeElement:
- given: []
  when: null
  then: []
  xpath: "/*"
  action: "Thread.sleep(500)"
  actions: []
  times: 0
afterElement: []
afterPage: []
afterPageMax: 2
tagLimitMax: 2
tagLimit:
- given: []
  when: null
  then: []
  xpath: "确定"
  action: null
  actions: []
  times: 1000
- given: []
  when: null
  then: []
  xpath: "取消"
  action: null
  actions: []
  times: 1000
- given: []
  when: null
  then: []
  xpath: "share_comment_guide_btn_name"
  action: null
  actions: []
  times: 1000
assertGlobal: []

  1. 连接模拟器
# 连接模拟器
adb connect 127.0.0.1:7555
# 查看是否连接成功
adb devices
  1. 执行测试
java -jar appcrawler-2.4.0-jar-with-dependencies.jar -c xueqiu.yml
  1. 测试报告


    测试报告
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
禁止转载,如需转载请通过简信或评论联系作者。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351

推荐阅读更多精彩内容

  • ORA-00001: 违反唯一约束条件 (.) 错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。 O...
    我想起个好名字阅读 5,268评论 0 9
  • 一 使用目的 该工具主要是基于appium,可以面向Android和Ios移动App,或H5或微信等应用的,基于元...
    AIHorse阅读 8,632评论 9 1
  • Appium Desktop 原滋原味的官方文档 Appium Desktop是一款用于Mac、Windows和L...
    Roshan_阅读 3,407评论 4 10
  • 1、风华是一指流砂,苍老是一段年华。 2、山河拱手,为君一笑。 3、几段唏嘘几世悲欢可笑我命由我不由天。 4、经流...
    莹_9d22阅读 166评论 0 0
  • 闭上眼 我看到了你 长发茜茜 身姿翩翩 行走在四月的晴天 这是一个浪漫的季节 杨柳深处飘着晶莹的雪 像白色精灵 ...
    三月晨光阅读 224评论 1 0