如何使用SeleniumWebDriver通过断点调试Node.js上的javascript测试

How to debug javascript tests on Node.js with Selenium WebDriver by breakpoints?

本文关键字:js Node 上的 javascript 测试 调试 断点 何使用 SeleniumWebDriver      更新时间:2024-05-02

我使用WebStorm编写javascript测试。我已经包含了Selenium WebDriver(+chromedriver)来在浏览器中运行我的测试。作为一个测试运行程序框架,我使用Mocha。

问题是:当我尝试调试测试并在代码中设置断点时,调试WebDriver没有启动。因此,我无法实时看到任何变量。

代码示例:

// Add external libraries
var test = require('selenium-webdriver/testing'), webdriver = require('selenium-webdriver'), By = require('selenium-webdriver').By;
var mocha = require('./node_modules/mocha/mocha.js'), chai = require('chai'), chaiuse = require('chai-as-promised'), expect = require('chai').expect;
var assert = require('assert');
// global variable for webdriver browser
var browser;
// Main part with test suites
test.describe('Suite 1', function() {
    this.timeout(5000);
    test.beforeEach( function(){ // Executes before each test
        browser = new webdriver.Builder().usingServer().withCapabilities({ 'browserName' : 'chrome', 'timeout' : '5000' }).build();
    });
    test.afterEach( function(){ // Executes after each test
        browser.close();
    });
    test.it('Get Fields', function(done) {
        browser.get('http://google.com');
        var btnFirst = browser.wait(webdriver.until.elementLocated(webdriver.By.name('btnK'), 30000));
        var btnSecond = browser.findElement(webdriver.By.name('btnI')).getAttribute("name");
        btnSecond.then(function(text) {
            console.log("Name of Second button: " + text + "'n");
            assert.equal(text,'btnI','Button with name ''btnI'' not presented');
        });
        done();
    });
});

所以现在所有的过程就像黑盒测试开发一样。

我试过DevTools-一个铬控制台来工作。但它只是在断点上不停顿地运行所有测试。命令:

devtool node_modules/mocha/bin/_mocha -qc -- ./Tests.js --break

在C#+Selenium WebDriver上,我对逐步调试没有问题,但现在我需要在JavaScript+SeleniumWebDriver中进行调试。

请给我个建议?

节点检查器的帮助下,您可以像调试任何Node.js脚本一样调试Mocha测试

  • 安装并运行节点检查器:

    npm install -g node-inspectornode-inspector

  • 使用break选项运行测试:mocha [options] --debug-brk

  • 在url打开Chrome中的调试器http://127.0.0.1:8080/?port=5858

您可以使用Chrome开发工具设置断点并享受调试!

来源:如何使用Chrome 调试Mocha测试