lsekfe 发表于 2024-4-30 11:31:46

TestNG自动化测试框架实战详解

1、TestNG 导言

在软件测试工作中,自动测试框架是不可或缺的,之前有Junit和Nunit框架,后有TestNG。TestNG不但吸取了Junit和Nunit框架的思想,而且创造了更强大的功能,它不但是单元测试框架,同时也是集成自动化测试框架。TestNG突破了以前一些测试框架的限制,成为用途最广泛的自动和单元测试框架之一,大家由浅入深地一起认识TestNG的强大之处,实现从初级测试工程师到资深测试工程师的进阶!
2、TestNG - 初步认知
软件测试是检查应用程序功能以确保其按要求运行的过程。单元测试由开发人员编码中开展,其中采取了足够的措施来测试每个实体(类或方法)以确保最终产品满足要求.TestNG不仅支持单元测试,同时,是很优秀的的自动化测试框架。
JUnit促使开发人员了解与任何其他测试框架相比,测试的有用性,特别是单元测试的有用性.利用相当简单,实用和严格的架构,JUnit能够"感染"大量的开发人员,JUnit同时也有一些缺点:ü最初设计用于启用单位仅测试,现在用于各种测试.ü无法进行依赖性测试.ü配置控制不佳(setUp/tearDown).üIntrusive(强制你扩展类并以某种方式命名你的方法).ü静态编程模型(强制您不必要地重新编译).ü管理不同的测试套件复杂的项目可能非常棘手.

3、TestNG 定义
TestNG是一个受JUnit和NUnit启发的测试框架,但引入了一些新功能,使其功能更强大,更易于使用.TestNG是一个开源自动化测试框架,其中 NG 表示 N ext G 通气.TestNG类似于JUnit(尤其是JUnit 4),但它不是JUnit扩展,它的灵感来自JUnit.它的设计优于JUnit,尤其是在自动化测试时. TestNG的创建者是 Cedric Beust .消除旧框架的大多数限制,TestNG使开发人员能够编写更灵活,更强大的测试.由于它大量借鉴Java Annotations(用JDK 5.0引入)来定义测试,它还可以向您展示如何在真实的生产环境中使用Java语言的这一新功能.
4、TestNG功能

ü支持注释.üTestNG使用更多Java和OO功能.ü支持测试集成类(例如,默认情况下,不需要为每个测试方法创建新的测试类实例).ü将编译时测试代码与运行时配置/数据信息分开.ü灵活的运行时配置.ü介绍'测试组'编译完测试后,可以让TestNG运行所有"前端"测试,或"快速","慢速","数据库"测试等.ü支持相关测试方法,并行测试,负载测试和部分故障.ü灵活的插件API.ü支持多线程测试.

5、TestNG - 环境和编辑工具
TestNG是Java的框架,因此第一个要求是在您的计算机上安装JDK. 需要安装idea 开发工具或者eclipse等编码工具。
6、JDK系统配置要求

7、JDK1.8的安装及环境变量的配置
1、https://www.oracle.com/java/technologies/downloads/下载JDK 安装包

2.具体安装步骤点击下一步:C盘空间足够可以傻瓜式安装到C盘,也可自行更改路径到D盘
更改路径的具体步骤:2:复制红色框中的名称并在刚刚新建Java文件夹中再新建一个为其文件名的文件夹(注:文件名不要任何有其他字符)


4:下一步:

二.环境变量的配置这里以win11系统为例:1.首先win+E打开文件管理器,找到此电脑图标,右击选择属性


2.选择高级系统设置

3.选择环境变量

4.配置环境变量(注:这里选择配置系统变量而不是用户变量)


5.以此输入变量名和变量值后点击确认变量名:JAVA_HOME变量值: 这里是刚刚你安装jdk的路径,如果是一步一步跟着安装的可以输入:D:\Java\jdk1.8.0_131



6.点击path并进行编辑

7.点击新建


8.输入%JAVA_HOME%\bin



9.点击确认

三.确保jdk是否安装并配置成功1.win+r输入cmd打开命令窗口输入javac,如果出现以下提示表示安装配置成功
javac
java -version




8、TestNG - 基本注释
在JUnit 3中指示测试方法的传统方法是在名称前加上test.这是一种非常有效的方法,用于将类中的某些方法标记为具有特殊含义,但命名不能很好地扩展(如果我们想为不同的框架添加更多标记,会怎样?)并且相当不灵活(如果我们怎么办?想要将其他参数传递给测试框架?).注释在JDK 5中正式添加到Java语言中,TestNG可以选择使用注释来注释测试类.以下是TestNG支持的注释列表 :


序号
注释&说明
1
@BeforeSuite在此套件中的所有测试运行之前,带注释的方法只运行一次.
2
@AfterSuite在此套件中的所有测试运行后,带注释的方法只运行一次.
3
@BeforeClass注释方法只会在调用当前类的第一个测试方法之前运行一次.
4
@AfterClass带注释的方法仅会运行一旦所有当前类的测试方法都已运行.
5
@BeforeTest带注释的方法将在任何属于<test>的测试方法之前运行.
6
@AfterTest带注释的方法将在属于<test>的类的所有测试方法之后运行
7
@BeforeGroups此配置方法之前将运行的组列表.保证在调用属于任何这些组的第一个测试方法之前不久运行此方法.注释的方法只会在属于指定组的所有测试方法执行之前运行一次。
8
@AfterGroups组列表此配置方法将在之后运行.保证在调用属于任何这些组的最后一个测试方法后不久运行此方法.
9
@BeforeMethod带注释的方法将在每种测试方法之前运行.
10
@AfterMethod带注释的方法将在每种测试方法之后运行.
11
@ DataProvider将方法标记为为测试方法提供数据.带注释的方法必须返回一个Object [] [],其中每个Object []都可以分配测试方法的参数列表.想要从此DataProvider接收数据的@Test方法需要使用dataProvider名称等于此批注的名称.
12
@FactoryMarks作为工厂的方法,返回将由TestNG用作Test类的对象.该方法必须返回Object [].
13
@Listeners在测试类上定义侦听器.
14
@Parameters描述如何将参数传递给@Test方法.
15
@Test标记a作为测试一部分的类或方法.

9、使用注释的优点
以下是使用注释和减号的一些好处:² TestNG识别通过查找注释,它感兴趣的方法.因此,方法名称不限于任何模式或格式.² 我们可以将其他参数传递给注释.² 注释是强类型的,因此编译器会立即标记任何错误.² 测试类不再需要扩展任何内容(如作为TestCase,用于JUnit3).

10、TestNG - 执行程序案例演示

TestNgExecutionOrder.java案例代码如下:packagecom.test; importorg.testng.annotations.*; /** * @author Fson * @date 2024/1/26 14:06 */publicclass TestNgExecutionOrder {    //test case1    @Test    public void testCase1(){      System.out.println("in testcase1");    }    //test case2    @Test    public void testCase2(){      System.out.println("in testcase2");    }    // test beforeMethod    @BeforeMethod    public void testBeforeMethod(){      System.out.println("inbeforeMethod 每次执行Test 方法前执行");    }    // test afterMethod    @AfterMethod    public void testAfterMethod(){      System.out.println("in afterMethod每次执行test 方法后执行");    }    // test beforeClass@BeforeClass    public void testBeforeClass(){System.out.println("inbeforeClasstestcase1 执行注释方法只会在调用当前类的第一个测试方法之前运行一次");    }    // test AfterClass    @AfterClass    public void testAferClass(){      System.out.println("in afterClasstestcase1 执行带注释的方法仅会运行一旦所有当前类的测试方法都已运行.");     }    // test BeforeTest    @BeforeTest    public void testBeforeTest(){      System.out.println("inBeforeTest(比如先登录)执行完suit执行BeforeTest 带注释的方法将在任何属于该方法的测试方法之前运行里面的课程LT;试验>标签运行.");    }    // test AfterTest    @AfterTest    public void TestAfterTest(){      System.out.println("in afterTest (比如退出登录)带注释的方法将在属于<test>内的类的所有测试方法之后运行.标签已经运行.");    }    // test beforeSuite    @BeforeSuite    public void testBeforeSuite(){      System.out.println("in beforeSuite最早执行 在此套件中的所有测试运行之前,带注释的方法只运行一次.");    }    // test @AfterSuite   @AfterSuite    public void testAfterSuite(){      System.out.println("in afterSuite 最后执行 在此套件中的所有测试运行后,带注释的方法只运行一次. ");    } }
代码中直接运行效果如下:


根据以上输出,执行程序如下 :
Ø首先,beforeSuite()方法只执行一次.Ø最后,afterSuite()方法只执行一次.Ø甚至方法beforeTest(),beforeClass(),afterClass()和afterTest()方法也只执行一次.ØbeforeMethod()方法为每个测试用例执行但在执行测试用例之前.ØafterMethod()方法在执行测试用例后执行每个测试用例.Ø在beforeMethod()和afterMethod()之间,每个测试用例都会执行.
通过testng.xml 配置文件运行程序

让我们在其中创建 testng.xml 文件 /work/testng/src,执行测试用例。此文件以XML 格式捕获您的整个测试。该文件使您可以轻松地在一个文件中描述所有测试套件及其参数,您可以将其签入代码存储库或通过电子邮件发送给同事。它还可以轻松提取测试的子集或拆分多个运行时配置(例如,testngdatabase.xml 将仅运行测试您的数据库的测试)。


<?xml version="1.0" encoding="UTF-8"?>
<!--@beforeSuite-->
<suite name="tester">
    <test name="case1">
    <classes>
      <class name="com.test.TestNgExecutionOrder" />

    </classes>
    </test>

</suite>
右键--->run TestNgExecution.xml


创建testng.xml文件

运行TestNG测试脚本有两种方式:一种是直接通过IDE运行(例如使用eclipse中的“Run TestNG tests”),另一种是从命令行运行(通过使用xml配置文件)。当我们想执行某个包或者某个类中的一部分测试脚本的时候,使用xml配置文件是非常便利的。在xml配置文件里,不仅可以选择某些需要执行的测试脚本,还可以排除某些不需要运行的测试脚本。
创建xml文件很容易,只需要在其中填充一些内容。可以同时执行多个类中间的测试方法。

首先要声明一个suite的名字,用于描述将要运行的测试脚本集,可以根据自己需要任意命名,最终这个名字会在testng的测试报告中看到。


<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="SuiteName" verbose="1" >
<test name="TestName" >
</test>

</suite>
如果选择的测试脚本是基于组的(使用了@Test (groups={"student"})这样的注解),那么接下来需要声明如何使用这些组:包含或者排除。如果使用了include标签标注某些组,那么在选择的测试脚本中,只有属于那些组的测试脚本会被运行。那些未被选中的测试脚本,或者被选中却不属于某些组的测试脚本都不会被运行。需要注意,一个测试脚本可以属于很多个组,只要有一个组被include标签标注,那么它就会被运行。如果使用了exclude标签标注某些组,那么在选择的脚本中,只有不属于那些组的测试脚本会被运行。如果同时使用了include标签和exclude标签,那么拥有被include标注的组的那些脚本会被运行,拥有被exclude标注的脚本不会被运行。有一个例外是,一个组同时被include和exclude标注了,那么拥有这个组的脚本会被运行。include和exclude标签的使用方式如下:
<groups>
<run>
   <include name = "includedGroupName" />
   <exclude name = "excludedGroupName" />
</run>
</groups>
11、TestNG include
include 在testng.xml 中间指定需要执行的方法,如果只执行类中间的指定方法,需要通过testng.xml 配置文件选中需要执行的方法,未包含的方法将不会执行.


IncludeTest.java案例代码
package com.test;

import org.testng.annotations.Test;

/**
* @author Fson
* @date 2024/2/20 14:20
* include 在testng.xml 中间指定需要执行的方法
*/
public class IncludeTest {
    @Test
    public void testRun(){
      System.out.println("+++++++++++++++testRun+++++++++++");
    }
    @Test
    public void testNotRun(){
      System.out.println("+++++++++++testNotRun+++++++++++++++++++++++");
    }
    @Test
    public void testTwoRun(){
      System.out.println("++++++++testTwoRun++++++++++++++");
    }
}
案例运行效果如下:


TestNG exclude
与include对立的是exclude,比如除去test01方法以外其他都运行,就用exclude,如果需要排除某个方法不执行,其他的方法都需要执行,就需要在testng.xml 配置文件中间用该关键字

ExcludeTest.java案例代码
package com.test;

import org.testng.annotations.Test;

/**
* @author Fson
* @date 2024/2/20 14:42
* exclude 排除该方法之外 所有的方法都执行 比如 该类中间有3个方法test01test02test03 除了test01 方法外 其他的方法都执行
* 就可以用该关键词
*/
public class ExcludeTest {
    @Test
    public void test01(){
      System.out.println("test01()");
    }
    @Test
    public void test02(){
      System.out.println("test02()");
    }
    @Test
    public void test03(){
      System.out.println("test03()");
    }

}
ExcludeTestNG.xml 案例配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!--@beforeSuite-->
<suite name="IncludeTestNG">
    <test name="IncludeTest">
    <classes>
      <class name="com.test.ExcludeTest" />
      <methods>
            <exclude name="test01"></exclude>
      </methods>
    </classes>
    </test>

</suite>
案例运行效果:


12、TestNG 自动化测试框架完整案例并输出报告
Testng_before_after_class.java 案例代码
package com.test;

import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test;

/**
* @author Fson
* @date 2024/1/16 14:06
*/
/*
* 四、注解说明
TestNG支持多种注解,可以进行各种组合,如下进行简单的说明

注解 描述
@BeforeSuite在该套件的所有测试都运行在注释的方法之前,仅运行一次
@AfterSuite在该套件的所有测试都运行在注释方法之后,仅运行一次
@BeforeClass在调用当前类的第一个测试方法之前运行,注释方法仅运行一次
@AfterClass在调用当前类的第一个测试方法之后运行,注释方法仅运行一次
@BeforeTest注释的方法将在属于test标签内的类的所有测试方法运行之前运行
@AfterTest注释的方法将在属于test标签内的类的所有测试方法运行之后运行
@BeforeGroups配置方法将在之前运行组列表。 此方法保证在调用属于这些组中的任何一个的第一个测试方法之前不久运行
@AfterGroups此配置方法将在之后运行组列表。该方法保证在调用属于任何这些组的最后一个测试方法之后不久运行
@BeforeMethod注释方法将在每个测试方法之前运行
@AfterMethod注释方法将在每个测试方法之后运行
@DataProvider标记一种方法来提供测试方法的数据。 注释方法必须返回一个Object [] [],其中每个Object []可以被分配给测试方法的参数列表。要从该DataProvider接收数据的@Test方法需要使用与此注释名称相等的dataProvider名称
@Factory将一个方法标记为工厂,返回TestNG将被用作测试类的对象。该方法必须返回Object []
@Listeners定义测试类上的侦听器
@Parameters描述如何将参数传递给@Test方法
@Test 将类或方法标记为测试的一部分,此标记若放在类上,则该类所有公共方法都将被作为测试方法




常用注解使用:
1.@BeforeClass @AfterClass 在运行类之前或之后执行一次
@BeforeClass中可写入初始数据
@AfterClass 清除数据
testng_before_after_class.java
*
*
*
*
*
* */
public class Testng_before_after_class {
    // 运行testng_before_after_class 类的时,会执行一次
    @BeforeClass
    public void BeforeClass(){
      System.out.println("BeforeClass 被运行登录");

    }
    @AfterTest
    public void AfterClass(){
      System.out.println("AfterClass 被运行退出登录");

    }
    // 运行每个测试方法进都会被执行到
@Test
    public void abc(){
      System.out.println("这里是abc");
}
@Test
    public void abc1(){
      System.out.println("这里是abc1");
}
@Test
    public void abc2(){
      System.out.println("这里是abc2");
}
@Test
    public void exportBaogao(){
      System.out.println("+++++++++++查看输出报告+++++");
}
}
testng_before.xml 案例配置文件
<suite name="tester_before_suite1" parallel="methods" thread-count="2">
<test name="test_before">
    <classes>
      <class name="com.test.Testng_before_after_class" />

    </classes>


</test>
</suite>

案例运行效果:


生成TestNG自带的默认报告Use Default Reportters

设置报告输出路径run-->Edit configuration


html 文件存放路径:


可以直接把该文件复制出来,浏览器打开开一下效果,TestNG 自动生成测试报告如下:




页: [1]
查看完整版本: TestNG自动化测试框架实战详解