Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >利器 | AppCrawler 自动遍历测试实践(三):动手实操与常见问题汇总

利器 | AppCrawler 自动遍历测试实践(三):动手实操与常见问题汇总

原创
作者头像
霍格沃兹测试开发
发布于 2022-05-26 09:49:31
发布于 2022-05-26 09:49:31
77000
代码可运行
举报
文章被收录于专栏:测吧测试开发测吧测试开发
运行总次数:0
代码可运行

上两篇文章介绍了自动遍历的测试需求、工具选择和 AppCrawler 的环境安装、启动及配置文件字段基本含义,这里将以实际案例更加细致的说明配置文件的用法和一些特殊场景的处理。

下面我们继续之前的例子,在雪球搜索框输入搜索内容后的页面开始:

  • testcase:设置测试用例,输入 alibaba 后,点选"阿里巴巴"

yaml 写法如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
testcase:
  name: "XueQiuTestDemo AppCrawler"
  steps:
  - { xpath: "//*[contains(@resource-id,'image_cancel')]", action: click }
  - xpath: home_search
    action: click
  - xpath: search_input_text
    action: alibaba
  - { xpath: 阿里巴巴, action: click }
  • selectedList:遍历范围设定
  • 接上一步点选"阿里巴巴"后到达如下界面:

我们先看demo配置文件中的原始写法,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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

原始文件中将所有可点击的控件类型都包括了进去,再加上了部分 text 长度的限制 现在我们按照自己平常的简便写法重新编写,先设置所有 clickable 等于 true 的控件进行点击:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
selectedList:
 - { xpath: "//*[@clickable='true']", action: click }
  • blackList:黑名单,将不想要被点击的元素加入黑名单中
  • 配置文件原始写法如下,表示将带有2位数字的排除在外,可能是App中包含了很对关于股价展示的,不需要挨个点击:
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
blackList:
- given: []
  when: null
  then: []
  xpath: ".*[0-9]{2}.*"
  action: null
  actions: []
  times: 0

我们现在希望不要点击到叉号

和取消按钮,否则会跳出此页面,那么就可以把其加入黑名单中,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
blackList:
 - xpath: ".*[0-9]{2}.*"
 - xpath: //*[@resource-id='action_delete_text']
 - xpath: //*[@resource-id='action_close']
  • firstList: 优先被遍历
  • 这里我们设置让text包含"股票"的优先遍历
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
firstList:
 - { xpath: "//*[contains(@text,'股票')]", action: click }
  • lastList:最后被点击
  • 在页面中有很多标签页(例如综合、股票、用户、组合):

每个标签页下面对应着很多控件需要被操作,可是在当前页面下的控件未被遍历完的时候就有可能会点击到其他标签页中了,我们希望的是在一个标签页下完全遍历结束后最后再点击标签控件,这个就可以借助lastList来完成,让元素在点进标签页后的内容为最后遍历

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
lastList:
 - { xpath: "//*[contains(@resource-id,'ti_tab_indicator')]//*", action: click }
  • backButton: 当所有元素都被点击后默认后退控件定位
  • AppCrawler是不知道后退按钮是哪一个的,这个可能会造成的一种情况是,当我们进入一个页面时,还没有对这个页面完全遍历就点到了后退按钮,这样就会造成测试不充分

因此我们可以给它设置一个默认的后退按钮,使所有事件完成后再 back

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
backButton:
 - { xpath: "//*[contains(@resource-id,'action_back')]", action: click }
  • maxDepth: 遍历的最大深度
  • 有时候我们的页面层次可能很深,每次遍历测试的需求可能不同,有时候可能需要在短时间内测试主要常用界面的功能,有时候可能需要全面的测试,所以测试的深度就不相同,我们可以依靠 maxDepth 来进行需求定制,这里以遍历 2 层深度为例:
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
maxDepth: 2
  • findBy:定位方式的选择
  • findBy 可以设置定位方式,有 default、android、id、xpth 方式可选,默认状态会自动判断是否是要 Android 定位或者 iOS 定位。当我们的定位很精准的时候,用默认的 default 速度会快一点;若是定位符写的不是很精准,在切换到 Android 定位的时候可能找不到,这个时候就可以尝试将其设置为 Xpath方式定位。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
findBy: "xpath"
  • defineUrl = ListString:用来确定url的元素定位 xpath,他的 text 会被取出当做 url 因素;就是说如果想要当前的页面布局与某个控件之间有层级关系,给定一个标记控件,以此来区分不同的界面(语言的描述怎么样都有点晦涩,还是结合下面的示例来理解吧。。。)

有时候我们会遇见这种情况:设置了 clickable 未 true 的控件都被遍历,可是运行时发现很多控件都没有被遍历到,一般这种情况有一下两种原因:

  • 元素属性 clickable 本身就为 false 或者它的父节点等都为 false,这样自然是无法遍历到的。
  • 还有一种情况是同属性的控件在两个tag页面都存在,在其中一个tag页遍历一遍之后,再到下一个tag页中就会默认已经遍历,不会再进行遍历,如下这种:

在“股票”和“用户”tag页中,“加自选”和“关注”控件的clickable及id属性一样。

他们所属的页面属性也一样,所以会被看做是同一个页面下的同一个控件:

如上这种情况肯定不是我们想要的,我们想要它在股票和用户页都分别进行遍历,更好的覆盖测试,那么就要借助于 defineUrl 了;

1)按照上面的介绍,我们首先要找一个标志控件,用来做页面的区分,那么我们首先想到的就是从“股票”和“用户”这两个 tag 标签属性上来找,遗憾的是最终发现这两个控件的属性全都一毛一样:

2)接着我们就必须从 tag 页内部来找标志控件了,我们发现在“股票”和“用户”页中搜索出来的结果名称的 id 是不同的:

3)上面介绍过了 defineUrl 是取的 text 属性值作为标志区分,所以这里取股票页的第一个元素“阿里巴巴”和用户页的第二个元素“阿里巴巴四十大盗”, 具体 yaml 写法如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
defineUrl: 
- (//*[contains(@resource-id, "stockName")])[1]
- (//*[contains(@resource-id, "user_name")])[2]

缺点:上面的做法虽然解决了页面区分的问题,但是有一个缺点就是我们定义了遍历的深度,然而使用 defineUrl 之后将每个标志符在的页面都视为一个新的 activity,因此遍历深度就会从这里开始重新计算

4)继续解决上述的缺点,我们可以在 clickable 之前指定所属的页面,当判断不在此页面后就会自动跳回

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
selectedList: 
- { xpath: "//*[@resource-id='com.xueqiu.android:id/ll_search_result']//*[@clickable='true']//*", action: click }

5)另外我们之前在 selectList 中写了 clickable=true, 而 clickable=true 通常只是布局元素,布局元素一般是没有任何属性的,不知道控件里包含什么,这样在截图和生成报告的时候就会造成不精准,截图中的步骤框就很可能选择错误,对我们定位分析问题造成困扰;

所以我们要继续往下找标志符,以 Text 作为定位标志符:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
selectedList:
 - { xpath: "//*[@resource-id='com.xueqiu.android:id/ll_search_result']//*[@clickable='true']//*[contains(@class,'Text')]", action: click }

用 Text 作为标志符以后所有的 Text 属性都会遍历一遍,还可以进一步优化,使用id非空作为判定条件,并且通常研发将控件设置 id 的话很可能此控件有关键的作用

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
selectedList:

 - { xpath: "//*[@resource-id='com.xueqiu.android:id/ll_search_result']//*[@clickable='true']//*[@resource-id!='']", action: click }

6)按照上面的写法又引发了新的问题,就是 id 不为空的时候,我们的 tag 控件无法被选中了,因为 tag 控件的 id 正好为空:

因此我们又需要对 selectedList 进行修改,单独增加一条判定条件用来过滤出 tag 控件;我们注意到它们同属一片有 id 的区域,并且各自自身有 text:

修改后的selectedList如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
selectedList:
 - { xpath: "//*[@clickable='true']//*[contains(@class,'Text')]", action: click }
 - { xpath: "//*[contains(@resource-id, 'ti_tab_indicator')]//*[contains(@class,'Text')]",
  • tagLimitMax:最大的点击次数
  • 有时候页面中可能会有多个相同类型的控件,这些控件之间可能只是展示的信息不同,其他功能属性都一直,那么为了保证测试效率可以只设置让它被点击少数次或者一次,通过 tagLimitMax 设置即可。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
tagLimitMax: 1

缺点:这个设置是一个全局的,一旦设置,那么所有的同类型的控件都只会被点击一次,但是像上个例子中的 4 个tag标签控件虽然是同类型的,但是每一个都需要被点击一次,这样显然就不符合我们的需求了,这个时候就需要 tagLimit 参数了

  • tagLimit:自定义控件类型的点击次数
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
tagLimit:
 - xpath: //*[contains(@resource-id, 'ti_tab_indicator')]//*[contains(@class,'Text')]
  action: click
  times: 4
  • triggerActions:触发器,特定条件触发执行动作的设置 这个参数是一个非常有用的参数,比如我们可能会遇到如下的情况
  • 广告、升级弹框在测试过程中突然出现
  • 某些动作需要输入
  • 某些动作需要特定次数的操作
  • 这样每次出现弹框都会被处理
  • 测试中途碰到了账号密码输入框需要输入的可以提前在triggerActions中设置
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
triggerActions:
 - xpath: //*[contains(@resource-id,'image_cancel')]
   action: click
   times: 1
  1. App 运行比较慢,容易超时怎么办? 答:AppCrawler 默认每次操作时会等待 500ms; 通过 triggeraction 来解决需要等待的条件,xpath 为进度条,action 为 sleep 1s。
  2. tagLimit 会限制同属性但不同层级的元素吗? 答:tagLimit 限制的是相同的父节点层级,不管属性,是看布局的层级。
  3. 如何防止遍历的时候不小心跳到别的应用?跳到别的应用后怎么回来? 答:会自动跳转回来的。除非设置了 App 的白名单
  4. 页面需要在当前页不停滑动加载测试 答:遍历完当前页后用 afterpage 参数设置滑动
  5. firstList 和 lastList 可以写多个表达式吗?他们是如何执行的? 答:顺序是这样排列的
  6. app 运行比较慢,容易超时怎么办? 答:AppCrawler 默认每次操作时会等待 500ms;通过 triggeraction 来解决需要等待的条件,xpath 为进度条,action 为 sleep 1s
  7. tagLimit 会限制同属性但不同层级的元素吗? 答:tagLimit 限制的是相同的父节点层级,不管属性,是看布局的层级
  8. 如何防止遍历的时候不小心跳到别的应用?跳到别的应用后怎么回来? 答:会自动跳转回来的。除非设置了 App 的白名单
  9. 页面需要在当前页不停滑动加载测试 答:遍历完当前页后用 afterpage 参数设置滑动
  10. firstList 和 lastList 可以写多个表达式吗?他们是如何执行的? 答:顺序是这样排列的
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
firstList[0]
firstList[1]
排除lastList firstList之后剩下的元素
lastList[0]
lastList[1]
backbutton
  1. Appclawer ==>maxDepth:这个层级是如何定义的? 答:maxDepth 可以从 log 中看到,AppCrawler.log 中有一个 Stack 的输出,里面默认保存的是所有 activity 的栈记录。

Main Main->UserProfile Main->UserProfile->Login Main maxDepth是判断这个堆栈最长的长度,一旦超过就回退

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
软件测试|AppCrawler 自动遍历测试实践
上两篇文章介绍了自动遍历的测试需求、工具选择和 AppCrawler 的环境安装、启动及配置文件字段基本含义,这里将以实际案例更加细致的说明配置文件的用法和一些特殊场景的处理。
霍格沃兹测试开发Muller老师
2023/01/04
9940
技术分享 | app自动化测试(Android)--高级定位技巧
通常使用定位器定位页面上的元素会发生一些定位不到元素,或者定位失败的情况。有可能是页面上元素不唯一,有可能是页面发生变化。这节介绍定位元素的高级用法,使用层级关系定位或者多重属性定位的方式来确定元素的唯一性,从而更精准,更稳定的定位到想要的元素。
霍格沃兹测试开发
2022/06/13
1.5K0
自动化测试的理想境界:AppCrawler自动遍历工具
内容来源:2017 年 6 月 24 日,TesterHome联合创始人黄延胜在“Testwo第一届测试分享沙龙”进行《App crawler自动遍历工具》演讲分享。IT 大咖说(微信id:itdakashuo)作为独家视频合作方,经主办方和讲者审阅授权发布。
IT大咖说
2018/10/23
4.1K0
自动化测试的理想境界:AppCrawler自动遍历工具
技术分享 | app自动化测试(Android)--高级定位技巧
通常使用定位器定位页面上的元素会发生一些定位不到元素,或者定位失败的情况。有可能是页面上元素不唯一,有可能是页面发生变化。这节介绍定位元素的高级用法,使用层级关系定位或者多重属性定位的方式来确定元素的唯一性,从而更精准,更稳定的定位到想要的元素。
Hogwarts_测试
2022/06/13
9140
史上最全 Appium 自动化测试从入门到框架实战精华学习笔记(三)
本系列文章汇总了从 Appium 自动化测试从基础到框架高级实战中,所涉及到的方方面面的知识点精华内容(如下所示),希望对大家快速总结和复习有所帮助。
霍格沃兹测试开发
2022/05/30
1.2K0
app自动化测试(Android)--显式等待机制
WebDriverWait 通常与 until 和 util_not 结合使用,Java 与 Python 用法相同。
霍格沃兹测试开发Muller老师
2023/01/03
7250
技术分享 | app自动化测试(Android)--App 控件交互
通常获取到元素之后,可以调用 click() 方法来实现对这个元素的点击操作。示例代码如下:
Hogwarts_测试
2022/06/14
5180
技术分享 | app自动化测试(Android)–App 控件交互
通常获取到元素之后,可以调用 click() 方法来实现对这个元素的点击操作。示例代码如下:
霍格沃兹测试开发
2022/06/14
8250
XPath定位如何在App自动化测试中大显神威
和selenium类似,作为App自动化测试的主流框架,appium也是以webdriver为基础来自动化操作App的,所以对于元素定位,其实appium与selenium也是类似的,只是appium还有自己的安卓原生定位方式等方法,但是关于ID定位,name定位,xpath定位等,appium也是支持的,本篇文章就来给大家介绍一下xpath定位是如何在appium中大显神威的。
霍格沃兹测试开发Muller老师
2024/03/26
2600
appium+python自动化58-xpath定位
3.class属性唯一的话,可以通过class属性定位到,定位class属性有两种方法
上海-悠悠
2018/07/25
1.5K0
appium+python自动化58-xpath定位
软件测试|App自动化控件定位
客户端的页面通过 XML 来实现 UI 的布局,页面的 UI 布局作为一个树形结构,而树叶被定义为节点。这里的节点也就对应了我们要定位的元素,节点的上级节点,定义了元素的布局结构。在 XML 布局中可以使用 XPath 进行节点的定位。
霍格沃兹测试开发Muller老师
2023/01/09
5330
技术分享 | app自动化测试(Android)--App 控件定位
客户端的页面通过 XML 来实现 UI 的布局,页面的 UI 布局作为一个树形结构,而树叶被定义为节点。这里的节点也就对应了要定位的元素,节点的上级节点,定义了元素的布局结构。在 XML 布局中可以使用 XPath 进行节点的定位。
霍格沃兹测试开发
2022/06/08
1.1K0
App自动化之dom结构和元素定位方式(包含滑动列表定位)
控件的基础知识和selenium一样,appium为移动端抽象出了一个控件模型,称为dom结构;会把所有的控件都理解为xml文件,在xml文件里,每个控件都有自己的类型和属性;
霍格沃兹测试开发
2022/04/24
8190
Java自动化测试(Android app界面元素 33)
开发成本较低,可以跨平台,调试方便,维护成本低,功能可复用,性能和体验要比web app好,更新较自由
zx钟
2020/10/21
1.2K0
Java自动化测试(Android app界面元素 33)
Appium元素定位方式
控件的基础知识和selenium一样,appium为移动端抽象出了一个控件模型,称为dom结构;会把所有的控件都理解为xml文件,在xml文件里,每个控件都有自己的类型和属性;
Hogwarts_测试
2022/06/09
1.3K0
Appium控件交互策略:优化自动化测试效率的关键方法
与 Web 元素操作一样(参考 Selenium Web 元素操作),定位到 APP 控件元素后,可以对控件进行一系列的操作,实现与 APP 交互,比如点击、文本输入、元素属性获取等。
霍格沃兹测试开发Muller老师
2024/04/25
1510
基于Appium的移动端UI自动化测试
移动端APP是一个复杂的系统,不同功能之间耦合性很强,很难仅通过单元测试保障整体功能。UI测试是移动应用开发中重要的一环,但是执行速度较慢,有很多重复工作量,为了减少这些工作负担,提高工作效率,需要引入可持续集成的自动化测试方案。
测试开发社区
2020/05/26
3K0
【Python爬虫实战】深入解析 Selenium:从元素定位到节点交互的完整自动化指南
Selenium 是进行网页自动化操作的强大工具,在测试、数据抓取、用户行为模拟等领域广泛应用。本指南将带您详细了解如何在 Selenium 中查找和定位页面元素,并深入介绍各种节点交互方法,包括点击、输入文本、选择选项等操作。无论您是初学者还是经验丰富的开发者,本篇文章将帮助您掌握 Selenium 自动化的核心技能,实现更高效的网页自动化操作。
易辰君
2024/11/07
7780
『App自动化测试之Appium应用篇』| 元素定位工具uiautomatorviewer从简介、特点、启动到使用的完整过程
虫无涯
2023/12/14
3.8K0
基于Appium实现深度UI遍历工具(四)代码实现篇(上)
终于来到了代码编写的地方了,提前预告,所有代码都将放到github上面,作为我开源的项目,并且在以后会进行维护。文末我会贴上开源地址。
雷子
2022/05/21
9720
基于Appium实现深度UI遍历工具(四)代码实现篇(上)
推荐阅读
相关推荐
软件测试|AppCrawler 自动遍历测试实践
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验