Android-CTS 4.0.3测试基本配置

1. Download CTS

CTS的获取方式有两种:

1.1.由Google提供

1.1.1.打开浏览器输入连接: http://source.android.com/compatibility/downloads.html

1.1.2.下载所需文件

选择对应Android版本的CDD文档(介绍CTS测试),CTS测试包下载(测试包会不断更新),android-cts-verifier-4.0.3_r1-linux_x86-arm.zip,android-cts-media-1.0.zip

1.1.3.基本文件结构

将下载的CTS测试包解压到相应文件夹里面:android-cts文件夹里面包含Docs、Repository、Tools三个文件夹。

1.1.4.下载android SDK

1.2.通过4.0.3的源码编译得来

在Google提供的Android源码中是包含CTS测试的,源码下可以看到有一个CTS文件夹,里面就是CTS的测试源码。

在Android项目源码下使用命令:

(切换分支,并保证自己的项目源码最新)

./source build/envsetup.sh

choosecombo 1 18 1(仅针对公司自己的手机,我们这儿选择Variant choices :user模式)

make cts

来得到,生成的android-cts包在~/<源码目录>/out/host/linux-x86/cts中。

2.RUN CTS 前期准备工作

2.1.先确定Linux 系统的adb path是否设置正确(我是在虚拟机Ubuntu下模拟的)

Shell 命令:(配置环境变量)

shz@ubuntu:$ cd ~

shz@ubuntu:$ gedit .bashrc

在.bashrc文件中添加

PATH=$PATH:/home/shz/java/jdk1.6.0_35/bin:

PATH=$PATH:/home/shz/sdk/android-sdk-4.0.3/platform-tools:

PATH=$PATH:/home/shz/sdk/android-sdk-4.0.3/tools:

(根据你自己的实际的文件路径来配置)

2.2.确保你所配置的环境变量都正确

shz@ubuntu:$ java

shz@ubuntu:$ adb

查看信息是否正确,如果没有配置好,会有提示

(例如adb: command not found)

2.3.确保手机已正确连接上

shz@ubuntu:$ adb devices

有的时候会出现这种情况

解决办法:权限问题,给予root权限并在root权限下重启adb server即可。

具体步骤:

shz@ubuntu:$ cd sdk/android-sdk-4.0.3/platform-tools

shz@ubuntu:~/sdk/android-sdk-4.0.3/platform-tools$ sudo su

[sudo]password for shz: (输入密码,回车,root权限)

退出root模式:

Look,一切OK。

3.调整系统状态

3.1.执行系统重置,恢复为出厂状态

3.2.测试前需要安装apk:adb install android-cts/repository/testcases/CtsDelegatingAccessibilityService.apk

然后在设置里面的辅助功能中会多一个Delegating Accessibility Service选项,将这个选项打开

3.3.测试前需要安装apk:adb install android-cts/repository/testcases/CtsDeviceadmin.apk

3.4.测试前需要安装apk:adb install CtsVerifier.apk

(之前下载下来的android-cts-verifier-4.0.3_r1-linux_x86-arm.zip解压有)

然后在设置安全->选择设备管理器对多出三个选项,将这三个选项勾选并激活

3.5.测试Media相关项需要用到官方提供的一个media包,有三种方式:

a).在SD卡中建目录test, 将android-cts-media-1.0.zip解压到test目录中,将SD卡插入设备中。确定SD卡为可读可写状态。

b).在Ubuntu环境下,可以再android-cts-media-1.0.zip解压出来的文档中放在一个新建的test文件夹汇中,直接运行文件夹下的

./copy_media.sh

即可。

它会自动把这些media文件拷贝到你的sd卡中。

c).当知道自己的设备适应的视频分辨率,使用

. copy_media.sh 1280x720

将该分辨率及以下的分辨率的视频复制到手机的SD卡中进行测试。

Google一共提供了五种分辨率的视频文件,176x144、480x360、720x480、1280x720、1920x1080。根据自己设备的具体情况添加,公司手机最大支持1080p的视频,但是超过720p之后的视频播放都会很卡,所以我暂定为选择720p的视频来测试。

3.6.在 android设备设置中:安全->屏幕安全保护->自动锁定设为“无”

3.7. 在 android设备设置中:显示->休眠->休眠时间调节到最长

3.8.在 android设备设置中:开发人员选项->保持唤醒状态,允许模拟地址两项勾选(当然了,USB调试也是需要打开的)

3.9.将 android设备的语言设置为英文。

3.10.需要有一张有话费的可正常使用的SIM卡。

3.11.将WIFI打开,连接一个可用AP(我所在公司的手机为双卡,需要设置好手机的语音、数据、短消息的默认卡)设置->双卡设置

3.12.设置->输入语言设为android

3.13.手机屏幕停留在主界面上

4.RUN CTS

4.1.打开终端,进入android-cts/tools目录

执行命令:

shz@ubuntu:$ cd android-cts/tools

4.2.进入CTS,执行cts-tradefed脚本

执行命令:

shz@ubuntu:~/android-cts/tools$: ./cts-tradefed

当手机连接好的时候,执行该命令,会显示出Android设备的ID, 如果没有这句话,说明手机没有和PC连通。调整手机和PC的连接,连接好了之后,就重复第二步里面的内容并给与手机权限:

之后再重复之前的步骤就可以看见Android设备的ID了。

注:有时候进入CTS测试状态后无法出现cts-tf >,此时电脑按一个回车键就可以了。这算是CTS的一个小bug。

4.3开始整个CTS测试

4.3.1.首先我们先使用help命令来看一下cts-tf >里面的信息:

在这个里面会显示出CTS测试包的版本:

CTS-tradefed host version 4.0.3_r3

我们可以看一下都有哪些测试plan:

测试packages:

后面还有许多就不都贴出来了。

4.3.2.开始执行命令

a) 执行一个plan:run cts --plan <plan名称>

全部测试一遍命令:

run cts --plan CTS

b) 仅测试一个包:run cts -p <测试包名称>

例如:run cts -p android.acceleration

c) 因为是基于JUnit测试,属于白盒测试,所有基本上我们都知道它的内部是如何运行的,所以我们也可以根据某个测试包中某一个具体的类或者方法进行测试:

run cts –p <packages name> –c <class name> [-m  <method name>]

d) 多台Android设备同时测试:

run cts –s 设备名称 -plan <plan名称>

注:

(1)、这儿有一个很重要的命令

我们在进行CTS测试的时候总会有一些因为各种原因引起的不成功的测试项,但是,要完全进行一次全部的CTS测试又是一项很费时的操作,这个时候这个命令就派上用场了,它可以让我们之前测试的结果的基础上,新建一个根据测试结果为fail/not Executed /time out的集合组建出一个新的plan,之后测试这个plan,就可以只需要测试那些之前测试没有通过的项目,而不用再把已经通过的项目再测一遍,就节约了很多时间。

(2)、在Google的官网上有这么提到过,当我们在测试一个整的包的时候,成功率比单独测一个类和方法要高。

所以,我们再重测一些失败项的时候,根据情况选择测试一个包的模式也是一个不错的选择。

5.测试结果

测试结果在android-cts/repository/results目录下;

测试日志在android-cts/repository/logs目录下。

6. 失败项目重测及xml文档整合

我们在测试一些项目的时候,完全跑一遍CTS测试,很多项都会失败fail,但是我们在对这些失败项单独测得时候,这些项目pass,这时,我们不可能再去重新完全跑一次CTS,这样既耗时,也不能确保该项一定会pass,这样,我们就可以用下面的方法来对失败项操作,做到失败项的pass结果整合。

原理:

将fail项修改成not Executed项,使用该命令进行重测。

6.1. 定位

找到那些测试fail的项,对它们进行源码的修改、调试,之后进行单独测试,直到它不再fail。使用文本编译器打开result的xml文件,找到该项

6.2. 修改

找到项目之后,将[result=”fail”]改成[result=”not  Executed”],记得在xml文件的开头将fail总数和not Executed的总数根据你修改的数目进行修改

修改之后:

6.3. 测试

session_ID是之前查看result前面的ID。

运行,测试完成,结果就被整合到了原来的result集中,pass项将会把原来的fail的log在result的xml文件中也一并删除。

注意事项:CTS测试中不能对终端做任何操作。

Android 4.0.3 CTS 测试相关推荐

  1. 【转】Android 4.0.3 CTS 测试

    原文网址:http://blog.csdn.net/zxm317122667/article/details/8508013 Android-CTS 4.0.3测试基本配置 1. Download C ...

  2. CTS(5)---Android8.0中CTS测试对于TEE的要求

    Android8.0中CTS测试对于TEE的要求 我们知道TEE在Google Android7.0后成为一种强制性要求,那么Android8.0又是如何要求的呢? 对于Android8.0中CTS测 ...

  3. Android 9.0 hal3 CTS Verifier Camera Video配置修改

    CTS Verifier Camera Video的配置是自动生成的,可能修改吗,可以的. 1.Camera Video自动生成与什么文件有关: 修改media_profiles.xml中的配置来修改 ...

  4. Testin云测率先全面支持Android 5.0手游云测试

    Testin云测率先全面支持Android 5.0手游云测试 2014/11/21 · Testin · 业界资讯 谷歌公司于今年10月16日推出全新Android 5.0操作系统,迅速成为全球移动互 ...

  5. Android 7.0 Nougat介绍

    Android 7.0 Nougat 1.多窗口支持 在 Android 7.0 中,我们为该平台引入了一个新的而且非常需要的多任务处理功能 - 多窗口支持. 现在,用户可以一次在屏幕上打开两个应用. ...

  6. CTS(1)---谷歌CTS测试简介

    谷歌CTS测试简介 CTS测试 1.设置CTS(物理环境) WLAN 和 IPv6 CTS 测试需要满足以下要求的 WLAN 网络:支持 IPv6,可以将被测设备 (DUT) 视为隔离客户端,并可以连 ...

  7. CTS(3)---CTS 测试的一点心得

    CTS 测试的一点心得 CTS介绍-----------------------------------------------3 什么是CTS---------------------------- ...

  8. android ble5.0添加扫描过滤,bluetooth-lowenergy

    精简版: 在我使用Android 5.0 Lollipop的测试中,我注意到android.bluetooth.le.BluetoothLeScanner检测BLE设备的频率低于Android 4.4 ...

  9. 三星s9没有推送android10,2月14日 三星Galaxy S9/S9+开始推送Android 9.0正式版

    2月13日,据三星盖乐世社区官方消息,三星Galaxy S9/S9+将于2月14日推送基于Android 9.0的One UI的正式版更新. 此前在11月23日,盖乐世社区已经开始招募Android ...

最新文章

  1. RxJava 和 RxAndroid 一 (基础)
  2. 以感恩的心离职,站好最后一班岗
  3. 单片机平台的最小偏差圆弧插补算法
  4. 纯Java JavaFX 2.0菜单
  5. 生命很短,我用tldr
  6. 鼠标放到图片上替换图片,改变样式。
  7. 小前端眼里的大前端:GMTC 2018 参会小结
  8. 超级简单的Android Studio jni 实现(无需命令行)
  9. 圆满结束,一睹各位大神风采
  10. mysql数据库原理与应用武洪萍第三张答案_MySQL数据库原理及应用(第2版)(微课版)...
  11. Mysql中使用mybatis中sql语句写法操作
  12. 软件测试基础——概念篇
  13. MIUI系统获取短信权限问题
  14. 微信刷脸支付php后端,2.1 微信刷脸支付初始化
  15. Aapache 启动不了,报错信息:suEXEC mechanism enabled (wrapper: /usr/sbin/suexec)
  16. 悲观者往往正确,乐观者往往成功
  17. 产品Backlog 管理
  18. redis工具redis Desktop Manager使用
  19. 16 16点阵c语言程序,用C语言编程16点阵字库
  20. 鹤林全集·怡情枫林 | 第二篇——励志创造奇迹

热门文章

  1. H2 数据库使用简介
  2. gatling详细使用
  3. java初学之短路运算符练习
  4. 十几亿用户中心系统架构,落地实践
  5. 修改linux终端中的程序名字,在Ubuntu/Debian/Arch Linux/Fedora/OpenSUSE下更改主机名的方法...
  6. 全栈开发——动手打造属于自己的直播间(Vue+SpringBoot+Nginx)的补充使用说明
  7. 分布式部署(不同服务存放不同服务器)
  8. Android 面试题集(2019-04-04总结)
  9. “AI Earth”人工智能创新挑战赛:助力精准气象和海洋预测Baseline[3]:TCNN+RNN模型、SA-ConvLSTM模型
  10. CATIA 桥梁正向设计及开发资料文章汇总