【一:实战开发testng的介绍】

目录

  • 1、主要内容
    • 1.1、为啥要做接口测试
    • 1.2、接口自动化测试落地过程
    • 1.3、接口测试范围
    • 1.4、手工接口常用的工具
    • 1.5、自动化框架的设计
  • 2、testng自动化测试框架
    • 基本测试
      • 1、基本注解
      • 2、忽略测试
      • 3、依赖测试
      • 4、超时测试
      • 5、异常测试
      • 6、通过xml文件参数测试
      • 7、通过data实现数据驱动
    • 2.1、suit套件测试(按类分)
    • 2.2、分组测试(按方法分组,也可以分开写)
      • 2.2.1、在class文件中分组
      • 2.2.2、使用xml文件分组
    • 2.3、多线程运行(注解的方式配置)
    • 2.4、多线程运行(在xml里面配置)

1、主要内容

1.1、为啥要做接口测试

  • 更容易实现持续集成
  • 自动化测试落地性价比更高,比UI更稳定
  • 大型系统更多更复杂,系统间模块越来越多
  • BUG更容易定位
  • 降低研发成本,提高效率

1.2、接口自动化测试落地过程

需求阶段项目立项,产品设计,需求文档
研发阶段UI设计、前端开发,后端开发,测试设计,测试开发
测试阶段环境搭建,多项测试执行,BUG修复,测试报告
项目上线显示回归测试,上线报告,添加监控

1.3、接口测试范围


1.4、手工接口常用的工具

  • postman(Chrome)
  • httpRequest
  • fiddler
  • jemter(统计结果不完善,倾向于性能测试)

1.5、自动化框架的设计


2、testng自动化测试框架

  1. @test:最基本的注解,用来把方法标记为测试的一部分
  2. @BeforeMethod: 测试方法之前运行的方法
  3. @AfterMethod:测试方法之后运行的方法
  4. @BeforeClass: 指的是在类运行之前运行的方法
  5. @AfterClass:指的是在类运行之后运行的方法
  6. @BeforeTest:多个测试类的集合,在设定好的测试集合前运行的方
  7. @AfterTest:多个测试类的集合,在设定好的测试集合后运行的方法
  8. @ BeforeSuite: 测试套件,在类运行之前运行的方法:
  9. @ AfterSuite: 测试套件,在类运行之后运行的方法
  10. @Test(dependsOnMethods = {“test1”}):依赖测试,在执行次方法之前执行test1方法之前
  11. 1@Test(expectedExceptions = RuntimeException.class):异常测试,方法里面要抛出异常throw new RuntimeException();,否则会是一个失败的异常测试
  12. @Test(enabled = true):忽略测试
  13. @Test(timeOut = 2000):超时测试
  14. @Test(invocationCount = 10,threadPoolSize = 3),多线程测试,一般用xml配置

总结:testng的annotations运行顺序为:
@BeforeSuite>@BeforeTest>@BeforeClass>@BeforeMethod>@test>@AfterMethod>@AfterClass>@AfterTest>@AfterSuite

基本测试

1、基本注解

import org.testng.annotations.*;
public class BasicAnnotation {//最基本的注解,用来把方法标记为测试的一部分@Testpublic void testCase1(){System.out.printf("Thread Id : %s%n",Thread.currentThread().getId());System.out.println("Test这是测试用例1");}@Testpublic void testCase2(){System.out.printf("Thread Id : %s%n",Thread.currentThread().getId());System.out.println("Test这是测试用例2");}@BeforeMethodpublic void beforeMethod(){System.out.println("BeforeMethod这是在测试方法之前运行的");}@AfterMethodpublic void afterMethod(){System.out.println("AfterMethod这是在测试方法之后运行的");}@BeforeClasspublic void beforeClass(){System.out.println("beforeClass这是在类运行之前运行的方法");}@AfterClasspublic void afterClass(){System.out.println("afterClass这是在类运行之后运行的方法");}@BeforeSuitepublic void beforeSuite(){System.out.println("BeforeSuite测试套件");}@AfterSuitepublic void afterSuite(){System.out.println("AfterSuite测试套件");}
}

image.png

2、忽略测试

public class IgnoreTest {@Test(enabled = false)public void ignore2(){System.out.println("ignore2 执行");}@Test(enabled = true)public void ignore3(){System.out.println("ignore3 执行");}
}

image.png

3、依赖测试

依赖测试,被依赖测测试方法必须成功,不能失败,失败的话会不成功

public class DependTest {@Testpublic void test1(){System.out.println("test1 run");throw new RuntimeException();}@Test(dependsOnMethods = {"test1"}) //执行前依赖于test1()public void test2(){System.out.println("test2 run");}}

image.png

4、超时测试

public class TimeOutTest {@Test(timeOut = 3000)//单位为毫秒值public void testSuccess() throws InterruptedException {Thread.sleep(2000);}@Test(timeOut = 2000)public void testFailed() throws InterruptedException {Thread.sleep(3000);}
}

image.png

5、异常测试

public class ExpectedException {/*** 什么时候会用到异常测试??* 在我们期望结果为某一个异常的时候* 比如:我们传入了某些不合法的参数,程序抛出了异常* 也就是说我的语气结果就是这个异常。*///这是一个测试结果会失败的异常测试@Test(expectedExceptions = RuntimeException.class)public void runTimeExceptionFailed(){System.out.println("这是一个失败的异常测试");}//这是一个成功的异常测试@Test(expectedExceptions = RuntimeException.class)public void runTimeExceptionSuccess(){System.out.println("这是我的异常测试");throw new RuntimeException();}}

image.png
image.png

6、通过xml文件参数测试

public class ParamterTest {@Test@Parameters({"name","age"})public void paramTest1(String name,int age){System.out.println("name = " + name + ";  age = " + age);}
}
<?xml version="1.0" encoding="UTF-8" ?><suite name="parameter"><test name="param"><classes><parameter name="name" value="zhangsan"/><parameter name="age" value="10"/><class name="com.course.testng.paramter.ParamterTest"/></classes></test></suite>

image.png
image.png

7、通过data实现数据驱动


public class DataProviderTest {@DataProvider(name="data")public Object[][] providerData(){Object[][] o = new Object[][]{{"zhangsan",10},{"lisi",20},{"wangwu",30}};return o;}@Test(dataProvider = "data")public void testDataProvider(String name,int age){System.out.println("name =" + name +"; age=" + age);}}

image.png


public class DataProviderTest {@DataProvider(name="methodData")public Object[][] methodDataTest(Method method){Object[][] result=null;if(method.getName().equals("test1")){result = new Object[][]{{"zhangsan",20},{"lisi",25}};}else if(method.getName().equals("test2")){result = new Object[][]{{"wangwu",50},{"zhaoliu",60}};}return result;}@Test(dataProvider = "methodData")public void test1(String name,int age){System.out.println("test111方法 name="+name+";age="+age);}@Test(dataProvider = "methodData")public void test2(String name,int age){System.out.println("test222方法 name="+name+";age="+age);}}

image.png

2.1、suit套件测试(按类分)

上述内容大家基本都了解,而在实际使用中我们再配合套件时,需要注意:
假设现在有如图所示项目:

  • LogInTest类:登录测试类;
public class LoginTest {@Testpublic void loginTaoBao(){System.out.println("淘宝登陆成功");}
}
  • ParTest类:支付测试类;
public class PayTest {@Testpublic  void paySuccess(){System.out.println("支付宝支付成功");}
}
  • SuiteConfig类:套件配置类;
public class SuiteConfig {@BeforeSuitepublic void beforeSuite(){System.out.println("before suite运行啦");}@AfterSuitepublic  void aftersuite(){System.out.println("after suite 运行啦");}@BeforeTestpublic void beforeTest(){System.out.println("beforeTest");}@AfterTestpublic void afterTest(){System.out.println("afterTest");}
}
  • suite.xml:套件xml文件
<?xml version="1.0" encoding="UTF-8" ?>
<suite name="test"><test name="login"> <!--名字自定义--><classes><class name="com.course.testng.suite.SuiteConfig"/><class name="com.course.testng.suite.LoginTest"/></classes></test><test name="pay"> <!--名字自定义--><classes><class name="com.course.testng.suite.SuiteConfig"/><class name="com.course.testng.suite.PayTest"/></classes></test>
</suite>


image.png
image.png

我们期望实现的是通过xml文件运行整个项目
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-blog.csdnimg.cn/e741c9f6165d42d5bfe59563d72860b3.png))
登录类内容

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-blog.csdnimg.cn/dfe5b5e7d057438eb5abe94a299a9677.png))
支付类内容
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-blog.csdnimg.cn/5148935f37cf49fcb86ed37d9214d06e.png))
套件配置类内容
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-blog.csdnimg.cn/2fdbc6fd61884bdf8fd1e3c4ba82cb53.png))
xml文件内容,xml的内容配置在resources下
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-blog.csdnimg.cn/1bdd3453d2fc45ce9453141b1a7836ee.png))
点击对应的xml,右键,实际运行结果如下:
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-blog.csdnimg.cn/08a9c2ad04004e869d4f65e19b662ee6.png))

2.2、分组测试(按方法分组,也可以分开写)

2.2.1、在class文件中分组


public class GroupsOnMethod {@Test(groups = "server")public void test1(){System.out.println("这是服务端组的测试方法1111");}@Test(groups = "server")public void test2(){System.out.println("这是服务端组的测试方法2222");}@Test(groups = "client")public void test3(){System.out.println("这是客户端组的测试方法3333");}@Test(groups = "client")public void test4(){System.out.println("这是客户端组的测试方法4444");}@BeforeGroups("server")public void beforeGroupsOnServer(){System.out.println("这是服务端组运行之前运行的方法");}@AfterGroups("server")public void afterGroupsOnServer(){System.out.println("这是服务端组运行之后运行的方法!!!!!");}@BeforeGroups("client")public void beforeGroupsOnClient(){System.out.println("这是客户端组运行之前运行的方法");}@AfterGroups("client")public void afterGroupsOnClient(){System.out.println("这是客户端组运行之后运行的方法!!!!!");}}

2.2.2、使用xml文件分组

2.2.1、@Test(groups = “stu”)组


2.2.2、@Test(groups = “teacher”)组

2.2.3、分组的配置文件

<?xml version="1.0" encoding="UTF-8" ?>
<suite name="suitename"><test name="runAll"><classes><class name="com.course.testng.groups.GroupsOnClass1"/><class name="com.course.testng.groups.GroupsOnClass2"/><class name="com.course.testng.groups.GroupsOnClass3"/></classes></test><test name="onlyRunStu"><groups><run><include name="stu"/></run></groups><classes><class name="com.course.testng.groups.GroupsOnClass1"/><class name="com.course.testng.groups.GroupsOnClass2"/><class name="com.course.testng.groups.GroupsOnClass3"/></classes></test>
</suite>

image.png
2.2.4、现在对应的xml,右键,查看运行结果
image.png

2.3、多线程运行(注解的方式配置)

2.3.1、通过注解的方式实现三个线程池运行里随机运行10次方法

public class MultiThreadOnAnnotion {@Test(invocationCount = 10,threadPoolSize = 3)public void test(){System.out.println(1);System.out.printf("Thread Id : %s%n",Thread.currentThread().getId());}}

运行结果
image.png

2.4、多线程运行(在xml里面配置)

public class MultiThreadOnXml {@Testpublic void test1(){System.out.printf("Thread Id : %s%n",Thread.currentThread().getId());}@Testpublic void test2(){System.out.printf("Thread Id : %s%n",Thread.currentThread().getId());}@Testpublic void test3(){System.out.printf("Thread Id : %s%n",Thread.currentThread().getId());}}
<?xml version="1.0" encoding="UTF-8" ?>
<suite name="thread" parallel="methods" thread-count="3"><!--tests级别:不同的test tag下的用例可以在不同的线程下执行相同的test tag下的用例只能在同一个线程中去执行classs级别:相同的class tag 下的用例在同一个线程中执行不同的class tag 下的用例可以在不同的线程中执行methods级别:所有用例都可以在不同的线程下去执行thread-count:代表了最大并发线程数xml文件配置这种方式不能指定线程池,只有方法上才可以指定线程池--><test name = "demo1"><classes name="d"><class name="com.course.testng.multiThread.MultiThreadOnXml"/><class name="com.course.testng.BasicAnnotation"/><class name="com.course.testng.multiThread.MultiThreadOnXml"/></classes><classes name="d1"><class name="com.course.testng.multiThread.MultiThreadOnXml"/><class name="com.course.testng.BasicAnnotation"/><class name="com.course.testng.multiThread.MultiThreadOnXml"/></classes></test><test name = "demo2"><classes name="d3"><class name="com.course.testng.BasicAnnotation"/></classes></test></suite>

xml文件配置这种方式不能指定线程池,只有方法上才可以指定线程池
运行结果;
image.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/163455.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

UWB十个知识点

UWB是一直被基于厚望的高精度定位技术 1&#xff1a;定位技术及UWB特点 位置空间感知技术包括了GNSS、RFID、蓝牙和UWB&#xff0c;在室内和区域空间测量最具技术优势的技术是UWB。 GNSS是广域定位技术&#xff0c;室内以及建筑物旁边等场景&#xff0c;GNSS无法实现定位&am…

【微服务 SpringCloud】实用篇 · Ribbon负载均衡

微服务&#xff08;4&#xff09; 文章目录 微服务&#xff08;4&#xff09;1. 负载均衡原理2. 源码跟踪1&#xff09;LoadBalancerIntercepor2&#xff09;LoadBalancerClient3&#xff09;负载均衡策略IRule4&#xff09;总结 3. 负载均衡策略3.1 负载均衡策略3.2 自定义负载…

企业IT资产设备折旧残值如何计算

环境&#xff1a; 企业/公司 IT资产 问题描述&#xff1a; 企业IT设备折旧残值如何计算&#xff1f; 解决方案&#xff1a; 1.按三年折旧 净值原值-月折旧额折旧月份 &#xff0c; 月折旧额原值(1-3%)/36 折旧月份ROUND(E2*(1-3%)/36,2) 2.净值E2-F2*G2

vue使用pdf 导出当前页面,(jspdf, html2canvas )

需要安装两个插件 npm install html2canvas jspdfyarn add html2canvas jspdf<div class"app-container" id"pdfPage">我是内容 </div><el-button size"mini" click"onExportPdf">导出数据</el-button>onexp…

代码随想录算法训练营第23期day24|回溯算法理论基础、77. 组合

目录 一、回溯算法基础 回溯法模板 二、&#xff08;leetcode 77&#xff09;组合 剪枝 一、回溯算法基础 1.回溯的本质是穷举&#xff0c;穷举所有可能&#xff0c;然后选出想要的答案&#xff08;为了提升效率&#xff0c;最多再加一个剪枝&#xff09; 2.回溯法解决的…

凝聚技术力量 共建测试生态 ——集成电路测试技术交流日成功举办

10月18日下午&#xff0c;凝聚技术力量&#xff0c;共建测试生态 ——集成电路测试技术交流会在上海成功举办。来自全国各地知名专家学者、技术大咖及企业代表齐聚一堂&#xff0c;共同探讨封装测试技术的发展方向&#xff0c;共话产业未来&#xff0c;共促产业发展。 本次活动…

Stable Diffusion WebUI扩展a1111-sd-webui-tagcomplete之Booru风格Tag自动补全功能详细介绍

安装地址 直接附上地址先: Ranting8323 / A1111 Sd Webui Tagcomplete GitCodeGitCode——开源代码托管平台,独立第三方开源社区,Git/Github/Gitlabhttps://gitcode.net/ranting8323/a1111-sd-webui-tagcomplete.git上面是GitCode的地址,下面是GitHub的地址,根据自身情…

CUDA编程入门系列(二) GPU硬件架构综述

一、Fermi GPU Fermi GPU如下图所示&#xff0c;由16个SM&#xff08;stream multiprocessor&#xff09;组成&#xff0c;不同的SM之间通过L2 Cache和全局内存进行相连。整个架构大致分为两个层次&#xff0c;①总体架构由多个SM组成 ②每个SM由多个SP core&#xff08;stream…

数据结构中的七大排序(Java实现)

目录 一、直接插入排序 二、希尔排序 三、直接选择排序 四、堆排序 五、冒泡排序 六、快速排序 七、归并排序 一、直接插入排序 思想&#xff1a; 定义i下标之前的元素全部已经有序&#xff0c;遍历一遍要排序的数组&#xff0c;把i下标前的元素全部进行排序&#xff0…

elementui select组件下拉框底部增加自定义按钮

elementui select组件下拉框底部增加自定义按钮 el-select组件的visible-change 事件&#xff08;下拉框出现/隐藏时触发&#xff09; <el-selectref"select":value"value"placeholder"请选择"visible-change"visibleChange">&…

一天吃透Java集合面试八股文

内容摘自我的学习网站&#xff1a;topjavaer.cn 常见的集合有哪些&#xff1f; Java集合类主要由两个接口Collection和Map派生出来的&#xff0c;Collection有三个子接口&#xff1a;List、Set、Queue。 Java集合框架图如下&#xff1a; List代表了有序可重复集合&#xff0c…

软考-访问控制技术原理与应用

本文为作者学习文章&#xff0c;按作者习惯写成&#xff0c;如有错误或需要追加内容请留言&#xff08;不喜勿喷&#xff09; 本文为追加文章&#xff0c;后期慢慢追加 by 2023年10月 访问控制概念 访问控制是计算机安全的一个重要组成部分&#xff0c;用于控制用户或程序如…

LiveGBS流媒体平台GB/T28181常见问题-安全控制HTTP接口鉴权勾选流地址鉴权后401Unauthorized如何播放调用接口

LiveGBS流媒体平台GB/T28181常见问题-安全控制HTTP接口鉴权勾选流地址鉴权后401 Unauthorized如何播放调用接口&#xff1f; 1、安全控制1.1、HTTP接口鉴权1.2、流地址鉴权 2、401 Unauthorized2.1、携带token调用接口2.1.1、获取鉴权token2.1.2、调用其它接口2.1.2.1、携带 Co…

Spring Boot 可以同时处理多少请求?

文章目录 Spring Boot 的请求处理能力1. 硬件资源2. 应用程序的设计3. 配置4. 运行时环境 基准测试和性能优化高性能的 Spring Boot 应用程序示例结论 &#x1f389;欢迎来到架构设计专栏~Spring Boot 可以同时处理多少请求&#xff1f; ☆* o(≧▽≦)o *☆嗨~我是IT陈寒&#…

C语言实现面向对象编程 | 干货

前言 GOF的《设计模式》一书的副标题叫做“可复用面向对象软件的基础”&#xff0c;从标题就能看出面向对象是设计模式基本思想。 由于C语言并不是面向对象的语言&#xff0c;C语言没有直接提供封装、继承、组合、多态等面向对象的功能&#xff0c;但C语言有struct和函数指针。…

019-第三代软件开发-Git提交规范

第三代软件开发-Git提交规范 文章目录 第三代软件开发-Git提交规范项目介绍Git提交规范分支规范Commit Message FormatHeaderBodyFooterRevert 总结一下 关键字&#xff1a; Qt、 Qml、 git、 Commit、 release 项目介绍 欢迎来到我们的 QML & C 项目&#xff01;这个…

【数据结构】优先级队列(堆)

作者主页&#xff1a;paper jie_博客 本文作者&#xff1a;大家好&#xff0c;我是paper jie&#xff0c;感谢你阅读本文&#xff0c;欢迎一建三连哦。 本文录入于《JAVA数据结构》专栏&#xff0c;本专栏是针对于大学生&#xff0c;编程小白精心打造的。笔者用重金(时间和精力…

java最新Springboot3+微服务实战12306高性能售票系统全套开发课程

java最新Springboot3微服务实战12306高性能售票系统全套开发课程 视频课程在文末获取 第1章 课程介绍与学习指南。 1-1 课前必读&#xff08;不读错过一个亿&#xff09; 1-2 课程导学 1-3 为什么要选择最新版本SpringBoot3和JDK17&#xff1f; 1-4 在线demo网站演示 第2…

谈谈 Redis 如何来实现分布式锁

谈谈 Redis 如何来实现分布式锁 基于 setnx 可以实现&#xff0c;但是不是可重入的。 基于 Hash 数据类型 Lua脚本 可以实现可重入的分布式锁。 获取锁的 Lua 脚本&#xff1a; 释放锁的 Lua 脚本&#xff1a; 但是还是存在分布式问题&#xff0c;比如说&#xff0c;一个客…

Java_Jdbc

目录 一.JDBC概述 二.JDBC API 三.ResultSet[结果集] 四.Statement 五.PreparedStatement 六. JDBC API 总结 一.JDBC概述 JDBC 为访问不同的数据库提供了同一的接口&#xff0c;为使用着屏蔽了细节问题Java程序员使用JDBC 可以连接任何提供了 JDBC驱动的数据库系统&am…