Selenium : TestNG error Reporting using IListener (without halt)
- Create a package in your project Example: logger
- Create a Class CustomLogging inside your package.
- Paste the below code as mentioned in the screenshot (code below) :
4. Open your Testng.xml and add the following code as mentioned in the screen shot:
5. Screen shot of the "SampleTest" which contains my test cases.
6. Result when i run the code.
Code Here - CustomLogging :
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import org.testng.ITestContext;
import org.testng.ITestListener;
import org.testng.ITestResult;
public class CustomLogging implements ITestListener{
@Override //Called when the test-method execution starts
public void onTestStart(ITestResult result) {
System.out.println("Test method started: "+ result.getName()+ " and time is: "+getCurrentTime());
}
@Override //Called when the test-method execution is a success
public void onTestSuccess(ITestResult result) {
System.out.println("Test method success: "+ result.getName()+ " and time is: "+getCurrentTime());
}
@Override //Called when the test-method execution fails
public void onTestFailure(ITestResult result) {
System.out.println("Test method failed: "+ result.getName()+ " and time is: "+getCurrentTime());
}
@Override //Called when the test-method is skipped
public void onTestSkipped(ITestResult result) {
System.out.println("Test method skipped: "+ result.getName()+ " and time is: "+getCurrentTime());
}
@Override //Called when the test-method fails within success percentage
public void onTestFailedButWithinSuccessPercentage(ITestResult result) {
// Leaving blank
}
@Override //Called when the test in xml suite starts
public void onStart(ITestContext context) {
System.out.println("Test in a suite started: "+ context.getName()+ " and time is: "+getCurrentTime());
}
@Override //Called when the test in xml suite finishes
public void onFinish(ITestContext context) {
System.out.println("Test in a suite finished: "+ context.getName()+ " and time is: "+getCurrentTime());
}
//Returns the current time when the method is called
public String getCurrentTime(){
DateFormat dateFormat =
new SimpleDateFormat("HH:mm:ss:SSS");
Date dt = new Date();
return dateFormat.format(dt);
}
}
No comments:
Post a Comment