前提条件

  • 在开始通过通讯报文创建参数化的测试客户端或消息响应器之前,您的团队必须已安装并正在运行数据资源库服务器。详情请参阅 安装远程数据资源库服务器
  • 消息内容必须是格式良好的(例如,如果是 XML,它必须是格式良好的;如是 EDI,它必须是有效的 EDI,等);否则,可能无法从通讯报文中自动创建测试。SOAP 消息和/消息响应器必须只有一个顶级 XML 元素。
  • 消息分组选项,注意数据资源库不支持具有混合类型的 JSON 数组的参数化。  如果 JSON 数组不是混合类型,那么 SOAtest 或 Virtualize 将假设数组中的所有元素都与第一个元素的类型相同。

监控控制台视图

当从通讯报文中创建测试和/或消息响应器时,保持控制台视图可见会很有帮助。此视图将显示在处理通讯报文文件时生成的任何警告、错误和信息消息。

使用向导

  1. 在可用的创建向导中选择通讯报文> 生成参数化的消息选项。更多详情,请参阅以下章节: 

    添加项目、虚拟资产和响应器套件

  2. 在通讯报文向导中指定以下信息,然后点击下一步
    1. 指定通讯报文文件的位置。
    2. 如果需要,请更改字符编码
    3. 如果要用保存在模板中的前一组设置填充向导,请输入该模板的位置。

      有关在 Virtualize 中创建和使用模板的详情,请参阅使用配置模板重用和共享向导设置

  3. 在 Parasoft 数据资源库设置页面中,指定哪个数据资源库应该存储用于参数化测试客户端或消息响应器,然后点击下一步。 

    • 服务器字段中,指定要连接的服务器(嵌入式服务器或远程服务器)。如果选择嵌入式服务器,端口用户密码字段将灰显。如果选择远程服务器,端口、用户和密码字段将自动填充,并且可根据需要进行调整。

    • 资源库名称字段中,选择或输入要使用的资源库的名称。如果输入新资源库的名称,将创建该资源库。
    • 定义资源库连接时,可以通过点击 Validate 检查连接。 

  4. 在消息格式和分组策略 界面配置设置:


    1. 验证请求消息格式响应消息格式是否设置正确。如果没有,请选择适当的格式。Virtualize 将尝试根据通讯报文文件中的第一条消息来标识请求和响应的消息格式。单个通讯报文文件中的所有请求都应具有一种格式,而同一文件中的所有响应都应具有一种格式。请求格式可能不同于请求格式。如果未检测到消息格式,则将选择纯文本。

    2. 转换选项可用于某些格式,如 EDI 或自定义格式。点击转换选项按钮并进行所需的更改。 


    3. 选择其中一项消息分组选项:

      • 基于操作/类型:根据操作或消息类型对消息进行分组。这对于包含可以通过操作或格式的消息类型(即,SOAP 主体下元素的名称、纯 XML 消息中根元素的名称或指定消息格式的消息类型)。为在通讯报文文件中发现的每个操作/类型生成一个响应器。如果选择此选项,Virtualize 将根据对通讯报文文件的分析,提供分组启发式方法建议。您可以更改预先选择的启发式方法。有关启发式方法的更多信息,请参阅了解按操作类型分组的启发式方法

      • 基于类似请求:根据请求消息结构对消息进行分组。这告诉 Virtualize 分析请求消息结构并将请求/响应分组到响应器中,以便每个响应器将包含与具有类似结构的请求相关的响应。当消息具有相同的 DOM 树模型时,即使它们具有不同的值,也会被认为“类似”。此选项用于优化和简化将请求与每个消息响应器中的响应关联的规则。
      • 基于类似响应: 根据响应消息结构对消息进行分组。这告诉 Virtualize 分析响应消息结构并将请求/响应对分组到响应器中,以便每个响应器将包含具有类似结构的响应。当消息具有相同的 DOM 树模型时,即使它们具有不同的值,也会被认为“类似”。

      • 无:没有分组。为通讯报文文件中的每个响应消息生成一个响应器。如果想让每个请求/响应对位于单独的消息响应器中,请使用此选项。


  5. 点击下一步并在消息分组审查界面审查有关操作和邮件的信息。 
    1. 包括的列基于所应用的分组策略。 
    2. 每个表行表示定义一个组的标准。将为每个表行生成一个组。将为每个组生成一个响应器。 
    3. 关联性标准将按它们在表中的显示顺序(从上到下)进行处理。 

      有关如何创建这些分组的详情,请参阅了解按操作类型分组的启发式方法

    1. 使用可用的控件添加、修改、重新排序和删除分组条件。 

      有关在 Virtualize 中配置分组条件的详情,请参阅自定义分组标准

      如果更改条件,请确保在继续之前点击重组

    2. 如果选中了所有自动配置框,并且希望 Virtualize 自动为指定组配置邮件响应器,则可以跳过此步骤

      如果要执行以下任何任务,请为要自定义的每个消息组禁用自动配置,点击下一步,然后按照中所述配置请求映射定制请求匹配和关联

      • 自定义应该使用哪些参数值确定虚拟资产的响应消息 
      • 修改自动的请求/响应对匹配 
      • 指定 WSDL 或模式

      当消息组中有多个请求且路径、参数或主体存在差异时,自动配置通常可用。如果自动配置框灰显,则表示该组无法使用自动配置;有关为何无法自动配置特定组的更多详细信息,请参阅该项目的工具提示。



      有关面板顶部列出的任何项目(处理对、未处理对、与组不匹配的消息等),请点击关联的超链接。



      要查看与特定响应者相关的消息和/或更改响应者和数据集名称,请点击计数列中的相关行。



  6. 点击下一步,然后在请求匹配界面配置设置。

    1. 点击请求/响应对,并验证是否已建立正确的关联性。您可以点击并拖动连接请求和响应的点以更改匹配。
    2.  点击请求关联性选项,然后在下拉菜单中选择一种响应器模式。 
  7. 以及在数据复用界面中配置导入的通讯报文应如何复用或如何影响现有数据。
    1. 定义的记录标识用于确定哪些数据是新的,哪些新记录与现有记录匹配。如果尚未为此数据集指定标识,则可以在此页面的数据树中添加/修改标识此页。 
    2. 树用绿色箭头图标指示标识字段。现有的数据集用注释标注。
    3. 您可以控制通讯报文文件的数据将如何扩展和/或更新现有资源库数据集。 

    4. 还可以控制匹配的数据(匹配现有的记录类型,由标识定义)是否重新使用现有的记录类型或更新现有的记录。复用选项允许您复用/共享匹配的现有记录。更新选项允许您使用来自通讯报文的数据更新现有记录相对应的字段,并为新的记录类型添加新记录。
       

      Virtualize 选项

      替换:删除现有数据,然后添加新数据。

      合并:在无需修改现有数据的情况下,导入新数据。

      更新:使用新数据更新匹配的记录,并根据需求创建新记录。

      覆盖:使用新数据更新匹配的记录(匹配键),不创建其他记录。


      针对 Virtualize,请参阅配置数据复用和更新

    5. 推断约束从选项允许 Virtualize 确定资源库中存储的数据的特征。可以根据数据或服务定义推断约束。
  8. 点击下一步并在最终选项界面指定其他配置:
    1. 您可以将向导配置为以表单或字面量模式创建消息。这些模式显示一个表单输入视图(请参阅表单输入)或字面量视图(请参阅字面量)。   
    2. 可启用导出配置数据到一个可重用模板选项,并指定文件名和位置以将在此向导中使用的设置保存为模板。 

      如果要在 Virtual Assets 文件夹中创建 .pva,以实现自动部署,请通过为要创建的虚拟资产指定所需的名称和部署路径来完成部署虚拟资产向导页面,然后点击下一步。虚拟资产将部署在列出的端点。详情请参阅配置单个虚拟资产部署设置

    3. 点击完成

将创建和配置以下项目:

    如果在虚拟资产文件夹中创建 .pva,则在向导完成时,虚拟资产将自动部署到本地 Virtualize 服务器。否则,可以手动将其部署到本地或远程服务器。

    有关如何编辑和扩展存储在数据资源库中的数据的详细信息,请参阅查看和修改资源库结构和内容

    请注意,通讯报文文件中存在的自定义传输头和任何 SOAP 头(例如,WS-Security 头)不会自动配置到生成的资产或数据资源库数据集中。您可以在生成的消息响应器中指定它们

     (详情请参阅消息响应器概要

    部署虚拟资产

    如果在虚拟资产文件夹中创建 .pva,则在向导完成时,虚拟资产将自动部署到本地 Virtualize 服务器。否则,您可以随时将其部署到本地或远程服务器。

    有关部署过程和选项的详情说明,请参阅部署虚拟资产 - 概要

    自定义虚拟资产

    有关如何自定义消息响应器行为的详情,请参阅消息响应器概要

     了解选择/扩展类型支持

    如果在向导的末尾没有输入 WSDL 或模式文件,Virtualize 将使用录制的通讯报文的数据结构来创建数据资源库。当一个元素的数据结构在录制的通讯报文中发生变化时,该元素的类型很可能是基础架构中的一个选项。但是,向导并不显式支持选择类型;它将元素的数据结构解释为所有可能的子元素的序列。

    例如,假设一个元素的实际架构如下:


    <element name="parent">
        <complexType>
            <choice minOccurs="0" maxOccurs="unbounded">
                <element name="child1"/> 
                <element name="child2"/> 
                <element name="child3"/>
            </choice>
        </complexType> 
    </element>


    Virtualize 将使用以下数据结构表示元素:


    <element name="parent">
        <complexType>
            <sequence>
                <element name="child1" minOccurs="0" maxOccurs="unbounded"/> 
                <element name="child2" minOccurs="0" maxOccurs="unbounded"/> 
                <element name="child3" minOccurs="0" maxOccurs="unbounded"/>
            </sequence>
        </complexType> 
    </element>


    尽管所录制的通讯报文可能具有以不同顺序出现的子元素(例如,响应消息中的一个“parent”有一个“child1”,然后再是“child2”,而另一个响应消息中的“parent”有一个“child2”,然后才是“child1”),Virtualize 将以固定顺序参数化消息数据。因此,在本例中,元素“child1”和“child2”在响应消息中的顺序始终相同。

    完成 Virtualize 向导:进阶主题

    以下主题提供了帮助您完成向导的其他详细信息:

    视频教程:从使用消息代理录制的通讯报文中创建虚拟资产

    在本视频中,您将学习如何从一个使用消息代理录制的通讯报文创建一个虚拟资产。

  • No labels