| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> |
| |
| <html> |
| <head> |
| <title>DTD for TestNG 1.0</title> |
| <link rel="stylesheet" href="http://beust.com/beust.css" type="text/css"/> |
| </head> |
| <body> |
| |
| <pre class="code"><span class="xml-comment"><!-- |
| |
| Here is a quick overview of the main parts of this DTD. For more information, |
| refer to the <a <span class="attribute">href="http://testng.org"</span> >main web site<span class="tag"></a>. |
| |
| </span> |
| A <span class="tag"><b>suite</b></span> is made of <span class="tag"><b>tests</b></span> and <span class="tag"><b>parameters</b>. |
| </span> |
| |
| A <span class="tag"><b>test</b></span> is made of three parts: |
| |
| <span class="tag"><ul> |
| <li></span> <span class="tag"><b>parameters</b>,</span> which override the suite parameters |
| <span class="tag"><li></span> <span class="tag"><b>groups</b>,</span> made of two parts |
| |
| <span class="tag"><li></span> <span class="tag"><b>classes</b>,</span> defining which classes are going to be part |
| of this test run |
| <span class="tag"></ul> |
| </span> |
| In turn, <span class="tag"><b>groups</b></span> are made of two parts: |
| |
| <span class="tag"><ul> |
| <li></span> Definitions, which allow you to group groups into |
| bigger groups |
| <span class="tag"><li></span> Runs, which defines the groups that the methods |
| must belong to in order to be run during this test |
| <span class="tag"></ul> |
| </span> |
| Cedric Beust & Alexandru Popescu |
| @title DTD for TestNG |
| @root suite |
| |
| --></span> |
| |
| |
| <span class="xml-comment"><!-- A suite is the top-level element of a testng.xml file --></span> |
| |
| <!ELEMENT suite (listeners|packages|test|parameter|method-selectors|suite-files)* > |
| |
| <span class="xml-comment"><!-- Attributes: --></span> |
| <span class="xml-comment"><!-- |
| @attr name The name of this suite (as it will appear in the reports) |
| @attr junit Whether to run in JUnit mode. |
| @attr verbose How verbose the output on the console will be. |
| This setting has no impact on the HTML reports. |
| @attr parallel Whether TestNG should use different threads |
| to run your tests (might speed up the process) |
| @attr configfailurepolicy Whether to continue attempting Before/After |
| Class/Methods after they've failed once or just skip remaining. |
| @attr thread-count An integer giving the size of the thread pool to use |
| if you set parallel. |
| @attr annotations If "javadoc", TestNG will look for |
| JavaDoc annotations in your sources, otherwise it will |
| use JDK5 annotations. |
| @attr time-out The time to wait in milliseconds before aborting the |
| method (if <span class="attribute">parallel="methods"</span> ) or the test (parallel="tests") |
| @attr skipfailedinvocationCounts Whether to skip failed invocations. |
| @attr data-provider-thread-count An integer giving the size of the thread pool to use |
| for parallel data providers. |
| @attr object-factory A class that implements IObjectFactory that will be used to |
| instantiate the test objects. |
| --></span> |
| <!ATTLIST suite |
| name CDATA #REQUIRED |
| junit (true | false) "false" |
| verbose CDATA #IMPLIED |
| parallel (false | methods | tests | classes) "false" |
| configfailurepolicy (skip | continue) "skip" |
| thread-count CDATA "5" |
| annotations CDATA #IMPLIED |
| time-out CDATA #IMPLIED |
| skipfailedinvocationCounts (true | false) "false" |
| data-provider-thread-count CDATA "10" |
| object-factory CDATA #IMPLIED |
| > |
| |
| <span class="xml-comment"><!-- A list of XML files that contain more suite descriptions --></span> |
| <!ELEMENT suite-files (suite-file)* > |
| |
| <!ELEMENT suite-file ANY > |
| <!ATTLIST suite-file |
| path CDATA #REQUIRED |
| > |
| |
| <span class="xml-comment"><!-- |
| Parameters can be defined at the <span class="tag"><suite></span> or at the <span class="tag"><test></span> level. |
| Parameters defined at the <span class="tag"><test></span> level override parameters of the same name in <span class="tag"><suite> |
| |
| Parameters</span> are used to link Java method parameters to their actual value, defined here. |
| --></span> |
| <!ELEMENT parameter ANY> |
| <!ATTLIST parameter |
| name CDATA #REQUIRED |
| value CDATA #REQUIRED > |
| |
| <span class="xml-comment"><!-- |
| Method selectors define user classes used to select which methods to run. |
| They need to implement <span class="tag"><tt>org.testng.IMethodSelector</tt></span> |
| --></span> |
| <!ELEMENT method-selectors (method-selector*) > |
| |
| <!ELEMENT method-selector ((selector-class)*|script) > |
| <!ELEMENT selector-class ANY> |
| <!ATTLIST selector-class |
| name CDATA #REQUIRED |
| priority CDATA #IMPLIED |
| > |
| <!ELEMENT script ANY> |
| <!ATTLIST script |
| language CDATA #REQUIRED |
| > |
| |
| <span class="xml-comment"><!-- |
| A test contains parameters and classes. Additionally, you can define additional groups ("groups of groups") |
| --></span> |
| |
| <!ELEMENT test (method-selectors?,parameter*,groups?,packages?,classes?) > |
| |
| <span class="xml-comment"><!-- |
| @attr name The name of this test (as it will appear in the reports) |
| @attr junit Whether to run in JUnit mode. |
| @attr verbose How verbose the output on the console will be. |
| This setting has no impact on the HTML reports. |
| Default value: suite level verbose. |
| @attr parallel Whether TestNG should use different threads |
| to run your tests (might speed up the process) |
| @attr thread-count An integer giving the size of the thread pool to be used if |
| parallel mode is used. Overrides the suite level value. |
| @attr annotations If "javadoc", TestNG will look for |
| JavaDoc annotations in your sources, otherwise it will |
| use JDK5 annotations. |
| @attr time-out the time to wait in milliseconds before aborting |
| the method (if <span class="attribute">parallel="methods"</span> ) or the test (if <span class="attribute">parallel="tests"</span> ) |
| @attr enabled flag to enable/disable current test. Default value: true |
| @attr skipfailedinvocationCounts Whether to skip failed invocations. |
| --></span> |
| <!ATTLIST test |
| name CDATA #REQUIRED |
| junit (true | false) "false" |
| verbose CDATA #IMPLIED |
| parallel CDATA #IMPLIED |
| thread-count CDATA #IMPLIED |
| annotations CDATA #IMPLIED |
| time-out CDATA #IMPLIED |
| enabled CDATA #IMPLIED |
| skipfailedinvocationCounts (true | false) "false" |
| > |
| |
| <span class="xml-comment"><!-- |
| Defines additional groups ("groups of groups") and also which groups to include in this test run |
| --></span> |
| <!ELEMENT groups (define*,run?) > |
| |
| <!ELEMENT define (include*)> |
| |
| <!ATTLIST define |
| name CDATA #REQUIRED> |
| |
| <span class="xml-comment"><!-- Defines which groups to include in the current group of groups --></span> |
| <!ELEMENT include ANY> |
| <!ATTLIST include |
| name CDATA #REQUIRED> |
| |
| <span class="xml-comment"><!-- Defines which groups to exclude from the current group of groups --></span> |
| <!ELEMENT exclude ANY> |
| <!ATTLIST exclude |
| name CDATA #REQUIRED> |
| |
| <span class="xml-comment"><!-- The subtag of groups used to define which groups should be run --></span> |
| <!ELEMENT run (include?,exclude?)* > |
| |
| <span class="xml-comment"><!-- The list of classes to include in this test --></span> |
| <!ELEMENT classes (class*) > |
| <!ELEMENT class (methods*) > |
| <!ATTLIST class |
| name CDATA #REQUIRED > |
| |
| <span class="xml-comment"><!-- The list of packages to include in this test --></span> |
| <!ELEMENT packages (package*) > |
| |
| <span class="xml-comment"><!-- The package description. |
| If the package name ends with .* then subpackages are included too. |
| --></span> |
| <!ELEMENT package (include?,exclude?)*> |
| <!ATTLIST package |
| name CDATA #REQUIRED > |
| |
| <span class="xml-comment"><!-- The list of methods to include/exclude from this test --></span> |
| <!ELEMENT methods (include?,exclude?)* > |
| |
| <span class="xml-comment"><!-- The list of listeners that will be passed to TestNG --></span> |
| <!ELEMENT listeners (listener*) > |
| |
| <!ELEMENT listener ANY> |
| <!ATTLIST listener |
| class-name CDATA #REQUIRED > |
| </pre> |