TestNG - การทดสอบการพึ่งพา

บางครั้งคุณอาจต้องเรียกใช้วิธีการในกรณีทดสอบตามลำดับที่เจาะจงหรือคุณอาจต้องการแบ่งปันข้อมูลและสถานะระหว่างวิธีการ TestNG สนับสนุนการพึ่งพาประเภทนี้เนื่องจากสนับสนุนการประกาศการอ้างอิงอย่างชัดเจนระหว่างวิธีการทดสอบ

TestNG ช่วยให้คุณระบุการอ้างอิงด้วย -

  • การใช้แอตทริบิวต์ขึ้นอยู่กับวิธีการในคำอธิบายประกอบ @Test หรือ

  • การใช้แอตทริบิวต์ขึ้นอยู่บนกลุ่มในคำอธิบายประกอบ @Test

ตัวอย่างการใช้ขึ้นอยู่กับวิธีการ

สร้างชั้นเรียน

สร้างคลาส 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"} ไปยังคำอธิบายประกอบ @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
   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 () หลังจากการดำเนินการของเมธอด 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
===============================================

ตัวอย่างการใช้ขึ้นอยู่กับกลุ่ม

คุณยังสามารถมีวิธีการที่ขึ้นอยู่กับทั้งกลุ่ม ลองมีตัวอย่างเพื่อสาธิตสิ่งนี้

สร้างชั้นเรียน

สร้างคลาส 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 () ในคลาสทดสอบของคุณและเพิ่มลงในกลุ่ม "init"

  • เพิ่มแอตทริบิวต์ dependsOnMethods = {"init.*"} ไปยังคำอธิบายประกอบ @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 ซึ่งเป็นค่าดีฟอลต์) เมธอดที่ขึ้นอยู่กับมันจะไม่ถูกทำเครื่องหมายว่า 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>

คอมไพล์ 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
===============================================

ขึ้นอยู่กับ OnGroups Vs ขึ้นอยู่กับOnMethods

  • ในการใช้กลุ่มเราจะไม่พบปัญหาในการปรับโครงสร้างอีกต่อไป ตราบเท่าที่เราไม่แก้ไขแอตทริบิวต์ dependOnGroups หรือกลุ่มการทดสอบของเราจะยังคงทำงานต่อไปพร้อมกับการตั้งค่าการอ้างอิงที่เหมาะสม

  • เมื่อใดก็ตามที่ต้องเพิ่มวิธีการใหม่ในกราฟการอ้างอิงสิ่งที่เราต้องทำคือวางไว้ในกลุ่มที่ถูกต้องและตรวจสอบให้แน่ใจว่าขึ้นอยู่กับกลุ่มที่ถูกต้อง เราไม่จำเป็นต้องแก้ไขวิธีการอื่นใด