使用java+TestNG进行接口回归测试

上一篇 / 下一篇  2020-02-05 11:40:35 / 个人分类:转贴收藏

TestNG是一个开源自动化测试框架,“NG”表示下一代(Next Generation的首字母)。 TestNG类似于JUnit(特别是JUnit 4),但它不是JUnit框架的扩展,相较于Junit而言,功能更强大,使用起来更加方便,比较适合测试人员来进行集成测试或是接口回归测试。

一、TestNG的特点

  • 使用java和面向对象的功能

  • 方法的名称就不必受限于某种固定的格式,可以通过注释来识别需要执行的方法;

  • 方法中需要的一些参数可以通过注释传递;

  • 注释是强类型的,所以有错误可以在编译期体现出来;

  • 支持分组测试,依赖测试,并行测试,负载测试等

  • 支持多线程测试

二、TestNG常用的注释类型

注释描述
@Test将类或是方法标记为测试的一部分
@BeforeSuite在该套件的所有测试都运行在注释的方法之前,仅运行一次。
@AfterSuite在该套件的所有测试都运行在注释的方法之后,仅运行一次
@BeforeClass在调用当前类的所有测试方法之前执行,注释方法仅运行一次
@AfterClass在调用当前类的所有测试方法之后执行,注释方法仅运行一次
@BeforeTest注释的方法将在属于<test>标签内的类的所有测试方法运行之前运行
@AfterTest注释的方法将在属于<test>标签内的类的所有测试方法运行之后运行。
@BeforeGroups此方法是保证在运行属于任何这些组的第一个测试方法之前,该方法被调用
@AfterGroups此方法是保证运行属于任何这些组的所有测试方法执行之后,该方法被调用
@BeforeMethod被注释的方法将在每个测试方法之前执行
@AfterMethod被注释的方法将在每个测试方法之后执行
@DataProvider被注释的方法的作用是提供测试数据,如果某个测试方法希望从这个DataProvider接收数据,就必须使用一个名字等于这个注解名字的DataProvider
@Parameters介绍如何将参数传递给测试方法

三、TestNG参数化测试

TestNG提供了2种传递参数的方式。

第一种: testng.xml

这种方式的优点是使得代码和测试数据分离,方便维护;缺点就是如果需要传递的参数不是基本的java类型,或是需要的值只能在运行时创建,这种方法就不再适用。

使用java+TestNG进行接口回归测试

使用java+TestNG进行接口回归测试

第二种:@DataProvider

这种能够提供比较复杂的参数(也叫data-driven testing)。

我们项目中使用的是第二种

使用java+TestNG进行接口回归测试

如图示:首先给测试方法添加值为WithdrawBatchQueryLoopData的属性dataProvider,然后提供一个name与之对应的@DataProvider方法,这个方法里的具体实现,就是从配置文件或是数据库中读取数据。

四、TestNG分组测试

分组测试是TestNG中的创新功能,分组测试使得我们可以进行各种灵活的测试,在想要并行多组不同的测试时,不需要重新进行编译。

使用java+TestNG进行接口回归测试

分组可以应用在方法上(一个方法可以属于一到多个分组),也可以应用在类上,应用在类上时,这个类中的所有public方法都变成测试方法,即便他们没有被注解,也可以继续在需要增加属性的方法上重复@Test注解。分组执行测试方法有多种形式:

可以通过在testng.xml配置,来指定具体要执行的分组

使用java+TestNG进行接口回归测试

也可以通过集成到jenkins中,通过参数化构建来设置要执行的分组

使用java+TestNG进行接口回归测试

还可以通过运行Run Configurations时,设置要执行的分组

使用java+TestNG进行接口回归测试

需要注意的一点:Group标签会导致@BeforeMethod失效

@BeforeMethod的作用是标明所注解的方法在每一个测试方法运行之前会执行一次。例如:

@BeforeMethodPublicvoidbeforeMehod()@Test
PublicvoidtestCase1()@Test
PublicvoidtestCase2()

正常的执行的顺序为:beforeMehod—> testCase1—> beforeMehod—> testCase2

但是,在将testCase放入某一个Group之后,@BeforeMethod就失效了

@BeforeMethodPublicvoidbeforeMehod()@Test(groups ="group1")PublicvoidtestCase1()@Test(groups ="group1")PublicvoidtestCase2()

再次执行脚本,执行顺序变为testCase1—>testCase2

解决方法:

1、将@BeforeMethod同样加入group1

2、设置@BeforeMethod的属性alwaysRun=true

五、TestNG依赖测试

我们经常会遇到要测试的多个接口之间存在依赖关系,即某一个接口的执行需要依赖上一个接口的返回结果,比如执行批付查询时,需要先执行批量代付,那么这时就使用到了TestNG的依赖测试,TestNG使用dependsOnMethods配合alwaysRun来设置测试方法之间的依赖关系,使用dependsOnGroups来设置分组之间的依赖关系

使用java+TestNG进行接口回归测试

  • 强依赖:在测试方法运行之前,所有的依赖方法都必须运行并且成功,哪怕只有一个失败,测试方法都不会被调用(是skip而不是fail)

  • 软依赖(alwaysRun=true):测试方法在依赖方法运行之后总是会被执行,即便某些依赖方法运行失败。

六、TestNG预期异常测试

测试中,有时候我们期望某些代码抛出异常。

TestNG通过@Test(expectedExceptions) 来判断期待的异常, 并且判断Error Message

使用java+TestNG进行接口回归测试

七、TestNG测试报告

执行完测试用例之后,会在项目的test-output(默认目录)下生成测试报告

打开index.html文件可以看到测试结果摘要,包括:套件名、测试用例成功数、测试用例失败数、测试用例忽略数、执行时间和testng.xml文件。

测试用例都成功的话,测试结果以绿底标志,测试用例有失败的话,测试结果以红底标志。testNG自带生成的测试报告不太美观,可以使用testng-xslt进行美化。


TAG:

 

评分:0

我来说两句

我的栏目

日历

« 2024-03-29  
     12
3456789
10111213141516
17181920212223
24252627282930
31      

我的存档

数据统计

  • 访问量: 830
  • 日志数: 4
  • 建立时间: 2020-02-04
  • 更新时间: 2020-02-05

RSS订阅

Open Toolbar