TestNG

官方地址:http://testng.org/doc/documentation-main.html

testNG是一个测试框架,旨在商业化广泛的测试需求,从单元测试到集成测试

特性:

①注释@

②多线程化

③支持数据驱动

④参数化

总结:灵活配置,注释,多线程安全,参数化及数据驱动

testNG三步过程

①编写测试的业务逻辑,并在代码中插入TestNG注释。

②在testng的.xml文件或build.xml中添加关于测试的信息(例如类名、您希望运行的组等等。)

③运行testNG

配置完成testNG

在pom.xml中添加testNG的配置:

  <!-- testng配置 -->
    <dependency>
      <groupId>org.testng</groupId>
      <artifactId>testng</artifactId>
      <version>6.9.9</version>
    </dependency>

仓库中下载所需jar包即完成配置

①编写测试的业务逻辑,并在代码中插入TestNG注释。

操作:在src/test/java中创建testNG类——>引入A,B

注:当testNG class文件创建完成后,即①②即完成,余下步骤是继续完善①②两步

新建testng类 File-new-Other-TestNG-TestNG.class

 

详解——testNG类文件

1.1查看注解相关

1.@DataProvider

 

@DataProvider(name)1)属性设置name="XX",@Test(dataProvider="XX")

                                          2)属性不设置name,@Test(dataProvider="方法名")

@DataProvidername(parallel)数量大时使用,需在testng.xml配置

data-provider-thread-count="20"

 

数据驱动的好处:数据和代码分离,代码耦合度低

ExcelUtil-->TestRun

2.@Test:官方文档

 

@Test(dataProvider)对应上面两种情况,@Test自己会循环每行数据

Object[][]有N列即需要有N个入参对应

@Test(dataProviderClass) :多个数据驱动

@Test(depandsOnGroups):先执行依赖的组

 

@Test(depandsOnMehods)

@Test(invocationCount) 方法执行的次数

@Test(invocationTimeOut) 必须和invocationCount一起用,规定时间内完成,否则超时报错

@Test(threadPoolSize)与invocationCout有关

@Test(timeOut)平时一般用timeout限制用例执行时间

@Test(successPercentage)用例单执行1次没必要设置,当设置invocation时可设置此属性

@Test(singleThread) 失效

以上解决执行效率的问题

@Test(invocationCount=100,invocationTimeOut=10000,successPercentage=99,threadPoolSize=4) //设置一个方法由四个线程共同调用100次,其中99%成功(实际生活中,需保证用例全部执行正确才算成功)

@Test(enabled)

@Test(priority)

②在testng的.xml文件或build.xml中添加关于测试的信息(例如类名、您希望运行的组等等)

 

1. 执行方式

基于类文件执行的好处:指定某类文件即执行某个类文件

                             不足:当包下类文件较多,用此方法效率较低

基于包执行

<packages>

      <package nane = "test.sample">

</packages>

 

类文件-include/exclude方式

<classes>

    <class name="com.youceedu.api.test.TestRun"/>

           <methods>

                 <exclude name="testExclude"/>

           </methods>

</classes>

总结:@Test用例不想执行的方法有哪些?1)@Test(enable=false)

                                                                    2)testng.xml配置include或exclude

                                                                    3)代码注释

 

 

parallel 4种设置+thread-count="n"

methods                    tests            classes                  instances

类中所有方法           @Test             类                        类的实例

注:invocationCount和thread-count选一种,是否用多线程执行要根据业务用例来定,当前的接口自动化不需要多线程

面试题:对方法执行parallel选用注解配置invocationCount还是对.xml配置thread-count?

③运行testNG

默认报告 autost\test-output\index.html(右键-属性-resources 复制目录路径,查看test-output)

(存在问题:基本信息都有,但不没关,缺少数据统计)

 

优化报告(引入reporter)

配置:pom.xml

配置:pom.xml配置(reporter.guice)

         注:reporng开源维护到1.1.4版本          报告地址:testng'项目名\test-output\heml\index.html

                guice是测试报告UI方面

         优化:testng.xml配置→配置listener

                    report.jar 优化出现圆饼图

 

 

参数配置位置

解决办法:在@beforeTest的方法下增加赋值,将参数传至testNG中

 

 

 

 

05-04
<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、付费专栏及课程。

余额充值