android之CTS兼容性测试及FAILissue
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
android之CTS兼容性测试及FAILissue
最近在忙碌着CTS测试,头大啊,各种莫名的fail,timeout,今天晚上刚好有时间来写篇文章来记录下;
CTS(Compatibility Test Suite);为什么要做CTS测试:
1.Give your users the best possible experience with the applications they run.
2.When a device is compatible with Android, users can choose from among many high-quality applications.
3.Applications that take full advantage of Android's features are likely to perform best on compatible devices.
4.Make it easy for developers to write top-quality applications for your device.Developers want to streamline their applications for Android,
5.and this is easiest for them when they are writing for a predictable platform.
6.Take advantage of the Android Market.
patible handsets can give users access to the Android Market.
一、CTS测试之前的需要的准备项和如何进行测试;
做CTS测试首先得做很多项的配置,现在来仔细说下CTS的配置过程:
1、首先得安装有adb,并且配置adb的环境变量;export PATH=$PATH:/home/myuser/adb;
2、准备一个cts包,可以在源码中通过make cts编译,也可以在android网站上面下载下来();
包里面有三个文件夹,其中tools下面有测试需要的jar包以及cts-tradefed脚本用于执行cts命令;还有一个repository文件夹,里面有一些测试计划,测试结果也会生成在里面;在repository/testcases目录下找到
CtsDelegatingAccessibilityService.apk 和/CtsDeviceAdmin.apk ,并且安装;
1 2 adb install android-cts/repository/testcases/CtsDelegatingAccessibilityService.apk adb install android-cts/repository/testcases/CtsDeviceAdmin.apk
安装以后在setting 中会多出设置项,需要进行设置Settings > Accessibility > Delegating AccessibilityService ,Settings > Security
> Device Administrators
>android.deviceadmin.cts.CtsDeviceAdmin*
settings ;
3、在setting 中需要设置多项设置项,setting-display-sleep 设置30min 钟,language 设置为E 文,Security 中Screen lock 设置NONE ;
4、Cts 有media stress 测试,你需要在这里下下载各种分辨率的mp4视频文件,在这里下载android-cts-media-X.Y.zip ,执行里面的copy_media.sh 脚本,把视频文件拷贝到/sdcard/test 目录下,当然你也可以手动push ;
5、插入一张有钱的SIM 卡;
都准备好了接下来就可以跑CTS 了,首先
1 ./android-cts/tools/cts-tradefed 这下就进入了CTS 测试的命令行模式了,然后执行
1 run cts --plan CTS
进行全部项的测试,如果你想测试某一个测试plan ,可以
1 run cts --plan <plan_name>
这个时候等待结果就行了...漫长的等待啊......
二、如何进行单项测试呢?
在Linux 环境下,如果你想进行单项测试,比如说某个package ,class ,method 之类的,可以这样
1 run cts --package packageName
1 run cts --class className
1 run cts --class className --method methodName
,这下就可以对单个的错误进行调试运行了;
如果我想在windows 环境下进行CTS 单项测试呢(不知道windows 下有没有CTS 整项测试)?你首先需要将repositorytestcases 下的所有的apk 之类的文件都push 到data/app 下面去,然后通过
1 adb shell pm list instrumentation
显示所有的Runner ,这里的Runner 作为下面这个命令-w 以后的参数,然后通过
1 adb shell am instrument -e class 类名#方法名 -w “Runner”
进行单项的测试;
举个例子,比如:
1 2 3 adb shell am instrument -e
class
android.accessibilityservice.cts.AccessibilityTextTraversalTest#tes tActionNextAndPreviousAtGranularityPageOverText -w com.android.cts.accessibilityservice/android.test.InstrumentationCt sTestRunner
悲催的result :
1 2 3 4 android.accessibilityservice.cts.AccessibilityTextTraversalTest: Error in testActionNextAndPreviousAtGranularityPageOverText:
java.util.concurrent.TimeoutException: Expected event not received within: 5000 ms.
at
android.accessibilityservice.cts.AccessibilityActivityTestCase$Acc essibilityInteractionBridge.executeCommandA
ndWaitForAccessibilityEvent(AccessibilityActivityTestCase.java:542)
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 at
android.accessibilityservice.cts.AccessibilityTextTraversalTest.te stActionNextAndPreviousAtGranularityPageOve
rText(AccessibilityTextTraversalTest.java:1219)
at ng.reflect.Method.invokeNative(Native Method) at
android.test.InstrumentationTestCase.runMethod(InstrumentationTest Case.java:214)
at
android.test.InstrumentationTestCase.runTest(InstrumentationTestCa se.java:199)
at
android.test.ActivityInstrumentationTestCase2.runTest(ActivityInst rumentationTestCase2.java:192)
at
android.test.AndroidTestRunner.runTest(AndroidTestRunner.java:190) at
android.test.AndroidTestRunner.runTest(AndroidTestRunner.java:175) at
android.test.InstrumentationTestRunner.onStart(InstrumentationTest Runner.java:555)
at
android.app.Instrumentation$InstrumentationThread.run(Instrumentat ion.java:1661)
Test results for InstrumentationCtsTestRunner=.E
Time: 5.796
FAILURES
Tests run: 1, Failures: 0, Errors: 1
相比windows 下进行单项测试,Linux 下还是简单的多了。
对于UiAutomatorTests 的测试项,如何进行单测呢?因为之前我们意见将CtsUiAutomatorTests.jar push 到了data/app 下,我们只需执行如下命令即可测试;
1 uiautomator runtest /data/app/CtsUiAutomatorTests.jar
-c
com.android.cts.uiautomatortest.CtsUiAutomatorTest
三、 如何针对所有的failed 的项进行重测呢?
首先你得通过l r 命令列出测试记录的sessionId ,然后进入respository/result/×××/testResult.xml 中,首先把failed 总项数改为0,notExecuted 总项数改为你之前failed 的项数;
然后通过vi 的全局替换命令“1,$s/old/new/g”替换所有的result=“failed”为result=“notExecuted”,
1 run cts --continue -session “sessionID”
接下来就可以通过上面这个命令进行重测了;
四、除去不需要测试的测项
在某些时候,当手机没有该项功能时,是否我们就不需要测试该项呢?比如不带telephony 的平板电脑CTS 就不需要去测试telephony 的项;
如何去除看下这段代码就知道了:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 PackageManagerService.java
void readPermissions() {
// Read permissions from .../etc/permission directory. File libraryDir = new File(Environment.getRootDirectory(), "etc/permissions");
if (!libraryDir.exists() || !libraryDir.isDirectory()) { Slog.w(TAG, "No directory " + libraryDir + ", skipping");
return;
}
if (!libraryDir.canRead()) {
Slog.w(TAG, "Directory " + libraryDir + " cannot be read");
return;
}
// Iterate over the files in the directory and scan .xml files
for (File f : libraryDir.listFiles()) {
// We'll read platform.xml last
if
(f.getPath().endsWith("etc/permissions/platform.xml")) {
continue;
}
if (!f.getPath().endsWith(".xml")) {
Slog.i(TAG, "Non-xml file " + f + " in " + libraryDir + " directory, ignoring");
continue;
31 32 33 34 35 36 37 38 }
if (!f.canRead()) {
Slog.w(TAG, "Permissions library file " + f + " cannot be read");
continue;
}
readPermissionsFromXml(f);
}
// Read permissions from .../etc/permissions/platform.xml last so it will take precedence
final File permFile = new File(Environment.getRootDirectory(),
"etc/permissions/platform.xml");
readPermissionsFromXml(permFile);
}
现在知道了去除的方法就是把/etc/permissions 下除了platform.xml 的其他xml 中找到telephony 相关的配置文件,去除就行了,当然其对应的编译前文件在framework/native/data/etc 下;对其进行修改即可;
五、CTS bug 的记录;
在此记录一下我跟了好几天的一个CTS bug :
1、
1 android.media.cts.MediaPlayerTest -- testGapless1 fail junit.framework.AssertionFailedError: silence detected, please increase volume and rerun test at android.media.cts.MediaPlayerTest.testGapless(MediaPlayerTest.java:397)
出现此问题的原因是EffectVisualizer.cpp 中的Context 状态一直是VISUALIZER_STATE_INITIALIZED 无法VISUALIZER_STATE_ACTIVE ,导致无法走进判断;修改system.prop 下的两个property 为false 即可通过测试;PS :不同的android 项目可能在不同的prop 里面,也有可能在build.prop 下;另外此选项是针对qcomm 平台的这种解码方式;
Tunnel.decode use for low latency playback, it use Qualcomm HW decoder. But Tunnel decoder don't support Gapless playback, so please disable it when do CTS test. 1 2 tunnel.decode=false tunnel.audiovideo.decode=false
当然,你也可以
1 getprop tunnel.decode
然后重测看一下结果;
2、
1 android.security.cts.PackageSignatureTest -- testPackageSignatures fail junit.framework.AssertionFailedError: These packages should not be signed with a well known key: [com.qualcomm.wifip2p.service, com.android.voicedialer, com.qualcomm.timeservice, com.qualcomm.qlogcat, com.qualcomm.atfwd, uncher, com.android.defcontainer, com.android.quicksearchbox, com.android.contacts, com.android.phone, com.android.calculator2, com.android.htmlviewer, com.android.cellbroadcastreceiver, com.android.MultiplePdpTest, com.android.providers.calendar,.......
[reason]
using android default key to sign apk ;
[Solution]
sign apk using our own key
[Change File]
buildtargetproductsecurity*
3、
1 -- testNoSetuidTcpdump fail junit.framework.AssertionFailedError: File "/system/xbin/tcpdump" is setUID at android.security.cts.BannedFilesTest.assertNotSetugid(BannedFilesTe
st.java:71)
[reason]
the permission for system/xbin/tcpdump is wrong.
[Solution]
set
the correct permission to 00755 for system/xbin/tcpdump
[Change File]
system/core/include/private/android_filesystem_config.h ; 4、
1 -- testStartUsingNetworkFeature_enableHipri fail junit.framework.AssertionFailedError: Couldn't connect using hipri... at .cts.ConnectivityManagerTest.testStartUsingNetworkFeatur e_enableHipri(ConnectivityManagerTest.java:293)
[reason]
don't set the right APN
[Solution]
set APN and in the APN type field include "hipri"
[Change File]
N/A
5、
1 -- testActivateGoodReceiverDisplaysActivationUi fail junit.framework.AssertionFailedError at android.admin.cts.DeviceAdminActivationTest.assertDeviceAdminDeacti vated(DeviceAdminActivationTest.java:200)
1 2 3 4 junit.framework.AssertionFailedError
at
android.admin.cts.DeviceAdminActivationTest.assertDeviceAdminDeacti vated(DeviceAdminActivationTest.java:200) at android.admin.cts.DeviceAdminActivationTest.testActivateGoodReceive rDisplaysActivationUi(DeviceAdminActivatio
nTest.java:102)
在网上找到的一个解决办法:
Install the "CtsDeviceAdmin.apk" and
enable only the first two
options in the security-->Deviceadministrators".
It will make the Test case "testActivateGoodReceiverDisplaysActivationUi"
PASS. Even all the 18 Test cases in this Package
(android.admin) will get PASS on Android 4.3;
但是奇怪的是这个fail 报错的位置在源码中找不到,DeviceAdminActivationTest,java 中根本没有200行的代码,查看
4.4的cts 源码也是一样的;不知道是不是android-cts-4.3_r2-linux_x86-arm.zip 的问题。
6、
1 -- testUsbDebugging fail parisonFailure: expected: but was: at bDebuggingTest.testUsbDebugging(UsbDebuggingTest.j ava:28)
这个是测试secure USB debug 的测项,需要ro.adb.secure 这个property ;
1 assertEquals("1", SystemProperties.get("ro.adb.secure"));
在main.mk 文件中添加
ADDITIONAL_DEFAULT_PROPERTIES += ro.adb.secure=1即可启用;
关于这个secure USB debugging 可以参考,请务必注意修改;在开启secure USB debugging 后,如果你的机器插入usb 时无法弹出authorization 的弹出框,你需要更新你的adb 版本,adb version :Android Debug Bridge version 1.0.31;
7、
1 2 3 4 5 6 7 8 9 .cts.TrafficStatsTest
-- testTrafficStatsForLocalhost fail junit.framework.AssertionFailedError: uidtxb: -1 -> -1 at .cts.TrafficStatsTest.testTrafficStatsForLocalhost(Traff icStatsTest.java:136)
[reason]
CONFIG_UID_STAT not set
[Solution]
set CONFIG_UID_STAT=y
[Change File]
kernel/arch/arm/configs/msm8960_defconfig"
8、
1 2 .URLConnectionTest
-- test_getOutputStream fail junit.framework.AssertionFailedError: Got different responseCode expected:<405> but was:<200> at .URLConnectionTest.test_getOu tputStream(URLConnectionTest.java:870)
这个CTS bug 是(2014.01)最近才会出现的,原因是/ie 的post 访问方式的HTTP 返回码问题,无需fix ,google 会在最新的code 中删除掉此项测试;。