- TestNG 教程
- TestNG - 首页
- TestNG - 概述
- TestNG - 环境
- TestNG - 编写测试
- TestNG - 基本注解
- TestNG - 执行流程
- TestNG - 执行测试
- TestNG - 套件测试
- TestNG - 忽略测试
- TestNG - 组测试
- TestNG - 异常测试
- TestNG - 依赖测试
- TestNG - 参数化测试
- TestNG - 运行 JUnit 测试
- TestNG - 测试结果
- TestNG - 注解转换器
- TestNG - 断言
- TestNG - 并行执行
- TestNG - 与 ANT 集成
- TestNG - 与 Eclipse 集成
- TestNG - TestNG 与 JUnit 的比较
- TestNG 有用资源
- TestNG - 快速指南
- TestNG - 有用资源
- TestNG - 讨论
TestNG - 基本注解 - 参数
@Parameters 描述了如何将参数传递给 @Test 方法。主要有两种方式可以为测试方法提供参数值
通过 testng XML 配置文件
通过 DataProviders
以下是 @Listeners 注解支持的属性列表
| 属性 | 描述 |
|---|---|
value |
用于填充此方法参数的变量列表。 |
@Parameters 注解可以放置在以下位置
在任何已经具有 @Test、@Before/After 或 @Factory 注解的方法上。
在测试类的一个构造函数上。每当需要实例化测试类时,TestNG 将使用在 testng.xml 中指定的参数值调用此特定构造函数。此功能可用于将类内部的字段初始化为将在测试方法中使用的值。
创建测试用例类
让我们看看如何使用 @Parameters 注解
创建一个 Java 测试类,例如,TestAnnotationParameter.java,位于 /work/testng/src 中。
向您的测试类添加一个测试方法 testparameter()。
向 testparameter() 方法添加一个 @Test 注解。指定 Java 方法的参数 firstName 应接收名为 first-name 的 XML 参数的值。此 XML 参数在 testng.xml 中定义。
以下是 TestAnnotationParameter.java 的内容。
import org.testng.annotations.Test;
import org.testng.annotations.Parameters;
public class TestAnnotationParameter {
@Parameters({ "first-name" })
@Test
public void testparameter(String firstName) {
System.out.println("Invoked method testparameter with string " + firstName);
}
}
创建 testng.xml
接下来,让我们在 /work/testng/src 中创建 testng.xml 文件,以执行测试用例。此文件以 XML 格式捕获整个测试过程。此文件使您可以轻松地在单个文件中描述所有测试套件及其参数,您可以将其检入代码库或通过电子邮件发送给同事。它还使您可以轻松地提取测试子集或拆分多个运行时配置(例如,testngdatabase.xml 将仅运行测试您的数据库的测试)。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "https://testng.org/testng-1.0.dtd">
<suite name="Suite">
<parameter name="first-name" value="TutorialsPoint"/>
<test thread-count="5" name="Test">
<classes>
<class name="TestAnnotationParameter"/>
</classes>
</test> <!-- Test -->
</suite> <!-- Suite -->
使用 javac 编译测试用例。
/work/testng/src$ javac TestAnnotationParameter.java
现在,运行 testng.xml,它将运行在 <test> 标签中定义的测试用例。
/work/testng/src$ java org.testng.TestNG testng.xml
验证输出。
Invoked method testparameter with string TutorialsPoint =============================================== Suite Total tests run: 1, Passes: 1, Failures: 0, Skips: 0 ===============================================