TestNG-종속성 테스트

때로는 테스트 케이스에서 특정 순서로 메서드를 호출해야하거나 메서드간에 일부 데이터와 상태를 공유해야 할 수도 있습니다. 이러한 종류의 종속성은 테스트 메서드 간의 명시 적 종속성 선언을 지원하므로 TestNG에서 지원합니다.

TestNG를 사용하면 다음과 같이 종속성을 지정할 수 있습니다.

  • @Test 주석에서 속성 dependentOnMethods 사용 또는.

  • @Test 주석에서 속성 dependentOnGroups 를 사용합니다 .

DependOnMethods를 사용하는 예

수업 만들기

테스트 할 Java 클래스를 만듭니다. MessageUtil.javaC:\>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"} @Test 주석에 testSalutationMessage() 방법.

Java 클래스 파일 이름 만들기 DependencyTestUsingAnnotation.javaC:\>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>

javac를 사용하여 MessageUtil, 테스트 케이스 클래스를 컴파일하십시오.

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

이제 testng.xml을 실행하면 initEnvironmentTest () 메서드를 실행 한 후에 만 ​​testSalutationMessage () 메서드가 실행됩니다.

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

DependOnGroups를 사용하는 예

전체 그룹에 의존하는 방법을 가질 수도 있습니다. 이것을 보여주는 예를 들어 보자.

수업 만들기

테스트 할 Java 클래스를 만듭니다. MessageUtil.javaC:\>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 ()를 테스트 클래스에 추가하고 "init"그룹에 추가합니다.

  • 속성 추가 dependsOnMethods = {"init.*"} @Test 주석에 testSalutationMessage() 방법.

다음과 같은 Java 클래스 파일을 만듭니다. DependencyTestUsingAnnotation.javaC:\>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, 기본값) 종속 된 메서드는 FAIL로 표시되지 않고 SKIP으로 표시됩니다. 건너 뛴 메소드는 최종 보고서에 그대로보고됩니다 (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>

javac를 사용하여 MessageUtil, 테스트 케이스 클래스를 컴파일하십시오.

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

DependOnGroupsDependOnMethods

  • 그룹을 사용할 때 더 이상 리팩토링 문제에 노출되지 않습니다. DependOnGroups 또는 groups 속성을 수정하지 않는 한 테스트는 적절한 종속성이 설정된 상태로 계속 실행됩니다.

  • 종속성 그래프에 새 메서드를 추가해야 할 때마다 올바른 그룹에 넣고 올바른 그룹에 종속되는지 확인하기 만하면됩니다. 다른 방법을 수정할 필요가 없습니다.