TestNg

介绍:

TestNG是一个测试框架,在 JUnit 和 NUnit 的基础上引入了新的功能,使它的功能更强大,使用更方便

一.安装,在idea上运行TestNg

     1.下载jar包  地址 或是 jar

            下载junit-4.12.jar,junit-4.12-javadoc.jar(文档),junit-4.12-sources.jar(源码)

             下载hamcrest-core-1.3.jar,hamcrest-core-1.3-javadoc.jar(文档),hamcrest-core-1.3-sources.jar(源码)

      2.添加jar包

           

      3.在src 同级目录下新建一个文件夹,测试类名建议以 类名+Test命名

                    

       4.Ctrl + Shift + T 生成@相关注解

       5.run....

整体目录结构是这样的

用到的注解有

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

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

@BeforeClas      注解的方法将只运行一次先行先试在当前类中的方法调用。

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

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

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

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

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

@BeforeMethod     注解的方法将每个测试方法之前运行

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

@DataProvider      

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

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

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

@Listeners       定义一个测试类的监听器

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

@Test       标记一个类或方法作为测试的一部分

运行方法

1.第一种直接执行:右键要执行的方法,  点Run As ->TestNG Test

2.通过testng.xml文件来执行. 把要执行的case, 放入testng.xml文件中。 右键点击testng.xml,   点Run As

文件

 <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Suite1">
    <test name="test12">
        <classes>
            <class name="TankLearn2.Learn.TestNGLearn1" />
        </classes>
    </test>
</suite>

抛出导常

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

测试组

@Test(groups = {"systemtest"})

参数传递

@Test
    @Parameters("test1")
    public void ParaTest(String test1){
        System.out.println("This is " + test1);
    }

忽略测试

 @Test(enabled = false)

依赖测试

@Test(dependsOnMethods = {"setupEnv"})

测试报告

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" ><suite name="Suite1">
    <test name="test12" verbose="2">
        <classes>
            <class name="TankLearn2.Learn.TestNGLearn1" />
        </classes>
    </test></suite>

 

 

 

<think>好的,我现在需要帮助用户了解TestNG框架的相关信息和使用方法。首先,我要回顾用户的问题,确保我准确理解他们的需求。用户提到“TestNG framework usage and documentation”,所以主要需要介绍TestNG的基本概念、核心功能以及使用方法,可能还需要包括配置和示例代码。 接下来,我需要回忆TestNG的主要特点。TestNG是一个测试框架,灵感来自JUnit和NUnit,但引入了更多功能,比如分组测试、参数化测试、依赖测试等。这些功能使得测试更灵活和强大。我需要分点解释这些功能,并给出具体例子,比如如何使用@Test注解,如何分组,如何参数化测试用例。 然后,用户可能需要了解如何配置TestNG。常见的配置方式包括Maven依赖和Gradle依赖,所以需要提供这两种构建工具的依赖代码块。同时,可能需要解释配置文件testng.xml的作用,以及如何通过XML文件来组织测试套件。 示例代码部分很重要,用户可能需要看到实际的测试类结构。应该提供一个简单的测试类示例,展示基本的@Test注解使用,以及可能用到的断言方法。此外,参数化测试也是一个亮点,可以用@DataProvider来演示如何提供不同的测试数据。 另外,用户可能对测试报告和运行方式感兴趣。TestNG生成的HTML报告默认位置在哪里,如何通过IDE或命令行运行测试,这些信息也需要涵盖。 还要注意用户提供的引用内容,虽然引用1提到测试在同一个进程中运行以利用缓存,引用2关于日志框架,引用3是TestNG的输出示例。虽然这些引用可能和用户当前问题关联不大,但如果有相关内容需要结合,可以适当提及,比如在配置测试运行时如何避免分叉进程以提升性能,但可能用户更关注TestNG本身的使用,所以这部分可能不需要深入。 最后,生成相关问题时要围绕TestNG的功能扩展,比如与JUnit的区别、并行测试、监听器、集成CI工具等,确保问题能够引导用户进一步探索。 现在需要组织这些信息,确保结构清晰,分步骤介绍,并包含代码示例和配置示例。同时,使用正确的中文表达,避免技术术语错误,并检查LaTeX格式是否符合要求,虽然用户的问题中没有涉及数学公式,但如果有测试方法中的参数或数据,可能需要使用行内公式,但这里可能不太需要,所以主要关注代码块和常规格式。</think>### TestNG框架使用指南 TestNG是基于Java的测试框架,提供比JUnit更丰富的功能,支持参数化测试、依赖管理、分组测试等特性。以下是核心功能和使用方法: #### 一、基础配置 1. **Maven依赖**: ```xml <dependency> <groupId>org.testng</groupId> <artifactId>testng</artifactId> <version>7.7.1</version> <scope>test</scope> </dependency> ``` 2. **Gradle依赖**: ```groovy testImplementation 'org.testng:testng:7.7.1' ``` #### 二、核心功能实现 1. **基础测试类**: ```java import org.testng.annotations.Test; import static org.testng.Assert.assertEquals; public class BasicTest { @Test public void testStringLength() { String str = "TestNG"; assertEquals(str.length(), 6); } } ``` 2. **分组测试**: ```java @Test(groups = {"regression", "smoke"}) public void loginTest() { // 登录功能测试 } @Test(groups = "regression") public void paymentTest() { // 支付功能测试 } ``` 3. **参数化测试**: ```java @DataProvider(name = "userData") public Object[][] provideData() { return new Object[][]{ {"admin", "admin123"}, {"user", "user123"} }; } @Test(dataProvider = "userData") public void testLogin(String username, String password) { System.out.println("Testing with: " + username + "/" + password); } ``` #### 三、测试套件配置 通过XML文件定义测试执行顺序和范围: ```xml <!DOCTYPE suite SYSTEM "https://testng.org/testng-1.0.dtd"> <suite name="RegressionSuite"> <test name="WebTests"> <classes> <class name="com.example.LoginTest"/> <class name="com.example.PaymentTest"/> </classes> </test> </suite> ``` #### 四、运行与报告 1. **IDE运行**:右键点击测试类或XML文件选择"Run as TestNG Test" 2. **命令行执行**: ```bash java -cp "path/to/testng.jar" org.testng.TestNG testng.xml ``` 3. **HTML报告**:默认生成在`test-output/index.html`,包含用例通过率、执行时间等详细信息 #### 五、高级特性 1. **依赖管理**: ```java @Test(dependsOnMethods = "initEnvironment") public void dataLoadTest() { // 需要先执行initEnvironment方法 } ``` 2. **超时控制**: ```java @Test(timeOut = 5000) // 单位:毫秒 public void apiResponseTest() { // 测试接口响应时间 } ``` [^1]: 测试执行时保持进程一致性可提升上下文缓存效率,这对TestNG的套件执行性能有直接影响
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值