• 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。

  • 相关阅读:
    Android(java)学习笔记197:ContentProvider使用之内容观察者02
    数据库连接池--druid
    在java中导出excel
    对excel进行封装
    创建excel,合并单元格,设置单元格样式
    认识Excel并创建一个excel(网址:http://poi.apache.org/)
    认识单元测试(jar包资源网址:http://search.maven.org/)
    Echarts在java中使用
    认识Echarts(网址:http://echarts.baidu.com/tutorial.html#ECharts%20%E7%89%B9%E6%80%A7%E4%BB%8B%E7%BB%8D)
    制作缩略图
  • 原文地址:https://www.cnblogs.com/Peter-Chen/p/3861818.html
Copyright © 2020-2023  润新知