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; |
+ }); |
+}; |