- 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 vs JUnit
- TestNG 有用资源
- TestNG - 快速指南
- TestNG - 有用资源
- TestNG - 讨论
TestNG - 基本注解 - BeforeSuite
@BeforeSuite 注解的方法将在执行文件夹中或TestNG套件内定义的所有测试用例之前运行。例如,当您有单独的URL来测试所有测试用例时,可以使用此注解。环境变量可以在@BeforeSuite注解的方法中设置。接下来,在执行所有测试用例之前,您需要先加载框架的所有环境变量,然后开始执行测试用例。
@BeforeSuite 注解支持以下属性列表
| 属性 | 描述 |
|---|---|
alwaysRun |
对于before方法(beforeSuite、beforeTest、beforeTestClass和beforeTestMethod,但不包括beforeGroups):如果设置为true,则无论此配置方法属于哪个组,都将运行。 对于after方法(afterSuite、afterClass……):如果设置为true,则即使之前调用的一个或多个方法失败或被跳过,此配置方法也将运行。 |
dependsOnGroups |
此方法依赖的组列表。 |
dependsOnMethods |
此方法依赖的方法列表。 |
enabled |
此类/方法上的方法是否启用。 |
groups |
此类/方法所属的组列表。 |
inheritGroups |
如果为true,则此方法将属于类级别@Test注解中指定的组。 |
onlyForGroups |
仅用于@BeforeMethod和@AfterMethod。如果指定,则只有当相应的测试方法属于列出的组之一时,才会调用此设置/拆卸方法。 |
创建类
创建一个要测试的Java类,例如,在/work/testng/src中创建MessageUtil.java。
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message) {
this.message = message;
}
// prints the message
public String printMessage() {
System.out.println(message);
return message;
}
}
创建测试用例类
创建一个Java测试类,例如,在/work/testng/src中创建TestAnnotationBeforeSuite.java。
向测试类添加测试方法testMethod()。
向testMethod()方法添加@Test注解。
向测试类添加一个带有@BeforeSuite注解的beforeSuite方法。
实现测试条件并检查@BeforeSuite注解的行为。
以下是TestAnnotationBeforeSuite.java的内容
import org.testng.Assert;
import org.testng.annotations.Test;
import org.testng.annotations.BeforeSuite;
public class TestAnnotationBeforeSuite {
MessageUtil messageUtil = new MessageUtil("Test method");
@BeforeSuite
public void beforeSuite(){
System.out.println("Before Suite method");
}
@Test
public void testMethod(){
Assert.assertEquals("Test method", messageUtil.printMessage());
}
}
创建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">
<test thread-count="5" name="Test">
<classes>
<class name="TestAnnotationBeforeSuite"/>
</classes>
</test> <!-- Test -->
</suite> <!-- Suite -->
使用javac编译测试用例。
/work/testng/src$ javac TestAnnotationBeforeSuite.java MessageUtil.java
现在,运行testng.xml,它将运行在<test>标签中定义的测试用例。正如您所看到的,@BeforeSuite在所有其他测试用例之前被调用。
/work/testng/src$ java org.testng.TestNG testng.xml
验证输出。
Before Suite method Test method =============================================== Suite Total tests run: 1, Passes: 1, Failures: 0, Skips: 0 ===============================================