Selenium Web驱动程序 - 失败屏幕截图未在TestNG报告中捕获

时间:2013-06-09 11:30:17

标签: selenium-webdriver testng

使用下面提到的代码,如果测试用例通过截屏已成功捕获并显示在报告中。但是当测试失败时 - 屏幕截图不会显示。甚至屏幕截图超链接也不会显示在报告中。任何人都可以理清代码中的错误?

package listeners;

import java.io.File;
import java.io.IOException;

import java.text.Format;
import java.text.SimpleDateFormat;
import java.util.Date;
import org.apache.commons.io.FileUtils;
import org.openqa.selenium.By;
import org.openqa.selenium.OutputType;
import org.openqa.selenium.TakesScreenshot;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;    
import org.testng.ITestResult;
import org.testng.Reporter;
import org.testng.annotations.Listeners;
import org.testng.annotations.Test;
import org.testng.ITestResult;
import org.testng.Reporter;
import org.testng.TestListenerAdapter;
import java.util.logging.Logger;


@Listeners

public class CountryChoserLayer extends TestListenerAdapter {


  @Test(priority=1)
  public void choseCountry() throws Exception{

      driver.findElement(By.id("intselect")).sendKeys("India");
        driver.findElement(By.xpath(".//*[@id='countryChooser']/a/img")).click();
        //window.onbeforeunload = null;
        Date date=new Date();
        Format formatter = new SimpleDateFormat("yyyy-MM-dd_hh-mm-ss");        
        File scrnsht = ((TakesScreenshot)driver).getScreenshotAs(OutputType.FILE);
        String NewFileNamePath=("C://Documents and Settings//vlakshm//workspace//MyTNG//test-output//Screenshots"+"//SearsINTL_"+ formatter.format(date)+".png");  
        FileUtils.copyFile(scrnsht, new File(NewFileNamePath));
        System.out.println(NewFileNamePath);
        Reporter.log("<a href=\"" + NewFileNamePath + "\">Passed Screenshot</a>");
        System.out.println("---------------------------------------");
        System.out.println("Country choser layer test case-Success");
        System.out.println("---------------------------------------");

  }


  public String baseurl="http://www.sears.com/shc/s/CountryChooserView?storeId=10153&catalogId=12605";
  public WebDriver driver;
  public int Count = 0;

  @Test(priority=0)
  public void openBrowser() {

      driver = new FirefoxDriver();
      driver.manage().deleteAllCookies();
      driver.get(baseurl);
  }
  @Test(priority=2)
  public void closeBrowser() {
     driver.quit(); 
  }

@Override
public void onTestFailure(ITestResult result){

    Reporter.log("Fail");
    System.out.println("BBB");
    //Reporter.setCurrentTestResult(result);     
      Date date=new Date();
      Format formatter = new SimpleDateFormat("yyyy-MM-dd_hh-mm-ss");    


      File scrnsht = ((TakesScreenshot)driver).getScreenshotAs(OutputType.FILE);
      //File scrFile = ((TakesScreenshot) WebDriver.globalDriverInstance).getScreenshotAs(OutputType.FILE);
      String NewFileNamePath=("C://Documents and Settings//vlakshm//workspace//MyTNG//test-output//Screenshots"+"//SearsINTL_"+ formatter.format(date)+".png"); 
      //System.out.println("AAA" + NewFileNamePath);
      try {
          //System.out.println("CCC");
        FileUtils.copyFile(scrnsht,new File(NewFileNamePath));
          System.out.println(NewFileNamePath);


    } catch (IOException e) {
        // TODO Auto-generated catch block
        System.out.println("DDD");
        e.printStackTrace();
    }
      Reporter.log("<a href=\"" + NewFileNamePath + "\">Failed Screenshot</a>");
      Reporter.setCurrentTestResult(null);
    System.out.println("---------------------------------------");
    System.out.println("Country choser layer test case Failed");
    System.out.println("---------------------------------------");

      }

      @Override
      public void onTestSkipped(ITestResult result) {
      // will be called after test will be skipped
        Reporter.log("Skip");
      }
      @Override
      public void onTestSuccess(ITestResult result) {
      // will be called after test will pass
        Reporter.log("Pass");
      }

}

1 个答案:

答案 0 :(得分:2)

您的onTestFailure方法未被调用,因为您没有为测试类指定侦听器。您缺少@Listeners注释中的值。它应该像

@Listeners({CountryChoserLayer.class})

您可以在official TestNg's documentation中找到更多指定侦听器的方法。

在尝试在onTestFailure方法中截取屏幕截图时,您可能遇到的另一个问题是NullPointerException。最简单的解决方法是将驱动程序字段的声明更改为静态。我使用这些修复程序运行代码,并获得带有屏幕截图的报告。

我必须补充一点,在我看来,将测试和听众方法都放在一个类中并不是一个好习惯。