Testng 简明教程

TestNG - Writing Tests

在 TestNG 中编写测试基本上涉及以下步骤 -

  1. 编写测试的业务逻辑并在你的代码中插入 TestNG 注解。

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

  3. Run TestNG.

在这里,我们将看到一个使用 POJO 类、业务逻辑类和一个由 TestNG 运行的测试 xml 的 TestNG 测试的完整示例。

/work/testng/src 中创建 EmployeeDetails.java ,这是一个 POJO 类。

public class EmployeeDetails {

   private String name;
   private double monthlySalary;
   private int age;

   // @return the name

   public String getName() {
      return name;
   }

   // @param name the name to set

   public void setName(String name) {
      this.name = name;
   }

   // @return the monthlySalary

   public double getMonthlySalary() {
      return monthlySalary;
   }

   // @param monthlySalary the monthlySalary to set

   public void setMonthlySalary(double monthlySalary) {
      this.monthlySalary = monthlySalary;
   }

   // @return the age

   public int getAge() {
      return age;
   }

   // @param age the age to set

   public void setAge(int age) {
      this.age = age;
   }
}

EmployeeDetails 类用于 -

  1. 获取/设置员工姓名值。

  2. 获取/设置员工月薪值。

  3. 获取/设置员工年龄值。

/work/testng/src 中创建一个 EmpBusinessLogic.java ,其中包含业务逻辑。

public class EmpBusinessLogic {

   // Calculate the yearly salary of employee
   public double calculateYearlySalary(EmployeeDetails employeeDetails) {
      double yearlySalary = 0;
      yearlySalary = employeeDetails.getMonthlySalary() * 12;
      return yearlySalary;
   }

   // Calculate the appraisal amount of employee
   public double calculateAppraisal(EmployeeDetails employeeDetails) {

      double appraisal = 0;

      if(employeeDetails.getMonthlySalary() < 10000) {
         appraisal = 500;

      } else {
         appraisal = 1000;
      }

      return appraisal;
   }
}

EmpBusinessLogic 类用于计算 -

  1. 员工的年薪。

  2. 员工的评估金额。

现在,让我们创建名为 TestEmployeeDetails.java 的 TestNG 类,位于 /work/testng/src 中。TestNG 类是包含至少一个 TestNG 注释的 Java 类。此类包含要测试的测试用例。可通过 @BeforeXXX 和 @AfterXXX 注释配置 TestNG 测试(我们将在章节 TestNG - Execution Procedure 中看到),以便在某个时间点之前和之后执行一些 Java 逻辑。

import org.testng.Assert;
import org.testng.annotations.Test;

public class TestEmployeeDetails {
   EmpBusinessLogic empBusinessLogic = new EmpBusinessLogic();
   EmployeeDetails employee = new EmployeeDetails();

   @Test
   public void testCalculateAppriasal() {

      employee.setName("Rajeev");
      employee.setAge(25);
      employee.setMonthlySalary(8000);

      double appraisal = empBusinessLogic.calculateAppraisal(employee);
      Assert.assertEquals(500, appraisal, 0.0, "500");
   }

   // Test to check yearly salary
   @Test
   public void testCalculateYearlySalary() {

      employee.setName("Rajeev");
      employee.setAge(25);
      employee.setMonthlySalary(8000);

      double salary = empBusinessLogic.calculateYearlySalary(employee);
      Assert.assertEquals(96000, salary, 0.0, "8000");
   }
}

TestEmployeeDetails 类用于测试 EmpBusinessLogic 类的方法。它执行以下操作 -

  1. 测试员工的年薪。

  2. 测试员工的评估金额。

在运行测试之前,必须使用一个特殊 XML 文件来配置 TestNG,该文件通常命名为 testng.xml。此文件的语法非常简单,且其内容如下所示。在 /work/testng/src 创建此文件。

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >

<suite name = "Suite1">
   <test name = "test1">
      <classes>
         <class name = "TestEmployeeDetails"/>
      </classes>
   </test>
</suite>

上述文件的详细信息如下:

  1. 一个套件由一个 XML 文件表示。它可以包含一个或多个测试,并由 <suite> 标记定义。

  2. <test> 标记表示一个测试,可以包含一个或多个 TestNG 类。

  3. <class> 标记表示一个 TestNG 类。它是包含至少一个 TestNG 注解的 Java 类。它可以包含一个或多个测试方法。

使用 javac 编译测试用例类。

/work/testng/src$ javac EmployeeDetails.java EmpBusinessLogic.java TestEmployeeDetails.java

现在使用以下命令对 TestNG 进行测试:

/work/testng/src$ java org.testng.TestNG testng.xml

如果一切顺利,你应该可以在控制台中看到自己测试的结果。此外,TestNG 会在当前目录中自动创建一个名为 test-output 的文件夹,并在其中创建一个非常不错的 HTML 报告。如果你将其打开并加载 index.html,你将会看到一个与下图中类似的页面:

writing tests