【全网最全】TestNG自动测试框架异常和依赖测试教程

TestNG异常测试

TestNG跟踪异常处理代码提供了一个选项。可以测试是否需要代码抛出异常或不抛出。 @Test注释expectedExceptions 参数一起使用。现在,让我们来看看@Test(expectedExceptions)在动作中。

创建一个类

  • 创建一个Java类进行测试说MessageUtil.java 在 C:\ > TestNG_WORKSPACE

  • 在printMessage()方法里添加一个错误条件

/*
* 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 void printMessage(){
      System.out.println(message);
      int a =0;
      int b = 1/a;
   }   

   // add "Hi!" to the message
   public String salutationMessage(){
      message = "Hi!" + message;
      System.out.println(message);
      return message;
   }   
}  	

创建测试案例类

  • 创建一个Java测试类为 ExpectedExceptionTest.java。

  • 添加的ArithmeticException 和 testPrintMessage()测试用例的预期异常。

创建一个Java类文件名ExpectedExceptionTest.java 在 C:\ > TestNG_WORKSPACE

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

public class ExpectedExceptionTest {
    String message = "Manisha";	
    MessageUtil messageUtil = new MessageUtil(message);
	   
    @Test(expectedExceptions = ArithmeticException.class)
    public void testPrintMessage() {	
        System.out.println("Inside testPrintMessage()");     
        messageUtil.printMessage();     
   }
   @Test
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "Hi!" + "Manisha";
      Assert.assertEquals(message,messageUtil.salutationMessage());
   }
}

创建测试运行

创建 testng.xml 在 C:\ > TestNG_WORKSPACE 执行测试案例。

<?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="ExpectedExceptionTest" />
	</classes>
   </test>
</suite>	

编译MessageUtil 测试用例类使用javac

C:\TestNG_WORKSPACE>javac MessageUtil.java TestJunit.java

现在,运行测试运行,这将运行提供的测试用例类中定义的测试用例。

C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml

验证输出。testPrintMessage()测试的情况下会获得通过。

Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha

===============================================
Suite1
Total tests run: 2, Failures: 0, Skips: 0
===============================================

【全网最全】TestNG自动化测试框架入门到实战

 

 

【全网最全】TestNG自动化测试框架入门到实战 

TestNG依赖测试

有时候,你可能需要在一个特定的顺序调用方法在测试案例,或你想分享一些数据和方法之间的状态。TestNG支持这种依赖测试方法之间的显式依赖它支持声明。

TestNG允许指定依赖,无论与否:

  • 使用属性dependsOnMethods在 @Test 注释OR

  • 使用属性dependsOnGroups在@Test注解。

使用属性dependsOnMethods例如

创建一个类

创建一个Java类进行测试为 MessageUtil.java 在 C:\ > TestNG_WORKSPACE

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 "Hi!" to the message
    public String salutationMessage() {
	message = "Hi!" + message;
	System.out.println(message);
	return message;
    }
}

创建测试案例类

  • 创建一个Java测试类为 DependencyTestUsingAnnotation.java.

  • 添加方法 testPrintMessage(), testSalutationMessage() 和 initEnvironmentTest() 到测试类

  • 添加属性 dependsOnMethods = { "initEnvironmentTest" } to the @Test 注释oftestSalutationMessage() 方法.

创建Java类文件名 DependencyTestUsingAnnotation.java 在 C:\ > TestNG_WORKSPACE

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

public class DependencyTestUsingAnnotation {
    String message = "Manisha";
    MessageUtil messageUtil = new MessageUtil(message);

    @Test
    public void testPrintMessage() {
	System.out.println("Inside testPrintMessage()");
	message = "Manisha";
	Assert.assertEquals(message, messageUtil.printMessage());
    }

    @Test(dependsOnMethods = { "initEnvironmentTest" })
    public void testSalutationMessage() {
        System.out.println("Inside testSalutationMessage()");
	message = "Hi!" + "Manisha";
	Assert.assertEquals(message, messageUtil.salutationMessage());
    }

    @Test
    public void initEnvironmentTest() {
	System.out.println("This is initEnvironmentTest");
    }
}

创建TESTNG.XML

创建一个文件 testng.xml 在 C:\ > TestNG_WORKSPACE 来执行测试用例

<?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="DependencyTestUsingAnnotation" />
	</classes>
    </test>
</suite>

编译MessageUtil的测试用例类使用javac

C:\TestNG_WORKSPACE>javac MessageUtil.java DependencyTestUsingAnnotation.java

现在运行 testng.xml  这将会运行 testSalutationMessage() 只有在执行 ofinitEnvironmentTest() 方法之后

C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml

验证输出

This is initEnvironmentTest
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha

===============================================
Suite1
Total tests run: 3, Failures: 0, Skips: 0
===============================================

示例,使用属性dependsOnGroups

也可以依赖于整个群组的方法。让我们来看看下面的例子:

创建一个类

创建一个Java类进行测试为 MessageUtil.java 在 C:\ > TestNG_WORKSPACE

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 "Hi!" to the message
    public String salutationMessage() {
	message = "Hi!" + message;
	System.out.println(message);
	return message;
    }
}

创建测试案例类

  • 创建一个Java测试类说依赖TestUsingAnnotation.java.

  • 添加测试方法  testPrintMessage(), testSalutationMessage() 和 initEnvironmentTest() 测试类和他们的组 "初始化"

  • 添加属性 dependsOnMethods = { "init.*" } to the @Test 注释 testSalutationMessage() 方法

创建Java类文件名 DependencyTestUsingAnnotation.java 在 C:\ > TestNG_WORKSPACE

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

public class DependencyTestUsingAnnotation {
    String message = "Manisha";
    MessageUtil messageUtil = new MessageUtil(message);

    @Test(groups = { "init" })
    public void testPrintMessage() {
	System.out.println("Inside testPrintMessage()");
	message = "Manisha";
	Assert.assertEquals(message, messageUtil.printMessage());
    }

    @Test(dependsOnGroups = { "init.*" })
    public void testSalutationMessage() {
	System.out.println("Inside testSalutationMessage()");
	message = "Hi!" + "Manisha";
	Assert.assertEquals(message, messageUtil.salutationMessage());
    }

    @Test(groups = { "init" })
    public void initEnvironmentTest() {
	System.out.println("This is initEnvironmentTest");
    }
}

在这个例子中,testSalutationMessage()被声明为根据任何一组匹配正则表达式“的init*”,这保证了,一种方法,testPrintMessage的()和initEnvironmentTest()将始终前testSalutationMessage()被调用。

如果一个方法失败,取决于你有一个很难依赖于它(alwaysRun= false,这是默认的),没有标记的方法依赖于它的失败,但作为跳过。跳过的方法将被报告为例如在最终报告(在HTML中,既不是红也不是绿的颜色),这是很重要的,因为跳过的方法不一定是失败。

创建TESTNG.XML

创建一个文件testng.xml C:\ > TestNG_WORKSPACE 执行测试案例

<?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="DependencyTestUsingAnnotation" />
	</classes>
    </test>
</suite>

编译MessageUtil的测试用例类使用javac

C:\TestNG_WORKSPACE>javac MessageUtil.java DependencyTestUsingAnnotation.java

现在,运行testng.xml,这将运行testSalutationMessage()方法后,才执行initEnvironmentTest()方法。

C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml

验证输出

This is initEnvironmentTest
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha

===============================================
Suite1
Total tests run: 3, Failures: 0, Skips: 0
===============================================

dependsOnGroups Vs dependsOnMethods

  • 在使用组,我们不再面临重构的问题。只要我们不修改dependsOnGroups或组属性,我们的测试将继续运行,设立适当的依赖。

  • 每当一个新的方法需要添加依存关系图中,我们需要做的就是把它正确的组中,并确保它依赖于正确的组。我们不需要修改任何其他方法。

【全网最全】TestNG自动化测试框架入门到实战

 

【全网最全】TestNG自动化测试框架入门到实战 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

传说三哥

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

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

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

打赏作者

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

抵扣说明:

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

余额充值