Почему я продолжаю получать "UnhandledPromiseRejectionWarning" при запуске теста с Selenium-webdriver? - PullRequest
0 голосов
/ 04 ноября 2019

Я пытаюсь реализовать тесты Selenium с мокко и без него на моем веб-интерфейсе, в моем приложении, построенном в React. Но я продолжаю получать ошибки. Мокко работает, так что с Selenium что-то не так?

На MacOS с версиями:

"mocha": "^6.2.2",
"selenium-webdriver": "^4.0.0-alpha.5"
"geckodriver": "^1.19.1",
"safari": "0.0.1"

Это только начало, действительно простой тест для возврата названия приложения.

Приложение запущено и работает на http://localhost:3000/

Я пробовал разные браузеры;Firefox и сафари. Все они открываются, но все они (в конечном итоге) возвращают одну и ту же ошибку.

Запуск теста в test / src node SimpleTest.js

Это SimpleTest.js

var webdriver = require("selenium-webdriver");
const serverUri = "http://localhost:3000";

var browser = new webdriver.Builder()
    .withCapabilities(webdriver.Capabilities.firefox())
    .build();

browser.get(serverUri);

browser.getTitle()
    .then(function (title) {
        console.log("The title", title);
    });

browser.quit();

Я ожидал вывод

$ node SimpleTest.js 
The title Me-Me-Me

Но я получил

$ node SimpleTest.js 
The title 
(node:1582) UnhandledPromiseRejectionWarning: NoSuchSessionError: Tried to run command without establishing a connection
    at Object.throwDecodedError (/$HOME/jsramverk/node_modules/selenium-webdriver/lib/error.js:550:15)
    at parseHttpResponse (/$HOME/jsramverk/node_modules/selenium-webdriver/lib/http.js:563:13)
    at Executor.execute (//$HOME/jsramverk/node_modules/selenium-webdriver/lib/http.js:489:26)
    at process._tickCallback (internal/process/next_tick.js:68:7)
(node:1582) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). (rejection id: 2)
(node:1582) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.

решено У меня было слишком много асинхронного кода, работающего синхронно.

const { Builder } = require('selenium-webdriver');
const Firefox = require('selenium-webdriver/firefox');
require('geckodriver');
const serverUri = "http://localhost:3000/#";
let browser;

async function main() {
    const builder = new Builder().forBrowser('firefox');
    builder.setFirefoxOptions(new Firefox.Options().headless());

    browser = await builder.build();
    await browser.get(serverUri);

    try {
        const title = await browser.getTitle();
        console.log(title);
    } catch (ex) {
        console.log("Something went wrong", ex.message);
    } finally {
        await browser.quit();
    }

}

main().catch(console.error);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...