webdriver.io 无法为 iframe 禁用 same-origin-policy

webdriver.io can't disable same-origin-policy for iframe

我需要为我的自动测试禁用 same-origin-policy。 我在 webdriver.io + selenium 独立服务器 + chromedriver Ubuntu 16.04. 我需要从具有不同于页面域的域的 iframe 获取标题。 我已阅读此主题并在我的代码中使用了答案,但它似乎不起作用/ Disable same origin policy in Chrome .

我的代码: 部分 wdio.conf.js

capabilities: [{
        maxInstances: 5,
        browserName: 'chrome',
        chromeOptions : {
            args: ["--disable-web-security", "--user-data-dir:path/to/profile"]
        }
    }],

规范中用于获取 iframe 标题的部分代码:

it('step' , function() {
  var iframeValue = browser.element('#iframe_id').value;
  browser.frame(iframeValue);
  browser.waitForExist('title'); //or any element inside head or body
  browser.getTitle(); //returns page title, not iframe
  browser.element('title').getText(); //returns ''
  browser.element('title').getHTML(); //returns '<title>iframe title</title>'     
});

我重新启动了 selenium 服务器,重新启动了测试,使用 browser.debug() 检查 iframe 是否是活动元素,检查了 profile --user-data-dir 参数是否有效。 是否有可能 webdriver.io 无法从 iframe 获取值或 --disable-web-security 根本不起作用?

更新: iframe 的结构:

<iframe src="http://www.example.com" id="iframe_id"></iframe>
    #document
    <html>
    <head>
        <title>iframe title</title>
    </head>
    <body>
        <div>
            <!--content-->
        </div>
    </body>
    </html>

我不明白你想做什么,但如果你这样做

browser.getHTML('html').then(function(data) {
// match something from data with regex
}

您可以使用正则表达式匹配您搜索的所有内容。如果您不是随机网站,并且您可以访问该文档,则只需添加 class。然后你可以在你创建的 class 上制作 .getHTML 或 .getText 。但是,如果您在 'html' 上制作 .getHTML,那么您将获得完整的 html 文档,这意味着您将获得在源代码中看到的所有内容。