最近Android发布了AndroidStudio 3.6稳定版,升级后明显能体验到好多细节的提升,最大的提升莫过于可以创建Android R预览版的模拟器了,并且模拟器可以设置多个尺寸的屏幕。Android R的xm6模拟器可以直接运行arm架构的程序,以后开发过程中再也不用为测试机担忧了。但是在执行UiAutomator1脚本时就存在了不兼容问题。

异常情况

但是在使用Android R模拟器进行开发工作中发现执行UiAutomator1.0脚本出现如下异常:

  1. Warning: This version of UI Automator is deprecated. New tests should be written using
  2. UI Automator 2.0 which is available as part of the Android Testing Support Library.
  3. See https://developer.android.com/training/testing/ui-testing/uiautomator-testing.html
  4. for more details.
  5. INSTRUMENTATION_STATUS: stream=
  6. Test results for WatcherResultPrinter=Test run aborted due to unexpected exception: Failed resolution of: Landroid/test/RepetitiveTest;
  7. java.lang.NoClassDefFoundError: Failed resolution of: Landroid/test/RepetitiveTest;
  8. at com.android.uiautomator.testrunner.UiAutomatorTestRunner$WatcherResultPrinter.startTest(UiAutomatorTestRunner.java:297)
  9. at junit.framework.TestResult.startTest(TestResult.java:168)
  10. at junit.framework.TestResult.run(TestResult.java:119)
  11. at junit.framework.TestCase.run(TestCase.java:129)
  12. at com.android.uiautomator.testrunner.UiAutomatorTestRunner.start(UiAutomatorTestRunner.java:160)
  13. at com.android.uiautomator.testrunner.UiAutomatorTestRunner.run(UiAutomatorTestRunner.java:96)
  14. at com.android.commands.uiautomator.RunTestCommand.run(RunTestCommand.java:91)
  15. at com.android.commands.uiautomator.Launcher.main(Launcher.java:83)
  16. at com.android.internal.os.RuntimeInit.nativeFinishInit(Native Method)
  17. at com.android.internal.os.RuntimeInit.main(RuntimeInit.java:396)
  18. Caused by: java.lang.ClassNotFoundException: android.test.RepetitiveTest
  19. ... 10 more
  20. Time: 0.039
  21. OK (1 test)
  22. INSTRUMENTATION_STATUS: shortMsg=Failed resolution of: Landroid/test/RepetitiveTest;
  23. INSTRUMENTATION_STATUS_CODE: -1

异常触发流程

通过分析发现是因为找不到Landroid/test/RepetitiveTest类文件。那么分析一下堆栈信息看异常具体出现在哪里?

在执行UiAutomator1.0测试用例时,是在UiAutomatorTestRunner类中初始化测试资源并执行测试用例的。所以对异常堆栈信息的分析从UiAutomatorTestRunner类开始。

com.android.uiautomator.testrunner.UiAutomatorTestRunner.run(UiAutomatorTestRunner.java:96)源码如图,可以看到此处不存在异常行为,需要定位下一个堆栈信息

com.android.uiautomator.testrunner.UiAutomatorTestRunner.start(UiAutomatorTestRunner.java:160) 通过分析源码会发现是遍历执行测试用例时产生的异常,并且此处是

junit.framework.TestResult.startTest 仅仅调用了WatcherResultPrinter#startTest方法,所以需要继续定位异常原因

com.android.uiautomator.testrunner.UiAutomatorTestRunner$WatcherResultPrinter.startTest(UiAutomatorTestRunner.java:297)是真正触发异常的位置,可以看到第一次引用android.test.RepetitiveTest接口文件时产生了java.lang.NoClassDefFoundError:异常信息。

定位问题原因

通过上述堆栈调用链发现触发异常时还没有执行测试用例,所以这个异常应该是出现在framework层面。由于运行环境是Android R预览版,无法查阅对应的源码,所以无法断定为系统bug还是Android R系统开始不再支持uiautomator1.0测试服务。

对于采用uiautomator1.0测试框架的业务线需要提前对相关技术进行调研,可以提早设计应对方案。通过上文可以看到,在抛异常时程序已经初始化了uiautomator1.0测试环境,所以要实现uiautomator1.0兼容Android R运行时自己注册测试服务并管理用例即可。

想要了解Uiautomator执行原理可以参考Uiautomator 项目搭建与实现原理

记Android R(SDK=30)系统执行UiAutomator1.0异常的更多相关文章

  1. webview在compileSdkVersion 大于等于23 android6.0以上系统执行js代码异常,但是在compileSdkVersion小于23 android6.0以下系统却执行正常问题

    问题分析: 在compileSdkVersion>=23 android6.0以上webview.loadUrl用这个方法执行js时会将js中的一些代码当做特殊字符处理, 比如js中var t= ...

  2. Android 开发进入Linux系统执行命令 2018-5-25 Fri.

    /** * 进入linux cmd执行命令 * * @param command * @return */ private boolean runRootCommand(String command) ...

  3. Android名片扫描识别系统SDK

    Android名片扫描识别系统SDK 一.Android名片扫描识别系统应用背景 这些年,随着移动互联的发展,APP应用成爆发式的增长,在很多APP中都涉及到对名片信息的录入,如移动CRM.移动端OA ...

  4. Android R 新特性分析及适配指南

    Android R(Android 11 API 30)于2020年9月9日正式发布,随国内各终端厂商在售Android设备的版本更新升级,应用软件对Android R 版本的兼容适配已迫在眉睫. 对 ...

  5. android API版本对应的系统版本及Android获取手机和系统版本等信息的代码

    学了这么久的Android,竟然一直对其API对应的名称关系一值搞不清楚,现在网上认真看了下资料,转载一个觉得写得不错的作者的文章,记下来: [背景] 之前折腾android期间,慢慢地知道了,And ...

  6. Android之SDK、NDK、JNI和so文件

    1.     SDK Android SDK(AndroidSoftware Development Kit),即Android软件开发工具包,Android的SDK基于Java实现,这意味着基于An ...

  7. Android核心分析 之十一Android GWES之消息系统

        Android GWES之Android消息系统                                                                        ...

  8. Android安装 sdk+jdk+Eclipse+Adt开发工具

    根据别人提供的手册和安装过程体验加以更新和详细描述 安装Android开发工具 开发Android应用程序的门坎并不高,因为Google已经为Android应用程序开发提供了免费而且跨平台的集成开发环 ...

  9. Centos Android开发环境配置-Android Tools -android list sdk --extended --all

    Centos Android开发环境配置-Android Tools -android  list sdk --extended --all 安装完Android Tools后执行 android   ...

随机推荐

  1. 位移&二进制转换&原码&反码&补码

    << 左移 按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零. 格式 需要移位的数字 << 移位的次数 计算过程 1. 按二进制形式把所有的数字向左 ...

  2. pandas向表格中循环写入数据

    pandas向表格中循环写入多行数据 import pandas as pd def list_topic(total_num, str1): """ 生成多个主题 :p ...

  3. POJ 2553 The Bottom of a Graph Tarjan找环缩点(题解解释输入)

    Description We will use the following (standard) definitions from graph theory. Let V be a nonempty ...

  4. 查漏补缺:Linux进程与线程的区别

    1.概念的区别 进程:是具有独立功能的程序在一个数据集合上运行的过程,是系统进行资源分配的基本单位,也是调度运行的基本单位.一个进程中可以包含多个线程. 线程:是进程的一个实体,是CPU调度和分派的基 ...

  5. UEditor问题整理

    网上可以使用的富文本编辑器有很多,但是经过慎(sui)重(shou)思(yi)考(cha),选择了UEditor,毕竟是百度的东西,质量上应该经得起推敲,另外,使用别人的插件,总要去适应别人的编码习惯 ...

  6. python通用读取vcf文件的类(可以直接复制粘贴使用)

    前言   处理vcf文件的时候,需要多种切割,正则匹配,如果要自己写其实会比较麻烦,并且每次还得根据vcf文件格式或者需要读取的值不同要修改相应的代码.因此很多人会选择一些python的vcf的库,但 ...

  7. Neural Turing Machine - 神经图灵机

    Neural Turing Machine - 神经图灵机 论文原文地址: http://arxiv.org/pdf/1410.5401.pdf 一般的神经网络不具有记忆功能,输出的结果只基于当前的输 ...

  8. Appium自动化测试实践

    安装配置Appium环境 安装appium 安装appium有两种方式,一种是通过命令行终端方式,一种是Appium Desktop.这里推荐使用Appium Desktop方式,只需下载下来安装就可 ...

  9. java反序列化-ysoserial-调试分析总结篇(6)

    前言: 这篇记录CommonsCollections6的调试,外层也是新的类,换成了hashset,即从hashset触发其readObject(),yso给的调用链如下图所示 利用链分析: 首先在h ...

  10. 利用短信通知的方式在Tasker中实现收到Android手机短信自动转发到邮箱

    利用短信的通知实现短信内容转发到微信 code[class*="language-"] { padding: .1em; border-radius: .3em; white-sp ...