eclipse调试Cts 单项

        Cts测试中,单项失败是常用的事情,想要查找原因却比较麻烦,因为cts的command line 虽然提供了单项单独测试的方法,却只会输出结果,最多也就保留了device和host的log,用eclipse来调试还是比较不常见的。今天想到了这个麻烦,研究了下eclipse 调试Cts单项的方法:

        首先,Cts的测试主要还是要依赖apk,所以它的调试还是和app的调试很类似的。

1. 通过Cts command line 单独测试一下失败项,从log给出的信息中找到对应的apk。

2. Install这个apk,想办法让它跑起来,如果有activity,那am start 就好了。

3. 如果没有activity 只有instrumentation,那就要用am instrument,这个命令不太常用


am instrument: start an Instrumentation.  Typically this target <COMPONENT>
  is the form <TEST_PACKAGE>/<RUNNER_CLASS>.  Options are:
    -r: print raw results (otherwise decode REPORT_KEY_STREAMRESULT).  Use with
        [-e perf true] to generate raw output for performance measurements.
    -e <NAME> <VALUE>: set argument <NAME> to <VALUE>.  For test runners a
        common form is [-e <testrunner_flag> <value>[,<value>...]].
    -p <FILE>: write profiling data to <FILE>
    -w: wait for instrumentation to finish before returning.  Required for
        test runners.
    --user <USER_ID> | current: Specify user instrumentation runs in;
        current user if not specified.
    --no-window-animation: turn off window animations while running.
    --abi <ABI>: Launch the instrumented process with the selected ABI.
        This assumes that the process supports the selected ABI.


说明不是很清楚,大概可以看出可以通过 am instrument -r -w XXX 一个instrumentation的名字来跑这个instrumentation。

如何跑单项呢? 要用到-e 

例如:

am instrument -r -e class android.provider.cts.MediaStore_FilesTest#testAccess -w com.android.cts.provider/android.support.test.runner.AndroidJUnitRunner


android.provider.cts.MediaStore_FilesTest#testAccess 这一串是不是很熟悉呢,对了,就是cts单项测试时候打印出来的东东,包名类名加方法名。

com.android.cts.provider/android.support.test.runner.AndroidJUnitRunner 这一串呢就是instrumentation的名字,咋知道呢?AndroidManifest里有。

通过pm list instrumentation 也可以查出来。


ok,只要能让这个apk跑起来就好办了,eclipse就可以attach来调试咯。

找个时机去attach也是关键,这里就可以用am set-debug-app来创造时机了。这是一个很有内涵的命令,找个时间再来分析了。


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。