CTS FAIL(一)
首先简单介绍下CTS:全称Compatibility Test Suite,通过CTS测试,来检测android apk与android系统的兼容性。
最近公司release一版新的Image,但在新Image上跑CTS后出现了和Audio有关的测试FAIL项(testVolume),因为是第一次看CTS的问题,所以简单的整理了关于该FAIL项的解决过程,方便以后的复习。
在跑完testVolume项的CTS测试FAIL时,在命令窗口显示的错误信息如下:

根据提示的信息,定位到该测试项对应的AudioManagerTest.java文件的第335行。为了方便分析,如下code是AudioManagerTest.java文件中testVolume函数的部分代码,其中红色HIghline的就是FAIL项提示的第335行。
public void testVolume() throws Exception {
int[] streams = { AudioManager.STREAM_ALARM,
AudioManager.STREAM_MUSIC,
AudioManager.STREAM_VOICE_CALL,
AudioManager.STREAM_RING };
mAudioManager.adjustVolume(ADJUST_RAISE, 0);
mAudioManager.adjustSuggestedStreamVolume(
ADJUST_LOWER, USE_DEFAULT_STREAM_TYPE, 0);
int maxMusicVolume = mAudioManager.getStreamMaxVolume(STREAM_MUSIC);
for (int i = 0; i < streams.length; i++) {
// set ringer mode to back normal to not interfere with volume tests
mAudioManager.setRingerMode(RINGER_MODE_NORMAL);
int maxVolume = mAudioManager.getStreamMaxVolume(streams[i]);
mAudioManager.setStreamVolume(streams[i], 1, 0);
if (mUseFixedVolume) {
assertEquals(maxVolume, mAudioManager.getStreamVolume(streams[i]));
continue;
}
assertEquals(1, mAudioManager.getStreamVolume(streams[i]));
... ...
}
}
根据maxVolume = mAudioManager.getStreamMaxVolume(stream[i]),可以知道maxVolume是用来记录stream[i]的MAX_STREAM_VOLUME,这个值可以在AudioService.java中获得。当for循环中的i = 0时,stream[i] = AudioManager.STREAM_ALARM。而STREAM_ALARM的MAX_STREAM_VOLUME为7,即maxVolume = 7。
mAudioManager.getStreamVolume(stream[i])的值可以通过Souce Insight追到AudioService.java文件中,且值为(mIndex + 5)/10。因为CTS测试都是在系统恢复出厂设置后测试的,所以此处的mIndex应该对应于stream[i]的默认音量。音频流的默认音量可以在AudioManager.java中得到。STREAM_ALARM的默认音量为5,带入到(mIndex + 5)/10可以求得mAudioManager.getStreamVolume(stream[i]) = 1。
正是由于maxVolume和mAudioManager.getStreamVolume(stream[i]) 这两个值不等,所以会提示有AssertionFailedError:expected:<7>but was:<1>的错误。这说明CTS测试已经进入if(mUseFixedVolume)语句中,但是搜索配置文件config.xml发现config_useFixedVolume = false,这与测试结果正好相反。这里就有疑惑为什们这边的mUseFixedVolume与配置文件中的值不一样呢?当前mUseFixedVolume的值又是什么呢?为了解决这个疑惑,将CTS测试用例apk反编译得到
this.mUseFixedVolume = this.mContext.getResources().getBoolean();
进入out/target/common/obj/APPS/framework-res_intermediates/public_source.xml中发现编译结束后config_useFixedVolume对应的ID却为0x01110057,转化为十进制的值为17891415。原来mUseFixedVolume得到的值是配置文件中ID为17891414的值,查询该值大小为true,满足CTS结果。
解决办法:将config_useFixedVolume在config.xml中向前移动一位,以满足编译结果ID为17891414。修改后,测试PASS。
CTS FAIL(一)的更多相关文章
- CTS/GTS 常见问题解答
1.android.security.cts.PackageSignatureTest测试fail(MTK平台) 原因:由于用的是google default key而导致的fail,需要自己定义re ...
- Android CTS 结果 testResult.xml 修改 fail 项 为 notExecuted 项 分析
这两天一直在搞 Android 4.1 CTS ,每次完整跑完一遍后总有几百项 failed,用编辑器手动改为 notExecuted 项后重新跑,有很多项第二次都跑过了. 但是发现直接修改也带来很多 ...
- Android CTS測试Fail项改动总结(四)
Android5.1上的測试 1.android.security.cts.SELinuxDomainTest# testInitDomain fail 打印的log junit.framework. ...
- Android CTS - Cannot run program "aapt"/ Fail to run aapt on .../apk installed but AaptParser failed
今天同事碰到cts的一些问题,跑到某个apk的时候,就提示如下错误: Cannot run program "aapt": error=2. No such file or dir ...
- Android 4.0.3 CTS 测试
Android-CTS 4.0.3测试基本配置 1. Download CTS CTS的获取方式有两种: 1.1.由Google提供 1.1.1.打开浏览器输入连接: http://source.an ...
- android 兼容性测试 CTS 测试过程(实践测试验证通过)
source: http://blog.csdn.net/jianguo_liao19840726/article/details/7222814 写这个博客的时候是为了记忆,建议大家还是看官方的说明 ...
- 如何debug android cts
启动和关闭ADB服务(adb start-server和adbkill-server) 经作者测试,模拟器在运行一段时间后,adb服务有可能(在Windows进程中可以找到这个服务,该服务用来为模拟器 ...
- 【转】CTS tests 4.2_r4
原文网址:http://www.xuebuyuan.com/1722006.html Precondition: 1.Get android sdk 2.Set adb to environment ...
- 【转】android cts failed items
原文网址:http://blog.csdn.net/linsa0517/article/details/19031479 Fail的一些修改 1.直接设置问题 estUnknownSourcesO ...
随机推荐
- Easyui 中的placeholder属性
在 easyui有文档中,没注意还真找不到placeholder属性,因为在属性只在searchbox中提到了, <input id="ss" class="eas ...
- 车牌识别LPR(二)-- 车牌特征及难点
第二篇:车牌的特征及难点 2.1 对我国车牌的认识 我国目前使用的汽车牌号标准是 2007 年开始实施的<中华人民共和国机动车号牌>GA36-2007(2010 年修订).根据 GA36 ...
- BZOJ 2005 能量采集(容斥原理)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2005 题意:给定n和m,求 思路:本题主要是解决对于给定的t,有多少对(i,j)满足x= ...
- 对github中项目进行更新
进入本地仓库文件夹,我的仓库名是tufujiegit,然后 进入 git clone 接着将先前记录下来的地址复制到后面,回车 将下载github中该仓库的所有文件及文件夹,包括.git文件夹在内 ...
- [IE编程] 多页面基于IE内核浏览器的代码示例
有不少人发信问这个问题,我把答案贴在这里: 建议参考 WTL (Windows Template Library) 的代码示例工程TabBrowser (在WTL目录/Samples/TabBrow ...
- tornado中使用torndb,连接数过高的问题
问题背景 最近新的产品开发中,使用了到了Tornado和mysql数据库.但在基本框架完成之后,我在开发时候发现了一个很奇怪的现象,我在测试时,发现数据库返回不了结果,于是我在mysql中输入show ...
- bzoj2245: [SDOI2011]工作安排
费用流. 这道题的模型比较明显,拆点也是很容易看出来的. #include<cstdio> #include<algorithm> #include<cstring> ...
- UVa 10943 (数学 递推) How do you add?
将K个不超过N的非负整数加起来,使它们的和为N,一共有多少种方法. 设d(i, j)表示j个不超过i的非负整数之和为i的方法数. d(i, j) = sum{ d(k, j-1) | 0 ≤ k ≤ ...
- Samba 4.x.x全版本存在命令执行漏洞
Samba 4.0.0到4.1.10版本的nmbd(the NetBIOS name services daemon)被发现存在远程命令执行漏洞.CVE编号为CVE-2014-3560.目前官方已经发 ...
- Oracle 隔离级别
From 11gR2: http://download.oracle.com/docs/cd/E11882_01/server.112/e16508/consist.htm#CNCPT621 一. A ...