Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android系統教程 >> Android開發教程 >> Android cts all pass詳解

Android cts all pass詳解

編輯:Android開發教程

android CTS ! Goodbye fails ! Goodbye timeout !

為什麼要進行cts測試

Android 兼容性測試(CTS)和連帶的兼容性定義文檔(CDD),是一個確保終端設備與特定版本Android兼容的自管理程序。CTS測試集包含大約 24,000個在Android設備上運行的測試用例,這些用例分別針對電話、圖形、相機、GPS、觸摸屏、無線網等功能。Google針對每個主要 Android版本公布了CDD文檔,其中指出了對CTS中每類測試的具體要求。通過CTS測試是訪問Android軟件市場的必要條件之一。通過CTS測試之後便允許在設備上使用Android商標,它標志著該設備能夠良好兼容軟件市場中的數十萬應用程序。

常見問題和解決方案

我在這裡不寫怎麼執行CTS,-p 是什麼意思 -t是什麼意思,我總結的是在執行  cts_host > start --plan CTS 之後,想all pass 的那些有營養的東西。

testcase timeout

測試某個testcase的時候一直出現 “........”,遲遲沒有pass或者fail,等良久出現一個血淋淋的timeout,很讓人傷心。有不少人笑嘻嘻的以為timeout 挺好,至少它不是fail。在我看來timeout 比 fail 還恐怖,因為它連進行測試到底是pass還是fail的權利都沒有。想不被硬件設備廠商笑話,必須0 timeout ,然後再爭取0 fail 。

timeout多數都是由於這個錯誤造成的:

Exception in thread "Thread-XX" com.android.ddmlib.ShellCommandUnresponsiveException

at com.android.ddmlib.AdbHelper.executeRemoteCommand(AdbHelper.java:408)

at com.android.ddmlib.Device.executeShellCommand(Device.java:276)

at com.android.cts.TestDevice$1.run(TestDevice.java:1718)

解決方案:

這個錯誤是由於CTS和SDK版本不匹配造成的。倘若用android2.2 SDK 和 android2.2 cts -r6 還是出現了這個問題,那麼編譯自己工程的sdk (在整體m後,再make sdk),配套官方的cts一起,就可以百分百解決這個問題了。

必須要注意的是,不要用自己的工程代碼編譯出來的cts(make cts),因為可能編譯出來的不是最新的(通常是r1版本)。而google提供的才是最新的,而硬件設備廠商都會信賴最新版本的cts的測試結果。

Restarting device ...Restarting ADB...

板子執行幾個測試項就停下,讓人很郁悶

CTS_INFO >>> Max ADB operations reached. Restarting ADB...

CTS_INFO >>> Restarting device ...

Device(xxxxxxxxxxxxxxxxxxxxxx) disconnected

Test stopped.

Device(xxxxxxxxxxxxxxxxxxxxxx) connected

解決方案:

其實重啟adb和板子是正常現象,如果不重啟會影響他們的正常工作。但是這樣頻繁的重啟,很影響工作效率。

我們可以控制測試中重啟的頻率:

修改android-cts/repository/host_config.xml中的 reboots value:

<!-- Number of tests executed between reboots. A value <= 0 disables reboots. -->

<IntValue name="maxTestCount" value="200" />

5000是我測試比較合理的數字,如果不跑全部的cts項23700個test的話,數量不多可以修改為-1,禁止重啟。

如果數量過多,則還是重啟的好,否則中途adb會卡死停止test。自動化測試,你不會一直盯著它的對吧?

java.io.IOException: sad result from adb: closed

倘若中途出現:

java.io.IOException: sad result from adb: closed

00:47 E/ddms: ADB rejected shell command (am instrument -w -e bundle true android.tests.devicesetup/android.tests.getinfo.DeviceInfoInstrument): closed

CTS_ERROR >>> Failed to execute shell command am instrument -w -e bundle true android.tests.devicesetup/android.tests.getinfo.DeviceInfoInstrument on device 0xxxxxxxxxxxx

java.io.IOException: sad result from adb: closed

解決方案:

別擔心,重啟一下板子就好了。

其他fail

因為各個項目差異,所以fail項不同,拋開硬件差異所決定的fail,還有系統工程師為了掩飾別的bug而新增的cts fail bug,我們還需要注意的是:

1.Net相關的testcase ,記得開wifi  3G,保持網絡聯通

2.SMS相關的testcase,記得插SIM卡

3.當I2C上某個設備的testcase沒有過,試試禁掉I2C上其他的sensor服務,單一測試,也許會有意外收獲

查看本欄目更多精彩內容:http://www.bianceng.cn/OS/extra/

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved