2分时时彩公式_Java自动化测试框架

  • 时间:
  • 浏览:0
  • 来源:洛叶资源网 - 专注共享简约博客资源

1.简介

现在这篇,或多或少人来学习TestNG.xml文件,前面或多或少人时候 知道,TestNG有时候运行你这些 文件来执行测试用例的。通过本篇,你会进一步了解到:你这些 文件是配置测试用例,测试套件。简单来说,利用你这些 文件,或多或少人还都还里能 都还里能 跑同有另有一个类时候 多个不这类于里面的测试用例。

TestNG通过设置testng.xml文件能做以下事情

1)创建来源不同包、类、法律法律依据的测试套件

2)包括或多或少选项,这类于失败的用例还都还里能 都还里能 重跑。

3)支持使用正则表达式

4)运行把内控 参数传入测试法律法律依据

5)支持配置多线程池池 的执行环境

testNG启发自JUnit和NUnit的有一种测试框架,通过使用testNG使的测试更简单。,比如如下的或多或少特点:

1.通过注释来管理测试

2.多线程池池 并发执行测试,且是安全的

3.支持数据驱动测试

4.支持在简化的平台上使用(Eclipse、IDEA、Maven等)

5.嵌入了BeanShell,使的更具灵活性

6.支持依赖

2.testNG的xml文件的形态

2.1简单的共要 形态如下:

<suite>
 --<test>
 -- --<parameter>
 -- --<test>
 -- -- -- <parameter>
 -- -- -- <groups>
 -- -- -- <classes>

2.2比较完整的形态如下:

<suite>
     <suite-files>
          <suite-file path=""></suite-file>
     </suite-files>
     <parameter name="" value=""></parameter>
     <method-selectors>
          <method-selector>
               <selector-calss name=""></selector-calss>
          </mehod-selector>
     </method-selectors>
     <test name="">
          <parameter name="" value=""><parameter>
          <groups>
               <define name="">
                    <include name=""/>
                    <exclude name=""/>
               </define>
               <run>
                    <include name=""/>
                    <exclude name=""/>
               </run>
          </groups>
          <classes>
               <class name="">
                    <mehods>
                         <parameter name="" value=""></parameter>
                         <include name=""></include>
                         <exclude name=""></exclude>
                    </methods>
               </class>
               <class></class>
          </classes>
          <packages>
               <package name="">
                    <include name=""></include>
                    <exclude name=""></exclude>
               </package>
          </packages>
          <listeners>
               <listener class-name=""/>
          </listenters>
     </test>
     <test></test>
</suite>

3.文档具体的元素说明

3.1<suite>

testNG.xml文件的最外层标签即suite,即测试套件,其下还都还里能 都还里能 有多个<test><groups>,其有几还都还里能 都还里能 还都还里能 打上去的属性

说明:有另有一个xml文件还都还里能 都还里能 有有另有一个<suites>,,是有另有一个xml文件的根级

<suite>由<test>和<parameters>组成

参数说明:

参数 说明 使用法律法律依据 参数值
name 必选项,<suite>的名字,将冒出在reports里 name="XXX" suite名字
junit 是有无执行Junit模式(识别setup()等) junit="true" true和false,默认false
verbose 控制台输出的完整内容等级,0-10级(0无,10最完整) verbose="5" 0到10
parallel 是有无在不同的线程池池 并行进行测试,要与thread-count配套使用 parallel="mehods" 详见表格下内容,默认false
parent-module 和Guice框架有关,只运行一次,创建有另有一个parent injector给所有guice injectors  
guice-stage 和Guice框架有关 guice-stage="DEVELOPMENT" DEVELOPMENT,PRODUCTION,TOOL,默认"DEVELOPMENT"
configfailurepolicy 测试失败后是再次执行还是跳过,值skip和continue configfailurepolicy="skip" skip、continue,默认skip
thread-count 与parallel配套使用,线程池池 池的大小,决定并行线程池池 数量 thread-count="10" 整数,默认5
annotations 获取注解,值为javadoc时,使用JavaDoc的注释;或多或少 用JDK5注释 annotations="javadoc" javadoc
time-out 设置parallel时,终止执行单元时候 的听候时间(毫秒) time-out="500000" 整数,单位毫秒
skipfailedinvocationcounts 是有无跳过失败的调用 skipfailedinvocationcounts="true" true和false,默认false
data-provider-thread-count 并发时data-provider的线程池池 池数量 data-provider-thread-count="5" 整数
object-factory 有另有一个实现IObjectFactory接口的类,实例化测试对象 object-factory="classname" 类名
allow-return-values 是有无允许返回函数值 all-return-values="true" true和false
preserve-order 是有无按照排序执行 preserve-order="true" true和false,默认true
group-by-instances 按照实例分组 group-by-instances="true" true和false,默认false

parallel

该参数的值false,methods,tests,classes,instances。默认false

parallel前要和thread-count配套使用,或多或少 共要 无效参数,thread-count决定了并行测试时开启的线程池池 数量

parallel="mehods"  TestNG将并行执行所有的测试法律法律依据在不同的线程池池 里

parallel="tests"  TestNG将并行执行在同有另有一个<test>下的所有法律法律依据在不同线程池池 里

parallel="classes"  TestNG将并行执行在相同<class>下的法律法律依据在不同线程池池 里

parallel="instances"  TestNG将并行执行相同实例下的所有法律法律依据在不同的县城里

parent-module和guice-stage和Guice框架有关,testNG 6对Guice框架提供了支持,我没用过你这些 框架,时候 这有另有一个参数没看懂╮(╯▽╰)╭

3.2<suite-file>

说明:引入内控 的xml文件(地址由path参数决定,path必填项),将引入的xml与当前的xml文件同时使用

声明法律法律依据:

<suite-files>
     <suite-file path="/path/suitefile1"></suite-file>
</suite-files>

3.3<test>

此标签无有点儿意义,其下还都还里能 都还里能 包括多个标签,如groupsclasses

说明:有另有一个<suite>下还都还里能 都还里能 有多个<test>,还都还里能 都还里能 通过<suite>的parallel="tests"来进行并行测试,前要和thread-count配套使用,或多或少 是无效参数

<test>由<parameters>、<groups>、<classes>三每项组成

参数说明:

参数 说明 使用法律法律依据 参数值
name test的名字,将冒出在报告里 name="testname" test的名字
junit 是有无按照Junit模式运行 junit="true" true和false,默认false
verbose 控制台输出的完整内容等级,0-10级(0无,10最完整),不在 报告显示 verbose="5" 0到10
parallel 是有无在不同的线程池池 并行进行测试,要与thread-count配套使用 parallel="mehods" 与suite的parallel一致,默认false
thread-count 与parallel配套使用,线程池池 池的大小,决定并行线程池池 数量 thread-count="10" 整数,默认5
annotations 获取注解,值为javadoc时,使用JavaDoc的注释;或多或少 用JDK5注释 annotations="javadoc" javadoc
time-out 设置parallel时,终止执行单元时候 的听候时间(毫秒) time-out="500000" 整数,单位毫秒
enabled 标记是有无执行你这些 test enabled="true" true和false,默认true
skipfailedinvocationcounts 是有无跳过失败的调用 skipfailedinvocationcounts="true" true和false,默认false
preserve-order 是有无按照排序执行,时候 是true,将按照xml文件中的顺序去执行 preserve-order="true" true和false,默认true
allow-return-values 是有无允许返回函数值 all-return-values="true" true和false,默认false

3.4<parameter>

说明:提供测试数据,有name和value有另有一个参数

声明法律法律依据:<parameter name = "parameter_name" value = "parameter_value "/>

testng.xml文件中的<parameter>还都还里能 都还里能 声明在<suite>时候 <test>级别,在<test>下的<parameter>会覆盖在<suite>下声明的同名变量

3.5<method-selectors>

说明:法律法律依据选取器定义了那先 类的法律法律依据前要去执行,类前要继承自org.testng.IMethodSelector

声明法律法律依据:

<method-selectors>
     <method-selector>
          <selector-class name="classname" priority="1"></selector-class>
          <script language="java"></script>    (language还还都还里能

都还里能



用beanshell等)
     </method-selector>
</method-selectors>

备注:<method-selectors>你这些 我没用过,时候 了解,时候 有错的欢迎指出来~

3.6<groups>

此标签必然是在<test>标签下的,用于标识那先 组会被用于测试时候 被排除在测试之外,其同级必然要富含 晒 另有一个<classes>标签时候 <pakages>标签,用于指定groups来自于那先 包时候 类

说明:要运行的组,还都还里能 都还里能 自定义有另有一个组,还都还里能 都还里能 包括要执行的,还排除要执行的法律法律依据。前要和<classes>配套使用,从下面的类中找到对应名字的法律法律依据

<groups>由<difine>和<run>、<dependencies>三每项组成。<diffine>还都还里能 都还里能 将group组成有另有一个新组,包括要执行和不执行的大组;<run>要执行的法律法律依据;<dependencies>指定了某group前要依赖的group(比如下面的例子,group1前要依赖group2和group3先执行)。

声明法律法律依据:

<groups>
     <define name ="all">
          <include name ="testgroup1"/>
          <exclude name ="testgroup2'/>
     </define>
     <run>
          <include name ="all"/>
          <include name ="testmethod1"/>
          <exclude name="testmethod2"/>
     </run>
     <dependencies>
          <group name ="group1" depends-on="goup2 group3"/>
     </dependencies>
</groups>

3.7<classes>

说明:法律法律依据选取器,要执行的法律法律依据写在这里,参数有name和priority。

注释:

1.<classes>下前要写要执行的<class>,或多或少 还里能 执行任何内容,时候 填写了class这么写methods,会按照填写的class的下的注释@Test去执行所有的法律法律依据

2.<classes>下的<methods>时候 填写了<include>,那只会执行所填写的法律法律依据,这么填写的法律法律依据还里能 去执行

声明法律法律依据:

<classes>
     <class name="要执行的class名">
          <methods>
               <include name ="要执行的法律法律依据名"></include>
          </methods>
     </class> 
</classes>

3.8<packages>

说明:<packages>指定包名代替类名。查找包下的所有富含 testNG annotation的类进行测试

声明法律法律依据:

<packages>
     <package name="packagename"/>
     <package name="packagename">
          <include name="methodname"/>
          <exclude name="methodname"/>
     </package>
</packages>

3.9<listener>

说明:指定listeners,你这些 class前要继承自org.testng.ITestNGListener。在java中使用@Listeners({com.example.MyListener.class,com.example.MyMethodInterceptor.class})的注释也还都还里能 都还里能 有同样效果

声明法律法律依据:

<listeners>
     <listener class-name="com.example.MyListener"/>
     <listener class-name="com.example.MyMehodIntercepor"/>
</listeners>

4.小结

  好了,今天关于TestNG之xml文件详解篇 ,就分享到这里。