How to stop TestNG from running after a test fail?



A TestNG class can have different tests like test1, test2, test3 etc. There could be some failure while running the test suite and user may get failures in between of @Test methods. Once a test method gets failed, it skip remaining code of the @Test method and moves to the next @Test method. However, user may want to skip remaining all @Test methods after getting 1st failure.

There are 2 most popular solution for such use cases:

  • Write dependsOnMethods annotation ? But this solution works only if user knows exact dependent method/s otherwise in large suite it would be very clumsy.

  • Using IInvokedMethodListener to add a common logic across suite.

In this article, let's analyse how to stop site execution after 1st failure using IInvokedMethodListener.

Approach/Algorithm to solve this problem

  • Step 1: import org.testng.annotations.Test for TestNG.

  • Step 2: Write an annotation as @test in NewTest class

  • Step 3: Create a method for the @Test annotation as test1.

  • Step 4: Repeat the steps for test2 and test3. Add a failure assertion at test2.

  • Step 5: Now, create a ListenerClass that uses IInvokedMethodListener to check the status of previous @Test method. If it gets failed status, ignore remaining suite.

  • Step 6: Now create the testNG.xml and add Listener class.

  • Step 7: Now, run the testNG.xml or directly testNG class in IDE or compile and run it using command line.

Example

The following code to create a TestNG class and displays the Listener functionality:

src/NewTest.java

import org.testng.annotations.Test; public class NewTest { @Test() public void testCase1() { System.out.println("in test case 1 of NewTest"); } @Test() public void testCase2() { System.out.println("in test case 2 of NewTest"); assert false; } @Test() public void testCase3() { System.out.println("in test case 3 of NewTest"); } } 

src/ListenerClass.java

import org.testng.IInvokedMethod; import org.testng.IInvokedMethodListener; import org.testng.ITestResult; import org.testng.SkipException; public class ListenerClass implements IInvokedMethodListener { private boolean hasFailures = false; @Override public void beforeInvocation(IInvokedMethod method, ITestResult testResult) { synchronized (this) { if (hasFailures) { throw new SkipException("Skipping this test"); } } } @Override public void afterInvocation(IInvokedMethod method, ITestResult testResult) { if (method.isTestMethod() && !testResult.isSuccess()) { synchronized (this) { hasFailures = true; } } } } 

testng.xml

This is a configuration file that is used to organize and run the TestNG test cases.

It is very handy when limited tests are needed to execute rather than full suite.

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE suite SYSTEM "https://testng.org/testng-1.0.dtd"> <suite name="Parent_Suite"> <listeners> <listener class-name="ListenerClass"/> </listeners> <test name="group test"> <classes> <class name="NewTest" /> </classes> </test> </suite> 

Output

[INFO] Running TestSuite in test case 1 of NewTest in test case 2 of NewTest [ERROR] Tests run: 3, Failures: 1, Errors: 0, Skipped: 1, Time elapsed: 0.671 s <<< FAILURE! - in TestSuite [ERROR] NewTest.testCase2 Time elapsed: 0.009 s <<< FAILURE! java.lang.AssertionError	at NewTest.testCase2(newTest.java:14) [INFO] [INFO] Results: [INFO] [ERROR] Failures: [ERROR] NewTest.testCase2:14 [INFO] [ERROR] Tests run: 3, Failures: 1, Errors: 0, Skipped: 1 
Updated on: 2023-08-17T14:18:41+05:30

1K+ Views

Kickstart Your Career

Get certified by completing the course

Get Started
Advertisements