TestNG - 组测试

TestNG - 组测试

组测试是TestNG 中一个新的创新特性,它在JUnit 框架中是不存在的。它允许您将方法分派到适当的部分并执行复杂的测试方法分组。

您不仅可以声明属于组的那些方法,还可以指定包含其他组的组。然后,可以调用 TestNG 并要求它包含一组特定的组(或正则表达式),同时排除另一组。

组测试在如何划分测试方面提供了最大的灵活性,并且如果您想背靠背运行两组不同的测试,则不需要重新编译任何内容。

使用 标记在 testng.xml 文件中指定组。它可以在 或 标签下找到。 标记中指定的组适用于下面的所有 标记。

现在,让我们举一个例子来看看组测试是如何工作的。

创建一个类
  • 创建一个要测试的java类,比如说, MessageUtil.java/work/testng/src.
/*
* 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;
   }
   // add "jc2182" to the message
   public String salutationMessage() {
      message = "jc2182" + message;
      System.out.println(message);
      return message;
   }
   // add "www." to the message
   public String exitMessage() {
      message = "www." + message;
      System.out.println(message);
      return message;
   }
}

创建测试用例类
  • 创建一个 java 测试类,比如说, GroupTestExample.java/work/testng/src.
  • 将测试方法 testPrintMessage() 和 testSalutationMessage() 添加到您的测试类。
  • 将测试方法分为两类 -
    • Check-in tests (checkintest)- 这些测试应该在您提交新代码之前运行。它们通常应该很快,并且确保没有基本功能被破坏。
    • Functional tests (functest) − 这些测试应涵盖您软件的所有功能,并且每天至少运行一次,尽管理想情况下您希望连续运行它们。

以下是内容 GroupTestExample.java.

import org.testng.Assert;
import org.testng.annotations.Test;
public class GroupTestExample {
   String message = ".com";
   MessageUtil messageUtil = new MessageUtil(message);
   @Test(groups = { "functest", "checkintest" })
   public void testPrintMessage() {
      System.out.println("Inside testPrintMessage()");
      message = ".com";
      Assert.assertEquals(message, messageUtil.printMessage());
   }
   @Test(groups = { "checkintest" })
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "jc2182" + ".com";
      Assert.assertEquals(message, messageUtil.salutationMessage());
   }
   @Test(groups = { "functest" })
   public void testingExitMessage() {
      System.out.println("Inside testExitMessage()");
      message = "www." + "jc2182"+".com";
      Assert.assertEquals(message, messageUtil.exitMessage());
   }
}

创建 testng.xml

在中创建 testng.xml /work/testng/src, 执行测试用例。在这里,我们将只执行那些属于functest组的测试

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
   <test name = "test1">
      <groups>
         <run>
            <include name = "functest" />
         </run>
      </groups>
      <classes>
         <class name = "GroupTestExample" />
      </classes>
   </test>
</suite>

组组

组还可以包括其他组

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
   <test name = "test1">
      <groups>
         <define name = "all">
            <include name = "functest"/>
            <include name = "checkintest"/>
         </define>
         <run>
            <include name = "all"/>
         </run>
      </groups>
      <classes>
         <class name = "GroupTestExample" />
      </classes>
   </test>
</suite>

排除组
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
   <test name = "test1">
      <groups>
         <define name = "all">
          	<!使用 exclude 排除>
            <exclude name = "functest"/>
            <include name = "checkintest"/>
         </define>
         <run>
            <include name = "all"/>
         </run>
      </groups>
      <classes>
         <class name = "GroupTestExample" />
      </classes>
   </test>
</suite>

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一个双鱼座的测开

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值