java loggingselenium,使用Java使用Selenium WebDriver捕获浏览器日志

Is there a way to capture browser logs while running automated test cases with Selenium? I found an article on how to capture JavaScript errors in Selenium. But that is just for Firefox and only for errors. I would like to get all the console logs.

解决方案

I assume it is something in the lines of:

import org.openqa.selenium.WebDriver;

import org.openqa.selenium.chrome.ChromeDriver;

import org.openqa.selenium.logging.LogEntries;

import org.openqa.selenium.logging.LogEntry;

import org.openqa.selenium.logging.LogType;

import org.openqa.selenium.logging.LoggingPreferences;

import org.openqa.selenium.remote.CapabilityType;

import org.openqa.selenium.remote.DesiredCapabilities;

import org.testng.annotations.AfterMethod;

import org.testng.annotations.BeforeMethod;

import org.testng.annotations.Test;

public class ChromeConsoleLogging {

private WebDriver driver;

@BeforeMethod

public void setUp() {

System.setProperty("webdriver.chrome.driver", "c:\\path\\to\\chromedriver.exe");

DesiredCapabilities caps = DesiredCapabilities.chrome();

LoggingPreferences logPrefs = new LoggingPreferences();

logPrefs.enable(LogType.BROWSER, Level.ALL);

caps.setCapability(CapabilityType.LOGGING_PREFS, logPrefs);

driver = new ChromeDriver(caps);

}

@AfterMethod

public void tearDown() {

driver.quit();

}

public void analyzeLog() {

LogEntries logEntries = driver.manage().logs().get(LogType.BROWSER);

for (LogEntry entry : logEntries) {

System.out.println(new Date(entry.getTimestamp()) + " " + entry.getLevel() + " " + entry.getMessage());

//do something useful with the data

}

}

@Test

public void testMethod() {

driver.get("http://mypage.com");

//do something on page

analyzeLog();

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值