1.はじめに
今、この、我々はすでに知っている私たちの前にTestNG.xmlファイルを学び、TestNGのテストケースを実行するために、このファイルを実行することです。手動により慎重に、あなたはさらに理解することができます:このファイルは、テストケース、テストスイートを構成しています。簡単に言えば、このドキュメントの使用は、我々はより多くのテストケース内部の同じクラスまたは異なるクラスを実行することができます。
testng.xmlファイルを設定することにより、TestNGのは、次のことを行うことができます
1)別のパッケージ、クラス、メソッドのテストスイートソースを作成します。
2)オプションの数を含む、例えば、障害は、実施の形態で再実行してもよいです。
3)正規表現の使用をサポート
4)外部パラメータ渡される試験方法を実行
5)マルチスレッド実行環境の構成をサポートしています
TestNGのテストフレームワークJUnitとNUnitのでかつ容易にTestNGのテストを利用することからインスピレーションを受けています。このような次のような特徴として:
コメントでテストを管理するための1
2.マルチスレッドテストの同時実行し、安全です
3.サポート・データ駆動型テスト
前記プラットフォーム(Eclipseの、IDEA、Mavenの、等)の様々な使用された場合
組み込みBeanShellの、そのような柔軟性
6.サポート依存性
xmlファイルの2.testNGの構造
2.1はおそらく、単純な構造であり、次のとおりです。
< スイート> - < 試験> - - < パラメータ> - - < 試験> - - - < パラメータ> - - - < グループ> - - - < クラス>
次のように詳細な構造の2.2比較です。
< スイート> < スイート-ファイル> < スイートファイルパス= "" > </ スイート-ファイル> </ スイート-ファイル> < パラメータ名= "" 値= "" > </ パラメータ> < メソッドセレクタ> < 方法セレクタ> < セレクタ-calss 名= "" > </ セレクタcalss > </ mehodセレクタ> </ メソッドセレクタ> < テスト名=「」> < パラメータ名= "" 値= "" > < パラメータ> < グループ> < 定義名= "" > < 含める名= "" /> < 除外名= "" /> </ 定義> < 実行> < 含めます名前= "" /> < 除外名= "" /> </ 実行> </ グループ> < クラス> < クラス名= "" > < mehods > < パラメータ名= "" 値= "" > </ パラメータ> < などが名を= "" > </ 含める> < 除外名= "" > </ 除外> </ 方法> </ クラス> < クラス> </ クラス> </ クラス> <パッケージ> < パッケージ名= "" > < 含める名"=" > </ 含める> < 除外名前を"=" > </ 除外>を </ パッケージ> </ パッケージ> < リスナー> < リスナーのクラス名= "" /> </ listenters > </ テスト> < テスト> </ テスト> </ スイート>
3.ドキュメントの特定の要素説明
3.1 <スイート>
タグファイル最外testNG.xml、すなわちsuite
、以下の複数を有することができる試験キット、それ<test>
と<groups>
添加することができるいくつかの特性があること
説明:XMLファイルは一つだけ<スイート>を持つことができますが,,ルートレベルのxmlファイルであります
<スイート> <テスト>と<パラメータ>作曲
パラメータ:
パラメータ | 説明 | 使用 | パラメータ値 |
名前 | 必要に応じ、<スイート>名前がでレポートに表示されます | 名前= "XXX" | スイート名 |
JUnitの | かどうかはJUnitのパターン(認識のセットアップ()、など) | JUnitを= "true" を | trueとfalse、デフォルトはfalse |
冗長 | 0-10スケール(最も詳細0なし10)のコンソールの出力レベルの詳細 | 冗長= "5" | 0-10 |
平行 | 私たちは、スレッドカウントのパッケージを使用するために、並行して別のスレッドでテストされています | パラレル= "mehods" | 表に示されている内容、デフォルトはfalse |
親モジュール | そして、一度だけ実行用のGuiceフレームワークは、すべてのGuiceのインジェクタに親インジェクターを作成します | ||
Guiceのステージ | 用とGuiceのフレームワーク | Guiceのステージ=「開発」 | 開発、生産、ツール、默认 "DEVELOPMENT" |
configfailurepolicy | テストは実行したり、スキップし、値をスキップして続行するかどうかを再度失敗した後、 | configfailurepolicy = "スキップ" | スキップし、引き続き、デフォルトスキップ |
スレッド数 | 並列スレッド・プール・サイズの使用を支持する、並列スレッドの数を決定します | スレッドカウント=「10」 | 整数、デフォルトは5 |
注釈 | javadocツールの値は、Javadocコメントを使用する場合、メモを取得し、それ以外の場合はJDK5でアノテート | 注釈= "javadocを" | javadocツール |
タイムアウト | ときに平行に配置され、終了待機時間(ミリ秒)実行ユニットの前 | タイムアウト=「10000」 | ミリ秒単位の整数 |
skipfailedinvocationcounts | 失敗したコールをスキップするかどうか | skipfailedinvocationcounts = "true" を | trueとfalse、デフォルトはfalse |
データ・プロバイダースレッドカウント | データ・プロバイダ同時スレッドプールの数 | データ・プロバイダースレッドカウント=「5」 | 整数 |
オブジェクト・工場 | IObjectFactoryクラスを実装するインタフェース、テストオブジェクトをインスタンス化 | オブジェクト・ファクトリー=「クラス名」 | クラス名 |
許可リターン値 | 関数の値を返すことができるように | すべてのリターン値=「true」を | 真と偽 |
保存オーダー | かどうかは、ソート | 保存オーダー=「true」を | 真と偽、真のデフォルト |
グループごとのインスタンス | 実施例に係るパケット | グループごとのインスタンス=「true」を | trueとfalse、デフォルトはfalse |
パラメータ、メソッド、テスト、クラス、インスタンスの値False。デフォルトはfalse
平行とスレッドカウントがの使用、または無効なパラメータの等価をサポートである必要があり、スレッドカウントは、スレッドの数は、並列テストを開く決定します
パラレル=別のスレッド内のすべての試験方法の「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>
此标签无特别意义,其下可以包括多个标签,如groups
、classes
等
说明:一个<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="10000" | 整数,单位毫秒 |
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文件详解篇 ,就分享到这里。