欢迎使用 Google Home 开发者中心,您可以在这里学习有关如何开发智能家居 Action 的新平台。注意:你将继续在 Actions 控制台中构建操作。

Google Home 测试套件

使用集合让一切井井有条 根据您的偏好保存内容并对其进行分类。

Google Home Test Suite 是一款 Web 应用,可让你自行测试智能家居 Action。Test Suite 会根据与您的帐号关联的设备和特征自动生成和运行测试用例。完成测试后,您可以查看测试结果,或填写提交表单以向 Google 提交测试结果。

Test Suite 执行的测试包括但不限于:

  • 检查是否已针对您的设备和特征实现报告状态请求同步

  • 验证是否已针对您的设备实现 QUERY intent,并且结果是否与报告状态结果匹配。

您可以点击下面的按钮启动 Test Suite 工具:

启动 Test Suite

自行测试你的 Action

以下部分介绍了如何在设备和智能家居 Action 项目上运行 Test SuiteTest Suite 要求您登录帐号,以便它可以检查 Google Home Graph 中的设备并将命令直接发送到 Google Assistant

如需自行测试你的 Action,请按以下步骤操作:

  1. 在网络浏览器中,打开 Test Suite
  2. 使用右上角的按钮登录 Google。

  3. 配置项目详情

    1. Project ID 字段中,输入智能家居 Action 的项目标识符。
    2. 点击下一步
  4. 配置测试设置

    1. 如果你对智能家居 Action 进行了认证,请保留默认的报告状态/请求同步超时值。不过,为了进行测试,如果您的代理需要更多时间向 Home Graph 报告状态,您可以更改超时值。
    2. 如果要认证智能家居 Action,请确保已启用测试请求同步选项。在测试期间,系统会提示您添加、更新或移除设备,并检查 Home Graph 中设备列表是否已更改。更改操作通过您正在测试的集成进行。接受测试的集成必须始终至少有一个设备连接到代理用户。

    3. 如果您使用的是场景特征,请选择测试场景特征

    4. 如果您运行的是 Local Home 设备的测试套件,请选择 Supports Local Home SDK

      1. 选择 Local FulfillmentSeamless Setup
      2. 如果设备可以在本地处理 QUERY intent,请点击 Support Local Query
  5. 执行 Test Run 并查看结果:

    1. 点击下一步以开始运行测试。界面会显示受测设备和特征。
  6. 查看结果和提交内容页面:

    1. 测试完成后,点击下一步以查看结果。

测试结果包括通过和失败的测试数量,以及表明通过百分比的最终得分。

帐号关联验证测试

帐号关联在 Google 智能家居生态系统中发挥着重要作用。Test Suite 中的帐号关联验证测试会检查您的 OAuth 服务是否存在潜在问题。

帐号关联验证测试包含用于验证访问令牌刷新令牌的测试:

访问令牌验证测试

系统会测试从令牌交换端点返回的访问令牌,以确保这些令牌具有有效的格式,并随有效的刷新令牌返回。

测试项 说明
检查访问令牌是否为 JWT 格式 Google 帐号关联不建议使用 JWT 格式的访问令牌。如果发现 JWT 格式,系统会显示以下警告: The access token seems to be JWT, this is not good. Because it unnecessarily exposes information about partner implementation and we recommend opaque symmetric encrypted access token.
检查过期的访问令牌是否有刷新令牌。 当访问令牌过期时,必须提供刷新令牌。如果找不到刷新令牌,此测试将失败。

刷新令牌验证测试

系统会测试刷新令牌,以确保您的令牌交换端点能正确将其交换为新的访问令牌。

测试项 说明
具有无效刷新令牌的刷新令牌,正在检查合作伙伴响应。 您的服务器应向无效的刷新令牌请求返回包含 {"error": "invalid_grant"} 的 HTTP 400 Bad Request 错误。 如果响应与“错误代码或消息”不匹配,则此测试用例将失败。如需了解详情,请参阅使用刷新令牌交换访问令牌
测试访问令牌刷新后是否已更新访问令牌。 应返回新的访问令牌以响应刷新令牌请求。如果您的服务器提供相同的访问令牌,则测试用例将失败。
检查未过期的访问令牌是否仍然有效。 系统会显示访问令牌过期时间。
在刷新期间检查刷新令牌是否已轮替。 我们检查刷新令牌请求之后是否更改了刷新令牌。如果刷新令牌发生更改,则只有在使用完新的刷新令牌后,您的服务器才应使旧的刷新令牌失效,以防出现竞态条件可能破坏用户的帐号关联。如果您在使用新刷新令牌之前使其失效,则测试将失败。

错误消息

下表列出了您可能会遇到的一些常见错误消息以及建议的解决方法。

错误消息 解决方法
之前未在项目 <_id_> 中使用过 HomeGraph API,或者该 API 已停用 确保您已启用 HomeGraph API
找不到请求的实体 请检查您的 agentUserId 是否有效以及是否已与您的服务相关联。
请确保您对项目 ${your project id} 拥有 resourcemanager.projects.get 权限,并且已在同意屏幕中授予所有权限。
  1. 按照排查 IAM 权限中的说明,确保您的帐号拥有项目的 resourcemanager.projects.get 权限。
  2. 前往有权访问您帐号的应用页面,查看“智能家居测试套件”的以下权限:
    • 基本帐号信息
      1. 查看您 Google 帐号的主电子邮件地址
      2. 查看您的个人信息,包括您已公开的任何个人信息
    • 其他访问权限
      1. 使用您的 Assistant:对您的 Google 帐号拥有较完整的访问权限
      2. 在 Home Graph 中检查和控制智能家居设备
    如果缺少任何用户,请先移除访问权限,然后重新登录时在同意屏幕授予所有权限。

提交测试结果

您的 Test Suite 结果必须通过 100% 的测试,然后才能提交认证表单。如果您有任何需要手动测试的特征,您仍然应该运行 Test Suite 工具并附加结果,即使结果尚未达到 100%。

如需提交你的测试结果并验证智能家居 Action,请按以下步骤操作:

  1. 收到测试结果并准备好对智能家居 Action 进行认证后,请点击 Test Suite 工具中的提交
  2. 点击下载测试结果按钮,以检索您的测试结果。
  3. 点击前往提交表单,向 Google 提交测试结果。
  4. 填写所有必填字段,然后点击提交