三星Galaxy S手机按下“向下”键时窗口管理器崩溃。

6


我使用Instrumentation在各种安卓设备上运行单元测试。测试用例在模拟器和所有设备上都能正常工作,但在三星Galaxy S上会显示一个窗口管理器崩溃,此事发生在注入大约30个按键事件后,以下是完整的崩溃日志:

D/dalvikvm(11862): GC_EXPLICIT freed 6800 objects / 374040 bytes in 54ms
D/dalvikvm(11862): GC_EXPLICIT freed 780 objects / 71856 bytes in 39ms
W/dalvikvm(11862): threadid=9: thread exiting with uncaught exception (group=0x4001d7d0)
E/WindowManager( 2472): Window Manager Crash
E/WindowManager( 2472): java.lang.NullPointerException
E/WindowManager( 2472):         at com.android.server.WindowManagerService$KeyWaiter.waitForNextEventTarget(WindowManagerService.java:5844)
E/WindowManager( 2472):         at com.android.server.WindowManagerService.injectKeyEvent(WindowManagerService.java:5565)
E/WindowManager( 2472):         at android.view.IWindowManager$Stub.onTransact(IWindowManager.java:110)
E/WindowManager( 2472):         at com.android.server.WindowManagerService.onTransact(WindowManagerService.java:692)
E/WindowManager( 2472):         at android.os.Binder.execTransact(Binder.java:288)
E/WindowManager( 2472):         at dalvik.system.NativeStart.run(Native Method)
E/AndroidRuntime(11862): FATAL EXCEPTION: Instr: com.myapp.test.ImpInstrumentation
E/AndroidRuntime(11862): java.lang.NullPointerException
E/AndroidRuntime(11862):        at android.os.Parcel.readException(Parcel.java:1266)
E/AndroidRuntime(11862):        at android.os.Parcel.readException(Parcel.java:1248)
E/AndroidRuntime(11862):        at android.view.IWindowManager$Stub$Proxy.injectKeyEvent(IWindowManager.java:830)
E/AndroidRuntime(11862):        at android.app.Instrumentation.sendKeySync(Instrumentation.java:859)
E/AndroidRuntime(11862):        at android.app.Instrumentation.sendKeyDownUpSync(Instrumentation.java:872)
E/AndroidRuntime(11862):        at com.myapp.test.util.ListUtil.<b>arrowDownToPosition</b>(ListUtil.java:69)

这里是通常导致崩溃的代码段:

    private void arrowDownToPosition(int position) {
          int maxDowns = 50;
        while(mListView.getSelectedItemPosition() < position && --maxDowns > 0) {
             mInstrumentation.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_DOWN);
        }

//Crashes on below line dispatching enter key
      mInstrumentation.sendKeyDownUpSync(KeyEvent.KEYCODE_ENTER);
    }

欢迎提供所有解决方案/建议。

安卓的哪个版本? - Reuben Scratton
@ReubenScratton 关于Android 2.2 - 100rabh
1
很烦人的是,你的堆栈跟2.2.x源代码树都不匹配。很可能是三星进行了定制。 - Reuben Scratton
你有什么想法关于方法waitForNextEventTarget()是做什么的? - 100rabh
你正在注入什么关键序列? - Reuben Scratton
显示剩余3条评论
2个回答

0

不确定这是否有帮助,但在简要研究此问题时,我发现了这个source。请看一下,特别是从第175行开始关于Galaxy S上DPAD_CENTER错误的bug以及如何解决该问题。


谢谢提示,我只在ListView中遇到问题。除了在该ListView上使用KEYPAD_DOWN之外,我没有其他方法移动到特定位置。 - 100rabh
啊,我明白了,我会继续寻找的。 - Mo Kargas

-1
根据您的堆栈跟踪,似乎您的变量 mInstrumentation 为空。您是否忘记初始化它了?
尝试这个:
while(mInstrumentation!=null && mListView.getSelectedItemPosition()>-1) {
    mInstrumentation.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_DOWN);
}

1
不,不是这样的。'mInstrumentation'明显已经被初始化了,因为堆栈跟踪显示异常源自于'sendKeyDownUpSync'方法的子类内部。 - Mark Allison

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接