TestNG - Beispiel für Konfigurationsanmerkungen

In TestNG können wir die folgenden Anmerkungen verwenden, um die Konfiguration für Ihre Testklasse vorzunehmen, z. B. das Einrichten / Bereinigen einer Datenbank, das Vorbereiten der Dummy-Daten, das Bereitstellen / Herunterfahren des Servers usw.
@BeforeSuite - For suite test, run before all tests in this suite have run. @AfterSuite - For suite test, run after all tests in this suite have run. @BeforeTest - For suite test, run before any test method belonging to the classes inside thetag is run. @AfterTest - For suite test, run after all the test methods belonging to the classes inside the tag have run. @BeforeGroups: Run before the first test method that belongs to the group is invoked. @AfterGroups: Run after the last test method that belongs to the groups is invoked. @BeforeClass - Run before the first test method in the current class is invoked. @AfterClass - Run after all the test methods in the current class have been run. @BeforeMethod - Run before each test method. @AfterMethod - Run after each test method.
P.S Suite test – Run multiple test classes together.
Sehen Sie sich die folgenden Beispiele an, um die Ausführungsreihenfolge zu ermitteln - welche Methode zuerst aufgerufen wird und welche als nächstes.
1. Einzelprüfungsklasse
Zeigen Sie in einem einzelnen Testfall die Verwendung von vor / nachgroup,class undmethod.
TestConfiguration.java
package com.example.testng.examples.configuration;
import org.testng.annotations.AfterClass;
import org.testng.annotations.AfterGroups;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.BeforeGroups;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;
public class TestConfiguration {
@BeforeGroups("shopping")
public void beforeGroups() {
System.out.println("@BeforeGroups");
}
@AfterGroups("shopping")
public void afterGroups() {
System.out.println("@AfterGroups");
}
@BeforeClass
public void beforeClass() {
System.out.println("@BeforeClass");
}
@AfterClass
public void afterClass() {
System.out.println("@AfterClass");
}
@BeforeMethod
public void beforeMethod() {
System.out.println("@BeforeMethod");
}
@AfterMethod
public void afterMethod() {
System.out.println("@AfterMethod");
}
@Test(groups = "shopping")
public void runTest1() {
System.out.println("@Test - runTest1");
}
@Test
public void runTest2() {
System.out.println("@Test - runTest2");
}
}
Ausgabe
@BeforeClass
@BeforeGroups
@BeforeMethod
@Test - runTest1
@AfterMethod
@AfterGroups
@BeforeMethod
@Test - runTest2
@AfterMethod
@AfterClass
PASSED: runTest1
PASSED: runTest2
===============================================
Default test
Tests run: 2, Failures: 0, Skips: 0
===============================================
2. Suite-Testklassen
Erstellen Sie zwei weitere Testklassen, um die Verwendung von vor / nachsuite undtest zu zeigen.
DBConfig.java
package com.example.testng.examples.configuration;
import org.testng.annotations.AfterSuite;
import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeSuite;
import org.testng.annotations.BeforeTest;
public class DBConfig {
@BeforeSuite()
public void beforeSuite() {
System.out.println("@BeforeSuite");
}
@AfterSuite()
public void afterSuite() {
System.out.println("@AfterSuite");
}
@BeforeTest()
public void beforeTest() {
System.out.println("@BeforeTest");
}
@AfterTest()
public void afterTest() {
System.out.println("@AfterTest");
}
}
TestDBConnection.java
package com.example.testng.examples.configuration;
import org.testng.annotations.Test;
public class TestDBConnection {
@Test
public void runOtherTest1() {
System.out.println("@Test - runOtherTest1");
}
@Test
public void runOtherTest2() {
System.out.println("@Test - runOtherTest2");
}
}
Erstellen Sie eine XML-Datei, um mehrere Testfälle zusammen auszuführen. Lesen Sie die XML-Kommentare zur Selbsterklärung.
testng.xml
Ausgabe
@BeforeSuite
@BeforeTest //Start {case1}
@BeforeClass
@BeforeGroups
@BeforeMethod
@Test - runTest1
@AfterMethod
@AfterGroups
@BeforeMethod
@Test - runTest2
@AfterMethod
@AfterClass
@Test - runOtherTest1
@Test - runOtherTest2
@AfterTest //End {case1}
@BeforeTest //Start {case2}
@Test - runOtherTest1
@Test - runOtherTest2
@AfterTest //End {case2}
@AfterSuite
===============================================
TestAll
Total tests run: 6, Failures: 0, Skips: 0
===============================================
Erledigt.