TestNG 单元测试框架的使用
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 单元测试框架的使用的更多相关文章
- Eclipse中怎么安装TestNG单元测试框架
在进行使用的eclipse的进行开发的代码中,必然就会需要进行单元测试,在单元测试的情况提供较多的框架单元测试,例如使用junit单元测试,而在国外进行开发较好的单元测试,提供了较好的测试的报告,ju ...
- TestNg JAVA 自动化单元测试框架Demo
TestNg TestNg 是java的一个自动化单元测试框架 参考:http://testng.org/doc/index.html 环境准备 既然是java 的自动化单元测试框架,就必须要有jav ...
- JAVA 利用MyEclipse结合TestNG测试框架进行单元测试
利用MyEclipse结合TestNG测试框架进行单元测试 by:授客 QQ:1033553122 测试环境 jdk1.8.0_121 myeclipse-10.0-offline-install ...
- unittest单元测试框架实现参数化
当我们在使用TestNG时,发现它有一个非常好用的参数化功能.当你的测试用例有固定的参数和断言结果时,它可以相似用例的节省用例的个数. 例子如下: import static org.testng.A ...
- 单元测试框架unittest
单元测试:单元测试,是指对软件中的最小可测试单元进行检查和验证,对于单元测试中单元的含义,一般来说,要根据实际情况去判定其具体含义如:c语言中单元指一个函数,java里单元指一个类,图形化的软件中可以 ...
- Python+Selenium框架设计篇之-简单介绍unittest单元测试框架
前面文章已经简单介绍了一些关于自动化测试框架的介绍,知道了什么是自动化测试框架,主要有哪些特点,基本组成部分等.在继续介绍框架设计之前,我们先来学习一个工具,叫unittest. unit ...
- Python+Selenium ----unittest单元测试框架
unittest是一个单元测试框架,是Python编程的单元测试框架.有时候,也做叫做“PyUnit”,是Junit的Python语言版本.这里了解下,Junit是Java语言的单元测试框架,Java ...
- 【转】nose-parameterized是Python单元测试框架实现参数化的扩展
原文地址: http://www.cnblogs.com/fnng/p/6580636.html 相对而言,Python下面单元测试框架要弱上少,尤其是Python自带的unittest测试框架,不支 ...
- 走进JavaWeb技术世界11:单元测试框架Junit
JUnit你不知道的那些事儿 转自 老刘 码农翻身 2016-02-24 话说有一次Eric Gamma 坐飞机的时候偶遇Kent Beck(对,就是极限编程和TDD的发起人) , 两位大牛见面寒暄 ...
随机推荐
- sql执行内部操作期间检测到不一致性解决方案
解决方法:重启下SQL服务,把下面脚本运行即可.运行后,坏掉的数据库可能会丢失. --mydb 为坏了的数据库名--mytable 为坏了的据库表--master 这里不需要更改 use mydb ...
- .htaccess 文件来进行用户组的目录权限访问控制
<IfModule rewrite_module>RewriteEngine onRewriteRule ^((?:bootstrap|css|img|js||MathJax|video) ...
- CentOS7虚拟机克隆,且成功互ping
第一步:克隆 https://blog.csdn.net/mijichui2153/article/details/80918285 打开VMware,确认已经完成安装配置的CentOS7虚拟机在关闭 ...
- 听说https更安全
0--介绍: 现在人们对网络的依赖越来越重,那么对于网络安全的要求也越来越高,传统的http协议实现了网络中的快速传输,完整传输,保证了信息的完整性,但是对于网络的安全性却没有那么强,很容易被人劫持, ...
- [C]最大公约数和最小公倍数
/*求最大公约数和最小公倍数 编写程序,在主函数中输入两个正整数 a,b,调用两个函数 fun1() 和 fun2(),分别求 a 和 b 的最大公约数和最小公倍数,在主函数中输出结果. */ #in ...
- Incjector
网上的注入工具很多,大多也有比较详细的解释,但是大部分windows下的注入软件都是对自己软件的一种推荐,而且很多也不是非常的安全,对于有些破解版本来说,很可能自身会被带有木马,所以,Linux下的注 ...
- 引擎设计跟踪(九.14.3) deferred shading 准备
目前做的一些准备工作 1.depth prepass for forward shading. 做depth prepass的原因是为了完善渲染流程, 虽然架构上支持多个pass, 但实际上从来没有测 ...
- 引擎设计跟踪(九.14.2j) TableView工具填坑以及多国语言
Blade的UI都是预定义的接口, 然后由插件来负责实现, 目前只有MFC的插件. 最近加上了TableView的视图, 用于一些文件的查看和编辑, 比如前面在文件包的笔记中提到需写一个package ...
- Java(全局变量-静态变量-位运算符)
全局变量是默认赋值的:而局部变量是没有默认赋值的(需要赋值才能使用)静态变量只能被静态方法使用 位运算右移,相当于做除法,2的n次幂00001000操作的位移数相当于是偏移量从右向左数n位,从第n+1 ...
- zabbix4.0离线快速编译安装(编译安装方法)
本博客已整理更新至第二版.更新与2019.4.17 其实这个主要是想试一下离线编译安装的具体步骤,记得要配置好本地yum云,因为我们需要使用yum,yum能帮我们自动解决很多依赖问题.发现最主要的问题 ...