TestNG - Teste de Grupo

O teste de grupo é um novo recurso inovador no TestNG, que não existe no framework JUnit. Ele permite que você distribua métodos em porções adequadas e execute agrupamentos sofisticados de métodos de teste.

Você não só pode declarar os métodos que pertencem a grupos, mas também pode especificar grupos que contêm outros grupos. Então, TestNG pode ser chamado e solicitado a incluir um determinado conjunto de grupos (ou expressões regulares), enquanto exclui outro conjunto.

Os testes de grupo fornecem flexibilidade máxima em como você particiona seus testes e não exige que você recompile nada se quiser executar dois conjuntos diferentes de testes consecutivos.

Os grupos são especificados em seu arquivo testng.xml usando a tag <groups>. Ele pode ser encontrado na tag <test> ou <suite>. Grupos especificados na tag <suite> se aplicam a todas as tags <test> abaixo.

Agora, vamos dar um exemplo para ver como funciona o teste de grupo.

Crie uma classe

  • Crie uma classe java a ser testada, digamos, MessageUtil.java dentro 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;
   }
}

Criar classe de caso de teste

  • Crie uma classe de teste java, digamos, GroupTestExample.java.

  • Adicione métodos de teste, testPrintMessage () e testSalutationMessage (), à sua classe de teste.

  • Agrupe o método de teste em duas categorias -

    • Check-in tests (checkintest)- Esses testes devem ser executados antes de enviar um novo código. Normalmente, eles devem ser rápidos e apenas garantir que nenhuma funcionalidade básica seja interrompida.

    • Functional tests (functest) - Esses testes devem cobrir todas as funcionalidades do seu software e ser executados pelo menos uma vez por dia, embora o ideal seja que você queira executá-los continuamente.

Crie o arquivo de classe java chamado GroupTestExample.java dentro 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());
   }  
}

Crie testng.xml

Crie testng.xml em C:\> TestNG_WORKSPACE, para executar caso (s) de teste. Aqui, estaríamos executando apenas aqueles testes, que pertencem ao grupo 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>

Compile o MessageUtil, classes de caso de teste usando javac.

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

Agora, execute o testng.xml, que executará apenas o método testPrintMessage (), por pertencer ao grupo functest .

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

Verifique a saída. Apenas o método testPrintMessage () é executado.

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

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

Grupo de Grupos

Os grupos também podem incluir outros grupos. Esses grupos são chamadosMetaGroups. Por exemplo, você pode querer definir um grupo todo que inclui checkintest e functest . Vamos modificar nosso arquivo testng.xml da seguinte maneira -

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

Executar o testng.xml acima executará todos os três testes e fornecerá o seguinte resultado -

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

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

Grupos de Exclusão

Você pode ignorar um grupo usando a tag <exclude> conforme mostrado abaixo -

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