JUnit让开发人员了解测试的实用性,尤其是在单元测试这一模块上比任何其他测试框架都要简单明了。凭借一个相当简单,务实,严谨的架构,JUnit已经能够“感染”了一大批开发人员。TestNG是一个测试框架,其灵感来自JUnit和NUnit,但引入了一些新的功能,使其功能更强大,使用更方便。

一:注解的使用

import org.testng.annotations.AfterClass;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.AfterSuite;
import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.BeforeSuite;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test; public class Annotation { @Test
public void testCase1(){
System.out.println("测试用例1被执行");
} @Test
public void testCase2(){
System.out.println("测试用例2被执行");
} @BeforeMethod
public void beforeMethod(){
System.out.println("@BeforeMethod:在每个测试方法开始运行前执行");
} @AfterMethod
public void afterMethod(){
System.out.println("@AfterMethod:在每个测试方法开始运行结束后执行");
} @BeforeClass
public void beforeClass(){
System.out.println("@BeforeClass:在当前测试类的第一个测试方法开始调用前执行");
} @AfterClass
public void afterClass(){
System.out.println("@AfterClass:在当前测试类的最后一个测试方法结束运行后执行");
} @BeforeTest
public void beforeTest(){
System.out.println("@BeforeTest:在测试类中的Test开始运行前执行");
} @AfterTest
public void afterTest(){
System.out.println("@AfterTest:在测试类中的Test运行结束后执行");
} @BeforeSuite
public void beforeSuite(){
System.out.println("@BeforeSuite:在当前测试集合(suite)中所有测试程序开始运行之前执行");
} @AfterSuite
public void afterSuite(){
System.out.println("@AfterSuite:在当前测试集合(suite)中所有测试程序运行结束之后执行");
}
}

运行结果:

@BeforeSuite:在当前测试集合(suite)中所有测试程序开始运行之前执行
@BeforeTest:在测试类中的Test开始运行前执行
@BeforeClass:在当前测试类的第一个测试方法开始调用前执行
@BeforeMethod:在每个测试方法开始运行前执行
测试用例1被执行
@AfterMethod:在每个测试方法开始运行结束后执行
@BeforeMethod:在每个测试方法开始运行前执行
测试用例2被执行
@AfterMethod:在每个测试方法开始运行结束后执行
@AfterClass:在当前测试类的最后一个测试方法结束运行后执行
@AfterTest:在测试类中的Test运行结束后执行
PASSED: testCase1
PASSED: testCase2

===============================================
    Default test
    Tests run: 2, Failures: 0, Skips: 0
===============================================

@AfterSuite:在当前测试集合(suite)中所有测试程序运行结束之后执行

===============================================
Default suite
Total tests run: 2, Failures: 0, Skips: 0
===============================================

二:依赖测试

import org.testng.annotations.Test;
public class DependentTest { /**
* TestNG 依赖测试(使用dependsOnMethods参数实现)
* 有时候需要按顺序来调用测试用例, 那么测试用例之间就存在依赖关系
* 通过依赖测试,可以在不同的方法间共享数据和程序状态
*/ // dependsOnMethods={"OpenBrowser"} 表示在OpenBrowser方法被调用后才能执行login方法
@Test(dependsOnMethods={"OpenBrowser"})
public void login(){
System.out.println("login方法被调用");
} @Test
public void OpenBrowser(){
System.out.println("OpenBrowser方法被调用");
} // dependsOnMethods={"login"} 表示在login方法被调用后才能执行logout方法
@Test(dependsOnMethods={"login"})
public void logout(){
System.out.println("logout方法被调用");
}
}

运行结果:

OpenBrowser方法被调用
login方法被调用
logout方法被调用
PASSED: OpenBrowser
PASSED: login
PASSED: logout

===============================================
    Default test
    Tests run: 3, Failures: 0, Skips: 0
===============================================

三:按特定顺序执行测试

import org.testng.annotations.Test;

public class SequenceTest {
/**
* 使用priority参数,可以按特定顺序执行测试
*/ @Test(priority=2)
public void test3(){
System.out.println("test3方法被调用");
} // enabled=false 跳过这个测试方法
@Test(priority=1,enabled=false)
public void test2(){
System.out.println("test2方法被调用");
} @Test(priority=0)
public void test1(){
System.out.println("test1方法被调用");
} @Test(priority=3)
public void test4(){
System.out.println("test4方法被调用");
} }

运行结果:

test1方法被调用
test3方法被调用
test4方法被调用
PASSED: test1
PASSED: test3
PASSED: test4

===============================================
    Default test
    Tests run: 3, Failures: 0, Skips: 0
===============================================

四:测试集合,通过testng.xml方式来执行测试用例

<suite name="Suite">
<test name="Test">
<classes> <!-- 测试集合,执行cn.testng包下的Annotation及test测试类 -->
<class name="cn.testng.Annotation"/>
<class name="cn.testng.test"/> </classes>
</test>
</suite>

五:测试用例的分组,通过testng.xml方式来执行测试用例

import org.testng.annotations.Test;

public class Grouping {

    /**
* 测试用例的分组,TestNG使用groups关键字进行分组,用来执行多个Test的测试用例
*/ @Test(groups={"人"})
public void student(){
System.out.println("学生方法被调用");
} @Test(groups={"人"})
public void teacher(){
System.out.println("老师方法被调用");
} @Test(groups={"动物"})
public void cat(){
System.out.println("小猫方法被调用");
} @Test(groups={"动物"})
public void dog(){
System.out.println("小狗方法被调用");
} }

设置testng.xml

<suite name="Suite">
<test name="Grouping"> <groups>
<run>
<include name="动物"></include>
</run>
</groups> <classes>
<class name="cn.testng.Grouping"/>
</classes>
</test>
</suite>

通过testng.xml方式来执行测试用例,结果如下:

小猫方法被调用
小狗方法被调用

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

TestNG 单元测试框架的使用的更多相关文章

  1. Eclipse中怎么安装TestNG单元测试框架

    在进行使用的eclipse的进行开发的代码中,必然就会需要进行单元测试,在单元测试的情况提供较多的框架单元测试,例如使用junit单元测试,而在国外进行开发较好的单元测试,提供了较好的测试的报告,ju ...

  2. TestNg JAVA 自动化单元测试框架Demo

    TestNg TestNg 是java的一个自动化单元测试框架 参考:http://testng.org/doc/index.html 环境准备 既然是java 的自动化单元测试框架,就必须要有jav ...

  3. JAVA 利用MyEclipse结合TestNG测试框架进行单元测试

    利用MyEclipse结合TestNG测试框架进行单元测试   by:授客 QQ:1033553122 测试环境 jdk1.8.0_121 myeclipse-10.0-offline-install ...

  4. unittest单元测试框架实现参数化

    当我们在使用TestNG时,发现它有一个非常好用的参数化功能.当你的测试用例有固定的参数和断言结果时,它可以相似用例的节省用例的个数. 例子如下: import static org.testng.A ...

  5. 单元测试框架unittest

    单元测试:单元测试,是指对软件中的最小可测试单元进行检查和验证,对于单元测试中单元的含义,一般来说,要根据实际情况去判定其具体含义如:c语言中单元指一个函数,java里单元指一个类,图形化的软件中可以 ...

  6. Python+Selenium框架设计篇之-简单介绍unittest单元测试框架

    前面文章已经简单介绍了一些关于自动化测试框架的介绍,知道了什么是自动化测试框架,主要有哪些特点,基本组成部分等.在继续介绍框架设计之前,我们先来学习一个工具,叫unittest.       unit ...

  7. Python+Selenium ----unittest单元测试框架

    unittest是一个单元测试框架,是Python编程的单元测试框架.有时候,也做叫做“PyUnit”,是Junit的Python语言版本.这里了解下,Junit是Java语言的单元测试框架,Java ...

  8. 【转】nose-parameterized是Python单元测试框架实现参数化的扩展

    原文地址: http://www.cnblogs.com/fnng/p/6580636.html 相对而言,Python下面单元测试框架要弱上少,尤其是Python自带的unittest测试框架,不支 ...

  9. 走进JavaWeb技术世界11:单元测试框架Junit

    JUnit你不知道的那些事儿 转自 老刘 码农翻身 2016-02-24 话说有一次Eric Gamma 坐飞机的时候偶遇Kent Beck(对,就是极限编程和TDD的发起人) ,  两位大牛见面寒暄 ...

随机推荐

  1. 前端导出功能get和post两种方式

    get方式: var url = ’/sjdd/eventQuery/exportSuperviseEventExcel.do?beginDate=' + beginDate + '&endD ...

  2. 关于java的跨平台特性

    Write once, compile anywhere,“一次编译,到处运行”的著名口号大家想必都听说过吧一次编译:把java代码(.java文件)通过编译器转换成字节码(.class文件)(符合j ...

  3. Mysql基本代码操作

    Mysql的基本代码生成操作 创建一个数据库   (myschool是数据库名) create database myschool; 删除数据库 drop database myschool 创建一个 ...

  4. CentOS6/7快捷使用gcc5

    Centos6/7自带的gcc为4.x版本,可通过devtoolset工具集安装gcc5.x版本 1. 添加yum源 1)CentOS6 [hhorak-devtoolset--rebuild-boo ...

  5. Java Native

    native 什么是Native Method 简单地讲,一个Native Method就是一个java调用非java代码的接口.一个Native Method是这样一个java的方法:该方法的实现由 ...

  6. MySQL 数据表操作

    MySQL 数据表操作 创建MySQL数据表需要以下信息: -表名: -表字段名: -定义每个表字段: 一.创建数据表 1)mysql> create  table  table_name (c ...

  7. Vue 中渲染字符串形式的组件标签

    在vue中如果要渲染字符串形式的标签,vue 提供了 v-html 指令,可以很方便的渲染出来.但是如果这个标签是一个组件,或者element-ui 的组件时,就不能解析出来了,因为v-html 只能 ...

  8. 18.23 inline函数功能

    GUN的C关键字,在函数定义中函数返回类型前加上关键字inline,可以把函数指定为内联函数.关键字inline必须与函数定义放在一起才能使函数成为内联,仅仅将inline放在函数声明前面不起任何作用 ...

  9. C# 生成海报,文本区域指定和换行,图片合成

    protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { string path = Server.MapPa ...

  10. Android Studio搭建系统App开发环境

    一.前言 在Android的体系中开发普通app使用Android Studio这一利器会非常的方便.但是开发系统app可能就会有些吃力,不过经过一些配置仍然会 很简单.我们知道系统app因为涉及到一 ...