Android16 【GTS】 GtsDevicePolicyTestCases 测试存在Failed项
文章目录
- [Android16 【GTS】 GtsDevicePolicyTestCases 测试存在Failed项](#Android16 【GTS】 GtsDevicePolicyTestCases 测试存在Failed项)
一、前言
这里记录一个【GTS】 GtsDevicePolicyTestCases 测试Failed项。
从报错堆栈看是和输入法有关。
刚开始以为是更新了GMS输入法导致,后面发现是设置了其他默认输入法导致的Failed项。
二、分析解决
1、报错信息
如下图所示:

测试模块: GtsDevicePolicyTestCases
测试项:
android.devicepolicy.gts.ManagedProfileProvisioningCrossProfileAppsTest#newlyProvisionedManagedProfile_unknownCrossProfileAppsAreNotPresent
报错堆栈信息:
java.lang.AssertionError: com.google.android.inputmethod.latin is pre-granted INTERACT_ACROSS_PROFILES and should not be
at org.junit.Assert.fail(Assert.java:89)
at android.devicepolicy.gts.ManagedProfileProvisioningCrossProfileAppsTest.assertNoUnknownCrossProfileApps(ManagedProfileProvisioningCrossProfileAppsTest.java:198)
at android.devicepolicy.gts.ManagedProfileProvisioningCrossProfileAppsTest.newlyProvisionedManagedProfile_unknownCrossProfileAppsAreNotPresent(ManagedProfileProvisioningCrossProfileAppsTest.java:165)
2、分析
通过回退验证发现是和一个修改输入法的对策有关:
(1)更新GMS release/vendor/partner_gms/apps/LatinImeGoogle 里面一系列apk
(2)设置默认输入法为android输入法
- <string name=" def_input_method ">com.google.android.inputmethod.latin/com.android.inputmethod.latin.LatinIME</string>
+ <string name=" def_input_method ">com.android.inputmethod.pinyin/.PinyinIME</string>
- <string name="def_enabled_input_methods">com.google.android.inputmethod.latin/com.android.inputmethod.latin.LatinIME</string>
+ <string name="def_enabled_input_methods">com.android.inputmethod.pinyin/.PinyinIME</string>
查看报错信息是权限问题,一直以为是替换apk导致的;
但是查看新旧apk的AndroidManifest都是有定义 INTERACT_ACROSS_PROFILES 权限的;
替换成旧版apk还是有这个报错Failed项;
所以基本确定是第二个对策有关,第二个对策是把默认输入法 google输入法替换成了android pinyin 输入法;
为啥替换了默认输入法,会导致Failed项,这个也是我想不明白的。
可能是这个测试项是有切换用户的,有些配置不同输入法会有影响?
还有可能是系统的pinyin输入法加入了很多定制化修改,多用户切换后,返回的状态异常。
3、解决
手动 默认输入法为Gboard输入法后再测试该项就可以PASS。
4、其他
那可以不可以设置默认输入法就是Gboard,进行解决问题呢?
其实可以的,但是产品不要这个Google输入法为默认输入法,
因为新版本的Google输入法,点击输入框后,默认是左边显示一个悬浮图标,需要点击悬浮图标后才显示键盘;
这个需要用户多操作了一步,不清楚新板Google输入法为啥要这样做。
如果不更新Google输入法可以吗?
不可以,因为旧版本的SDK版本是34,也会报Failed项;
认证的所有apk必须要SDK35以上才行。