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
===============================================

广告