技术文章

App自动化测试——定位工具和元素定位策略

上一章,我们学会了如何启动和关闭App,但是自动化用例的操作中,最主要的是对UI元素的操作。

 

这章我们主要就学习,如何定位元素,定位的工具使用,以及基本的元素操作有哪些。

 

【一】定位工具

 

我们常用的定位工具有两种:

1. android sdk自带的uiautomator viewer

2.  appium自带的inspector

 

这两种工具的使用,和用法都各有优劣和特点,接下来一一介绍:

 

uiautomator viewer

 

uiautomator viewer位于android-sdk\tools目录下,双击uiautomatorviewer.bat就可以运行。

 

注:如果没有jdk或jre,或者安装jdk没有配置好环境变量,uiautomator viewer运行不了。

 

App自动化测试

 

如图,工具显示大概分4块区域,菜单栏、截屏区域、xml文件代码区域、元素信息区域;

点击菜单栏第二个或第三个按键就可以获取手机屏幕截图,并对其中元素定位。

 

基本使用方式是:

1. 获取屏幕截图;

2. 移动鼠标到要定位的元素上方,点击鼠标左键,边框会从虚线变为实线;

3. 查看右下角元素信息区域的相关元素属性。

 

注:如果要取消选择元素只需要对已点击元素再点击一次鼠标左键

 

inspector

 

使用inspector工具需要先启动appium server,点击右上角的放大镜图标。

 

App自动化测试
App自动化测试
 

 

需要设置的大概是两个地方:

1. 点击Automatic Server

2. 填写App的desired capabilities就是之前启动app在python中设置的desired_caps,基本可以照搬。

 

App自动化测试

 

然后点击右下角的start session,启动inspector的session。

 

App自动化测试

 

如上图,inspector大概分成4块区域:菜单栏,截屏区域,xml文件源码,元素定位方式及属性信息。

 

选取元素的方式和uiautomator viewer类似,也是鼠标坐标点击选取,查看右侧元素信息,再次点击取消选取。

 

注:uiautomator viewer使用方便,启动快捷,不需要启动session与手机通信,但是某些App(例如京东)使用的框架可能无法解析并获取,导致如下的错误。

 

App自动化测试

 

注:inspector相对来讲,功能更强大一些,几乎所有的App都可以获取到截屏和xml源文件,但是启动慢,设置项多,最麻烦的是,每运行一次用例,inspector的都需要重新启动一次session。

 

【二】元素的定位策略

 

基本的元素定位策略有两种:

1. 基于元素的属性

2. 基于坐标值

 

这两种定位策略之间存在互补特性,建议优先使用属性定位,不能在使用坐标定位

 

基于元素的属性定位

 

基于元素的属性定位的方式主要有三种:

1. id

2. xpath

3. accessibility_id

 

id

 

id就是对应元素的resource-id属性值,一般是某些比较重要的元素才有id,大多数元素没有:

 

App自动化测试

 

xpath

 

xpath是一种在标记语言中对节点进行定位的语法,类似操作系统中对文件定位的路径表达式

 

Xpath有两种表达形式:

1. 绝对路径

2. 相对路径

 

原版的uiautomator viewer不能显示出元素的xpath,需要修改其jar包或替换为第三方的jar包才能显示 inspector可以显示xpath,但是都是绝对路径,通常非常的长,如下图:

 

App自动化测试

/hierarchy/android.widget.FrameLayout/android.view.View/android.widget.FrameLayout[2]/android.widget.GridLayout/android.widget.Button[3]

 

注:对于xpath定位,还有第三种解决方式,自己学会xpath语法之后自己编写;写出类似                //android.widget.Button[text()="1"]的相对路径表达式。

 

accessibility_id

 

accessibility_id就是元素属性里面的content-desc,不是每个元素都有这个属性,很多元素都没有

 

注:以上三种定位方式,优先推荐使用id和xpath定位,再其次是accessibility_id定位

 

基于坐标值定位

 

某些时候如果基于元素属性的定位方式不可用或者不方便用的时候,可以考虑使用坐标值定位操作元素。

 

首先我们要明确一下App界面的坐标系是怎样的:

 

App自动化测试

 

1. 左上角是屏幕的原点(0,0),向右是x轴正向,向下是y轴正向

2. 越向右x值越大,直到达到屏幕边界720

3. 越向下y值越大,直到达到屏幕边界1280

4. 屏幕的边界值大小取决于屏幕分辨率

 

如何查看元素的坐标: 

 

uiautomator viewer

 

App自动化测试

 

如上图,元素信息中,bounds代表元素左上角点和右下角点在屏幕坐标系中的坐标。

 

inspector

 

首先点击菜单栏的第二个swipe by coordinates;然后在截屏区域移动鼠标,截屏区域左上角会显示鼠标的坐标。