TestNG是一个开源的 自动化测试框架。



Junit最初的设计是用于 单元测试的,TestNG这个测试框架,灵感来源于Junit&Nunit,但是它还引入了很多新的功能。

特点


1·注解


2·java,面向对象


3·支持综合类测试


4·支持多线程



。。。




  • 测试和编写业务逻辑,在代码中插入TestNG的注解.
  • 添加一个testng.xml文件或build.xml中在测试信息(例如类名,您想要运行的组,等..)
  • 运行 TestNG.



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




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





强类型的,所以编译器会标记任何的错误





import org.testng.annotations.Test; 

 

  import org.testng.annotations.BeforeMethod; 

 

  import org.testng.annotations.AfterMethod; 

 

  import org.testng.annotations.BeforeClass; 

 

  import org.testng.annotations.AfterClass; 

 

  import org.testng.annotations.BeforeTest; 

 

  import org.testng.annotations.AfterTest; 

 

  import org.testng.annotations.BeforeSuite; 

 

  import org.testng.annotations.AfterSuite; 

 
 

  public class TestngAnnotation 

 

  {// test case 1 

 

      @Test 

 

      public void testCase1() { 

 

          System.out.println("in test case 1"); 

 

      } 

 
 

 

  // test case 2 

 

      @Test 

 

      public void testCase2() { 

 

      System.out.println("in test case 2"); 

 

      } 

 
 

 

      @BeforeMethod 

 

      public void beforeMethod() { 

 

      System.out.println("in beforeMethod"); 

 

      } 

 
 

 

      @AfterMethod 

 

      public void afterMethod() { 

 

      System.out.println("in afterMethod"); 

 

      } 

 
 

 

      @BeforeClass 

 

      public void beforeClass() { 

 

      System.out.println("in beforeClass"); 

 

      } 

 

       

 

      @AfterClass 

 

      public void afterClass() { 

 

      System.out.println("in afterClass"); 

 

      } 

 
 

 

      @BeforeTest 

 

      public void beforeTest() { 

 

      System.out.println("in beforeTest"); 

 
 

 

      } 

 
 

 

      @AfterTest 

 

      public void afterTest() { 

 

      System.out.println("in afterTest"); 

 

      } 

 
 

 

      @BeforeSuite 

 

      public void beforeSuite() { 

 

      System.out.println("in beforeSuite"); 

 

      } 

 

      @AfterSuite 

 

      public void afterSuite() { 

 

      System.out.println("in afterSuite"); 

 

      } 

 

  }



输出的顺序为



in beforeSuite
in beforeTest
in beforeClass
in beforeMethod
in test case 1
in afterMethod
in beforeMethod
in test case 2
in afterMethod
in afterClass
in afterTest
in afterSuite

===============================================
Suite
Total tests run: 2, Failures: 0, Skips: 0
===========================================





所以可以看到的是beforesuite()只执行一次,beforeTest(),beforeclass()只执行一次


而beforemethod()方法每个测试用例之前都行执行。