| Index: firefox_process.js |
| =================================================================== |
| new file mode 100644 |
| --- /dev/null |
| +++ b/firefox_process.js |
| @@ -0,0 +1,83 @@ |
| +/* |
| + * This file is part of Adblock Plus <https://adblockplus.org/>, |
| + * Copyright (C) 2006-present eyeo GmbH |
| + * |
| + * Adblock Plus is free software: you can redistribute it and/or modify |
| + * it under the terms of the GNU General Public License version 3 as |
| + * published by the Free Software Foundation. |
| + * |
| + * Adblock Plus is distributed in the hope that it will be useful, |
| + * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| + * GNU General Public License for more details. |
| + * |
| + * You should have received a copy of the GNU General Public License |
| + * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
| + */ |
| + |
| +/* eslint-env node */ |
| +/* eslint no-console: "off" */ |
| + |
| +"use strict"; |
| + |
| +const path = require("path"); |
| + |
| +const {Builder, Capabilities, logging} = require("selenium-webdriver"); |
| +const firefox = require("selenium-webdriver/firefox"); |
| +require("geckodriver"); |
| + |
| +logging.installConsoleHandler(); |
| +// logging.getLogger("webdriver.http").setLevel(logging.Level.ALL); |
| + |
| +let prefs = new logging.Preferences(); |
| +prefs.setLevel(logging.Type.BROWSER, logging.Level.ALL); |
| +prefs.setLevel(logging.Type.CLIENT, logging.Level.ALL); |
| +let caps = Capabilities.firefox(); |
| +caps.setLoggingPrefs(prefs); |
| + |
| +function runScript(script, scriptName, scriptArgs) |
| +{ |
| + let binary = new firefox.Binary(firefox.Channel.NIGHTLY); |
| + binary.addArguments("-headless"); |
| + |
| + const options = new firefox.Options() |
| + .setBinary(binary); |
| + |
| + const driver = new Builder() |
| + .forBrowser("firefox") |
| + .setFirefoxOptions(options) |
| + .build(); |
| + |
| + let index = path.join(__dirname, "test", "browser"); |
| + let realScript = `let f = ${script} return f(...arguments);`; |
| + return driver.get(`file://${index}/index.html`) |
| + .then(result => driver.executeScript( |
| +` window.consoleLogs = []; |
| + let oldLog = console.log; |
| + console.log = msg => { |
| + window.consoleLogs.push(msg); |
| + oldLog.call(this, msg); |
| + };` |
| + )) |
| + .then(result => driver.executeScript(realScript, scriptArgs)) |
| + .then(result => driver.executeScript("return window.consoleLogs;")) |
| + .then(result => |
| + { |
| + console.log("\nTest in Firefox\n"); |
| + result.forEach(item => console.log(item)); |
| + }) |
| + .then(() => driver.quit()); |
| +} |
| + |
| +module.exports = function(script, scriptName, ...scriptArgs) |
| +{ |
| + return Promise.race([ |
| + runScript(script, scriptName, scriptArgs) |
|
Sebastian Noack
2018/03/12 23:17:31
Isn't Promise.race([p]) equivalent to p?
hub
2018/03/13 01:59:37
indeed. will fix that.
|
| + ]).then(result => |
| + { |
| + return result; |
| + }).catch(error => |
| + { |
| + throw error; |
| + }); |
| +}; |