发现自己从android源代码编译出来的系统(跑在模拟器上)在用telnet提供的功能
测试电话流程时有问题。
用adb logcat一看,发现Phone模块死在这个位置
if (!provisioned) {
Log.i(LOG_TAG, "CallNotifier: rejecting incoming call: device isn't
provisioned");
往上看一个,原来是
boolean provisioned =
Settings.Secure.getInt(mPhone.getContext().getContentResolver(),Settings.Secure.DEVICE_PROVISIONED, 0) != 0;
条件不满足。
看到一个getContentResolver莫非是数据库里没有这个号码信息?
用sqlite3对比一下源代码编译出来的和SDK(可以用telnet测试电话流程)的,发
现一样的。
看来不是这个问题。
琢磨一下,觉得和DEVICE_PROVISIONED相关的地方无非就是在packages,
framework 或者 development里面。
果然,在development里面发现一个叫SdkSetup的程序,
Settings.Secure.putInt(getContentResolver(),
Settings.Secure.DEVICE_PROVISIONED, 1);
头上这句注释告诉我一切真相
// Add a persistent setting to allow other apps to know the device has
been provisioned.
ok,解决方案如下
手动安装SdkSetup到你的模拟器里面,然后重新启动模拟器。搞定!
模拟器上调试android电话模块流程的一般方法,
1) 启动android模拟器
2) 启动adb logcat 或者 ddms
3) 另开shell,运行 telnet localhost 5554
4) 利用telnet 发送命令给手机模拟器
5)利用logcat跟踪流程。
阅读(2972) | 评论(1) | 转发(0) |