我在 C# 中使用 Selenium WedDriver。
有没有办法捕获和记录我在 Google Chrome 中的测试运行可能发生的所有 JS 错误?
例如 Firefox 的“JSErrorCollector” - http://mguillem.wordpress.com/2011/10/11/webdriver-capture-js-errors-while-running-tests/
我在 C# 中使用 Selenium WedDriver。
有没有办法捕获和记录我在 Google Chrome 中的测试运行可能发生的所有 JS 错误?
例如 Firefox 的“JSErrorCollector” - http://mguillem.wordpress.com/2011/10/11/webdriver-capture-js-errors-while-running-tests/
现在我们有了相同的 Chrome 插件。它在这里 - https://github.com/dharria/ChromeJSErrorCollector
它与 JSErrorCollector 非常相似。
正如 Simeon Sinichkin 所提到的,ChromeJSErrorCollector 在这里非常有用。对于 C# 中的其他任何人,这里有一些示例代码来获取 JS 错误并将它们记录到文件/控制台:
var options = new ChromeOptions();
options.AddExtension("ChromeJSErrorCollector.crx");
var driver = new ChromeDriver(options);
// run tests...
var javascriptDriver = driver as IJavaScriptExecutor;
var errors = javascriptDriver.ExecuteScript("return window.JSErrorCollector_errors ? window.JSErrorCollector_errors.pump() : []");
var writer = new StreamWriter("jsErrors.log");
var collection = errors as ReadOnlyCollection<object>;
foreach (var item in collection)
{
var errorObject = item as Dictionary<string, object>;
foreach (var field in errorObject)
{
Console.WriteLine(field.Key + " - " + field.Value);
writer.WriteLine(field.Key + " - " + field.Value);
}
Console.WriteLine("-------------------");
writer.WriteLine("-------------------");
}
writer.Flush();
writer.Close();
输出如下所示:
errorMessage - Error: Script error
http://requirejs.org/docs/errors.html#scripterror
lineNumber - 1795
pageUrl - http://someURL
sourceName - http://someURL/Scripts/require.js
-------------------
我可能会在这里偏离基地,因为我从未使用过 Selenium,因此可能无法完全理解上下文:但您可以使用它window.onerror
来捕获浏览器中发生的任何错误,然后对它们执行某些操作(将它们发送到数据库或日志文件,也许)。
请注意,这不仅限于 JavaScript 错误,还可能包括一些 HTTP 错误。
使用 chrome 开发人员工具(ctrl+shift+i)并查看控制台选项卡是否有错误。
Chrome 还允许您在代码的某些行上设置断点并查看变量的所有值。