/*jshint unused: false */ /*global require, start_pretty_print */ var UnitTest = require("org/arangodb/testing"); var internalMembers = UnitTest.internalMembers; var fs = require("fs"); var print = require("internal").print; function resultsToXml(results, baseName) { "use strict"; function xmlEscape(s) { return s.replace(/[<>&"]/g, function (c) { return "&" + { "<": "lt", ">": "gt", "&": "amp", "\"": "quot" }[c] + ";"; }); } function buildXml () { var xml = [ "\n" ]; xml.text = function (s) { Array.prototype.push.call(this, s); return this; }; xml.elem = function (tagName, attrs, close) { this.text("<").text(tagName); attrs = attrs || { }; for (var a in attrs) { if (attrs.hasOwnProperty(a)) { this.text(" ").text(a).text("=\"") .text(xmlEscape(String(attrs[a]))).text("\""); } } if (close) { this.text("/"); } this.text(">\n"); return this; }; return xml; } for (var testrun in results) { if ((internalMembers.indexOf(testrun) === -1) && (results.hasOwnProperty(testrun))) { for (var test in results[testrun]) { if ((internalMembers.indexOf(test) === -1) && results[testrun].hasOwnProperty(test) && !results[testrun][test].hasOwnProperty('skipped')) { var xml = buildXml(); var failuresFound = ""; if (results[testrun][test].hasOwnProperty('failed')) { failuresFound = results[testrun][test].failed; } xml.elem("testsuite", { errors: 0, failures: failuresFound, name: test, tests: results[testrun][test].total, time: results[testrun][test].duration }); for (var oneTest in results[testrun][test]) { if (internalMembers.indexOf(oneTest) === -1) { var result = results[testrun][test][oneTest].status; var success = (typeof(result) === 'boolean')? result : false; xml.elem("testcase", { name: oneTest, time: results[testrun][test][oneTest].duration }, success); if (! success) { xml.elem("failure"); xml.text('\n'); xml.elem("/failure"); xml.elem("/testcase"); } } } if ((! results[testrun][test].status) && results[testrun][test].hasOwnProperty('message')) { xml.elem("testcase", { name: 'all tests in ' + test, time: results[testrun][test].duration }, false); xml.elem("failure"); xml.text('\n'); xml.elem("/failure"); xml.elem("/testcase"); } xml.elem("/testsuite"); var fn = baseName + testrun.replace(/\//g, '_') + '_' + test.replace(/\//g, '_') + ".xml"; fs.write(fn, xml.join("")); } } } } } function main (argv) { "use strict"; var test = argv[1]; var options = {}; var r; if (argv.length >= 3) { try { options = JSON.parse(argv[2]); } catch (x) { print("failed to parse the json options"); print(x); return -1; } } options.jsonReply = true; start_pretty_print(); try { r = UnitTest.UnitTest(test,options); } catch (x) { print("Caught exception during test execution!"); print(x.message); print(JSON.stringify(r)); } fs.write("UNITTEST_RESULT.json",JSON.stringify(r)); fs.write("UNITTEST_RESULT_SUMMARY.txt",JSON.stringify(!r.crashed)); try { resultsToXml(r, "UNITTEST_RESULT_"); } catch (x) { print("Exception while serializing status xml!"); print(x.message); print(JSON.stringify(r)); } UnitTest.unitTestPrettyPrintResults(r); }