testng.xml的格式

简单说明:

测试代码中在需要测试的方法前加上注释符,例如:
package com.yiban.test;
public class test2 {
  @Parameters({ "first-name" }) //参数
  @Test(groups={"g1","g2"}) //组名
  public void test001() throws Exception {
    System.out.println("test001");
  }
}

XML文件写法
<test name="xxxx">
  <!-- 参数定义的方法 -->
  <parameter name="first-name" value="Cedric"/>

  <!-- groups的用法,前提是需要存在classes的组,否则所有方法不被运行 -->
  <groups>
  <!-- 定义组中组的方法 -->
    <define name="groups_name">
      <include name="group1"/>
      <include name="group2"/>
    </define>

    <run>
      <!-- 此处用组名来区别 -->
      <inclue name="groups_name" />
      <exclue name="groups_name" />
      </run>
  </groups>

  <!-- classes的用法,classes中包含类名,类名底下可以包含方法名或排除方法名 -->
  <classes>
    <class name="class1">
      <methods>
        <!-- 此处用方法名来区别 -->
        <inclue name="method_name" />
        <exclue name="method_name" />
      </methods>
    </class>
  </classes>
</test>


以下详细XML规则

-结-构-树

suite
--tests
----parameters
----groups
------definitions
------runs
----classes
--parameters



**suite元素
suite 是testng.xml文档中最上层的元素
< suite (groups?,(listeners|packages|test|parameter|method-selectors|suite-files)*) >

属性: 参数列表(“”中是默认值,CDATA代表字符串)

name suite的名字(他会出现在测试报告中)
junit 是否以junit模式运行
verbose 在控制台中如何输出,这个设置不影响html版本的测试报告
parallel 是否使用多线程测试(可能加速测试)
configfailurepolicy 是否在运行失败了一次后继续尝试或跳过
thread-count 如果设置了parallel,可以设置线程数
annotations 有‘javadoc’的时候寻找,没有的话使用jdk5的注释
time-out   在终止method (如果parallel="methods") 或者test (如果parallel="tests")之前设置以毫秒为单位的等待时间
skipfailedinvocationcounts 是否跳过失败的调用
data-provider-thread-count 提供一个整数线程池的范围为了使用parallel data
object-factory 一个继承IObjectFactory的类,被用来实例化测试对象
allow-return-values 如果设置true,将会运行测试用例并返回值


< suite
name CDATA #必填项
junit (true | false) "false"
verbose CDATA #隐含
parallel (false | methods | tests | classes | instances) "false"
configfailurepolicy (skip | continue) "skip"
thread-count CDATA "5"
annotations CDATA #隐含
time-out CDATA #隐含
skipfailedinvocationcounts (true | false) "false"
data-provider-thread-count CDATA "10"
object-factory CDATA #隐含
group-by-instances (true | false) "false"
preserve-order (true | false) "true"
allow-return-values (true | false) "false"
>


**suite-files元素

一个XML文档的列表包含更多的suite描述

< suite-files (suite-file)* >
< suite-file ANY >

参数列表

< suite-file
path CDATA #必填项
>


**Parameters元素

Parameters 可以在suite或者test级别被定义.
Parameters 定义在test级别时将覆盖sutie级别的同名参数
Parameters 被用来联系java方法参数的实际值,并在这里定义.

< parameter ANY>

参数列表

< parameter
name CDATA #必填项
value CDATA #必填项 >


**method-selectors元素

方法选择器定义了那些方法要运行,他们必须继承org.testng.IMethodSelector

< method-selectors (method-selector*) >
< method-selector ((selector-class)*|script) >
< selector-class ANY>

参数列表:

< selector-class
name CDATA #必填项
priority CDATA #隐含
>

**script元素

< script ANY>

参数列表:

< script
language CDATA #必填项
>


**test元素


一个test包含参数和classes,另外,你可以定义组(组中组)

< test (method-selectors?,parameter*,groups?,packages?,classes?) >

属性:

name test的名字(他会出现在测试报告中)
junit 是否以junit模式运行
verbose 在控制台中如何输出,这个设置不影响html版本的测试报告,默认值: suite 级别的verbose
parallel 是否使用多线程测试(可能加速测试)
thread-count 如果设置了parallel,可以设置线程数
annotations 有‘javadoc’的时候寻找,没有的话使用jdk5的注释
time-out 在终止method (如果parallel="methods") 或者test (如果parallel="tests")之前设置以毫秒为单位的等待时间
enabled 设置是否运行当前test,默认值:true
skipfailedinvocationcounts 是否跳过错误的调用
prserve-order 如果设置true,classes会按照XML文档中的顺序执行
allow-return-values 如果设置true,将会运行测试用例并返回值
 

属性列表:
< test
name CDATA #必填项
junit (true | false) "false"
verbose CDATA #隐含
parallel CDATA #隐含
thread-count CDATA #隐含
annotations CDATA #隐含
time-out CDATA #隐含
enabled CDATA #隐含
skipfailedinvocationcounts (true | false) "false"
preserve-order (true | false) "true"
group-by-instances (true | false) "false"
allow-return-values (true | false) "false"
>


**groups元素
定义包含在测试中要运行的组(组中组)
< groups (define*,run?,dependencies?) >


**define元素
< define (include*)>

属性列表
< define
name CDATA #必填项
>


**include元素
定义组中组
<include ANY>

属性列表
< include
name CDATA #必填项
description CDATA #隐含
invocation-numbers CDATA #隐含>


**exclude元素
定义排除的组
< exclude ANY>

属性列表
< exclude
name CDATA #必填项
>


**run元素
定义那些group需要被运行
< run (include?,exclude?)* >


**dependencies元素

< dependencies (group*)>



**group元素

< group ANY>

属性列表

< group
name CDATA #必填项
depends-on CDATA #必填项
>


**classes元素
包含在此次test中的classes列表
< classes (class*) >



**class元素
< class (methods*) >

属性列表:
< class
name CDATA #必填项 >



**packages元素
包含在此次test中的packages列表
< packages (package*) >



**package元素
如果package名字结尾包含.* ,则所有的子包也被包括其中
< package (include?,exclude?)*>

属性列表:
< package
name CDATA #必填项 
>
 



**methods元素
包含或排除在此次test中的methods列表

< methods (include?,exclude?,parameter?)* >



**listeners元素
将被传给TestNG的监听列表

< listeners (listener*) >



**listener元素

< listener ANY>

属性列表:

<listener
class-name CDATA #必填项
>

猜你喜欢

转载自865325772.iteye.com/blog/2094351
今日推荐