zoukankan      html  css  js  c++  java
  • 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(17891414);

      进入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。

  • 相关阅读:
    linux内核(四)内存管理单元MMU
    open函数详解
    linux内核(三)文件系统
    C++中数字与字符串之间的转换 scanf string总结(复习必读)
    hello程序的运行过程-从计算机系统角度
    剑指offer第12题打印从1到n位数以及大整数加法乘法
    2017-10-11第二次万革始面经
    为什么需要半关闭
    Ubuntu指令
    143. Reorder List
  • 原文地址:https://www.cnblogs.com/Peter-Chen/p/3861818.html
Copyright © 2011-2022 走看看