【问题标题】:UnhandledPromiseRejectionWarning: NoSuchSessionError: invalid session id selenium webdriverUnhandledPromiseRejectionWarning: NoSuchSessionError: invalid session id selenium webdriver
【发布时间】:2018-10-31 07:31:51
【问题描述】:

我正在使用 Selenium 运行集成测试。 我有"selenium-webdriver": "^4.0.0-alpha.1" and "chromedriver": "^2.42.0"。测试通过但仍然得到UnhandledPromiseRejectionWarning: NoSuchSessionError: invalid session id。我发现这是在 After hook 中调用 this.driver.quit() 时发生的。我检查了驱动程序的 sessionId 在开始时和运行 After 挂钩时是否相同。这是代码:

hooks.js

function openWindow(driver) {
  var verifyItsYouBtnXpath = "*//span[text()='Continue']/ancestor::div[@role='button']";
  switchTab(driver).then(function() {
    driver.wait(until.elementLocated(By.xpath(verifyItsYouBtnXpath))).then((verifyElement) => {
      verifyElement.click();
        navigateToEmail(driver).then(() => {
          driver.wait(until.elementLocated(By.xpath("//td[*//span[text()='Integration Test Mail Thread']]")))
            .then((element) => {
              driver.wait(until.elementIsVisible(element)).click()
                .then(() => {
                  driver.wait(until.elementLocated(By.xpath("//div[@aria-label='Thumbs Up!!']")))
                    .then(element => {
                      driver.wait(until.elementIsVisible(element)).click();
                    });
                });
            });
        });
    });
  });
}

spec.js

'use strict';

var {Then, When} = require('cucumber');
var {By, until} = require('selenium-webdriver');
var assert = require('assert');

When(/^Reaction Add-on is open$/, function (next) {
  next();
});

Then(/^User should get author name and first few words from message body$/, function (next) {
  var parentDivXpath = "//div[@jsaction='click:h5M12e; clickmod:h5M12e;']/preceding-sibling::div";
  var spanXpath = parentDivXpath + "/div/span[1]";
  this.driver.wait(
    until.elementsLocated(By.xpath(spanXpath))
  ).then(elements => {
    this.driver.wait(until.elementIsVisible(elements[0]))
      .then(element => {
        element.getText().then(text => {
          assert.equal(text, "Hello,  Please like...");
        });
      });

    this.driver.wait(until.elementIsVisible(elements[1]))
      .then(element => {
        element.getText().then(text => {
          assert.equal(text, "Done. I liked it....");
          assert.equal(elements.length, 2);
        });
      });
  });

  this.driver.wait(
    until.elementsLocated(By.xpath(spanXpath + "/following-sibling::span"))
  ).then(elements => {
    this.driver.wait(until.elementIsVisible(elements[0]))
      .then(element => {
        element.getText().then(text => {
          assert.equal(text.includes("J King"), true);
        });
      });

    this.driver.wait(until.elementIsVisible(elements[1]))
      .then(element => {
        element.getText().then(text => {
          assert.equal(text.includes("PM Meg"), true);
          assert.equal(elements.length, 2);
          next();
        });
      });
  });
});

这是错误,我得到了。但测试正在通过。

1 scenario (1 passed)
2 steps (2 passed)
0m56.079s
(node:3178) UnhandledPromiseRejectionWarning: NoSuchSessionError: invalid session id
  (Driver info: chromedriver=2.42.591059 (a3d9684d10d61aa0c45f6723b327283be1ebaad8),platform=Mac OS X 10.13.6 x86_64)
    at Object.checkLegacyResponse (/Users/jaiprak/workspace/reaction-app/spec/integration_tests/node_modules/selenium-webdriver/lib/error.js:585:15)
    at parseHttpResponse (/Users/jaiprak/workspace/reaction-app/spec/integration_tests/node_modules/selenium-webdriver/lib/http.js:533:13)
    at Executor.execute (/Users/jaiprak/workspace/reaction-app/spec/integration_tests/node_modules/selenium-webdriver/lib/http.js:468:26)
    at <anonymous>
    at process._tickCallback (internal/process/next_tick.js:118:7)
(node:3178) 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: 3)

【问题讨论】:

  • 之所以添加 Promise 是为了防止回调地狱。因此,如果不详细查看 openWindow 或您的测试用例,您已经可以假设您以错误的方式使用 Promises。仔细观察,你会发现你总是启动一个分离的 Promise 链,你不会返回,也没有为其添加 catch,所以你的大多数 Promise 链都是抛出 UnhandledPromiseRejectionWarning 的候选者
  • github.com/SeleniumHQ/selenium/issues/6824希望对其他人有所帮助。

标签: node.js selenium-webdriver selenium-chromedriver integration-testing


【解决方案1】:

使用超时来延迟进程,它会起作用的!

setTimeout(() => {
        driver.quit();
    }, 100);

【讨论】:

    【解决方案2】:

    对我来说,当我添加时它就解决了:

    "--remote-debugging-port=" + nextPort
    

    我使用 varibale nextPort 来使用许多驱动程序 完整代码:

     let options = new chrome.Options()
     nextPort++
     console.log('nextPort = ' + nextPort)
     options.addArguments(["--no-sandbox",
                           "--disable-gpu",
                           "--headless",
                           "--remote-debugging-port=" + nextPort])
     let driver = new webdriver.Builder()
         .withCapabilities(webdriver.Capabilities.chrome())
         .setChromeOptions(options)
         .build()
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2018-11-04
      • 2017-01-09
      • 2020-11-21
      • 2021-10-31
      • 2021-10-01
      • 2021-02-02
      • 2020-03-06
      • 2022-11-24
      相关资源
      最近更新 更多