Selenoid:Chrome浏览器启动几秒钟,然后关闭

时间:2019-09-17 14:57:51

标签: selenium-webdriver selenoid

详细信息: 1.浏览器出现一秒钟,然后关闭,导致下一步测试步骤是将cookie设置为失败。 错误:

UnableToSetCookieError: unable to set cookie
  (Session info: chrome=77.0.3865.75)
    at Object.throwDecodedError (/usr/app/node_modules/selenium-webdriver/lib/error.js:550:15)
    at parseHttpResponse (/usr/app/node_modules/selenium-webdriver/lib/http.js:563:13)
    at Executor.execute (/usr/app/node_modules/selenium-webdriver/lib/http.js:489:26)
    at processTicksAndRejections (internal/process/task_queues.js:93:5)
    at async thenableWebDriverProxy.execute (/usr/app/node_modules/selenium-webdriver/lib/webdriver.js:699:17)
    at async loginWithRoles (/usr/app/features/support/pages/common.js:16:3)

设置cookie的代码为:

await driver.get(TARGET_HOST)
  await driver.manage().addCookie({
    name: 'token',
    value: tokenValue,
    httpOnly: true,
    domain: TARGET_HOST_DOMAIN,
    path: '/',
    secure: false
  })
  await driver.get(TARGET_HOST)
  return driver.manage().window().setRect({width: 1920, height: 3000})

这些测试一直运行到2019年9月13日。这与selenoid/chrome:latest更新的日期相符。

我正在撰写文件中使用以下docker图像: aerokube / selenoid:最新发布 硒油/录像机:最新发布 硒油/铬:最新

Selenium-webdriver:4.0.0-alpha.4

任何调试技巧都会有所帮助

1 个答案:

答案 0 :(得分:0)

我通过在设置Cookie时不添加domain来解决了此问题。

设置cookie的代码现在看起来像这样:

    await driver.get(TARGET_HOST)
    await driver.manage().addCookie({
    name: 'token',
    value: tokenValue,
    httpOnly: true,
    path: '/',
    secure: false
  })
  await driver.get(TARGET_HOST)

请参阅:https://bugs.chromium.org/p/chromedriver/issues/detail?id=3141