App 自动化疑难杂症解决记录

本贴最后更新于 1170 天前,其中的信息可能已经时移世易

背景

在做App自动化测试时,有些App的页面无法通过UIAutomatorViewer或者Appium检查器识别元素,比如银行金融类App页面、密码输入页面,这里以B站(哔哩哔哩)App的登录页面为例:

image.png

此时工具会提示Error taking device screenshot:EOF(截图失败)这样的错误信息。

问题发生原因

有些App为了安全方面的考量,禁止用户在敏感页面(比如输入密码页面、用户隐私数据页面)进行截图,此时通过手动截图(一般是通过手机上的组合按键【音量-】+【电源键】)是无法截图的。

我们还可以通过另外的方法来进行验证:

  1. 打开电脑端命令行窗口
  2. 输入如下adb命令
adb shell screencap -p /sdcard/test.png
  1. 通过adb shell进入到手机内部文件系统中,查看sdcard目录下是否有test.png图片

此时也会发现图片是没有生成的,其他App的普通页面是可以生成截图的。

导致这类问题的根本原因是:

开发在App的源代码中加入了禁止截图限制:

getWindow().setFlags(LayoutParams.FLAG_SECURE, LayoutParams.FLAG_SECURE);

而元素识别工具UIAutomatorViewer或者Appium检查器都需要截图的权限,否则识别不到元素。

解决方案

在自动化脚本中使用getPageSource()这个方法获取页面的dom结构信息:

image.png

回帖
请输入回帖内容 ...