Java自动化测试框架--TestNG详解

2024-05-11 01:12

本文主要是介绍Java自动化测试框架--TestNG详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一. 什么是TestNG

TestNG是一个开源的自动化测试框架,它受JUnit和NUnit启发,其中“NG”即表示Next Generation,其功能更强大使用更方便。

二. TestNG配置

2.1 POM文件配置

在maven工程的pom.xml文件中加入以下依赖:

<dependency><groupId>org.testng</groupId><artifactId>testng</artifactId><version>6.14.2</version></dependency>

2.2 TestNG插件安装

三. 用例运行方法

3.1 单个用例

选中该用例->右键,Run As ->TestNG Test

3.2 单个类的用例

打开类文件,空白处右键,Run As ->TestNG Test

和单个用例一样,不同之处只是在类文件里空白处点击右键。此操作会执行该类下所有的测试用例

3.3 多个类的用例(Test Suite)

使用testng.xml文件,该文件用来管理测试用例,并运行testNG。

<suite>:套件就是将所有的测试类整理在一块,形成一套测试用例

<test>:测试集是指测试模块,一般一个项目可以按照模块分为几部分,即不同的test

<classes>:测试集下的所有测试类

<class>:具体测试类,name 属性指定测试类的路径

<methods>:测试类下具体的测试方法,如果不写此标签则默认包含测试类下的所有方法。

举例,本文的testng.xml内容如下:

<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" ><suite name="testng test" parallel="false"><test name="API test"><classes><class name="com.apitest.APITest"/><class name="com.apitest.APITest2"/></classes></test><test name="GUI test"><classes><class name="com.seletest.FirstWebTest"/></classes></test></suite>

 

注:<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" > 必须要添加,这是testng.xml文件的规范要求。

运行结果如下:

四. TestNG注解

4.1 Before/After注解

4.2 Test注解

@Test 注解的作用很简单,即用来标识当前方法是测试方法。它可以加很多参数:

1) denpendsOnMethonds: 用来设置用例依赖。

 @Testpublic void apitest01() {System.out.println("in APITest, apitest01");Assert.assertEquals(false,true);}@Test(dependsOnMethods= {"apitest01"})public void apitest02() {System.out.println("in APITest, apitest02");}

 如上的两个用例,apitest01执行通过,则执行apitest02;如果apitest01执行失败,则apitest02直接跳过,不会执行:

2) alwaysRun:默认是false,设置为true时,无论什么情况都会运行。一般和dependsOnMethods结合。

@Testpublic void apitest01() {System.out.println("in APITest, apitest01");Assert.assertEquals(false,true);}@Test(dependsOnMethods= {"apitest01"},alwaysRun=true)public void apitest02() {System.out.println("in APITest, apitest02");}

 如上的两个用例,不管apitest01是否失败,apitest02都运行。运行结果如下:

3) enabled:默认是true,设置为false时表示用例失效(即不运行)。使用方法:

@Test(enabled=false)

4) Priority:设置用例运行的优先级。默认是0,优先级P0最高,其次是P1;高优先级的用例优先运行

 @Test(priority=3)public void apitest01() {System.out.println("in APITest, apitest01 -- P3 ");//Assert.assertEquals(false,true);}@Test(priority=2)public void apitest02() {System.out.println("in APITest, apitest02 -- P2");}@Test(priority=1)public void apitest03() {System.out.println("in APITest, apitest03 -- P1");}

上述用例的运行结果如下:

5)timeOut:指定测试方法执行的超时时间,如果超过指定的毫秒数,则认为执行失败并终止执行抛出异常。使用方法:

@Test(timeOut = 1000)

6)Groups: 指定用例所属的组,一般是对用例进行逻辑划分,譬如只想执行一部分用例,例如冒烟测试,可以定义一个冒烟用例集:

@Test(groups="smoke")public void apitest01() {System.out.println("in APITest, apitest01 -- P3 ");//Assert.assertEquals(false,true);}@Test(groups="regression")public void apitest02() {System.out.println("in APITest, apitest02 -- P2");}@Test()public void apitest03() {System.out.println("in APITest, apitest03 -- P1");}

注意,group需要在testng.xml中加入以下配置:

则运行结果如下,即“API test”中,只有属于smoke组的用例才会执行:

 

五. 用例的传参

即给测试方法传递参数,更进一步说,如何实现数据-脚本的分离。

5.1 Parameters

需要首先在testng.xml里设置,注意此时必须通过testng.xml来运行,否则找不到parameter。

 @Test()@Parameters({"name","age"})public void apitest01(String name, int age) {System.out.println("in APITest, apitest01");System.out.println(name + "'s age is: " + age + ".");}

 运行结果如下:

这种方式传参缺点很明显:

·只能通过testng.xml来运行,不够灵活

· 只能传递基础类型的参数

· 只能传递一组参数

5.2 DataProvider

DataProvider是更灵活更强大的参数传递方式。它支持各种数据类型的参数,可以传递多组参数。其返回值类型是Object类型的二维数组,定义如下:

@DataProvider(name="paraDatas")public Object[][] paraDatas(){Object[][] paras = {{"zhang san", 20},{"li si", 21},{"wang wu", 22}};return paras;}

 在测试用例的Test方法里,使用方法如下:

@Test(dataProvider = "paraDatas")public void apitest01(String name, int age) {System.out.println("in APITest, apitest01");System.out.println(name + "'s age is: " + age + ".");}

运行结果如下:

DataProvider比较灵活且强大,但它也有局限,即实际上还是在代码中hardcode的方式。如果多一种情况,还需要修改case(paraDatas)。

5.3 POI技术

Apache POI 是基于 Office Open XML 标准(OOXML)和 Microsoft 的 OLE 2 复合文档格式(OLE2)处理各种文件格式的开源项目。简而言之,可以使用 Java 读写 MS Excel 文件,可以使用 Java 读写 MS Word 和 MS PowerPoint 文件。

本质上它还是使用DataProvider的方式传参,但可以真正实现数据-脚本的分离。

这里不多讲了~

此外还可以将数据库查询的结果作为参数传递,但本质是一样的。

六. 思考与总结

testNG还有很多很强大的机制,例如用例失败重试,需要实现IRetryAnalyzer接口,相比其他参数的使用,其稍微复杂一些,有空了再搞吧~

​现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:485187702【暗号:csdn11】

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走! 希望能帮助到你!【100%无套路免费领取】

这篇关于Java自动化测试框架--TestNG详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/978089

相关文章

MySQL中的事务隔离级别详解

《MySQL中的事务隔离级别详解》在MySQL中,事务(Transaction)是一个执行单元,它要么完全执行,要么完全回滚,以保证数据的完整性和一致性,下面给大家介绍MySQL中的事务隔离级别详解,... 目录一、事务并发问题二、mysql 事务隔离级别1. READ UNCOMMITTED(读未提交)2

Spring AI 实现 STDIO和SSE MCP Server的过程详解

《SpringAI实现STDIO和SSEMCPServer的过程详解》STDIO方式是基于进程间通信,MCPClient和MCPServer运行在同一主机,主要用于本地集成、命令行工具等场景... 目录Spring AI 实现 STDIO和SSE MCP Server1.新建Spring Boot项目2.a

spring security 超详细使用教程及如何接入springboot、前后端分离

《springsecurity超详细使用教程及如何接入springboot、前后端分离》SpringSecurity是一个强大且可扩展的框架,用于保护Java应用程序,尤其是基于Spring的应用... 目录1、准备工作1.1 引入依赖1.2 用户认证的配置1.3 基本的配置1.4 常用配置2、加密1. 密

Python处理超大规模数据的4大方法详解

《Python处理超大规模数据的4大方法详解》在数据的奇妙世界里,数据量就像滚雪球一样,越变越大,从最初的GB级别的小数据堆,逐渐演变成TB级别的数据大山,所以本文我们就来看看Python处理... 目录1. Mars:数据处理界的 “变形金刚”2. Dask:分布式计算的 “指挥家”3. CuPy:GPU

Spring Boot 集成 Solr 的详细示例

《SpringBoot集成Solr的详细示例》:本文主要介绍SpringBoot集成Solr的详细示例,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录环境准备添加依赖配置 Solr 连接定义实体类编写 Repository 接口创建 Service 与 Controller示例运行

Spring Cloud GateWay搭建全过程

《SpringCloudGateWay搭建全过程》:本文主要介绍SpringCloudGateWay搭建全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Spring Cloud GateWay搭建1.搭建注册中心1.1添加依赖1.2 配置文件及启动类1.3 测

Java如何将文件内容转换为MD5哈希值

《Java如何将文件内容转换为MD5哈希值》:本文主要介绍Java如何将文件内容转换为MD5哈希值的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java文件内容转换为MD5哈希值一个完整的Java示例代码代码解释注意事项总结Java文件内容转换为MD5

Spring Boot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)

《SpringBoot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)》:本文主要介绍SpringBoot拦截器Interceptor与过滤器Filter深度解析... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实

解决Java异常报错:java.nio.channels.UnresolvedAddressException问题

《解决Java异常报错:java.nio.channels.UnresolvedAddressException问题》:本文主要介绍解决Java异常报错:java.nio.channels.Unr... 目录异常含义可能出现的场景1. 错误的 IP 地址格式2. DNS 解析失败3. 未初始化的地址对象解决

SpringBoot后端实现小程序微信登录功能实现

《SpringBoot后端实现小程序微信登录功能实现》微信小程序登录是开发者通过微信提供的身份验证机制,获取用户唯一标识(openid)和会话密钥(session_key)的过程,这篇文章给大家介绍S... 目录SpringBoot实现微信小程序登录简介SpringBoot后端实现微信登录SpringBoo