TestNG - Bağımlılık Testi

Bazen, bir test senaryosundaki yöntemleri belirli bir sırayla çağırmanız gerekebilir veya yöntemler arasında bazı verileri ve durumu paylaşmak isteyebilirsiniz. Bu tür bir bağımlılık, test yöntemleri arasında açık bağımlılıkların beyanını desteklediği için TestNG tarafından desteklenir.

TestNG, aşağıdakilerden biri ile bağımlılıkları belirlemenizi sağlar:

  • @Test annotations, OR'da özniteliğin kullanılışı bağlıdırOnMethods .

  • @Test ek açıklamalarında bağımlıOnGroups özniteliğini kullanma .

BağımlıOnMethods Kullanan Örnek

Bir Sınıf Oluşturun

Test edilecek bir java sınıfı oluşturun, diyelim ki, MessageUtil.java içinde 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;
   }
}

Test Vaka Sınıfı Oluşturun

  • DependencyTestUsingAnnotation.java gibi bir java test sınıfı oluşturun.

  • Test sınıfınıza test yöntemleri, testPrintMessage () ve testSalutationMessage () ve initEnvironmentTest () ekleyin.

  • Öznitelik ekleyin dependsOnMethods = {"initEnvironmentTest"} @Test ek açıklamasına testSalutationMessage() yöntem.

Bir java sınıfı dosya adı oluşturun DependencyTestUsingAnnotation.java içinde 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 oluştur

İçinde testng.xml oluşturun C:\>TestNG_WORKSPACE test senaryolarını yürütmek için.

<?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 kullanarak MessageUtil, Test vaka sınıflarını derleyin.

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

Şimdi, testSalutationMessage () yöntemini yalnızca initEnvironmentTest () yönteminin yürütülmesinden sonra çalıştıracak olan testng.xml dosyasını çalıştırın.

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

Çıkışı doğrulayın.

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

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

BağımlıOnGroups Kullanan Örnek

Tüm gruplara bağlı olan yöntemlere de sahip olabilirsiniz. Bunu göstermek için bir örnek verelim.

Bir Sınıf Oluşturun

Test edilecek bir java sınıfı oluşturun, diyelim ki, MessageUtil.java içinde 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;
   }
}

Test Vaka Sınıfı Oluşturun

  • DependencyTestUsingAnnotation.java gibi bir java test sınıfı oluşturun.

  • Test yöntemlerini, testPrintMessage () testSalutationMessage () ve initEnvironmentTest () 'i test sınıfınıza ekleyin ve bunları "init" grubuna ekleyin.

  • Özniteliği ekleyin dependsOnMethods = {"init.*"} @Test ek açıklamasına testSalutationMessage() yöntem.

Adlı bir java sınıf dosyası oluşturun DependencyTestUsingAnnotation.java içinde 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");
   }
}

Bu örnekte, testSalutationMessage (), "init. *" Normal ifadesiyle eşleşen herhangi bir gruba bağlı olarak bildirilir; bu, testPrintMessage () ve initEnvironmentTest () yöntemlerinin her zaman testSalutationMessage () 'dan önce çağrılacağını garanti eder.

Bağlı bir yöntem başarısız olursa ve ona sıkı bir bağımlılığınız varsa (her zamanRun = false, varsayılan değerdir), ona bağlı olan yöntemler BAŞARISIZ olarak değil, ATLA olarak işaretlenir. Atlanan yöntemler, nihai raporda olduğu gibi rapor edilecektir (HTML'de Kırmızı veya Yeşil olmayan bir renkte), bu da önemlidir, çünkü atlanan yöntemler mutlaka başarısızlık değildir.

Testng.xml oluştur

İçinde testng.xml oluşturun C:\>TestNG_WORKSPACE test senaryolarını yürütmek için.

<?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 kullanarak MessageUtil, Test vaka sınıflarını derleyin.

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

Şimdi, testSalutationMessage () yöntemini yalnızca initEnvironmentTest () yönteminin yürütülmesinden sonra çalıştıracak olan testng.xml dosyasını çalıştırın .

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

Çıkışı doğrulayın.

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

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

bağlıdırOnGroups Vs bağlıdırOnMethods

  • Grupları kullanırken, artık yeniden düzenleme sorunlarına maruz kalmıyoruz. SubsOnGroups veya groups özniteliklerini değiştirmediğimiz sürece, testlerimiz uygun bağımlılıkların ayarlanmasıyla çalışmaya devam edecektir.

  • Bağımlılık grafiğine yeni bir yöntemin eklenmesi gerektiğinde, tek yapmamız gereken onu doğru gruba koymak ve doğru gruba bağlı olduğundan emin olmaktır. Başka bir yöntemi değiştirmemize gerek yok.