测试UI testing-your-ui

NOTE
从AEM 6.5开始,弃用hobbes.js UI测试框架。 Adobe不打算进一步增强其功能,因此建议客户使用Selenium自动化功能。
请参阅 已弃用和已删除的功能.

AEM提供了一个用于实现AEM UI测试自动化的框架。 使用该框架,您可以直接在Web浏览器中编写和运行UI测试。 该框架提供了用于创建测试的JavaScript API。

AEM测试框架使用Hobbes.js,这是一个使用JavaScript编写的测试库。 Hobbes.js框架是在开发过程中为测试AEM而开发的。 该框架现在可供公众用于测试您的AEM应用程序。

NOTE
请参阅Hobbes.js 文档 以了解API的完整详细信息。

测试结构 structure-of-tests

在AEM中使用自动测试时,请务必了解以下术语:

操作
An 操作 是网页上的特定活动,例如单击链接或按钮。
测试用例
A 测试用例 是一种特定情况,可以由一个或多个组成 操作.
测试套件
A 测试套件 是一组相关 测试用例 共同测试特定用例。

执行测试 executing-tests

查看测试包 viewing-test-suites

打开测试控制台以查看已注册的测试包。 测试面板包含测试套件及其测试用例的列表。

通过以下方式导航到“工具”控制台 全局导航>工具>操作>测试.

chlimage_1-63

打开控制台时,左侧列出测试包,并附带按顺序运行所有测试包的选项。 带有方格背景的右侧显示的空间是一个占位符,用于在测试运行时显示页面内容。

chlimage_1-64

运行单个测试套件 running-a-single-test-suite

测试包可以单独运行。 运行测试包时,页面会随着测试用例及其操作的执行而更改,并且在测试完成后显示结果。 图标指示结果。

复选标记图标表示已通过测试:

复选标记图标。

“X”图标表示测试失败:

圆圈内由X指示的失败测试图标。

要运行测试套件,请执行以下操作:

  1. 在测试面板中,单击要运行的测试用例的名称以展开操作的详细信息。

    chlimage_1-65

  2. 单击 运行测试.

    “运行测试”按钮的图像,由圆圈内面向右侧的指针指示。

  3. 测试执行时,占位符会被替换为页面内容。

    chlimage_1-66

  4. 通过点按或单击描述以打开测试用例的结果 结果 面板。 在中点击或单击测试用例的名称 结果 面板显示所有详细信息。

    chlimage_1-67

运行多个测试 running-multiple-tests

测试包将按照它们在控制台中的显示顺序依次执行。 您可以深入到测试中查看详细结果。

chlimage_1-68

  1. 在测试面板上,单击 运行所有测试 按钮或 运行测试 按钮时,单击要运行的测试包标题下方的“测试包”按钮。

    “Run all tests(运行所有测试)”按钮和“Run tests(运行测试)”按钮的图像,由圆圈内面向右侧的指针指示。

  2. 要查看每个测试用例的结果,请单击测试用例的标题。 单击中测试的名称 结果 面板显示所有详细信息。

    chlimage_1-69

创建和使用简单测试套件 creating-and-using-a-simple-test-suite

以下过程会引导您使用创建和执行测试包 We.Retail内容,但您可以轻松修改测试以使用其他网页。

有关创建您自己的测试包的完整详细信息,请参阅 Hobbes.js API文档.

  1. 打开CRXDE Lite。 (https://localhost:4502/crx/de)

  2. 右键单击 /etc/clientlibs 文件夹并单击 “创建”>“创建文件夹”. 类型 myTests 名称,然后单击 确定.

  3. 右键单击 /etc/clientlibs/myTests 文件夹并单击 创建>创建节点. 使用以下属性值,然后单击 确定

    • 名称:myFirstTest
    • 类型:cq:ClientLibraryFolder
  4. 将以下属性添加到myFirstTest节点:

    table 0-row-3 1-row-3 2-row-3
    名称 类型 价值
    categories 字符串[] granite.testing.hobbes.tests
    dependencies 字符串[] granite.testing.hobbes.testrunner
    note note
    NOTE
    仅限AEM Forms
    要测试自适应表单,请将以下值添加到类别和依赖关系中。 例如:
    类别granite.testing.hobbes.tests, granite.testing.hobbes.af.commons
    依赖关系granite.testing.hobbes.testrunner, granite.testing.hobbes.af
  5. 单击​ 全部保存

  6. 右键单击 myFirstTest 节点并单击 “创建”>“创建文件”. 命名文件 js.txt 并单击 确定.

  7. js.txt 文件,输入以下文本:

    code language-none
    #base=.
    myTestSuite.js
    
  8. 单击 全部保存 然后关闭 js.txt 文件。

  9. 右键单击 myFirstTest 节点并单击 “创建”>“创建文件”. 命名文件 myTestSuite.js 并单击 确定.

  10. 将以下代码复制到 myTestSuite.js 文件,然后保存文件:

    code language-none
    new hobs.TestSuite("Experience Content Test Suite", {path:"/etc/clientlibs/myTests/myFirstTest/myTestSuite.js"})
       .addTestCase(new hobs.TestCase("Navigate to Experience Content")
          .navigateTo("/content/we-retail/us/en/experience/arctic-surfing-in-lofoten.html")
       )
       .addTestCase(new hobs.TestCase("Hover Over Topnav")
          .mouseover("li.visible-xs")
       )
       .addTestCase(new hobs.TestCase("Click Topnav Link")
          .click("li.active a")
    );
    
  11. 导航至 测试 控制台以试用您的测试套件。

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2