作者: James Zwygart 来源:microsoft http://www.csai.cn 2005年11月25日
简介
Microsoft? Windows? CE .NET 测试工具包 (CETK) 是一种可用于测试单个设备驱动程序或整个平台的工具。CETK 中的测试工具会提供有关驱动程序功能的反馈信息,以便进一步提高设备的可靠性。还可以向 Windows CE .NET 测试工具包添加更多的测试,用于测试某个驱动程序。
Windows CE .NET 测试工具包 (CETK) 为 Windows CE .NET 团体提供了通用测试平台,可用于测试基于 Windows CE .NET 的嵌入设备和驱动程序。Windows CE .NET 测试工具包附带的测试与 Microsoft 内部使用的测试相同,用以验证平台和驱动程序的可靠性和稳定性。创建 Windows CE .NET 测试工具包是为了向 OEM 厂商提供快速有效地测试驱动程序的方法。Windows CE .NET 测试工具包的主要目标是:
需要测试和验证设备、BSP 或驱动程序的稳定性和可靠性的任何人都可以使用 CETK。CETK 测试能够确保设备或驱动程序符合稳定性和兼容性的最低标准。使用 CETK 来测试驱动程序或设备的 OEM 厂商可以确保与 Windows CE .NET 操作系统兼容。
Windows CE .NET 测试工具包使用设备端(客户端)和桌面端(服务器)应用程序,它们通过套接字交换信息。Windows CE .NET 设备上运行的客户端可以与主机应用程序交换信息,主机应用程序通常驻留在运行 Windows CE .NET Platform Builder 的开发工作站上。目标设备需要具备有效的以太网和显示器支持,才能运行 Windows CE .NET 测试工具包。
CETK 汲取多年对 Windows CE .NET 的测试经验,向嵌入式开发团体提供了最有价值、最全面、最易于自动化的测试。使测试易于使用又易于理解已成为 CETK 考虑的首要问题。CETK 测试可以验证运行 Windows CE .NET 操作系统的驱动程序和设备是否符合可靠性和稳定性标准。设备的兼容性标准是根据 Standard Development Board (SDB) 规范 (英文)建立的。此规范是为了帮助 OEM 厂商构建与 Windows CE .NET 操作系统兼容的硬件和软件而编写的。Windows CE .NET 测试工具包中的测试有助于确保设备和驱动程序符合此标准。开发人员通常都为新的硬件设计开发自定义的设备驱动程序。CETK 旨在帮助开发人员生成可靠的驱动程序,从而提高设备的可靠性。设计人员一直在努力扩展测试工具包的功能,以使它在测试内容以及调试和交付设备方面更加全面。
CETK 不是于 Windows 硬件质量实验室 ( WHQL [英文]) 的一部分。熟悉 WHQL 的用户会将 CETK 当作适用于 Windows CE .NET 的 WHQL 程序。WHQL 测试被开发成与 Windows 桌面操作系统配合,其体系和结构都与 Windows CE .NET 不兼容,这就是创建 Windows CE .NET 测试工具包的原因。Microsoft 提供了两个与 WHQL 测试有些类似的程序:BSP 认证程序和驱动程序验证程序。这两个程序都使用 CETK 来测试和验证驱动程序和 BSP。
CETK 中目前的测试集涵盖了 Windows CE .NET 中最常用的驱动程序和设备类型。CETK 还在不断地扩展,以包括范围更广的测试。在 CETK 帮助中,对每种测试的测试内容和使用方法都有全面的说明。
Windows CE .NET 测试工具包 - 发布的测试
在平台开发或发布设备的过程中,随时都可以使用测试工具包。CETK 可用于测试系统整体的稳定性,也可用于测试开发中的驱动程序的稳定性。
使用 CETK 之前,需要向平台添加对 CETK 的支持。可以使用以下两种方法:通过从 Platform Builder 目录添加 CETK 组件来向平台添加 CETK 支持,或者在运行 CETK 测试之前将文件复制到平台中。
CETK 要求目标设备与开发工作站所在的网络之间通过以太网连接。不能通过用于调试的以太网连接来运行 CETK 测试。请注意,可以在已作为调试映像生成的 Windows CE .NET 操作系统上运行 CETK 测试。在这种情况下,平台中需要包括完整的网络驱动程序,而不是用于调试的以太网驱动程序。
注意: 要使用 CETK,请不要通过小型内核配置生成平台,因为 CETK 无法在通过小型内核配置生成的平台上运行。
在 Platform Builder 中向平台添加 CETK 测试
注意: 在目录中包括 CETK 组件并不会向操作系统映像添加任何其他文件。某些 CETK 所需的文件将放置在生成发行版文件夹中,包括 clientside.exe 文件。
由于操作系统映像中不包括 CETK 组件,因此必须下载并运行名为 clientside.exe 的客户端 CETK 应用程序。
在操作系统映像中运行 CETK 客户端软件 (clientside.exe)
请注意, Run Programs 对话框将列出在平台的生成发行版文件夹中找到的所有可执行代码。此列表可能包括不属于有效操作系统映像 [nk.bin] 的应用程序。
现在可以在开发工作站上运行 CETK 工具了。
在开发工作站上运行 CETK 工具
在开发工作站上,Clientside.exe 文件位于与目标设备的 CPU 名称相对应的目录中,即 %_WINCEROOT%/Others/Wcetk 目录。
例如,键入 clientside /n=machine1 /p=5555 可以运行 Clientside.exe 可执行文件并连接到使用端口号 5555 的 machine1,还可以编辑 Clientside.exe 文件所在目录中的 Wcetk.txt 文件。如果在生成平台之前向平台添加了 CETK 支持,则 Platform Builder 将在发行版目录中为平台创建一个 Wcetk.txt 文件。
还可以修改目标设备上的以下注册表项:HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/CETT。如果找不到命令行和 Wcetk.txt 文件,Clientside.exe 将从此注册表项中读取设置。如果使用 Windows CE .NET Platform Builder 生成自定义的操作系统映像,则可以通过编辑平台的 product.reg 文件来修改目标设备的注册表,包括 HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/CETT 注册表项。生成操作系统映像时,Product.reg 文件的信息被内置到操作系统中。另外,也可以在目标设备运行时使用远程注册表编辑器工具来修改目标设备的注册表。
所有的工作都将在 CETK 的 PC 端或主机端完成。所有测试都存储在 PC 端,即控制设备的地方。主机端用户界面为用户测试设备提供了简单、灵活的环境,并提供了很多功能帮助您管理单个驱动程序或整个设备的测试。
Test Suite Editor 对话框可用于创建和管理 CETK 的测试套件。测试套件是选出的要进行的测试,存储在 CETK 中,可应用到 CETK 窗口中的任何目标设备。
Test Suite Editor 可用于创建包含要运行的测试的测试套件。可以将测试套件应用到目标设备上,以便自动选择在 Test Suite Editor(测试套件编辑器)中选定的测试,而不必在目标设备上逐一选择测试。
用户还可以更改用于测试的默认命令行,以更改测试的运行方式和测试的内容。每个测试通常都包含很多其他选项,用于添加更多功能测试。
CETK 的设备端称为 Clientside.exe。Clientside.exe 是一个很小的应用程序,负责调用主机以建立连接、检测设备、启动测试并向主机返回结果。
Tux 是一种用于在 Windows CE .NET 设备上编写和执行测试代码的标准方法。Tux 模型的主要组件是可执行文件 tux.exe,该文件负责启动和控制 tux.dll 文件。
CETK 为用户提供了生成自定义测试的所有必要文件和说明,使用 User Test Wizard (可以从主机用户界面访问该向导),可以将这些测试添加到 CETK 中。
Tux 客户端(即 tux.exe)是 Tux 的主要组件。它可以独立运行,也可以与 CETK 结合使用。Tux 客户端是一个控制台应用程序,它采用下面的语法。
tux [-b] [-e] [-s 文件名 | -d 测试 DLL] [-c 参数] [-r 初始化向量] [-x 测试事例] [-l] [-t 地址] [-h] [-k 地址] [-o] [-f 文件名] [-a]
下表显示了各种 Tux 参数。
-b | 加载每个 Tux DLL 后断开。 |
-e | 禁用异常处理。 |
-s 文件名 | 指定要加载/执行的 Tux 套件文件。 |
-d 测试 DLL | 指定要加载/执行的 Tux 测试 DLL。 |
-c 参数 | 要传递给 Tux DLL 的命令行。 |
-r 初始化向量 | 指定起始随机初始化向量。 |
-x 测试事例 | 指定要运行的测试事例。 |
-l | Tux DLL 中所有测试事例的列表。 |
-t 地址 | 指定运行 Tux 服务器的计算机。使用不带参数的 -t 指定本地服务器。 |
-h | 生成 Tux 参数列表。 |
Tux 还可以使用名为 Kato 的 .dll 日志记录文件,该文件用于提供通用日志记录接口。Kato 日志记录引擎 (Kato) 是一个面向对象的 32 位客户端/服务器日志记录引擎,允许应用程序记录到单个接口,并将其输出路由到用户定义的多个输出设备上。Kato 是完全线程安全和进程安全的。Kato 为基于 Windows 的桌面操作系统提供了 ANSI 和 UNICODE 接口。
CETK 自动将 Kato 用作日志记录的方法,以便所有 CETK 测试的结果都相似,从而更加便于理解。
要查看已运行的任何测试的结果,请在该测试上单击右键,然后单击 View Result 。将打开选定测试的最新结果。首先显示的信息是测试摘要。每个测试实际上是一个测试套件;每个套件中的某些测试可能会通过,而其他测试可能会失败。如果套件中的任意一个测试失败,CETK 将使整个测试套件失败。例如,如果在只包含 IPV4 的设备上运行 Winsock 测试,测试将显示为失败;如果查看结果,将看到 2 个测试通过,2 个测试失败。这 2 个失败的测试是由于设备中不包含 IPV6,因此在这种情况下,失败是可以预见的。要使 Winsock 测试完全通过,需要安装 IPV4 和 IPV6。
由于 CETK 中的每个测试都是一个测试套件,因此套件中可能有些测试会失败,有些测试会通过。图 1 显示了 Winsock 测试结果。该 Winsock 测试套件包含四个测试。在此方案中,两个测试通过,两个测试失败。如果选择失败的测试,测试列表下方的窗口将显示该测试的结果。结果将说明所测试的内容以及可能返回的结果。它还提供了测试源,以便进一步研究失败原因。测试源位于 Platform Builder 的最后一张 CD 的 CETK_Sources 文件夹中。也可以从 Web 上下载这些测试,如 Shared Source for the Windows CE .NET 4.1 Test Kit (英文)一文中所述。
图 1:Winsock 测试结果
板卡支持程序包 (BSP) 认证程序的建立,是为了创建用于 Windows CE .NET 的第三方设备和软件的可靠性和稳定性标准。
Microsoft Windows CE .NET BSP 和 CPU 认证计划旨在认证 Windows CE .NET BSP 和 CPU 的兼容性。由 Microsoft 确认的认证具有以下优势:
创建程序的目的是使其简单而有效。CETK 提供了用于认证的所有测试。这样,在将设备或 BSP 送往 Microsoft 进行认证之前,OEM 厂商和设备生产厂商就很容易先对它进行测试。有关该程序的详细信息,请访问 BSP and CPU Certification Process for Windows CE .NET (英文)。
准备提交硬件进行认证时,需要在申请表中填写设备运行的 Windows CE 版本。该表格位于 BSP Certification 网站 (英文)。
请将以下内容提交到下面列出的地址:
Microsoft Corporation
One Microsoft Way
Redmond WA, 98052
ATTN: James Zwygart
如果对 BSP/CPU 认证程序有疑问或意见,请向 [email protected] 发送电子邮件。
进行认证时要执行的测试取决于所提交的设备。由于每个设备的配置可能会有所不同,因此 CETK 将通过自动检测设备上的外围设备来完成大部分工作。验证是否选择了硬件所需的所有可用测试也是非常重要的。
BSP 认证程序使用 CETK 作为测试方法,因此可以用解释 CETK 测试通过或失败的方法来解释其结果。
设备或 BSP 的认证能够确保设备符合 Microsoft 的稳定性和可靠性标准。要了解 Microsoft 设置的基准,请访问 Standard Development Board Specification (英文)。Windows CE 测试工具包遵循标准开发板卡规范,因此可以验证您的板卡支持程序包是否符合标准开发板卡的基准要求。
驱动程序验证程序 (DVP) 旨在为 Microsoft Windows CE .NET 的开发人员、独立硬件供应商 (IHV) 或 OEM 许可证持有者提供验证其驱动程序适用于 Windows CE .NET 操作系统的机会。
此验证程序具有以下优点:
能包括在此列表中,表明通过验证的设备驱动程序符合 Microsoft 标准,与 Windows CE .NET 兼容,有助于树立良好的企业形象。
提交要验证的驱动程序
提交过程非常简单。 Driver Validation Program (英文)网站介绍了提交过程并提供了提交表。
如果要将驱动程序提交到 Microsoft Corporation 以便存储在 Microsoft 网站上并分发给最终用户,则必须将设备驱动程序作为 .msi 文件(通过 Windows CE .NET Platform Builder 创建)提交。还必须为 MSI 程序包中的设备驱动程序创建 .cec 文件。.MSI 和 .cec 文件能够将设备驱动程序更容易地集成到 Platform Builder IDE 目录中,最终用户只需一个单击操作即可完成操作。有关 Platform Builder 中提供的、有助于为设备驱动程序创建 .cec 和 .msi 文件的工具的详细信息,请参阅 Platform Builder 文档中的“Device Driver Integration into the IDE”。 注意: Microsoft 不负责确认驱动程序的最终用户许可条款。您应该在驱动程序文件中包括一个自述文件或最终用户许可协议 (EULA),来规定驱动程序可以在何种情况下使用。您必须完全为您的驱动程序负责。Microsoft 对驱动程序的任何技术或客户支持、更新、市场或其他方面的事宜概不负责。
设备驱动程序的验证能够确保设备驱动程序符合 Microsoft 的稳定性和可靠性标准。要了解 Microsoft 设置的基准,建议您阅读 Windows CE .NET 附带的设备驱动程序文档 (英文)。
Microsoft 致力于提供工具和文档,帮助开发人员构建可靠的设备和设备驱动程序。Microsoft 提供了 BSP 认证程序和驱动程序验证程序,OEM 厂商可以使用这些程序验证设备是否符合 Microsoft 稳定性和可靠性标准。
Microsoft 欢迎广大客户提供有关 BSP 和驱动程序测试工具当前版本的反馈信息。要提供反馈信息,请向以下地址发送电子邮件:
BSP 认证 - [email protected]
驱动程序验证 - [email protected]
有关 Windows CE .NET 的最新信息,请访问 Windows Embedded 网站 (英文)。
Windows CE .NET 附带的联机文档和上下文相关帮助也提供了有关使用 Windows CE .NET 的全面的背景信息和说明。
此外,还可以访问 Windows Embedded 网站 (英文)上有关 Windows CE .NET 的产品文档。