1

对于 DOZE 模式测试,我正在 Android 6.0 上开发示例 GCM 应用程序。

如前所述,在打盹模式下,设备不会为正常优先级 GCM 唤醒。我想检查一下。

根据文档(https://developers.google.com/cloud-messaging/concept-options#setting-the-priority-of-a-message

正常优先。这是消息传递的默认优先级。正常优先级消息不会在睡眠设备上打开网络连接,并且它们的传递可能会延迟以节省电池。对于时间敏感度较低的消息,例如新电子邮件通知或要同步的其他数据,请选择正常传递优先级。

我使用此链接中的一些服务器代码测试了我的应用程序。 https://stackoverflow.com/a/22169411/4242382

我从服务器发送的消息是这样的:

$msg = array
(
    'message'       => 'here is a message. message',
    'title'         => 'This is a title. title',
    'subtitle'      => 'This is a subtitle. subtitle',
    'tickerText'    => 'Ticker text here...Ticker text here...Ticker text here',
    'vibrate'   => 1,
    'sound'     => 1
);

如您所见,没有设置优先级,因此在打盹模式下我不应该立即得到它。但设备仍会立即收到 GCM 消息。

测试方法

  1. 运行基于 GCM 的应用程序
  2. 通过从 adb shell (链接) 发出命令来诱导打盹模式 $ adb shell dumpsys battery unplug $ adb shell dumpsys deviceidle step
  3. 从服务器发送消息(phpfiddle)

预期行为:正常优先级 GCM 没有立即传递 观察到的行为:消息立即传递

DOZE 模式是否按照文档工作?我没有看到它发生,有人面临同样的情况吗?

4

1 回答 1

2

我使用运行 API 23 的模拟器测试了非优先 GCM 消息传递,并观察了记录的行为:当模拟设备处于打盹模式时,消息未传递。退出打盹模式几秒钟后,收到了消息。

我的测试应用是使用 Goggle Play Services 8.3.0 构建的。API 23 的模拟器映像包含旧版本的 Play 服务,当应用程序初始化更新到 8.3.0 时会导致警告。我不知道如何在模拟器上做到这一点。该应用程序成功注册并接收了消息,因此我继续进行测试。

我将模拟设备置于打盹模式:

$ adb shell dumpsys deviceidle enable

并重复:

$ adb shell dumpsys deviceidle step

我按照此处提供curl的说明使用 发送消息。通过观察输出确认消息接收。logcat

生成的deviceidle step命令状态为:IDLE_PENDING、SENSING、IDLE_MAINTENANCE 和 IDLE。除了 IDLE 之外,所有消息都立即收到。未收到在 IDLE 中发送的消息。等待大约一分钟后,deviceidle step用于进入 IDLE_MAINTENACE 状态。在几秒钟内,保留的消息被传递。

两个建议:

  1. 如果您没有使用 Play Services 8.3.0 构建,请更新到该版本。
  2. 使用curl上面链接的说明发送测试消息,看看它是否会产生与您的服务器代码不同的行为。
于 2015-12-03T23:25:35.530 回答