Java单元测试——框架(三)——testNG

简介: Java单元测试——框架(三)——testNG

1. 配置


建立Maven Project

 

image.png

image.png

image.png

建立pom.xml文件


<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.jerry</groupId>
  <artifactId>mytest</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>jar</packaging>
  <name>mytest</name>
  <url>http://maven.apache.org</url>
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.jerry</groupId>
  <artifactId>mytest</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>jar</packaging>
  <name>mytest</name>
  <url>http://maven.apache.org</url>
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>


安装:https://www.cnblogs.com/xusweeter/p/6559196.html,将org.testng.eclipse.updatesite.zip 拷贝到%ECLIPSE_HOME%\dropins,建立TestNG Class

 

image.png

image.png

2. 基本架构


被测代码

package com.jerry;
public class Calculator{
    private static int result; 
    public void add(int n) {
        result = result + n;
    }
    public void substract(int n) {
        result = result - n;  
    }
    public void multiply(int n) {
        result = result * n;
    } 
    public void divide(int n){
        try {
            result = result / n;
        }catch(ArithmeticException ex){
            System.out.println(ex);
            throw new ArithmeticException("The n not allowed to 0!!")
        }
}
}


最基本的测试代码


package com.jerry.mytest;
import org.testng.annotations.Test;
import org.testng.AssertJUnit;
import org.testng.annotations.BeforeMethod;
public class CalculatorTest {
private static Calculator calculator = new Calculator();
@Test
public void testAdd() {
  calculator.add(2);
  calculator.add(3);
   AssertJUnit.assertEquals(5,calculator.getResult());
} 
@Test
public void testSubstract() {
  calculator.add(5);
  calculator.substract(3);
   AssertJUnit.assertEquals(2,calculator.getResult());
}
@Test
public void testMultiply() {
      calculator.add(3);
      calculator.multiply(2);
      AssertJUnit.assertEquals(6,calculator.getResult());
}
@Test
public void testDivide() {
  calculator.add(9);
   calculator.divide(3);
   AssertJUnit.assertEquals(3,calculator.getResult());
}
@BeforeMethod
  public void beforeMethod() {
  calculator.clear();
  }
}


3. TestNG的修饰符


注解

描述

@BeforeSuite

注解的方法将只运行一次,运行所有测试前此套件中。

@AfterSuite

注解的方法将只运行一次,此套件中的所有测试都运行之后。

@BeforeClass

注解的方法将只运行一次,在当前类中的方法调用前运行。

@AfterClass

注解的方法将只运行一次,在当前类中的所有测试方法后运行。

@BeforeTest

注解的方法将被运行之前的任何测试方法,属于内部类的 <test>标签的运行。

@AfterTest

注解的方法将被运行后,所有的测试方法,属于内部类的<test>标签的运行。

@BeforeGroups

组的列表,这种配置方法将之前运行。此方法是保证在运行属于任何这些组的第一个测试方法,该方法被调用。

@AfterGroups

组的名单,这种配置方法后,将运行。此方法是保证运行后不久,最后的测试方法,该方法属于任何这些组被调用。

@BeforeMethod

注解的方法将在每个测试方法之前运行。

@AfterMethod

被注释的方法将被运行后,每个测试方法。

@DataProvider

标志着一个方法,提供数据的一个测试方法。注解的方法必须返回一个Object[][],其中每个对象[]的测试方法的参数列表中可以分配。

@Test 方法,希望从这个DataProvider的接收数据,需要使用一个dataProvider名称等于这个注解的名字。

@Factory

作为一个工厂,返回TestNG测试类的对象将被用于标记的方法。该方法必须返回Object[]不常用

@Listeners

定义一个测试类的监听器。不常用

@Parameters

介绍如何将参数传递给@Test方法。

@Test

标记一个类或者方法,从而作为测试的一部分。


描述装饰符的程序


package MyUnit.MyTestNG;
import org.testng.Assert;
import org.testng.annotations.AfterClass;
import org.testng.annotations.AfterGroups;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.AfterSuite;
import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.BeforeGroups;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.BeforeSuite;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;
public class MyFirstNG {
  @Test(groups="group1")
  public void test1() {
    System.out.println("test1 from group1");
    Assert.assertTrue(true);
  }
  @Test(groups="group1")
  public void test11() {
    System.out.println("test11 from group1");
    Assert.assertTrue(true);
  }
  @Test(groups="group2")
  public void test2() 
{
    System.out.println("test2 from group2");
    Assert.assertTrue(true);
  }
  @BeforeTest
  public void beforeTest() 
{
    System.out.println("beforeTest");
  }
  @AfterTest
  public void afterTest() 
{
    System.out.println("afterTest");
  }
  @BeforeClass
  public void beforeClass() 
{
    System.out.println("beforeClass");
  }
  @AfterClass
  public void afterClass() 
{
    System.out.println("afterClass");
  }
  @BeforeSuite
  public void beforeSuite() 
{
    System.out.println("beforeSuite");
  }
  @AfterSuite
  public void afterSuite() 
{
    System.out.println("afterSuite");
  }
  //只对group1有效,即test1和test11
  @BeforeGroups(groups="group1")
  public void beforeGroups() 
{
    System.out.println("beforeGroups");
  }
  //只对group1有效,即test1和test11
  @AfterGroups(groups="group1")
  public void afterGroups() 
{
    System.out.println("afterGroups");
  }
  @BeforeMethod
  public void beforeMethod() 
{
    System.out.println("beforeMethod");
  }
  @AfterMethod
  public void afterMethod() 
{
    System.out.println("afterMethod");
  }
}


运行结果(缩进为了看起来方便,我自己设置的)

beforeSuite
    beforeTest
        beforeClass
            beforeGroups
                beforeMethod
                    test1 from group1
               afterMethod
               beforeMethod
                    test11 from group1
               afterMethod
            afterGroups
            beforeMethod
                test2 from group2
            afterMethod
        afterClass
    afterTest
PASSED: test1
PASSED: test11
PASSED: test2
===============================================
    Default test
    Tests run: 3, Failures: 0, Skips: 0
===============================================
afterSuite
===============================================
Default suite
Total tests run: 3, Failures: 0, Skips: 0
===============================================


4. 异常测试


被测的程序

public void divide(int n){
      try {
        result = result / n;
      }catch(ArithmeticException ex){
        System.out.println(ex);
        throw new ArithmeticException("The n not allowed to 0!!");
      }
    }


测试程序

@Test(expectedExceptions = ArithmeticException.class)
public void divisionWithException() {
    calculator.add(9);
    calculator.divide(0);
}


5. 忽略测试


@Test(enabled=false)
public void TestNgLearn1() {
    System.out.println("this is TestNG test case1");
}


6.参数化


6.1使用textng.xml传送参数

test.xml
<?xml version="1.0" encoding="UTF-8"?>
<suite name="Suite" parallel="false">
  <test name="Test">
    <parameter name="first" value="3" />
    <parameter name="second" value="3"/>
    <parameter name="result" value="6"/>
    <classes>
      <class name="MyUnit.MyTestNG.MyTestNG"/>
    </classes>
  </test> <!-- Test -->
</suite> <!-- Suite -->


测试代码

@Test
@Parameters({"first","second","result"})
public void TestParemByXML(int first, int second,int result) {
  calculator.add(first);
  calculator.add(second);
  AssertJUnit.assertEquals(result,calculator.getResult());
}


注意

1. 只能设置一组参数

2. 必须运行test.xml,而非测试代码


6.2使用DataProvider传送参数

可以设置多组

@DataProvider(name = "provideNumbers")
public Object[][] provideData() {
    return new Object[][] { { 3, 3, 9 }, { -3, -3, 9 }, { 3, -3, -9 } };
}
@Test(dataProvider = "provideNumbers")
public void TestParemByDataProvider(int first, int second,int result) {
  calculator.add(first);
  calculator.multiply(second);
  AssertJUnit.assertEquals(result,calculator.getResult());
}


7.总结




JUnit4

JUnit5

TestNG

忽略测试

@Ignore

@Disabled

@Test(enabled=false)

延迟测试

@Test(timeout=1000 )

@Timeout(SECOND)

assertTimeoutPreemptively

不支持

参数化测试

@RunWith(Parameterized.class )

@ParameterizedTest

@ValueSource

@EnumSource

@MethodSource

@CsvFileSource

使用textng.xml

使用DataProvider

异常测试

不支持

Assertions.assertThrows

@Test(expectedExceptions

内嵌测试

不支持

@Nested

不支持

重复测试

不支持

@RepeatedTest(X)

不支持

动态测试

不支持

@TestFactory

不支持

分组断言

不支持

assertAll

不支持

工厂方法

不支持

不支持

@Factory

分组测试

@Categories

@Tag

@Test(groups="")

目录
相关文章
|
17天前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
68 8
|
23天前
|
人工智能 JavaScript 前端开发
自动化测试框架的演进与实践###
本文深入探讨了自动化测试框架从诞生至今的发展历程,重点分析了当前主流框架的优势与局限性,并结合实际案例,阐述了如何根据项目需求选择合适的自动化测试策略。文章还展望了未来自动化测试领域的技术趋势,为读者提供了宝贵的实践经验和前瞻性思考。 ###
|
12天前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
47 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
18天前
|
安全 Ubuntu Linux
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
38 9
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
|
22天前
|
Java 测试技术 API
探索软件测试中的自动化测试框架
本文深入探讨了自动化测试在软件开发中的重要性,并详细介绍了几种流行的自动化测试框架。通过比较它们的优缺点和适用场景,旨在为读者提供选择合适自动化测试工具的参考依据。
|
25天前
|
jenkins 测试技术 持续交付
自动化测试框架的搭建与实践
在软件开发领域,自动化测试是提升开发效率、确保软件质量的关键手段。本文将引导读者理解自动化测试的重要性,并介绍如何搭建一个基本的自动化测试框架。通过具体示例和步骤,我们将探索如何有效实施自动化测试策略,以实现软件开发流程的优化。
52 7
|
22天前
|
数据管理 jenkins 测试技术
自动化测试框架的设计与实现
在软件开发周期中,测试是确保产品质量的关键步骤。本文通过介绍自动化测试框架的设计原则、组件构成以及实现方法,旨在指导读者构建高效、可靠的自动化测试系统。文章不仅探讨了自动化测试的必要性和优势,还详细描述了框架搭建的具体步骤,包括工具选择、脚本开发、执行策略及结果分析等。此外,文章还强调了持续集成环境下自动化测试的重要性,并提供了实际案例分析,以帮助读者更好地理解和应用自动化测试框架。
|
23天前
|
监控 测试技术 定位技术
探索软件测试中的自动化测试框架选择与实施###
本文不概述传统意义上的摘要内容,而是直接以一段对话形式引入,旨在激发读者兴趣。想象一下,你是一名勇敢的探险家,面前摆满了各式各样的自动化测试工具地图,每张地图都指向未知的宝藏——高效、精准的软件测试领域。我们将一起踏上这段旅程,探讨如何根据项目特性选择合适的自动化测试框架,并分享实施过程中的关键步骤与避坑指南。 ###
33 4
|
22天前
|
敏捷开发 测试技术 持续交付
自动化测试之美:从零开始搭建你的Python测试框架
在软件开发的马拉松赛道上,自动化测试是那个能让你保持节奏、避免跌宕起伏的神奇小助手。本文将带你走进自动化测试的世界,用Python这把钥匙,解锁高效、可靠的测试框架之门。你将学会如何步步为营,构建属于自己的测试庇护所,让代码质量成为晨跑时清新的空气,而不是雾霾中的忧虑。让我们一起摆脱手动测试的繁琐枷锁,拥抱自动化带来的自由吧!
|
23天前
|
测试技术 持续交付 数据安全/隐私保护
软件测试的艺术与科学:探索自动化测试框架
在软件开发的世界中,测试是确保产品质量的关键环节。本文将深入探讨自动化测试框架的重要性和实现方法,旨在为读者揭示如何通过自动化测试提升软件测试效率和准确性。我们将从测试的基本概念出发,逐步引导读者了解自动化测试框架的设计和实施过程,以及如何选择合适的工具来支持测试活动。文章不仅提供理论知识,还将分享实用的代码示例,帮助读者将理论应用于实践。无论你是测试新手还是经验丰富的开发者,这篇文章都将为你打开一扇通往更高效、更可靠软件测试的大门。
24 1