testNG常用用法总结

一.testNG介绍

     TestNG是Java中的一个测试框架, 类似于JUnit 和NUnit,   功能都差不多, 只是功能更加强大,使用也更方便

Java中已经有一个JUnit的测试框架了。  TestNG比JUnit功能强大的多。  测试人员一般用TestNG来写自动化测试。  开发人员一般用JUnit写单元测试。

官方网站: http://testng.org/doc/index.html

二. eclipse中安装testNG

1. 打开Eclipse   Help ->Install New Software ,   然后Add   "http://beust.com/eclipse"

三. testNG最简单的测试

 1 package TankLearn2.Learn;
 2 import org.junit.AfterClass;
 3 import org.junit.BeforeClass;
 4 import org.testng.annotations.Test;
 5 
 6 public class TestNGLearn1 {
 7 
 8     @BeforeClass
 9     public void beforeClass() {
10         System.out.println("this is before class");
11     }
12 
13     @Test
14     public void TestNgLearn() {
15         System.out.println("this is TestNG test case");
16     }
17 
18     @AfterClass
19     public void afterClass() {
20         System.out.println("this is after class");
21     }
22 }
View Code

四.testNG最基本的注解

注解

描述

@BeforeSuite

注解的方法将只运行一次,运行所有测试前此套件中。

@AfterSuite

注解的方法将只运行一次此套件中的所有测试都运行之后。

@BeforeClass

注解的方法将只运行一次先行先试在当前类中的方法调用。

@AfterClass

注解的方法将只运行一次后已经运行在当前类中的所有测试方法。

@BeforeTest

注解的方法将被运行之前的任何测试方法属于内部类的 <test>标签的运行。

@AfterTest

注解的方法将被运行后,所有的测试方法,属于内部类的<test>标签的运行。

@BeforeGroups

组的列表,这种配置方法将之前运行。此方法是保证在运行属于任何这些组第一个测试方法,该方法被调用。

@AfterGroups

组的名单,这种配置方法后,将运行。此方法是保证运行后不久,最后的测试方法,该方法属于任何这些组被调用。

@BeforeMethod

注解的方法将每个测试方法之前运行。

@AfterMethod

被注释的方法将被运行后,每个测试方法。

@DataProvider

标志着一个方法,提供数据的一个测试方法。注解的方法必须返回一个Object[] [],其中每个对象[]的测试方法的参数列表中可以分配。

该@Test 方法,希望从这个DataProvider的接收数据,需要使用一个dataProvider名称等于这个注解的名字。

@Factory

作为一个工厂,返回TestNG的测试类的对象将被用于标记的方法。该方法必须返回Object[]。

@Listeners

定义一个测试类的监听器。

@Parameters

介绍如何将参数传递给@Test方法。

@Test

标记一个类或方法作为测试的一部分。

五. testNG中如何执行测试

1.第一种直接执行:右键要执行的方法,点Run As ->TestNG Test

2. 第二种:  通过testng.xml文件来执行. 把要执行的case, 放入testng.xml文件中。 右键点击testng.xml, 点Run As

1 testng.xml
2 <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
3 <suite name="Suite1">
4     <test name="test12">
5         <classes>
6             <class name="TankLearn2.Learn.TestNGLearn1" />
7         </classes>
8     </test>
9 </suite>
View Code

六.testNG按顺序执行case

1.在testng.xml中,可以控制测试用例按顺序执行。  当preserve-order="true"是,可以保证节点下面的方法是按顺序执行的

 1 <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
 2 <suite name="Suite1">
 3     <test name="test12" preserve-order="true">
 4         <classes>
 5             <class name="TankLearn2.Learn.TestNGLearn1">
 6                 <methods>
 7                     <include name="TestNgLearn3" />
 8                     <include name="TestNgLearn1" />
 9                     <include name="TestNgLearn2" />
10                 </methods>
11             </class>
12         </classes>
13     </test>
14 </suite>
View Code

七. testNG异常测试

测试中,有时候我们期望某些代码抛出异常。

TestNG通过@Test(expectedExceptions)  来判断期待的异常, 并且判断Error Message

 1 package TankLearn2.Learn;
 2 
 3 import org.testng.annotations.Test;
 4 
 5 public class ExceptionTest {
 6     
 7     @Test(expectedExceptions = IllegalArgumentException.class, expectedExceptionsMessageRegExp="NullPoint")
 8     public void testException(){
 9         throw new IllegalArgumentException("NullPoint");
10     }
11 }
View Code

八.testNG组测试

TestNG中可以把测试用例分组,这样可以按组来执行测试用例比如:

 1 package TankLearn2.Learn;
 2 
 3 import org.testng.annotations.Test;
 4 
 5 public class GroupTest {
 6     
 7     @Test(groups = {"systemtest"})
 8     public void testLogin(){
 9         System.out.println("this is test login");
10     }
11     
12     @Test(groups = {"functiontest"})
13     public void testOpenPage(){
14         System.out.println("this is test Open Page");
15     }
16 }
View Code

然后在testng.xml中 按组执行测试用例

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
 3 <suite name="Suite1">
 4     <test name="test1">
 5         <groups>
 6         <run>
 7         <include name="functiontest" />
 8         </run>
 9     </groups>
10     </test>
11 </suite>
View Code

九.testNG参数化测试

软件测试中,经常需要测试大量的数据集。 测试代码的逻辑完全一样,只是测试的参数不一样。  这样我们就需要一种 “传递测试参数的机制”。 避免写重复的测试代码

TestNG提供了2种传递参数的方式。

第一种: testng.xml 方式使代码和测试数据分离,方便维护

第二种:@DataProvider能够提供比较复杂的参数。 (也叫data-driven testing)

方法一: 通过testng.xml 传递参数给测试代码

 1 package TankLearn2.Learn;
 2 import org.testng.annotations.Parameters;
 3 import org.testng.annotations.Test;
 4     
 5 public class ParameterizedTest1 {
 6     
 7     @Test
 8     @Parameters("test1")
 9     public void ParaTest(String test1){
10         System.out.println("This is " + test1);
11     }
12 }
View Code
 1 testng.xml
 2 <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
 3 <suite name="Suite1">
 4         <parameter name="test1" value="Tank" />
 5         <parameter name="test1" value="Xiao" />
 6     <test name="test12">
 7         <classes>
 8             <class name="TankLearn2.Learn.ParameterizedTest1" />
 9         </classes>
10     </test>
11 </suite>
View Code

方式二:   通过DataProvider传递参数

 1 package TankLearn2.Learn;
 2 
 3 import org.testng.annotations.DataProvider;
 4 import org.testng.annotations.Test;
 5 
 6 public class DataProviderLearn {
 7     
 8     @DataProvider(name="user")
 9     public Object[][] Users(){
10         return new Object[][]{
11                 {"root","passowrd"},
12                 {"cnblogs.com", "tankxiao"},
13                 {"tank","xiao"}
14         };
15     }
16     
17     @Test(dataProvider="user")
18     public void verifyUser(String userName, String password){
19         System.out.println("Username: "+ userName + " Password: "+ password);
20     }
21 }
View Code

十.testNG忽略测试

有时候测试用例还没准备好, 可以给测试用例加上@Test(enable = false),  来禁用此测试用例

 1 package TankLearn2.Learn;
 2 
 3 import org.testng.annotations.Test;
 4 
 5 public class TesgNGIgnore {
 6     
 7     @Test(enabled = false)
 8     public void testIgnore(){
 9         System.out.println("This test case will ignore");
10     }
11 }
View Code

十一.testNG依赖测试

有时候,我们需要按顺序来调用测试用例,  那么测试用例之间就存在依赖关系。 TestNG支持测试用例之间的依赖

 1 package TankLearn2.Learn;
 2 
 3 import org.testng.annotations.Test;
 4 
 5 public class DependsTest {
 6     
 7     @Test
 8     public void setupEnv(){
 9         System.out.println("this is setup Env");
10     }
11     
12     @Test(dependsOnMethods = {"setupEnv"})
13     public void testMessage(){
14         System.out.println("this is test message");
15     }
16 }
View Code

十二.testNG测试报告结果

测试报告是测试非常重要的部分.  

TestNG默认情况下,会生产两种类型的测试报告HTML的和XML的。 测试报告位于 "test-output" 目录下.

当然我们也可以设置测试报告的内容级别. 

verbose="2" 标识的就是记录的日志级别,共有0-10的级别,其中0表示无,10表示最详细

1 <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
2 <suite name="Suite1">
3     <test name="test12" verbose="2">
4         <classes>
5             <class name="TankLearn2.Learn.TestNGLearn1" />
6         </classes>
7     </test>
8 </suite>
View Code

 

posted @ 2016-06-18 11:46  li_wu  阅读(18771)  评论(2编辑  收藏