From d0a0695fb5d34996850723f7d4b1b59c3df909c2 Mon Sep 17 00:00:00 2001 From: Florian Dold Date: Thu, 3 Nov 2016 00:47:22 +0100 Subject: test harness for both browser and node --- testlib/selenium/runtime.js | 100 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 100 insertions(+) create mode 100644 testlib/selenium/runtime.js (limited to 'testlib/selenium/runtime.js') diff --git a/testlib/selenium/runtime.js b/testlib/selenium/runtime.js new file mode 100644 index 000000000..0cf6c6d18 --- /dev/null +++ b/testlib/selenium/runtime.js @@ -0,0 +1,100 @@ +/* + This file is part of TALER + (C) 2016 Inria + + TALER is free software; you can redistribute it and/or modify it under the + terms of the GNU General Public License as published by the Free Software + Foundation; either version 3, or (at your option) any later version. + + TALER 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 + TALER; see the file COPYING. If not, see + */ + +/** + * + * @author Florian Dold + */ + +"use strict"; + +var webdriver = require('selenium-webdriver'); +var chrome = require('selenium-webdriver/chrome'); +var path = require("path"); +var process = require("process"); + +var p = "file://" + __dirname + "/testhost.html"; + +if (!process.argv[2]) { + console.log("no test script given"); + process.exit(1); +} + +var testScript = path.resolve(process.argv[2]); + +var script = ` + function f() { + System.import("testlib/talertest") + .then(tt => { + SystemJS.import("file://${testScript}") + .then(() => { + return tt.run(); + }) + .then(() => { + window.__test_over = true; + }) + .catch((e) => { + window.__test_over = true; + console.error(e) + }); + }) + .catch((e) => { + console.error("can't locate talertest"); + console.error(e); + }); + } + if (document.readyState == "complete") { + f(); + } else { + document.addEventListener("DOMContentLoaded", f); + } +`; + +function untilTestOver() { + return driver.executeScript("return window.__test_over"); +} + +console.log("TAP version 13"); + +var driver = new webdriver.Builder() + .setLoggingPrefs({browser: 'ALL'}) + .forBrowser('chrome') + .build(); + +driver.get(p); +driver.executeScript(script); +driver.wait(untilTestOver); + +driver.manage().logs().get("browser").then((logs) => { + for (let l of logs) { + if (l.level.name != "INFO") { + continue; + } + if (l.message.startsWith("{")) { + // format not understood, sometimes messages are logged + // with more structure, just pass it on + console.log(l.message); + continue; + } + let s1 = l.message.indexOf(" ") + 1; + let s2 = l.message.indexOf(" ", s1) + 1; + // Skip file url and LINE:COL + console.log(l.message.substring(s2)); + } +}); + +driver.quit(); + -- cgit v1.2.3