TestNG - Групповой тест

Групповое тестирование - это новая инновационная функция в TestNG, которой нет в среде JUnit. Это позволяет вам распределять методы на соответствующие части и выполнять сложные группировки методов тестирования.

Вы можете не только объявлять те методы, которые принадлежат группам, но также можете указывать группы, которые содержат другие группы. Затем можно вызвать TestNG и попросить включить определенный набор групп (или регулярных выражений), исключив другой набор.

Групповые тесты обеспечивают максимальную гибкость в том, как вы разбиваете тесты, и не требуют перекомпиляции, если вы хотите запустить два разных набора тестов один за другим.

Группы указываются в файле testng.xml с помощью тега <groups>. Его можно найти под тегом <test> или <suite>. Группы, указанные в теге <suite>, применяются ко всем тегам <test> ниже.

Теперь давайте рассмотрим пример, чтобы увидеть, как работает групповой тест.

Создать класс

  • Создайте класс java для тестирования, скажем, MessageUtil.java в C:\> TestNG_WORKSPACE.

/*
* 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 "tutorialspoint" to the message
   public String salutationMessage() {
      message = "tutorialspoint" + 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.

  • Добавьте тестовые методы testPrintMessage () и testSalutationMessage () в свой тестовый класс.

  • Сгруппируйте метод тестирования в две категории -

    • Check-in tests (checkintest)- Эти тесты следует запустить перед отправкой нового кода. Как правило, они должны быть быстрыми и просто проверять, не нарушена ли базовая функциональность.

    • Functional tests (functest) - Эти тесты должны охватывать все функциональные возможности вашего программного обеспечения и выполняться не реже одного раза в день, хотя в идеале вы хотели бы запускать их непрерывно.

Создайте файл класса Java с именем GroupTestExample.java в C:\>TestNG_WORKSPACE.

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 = "tutorialspoint" + ".com";
      Assert.assertEquals(message, messageUtil.salutationMessage());
   }

   @Test(groups = { "functest" })
   
   public void testingExitMessage() {
      System.out.println("Inside testExitMessage()");
      message = "www." + "tutorialspoint"+".com";
      Assert.assertEquals(message, messageUtil.exitMessage());
   }  
}

Создать testng.xml

Создайте testng.xml в C:\> TestNG_WORKSPACE, чтобы выполнить тестовый пример (ы). Здесь мы будем выполнять только те тесты, которые принадлежат группе 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>

Скомпилируйте классы MessageUtil, Test case с помощью javac.

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

Теперь запустите testng.xml, который запустит только метод testPrintMessage (), поскольку он принадлежит к группе functest .

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

Проверьте вывод. Выполняется только метод testPrintMessage ().

Inside testPrintMessage()
.com
Inside testExitMessage()
www..com

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

Группа групп

Группы также могут включать другие группы. Эти группы называютсяMetaGroups. Например, вы можете определить группу all, в которую входят checkintest и functest . Давайте изменим наш файл testng.xml следующим образом -

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

Выполнение вышеуказанного testng.xml выполнит все три теста и даст вам следующий результат:

Inside testPrintMessage()
.com
Inside testSalutationMessage()
tutorialspoint.com
Inside testExitMessage()
www.tutorialspoint.com

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

Группы исключений

Вы можете игнорировать группу, используя тег <exclude>, как показано ниже -

<?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 name = "functest"/>
            <include name = "checkintest"/>
         </define>

         <run>
            <include name = "all"/>
         </run>
      </groups>

      <classes>
         <class name = "GroupTestExample" />
      </classes>

   </test>
</suite>