TestFormat.js revision 5aab19b8b78189ce79cf89283f2d505566d4e6a8
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * An object object containing test result formatting methods.
75c0816e8295e180f4bc7f10db3d0d880383bc1cMark Andrews * @namespace Test
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @class TestFormat
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein /* (intentionally not documented)
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * Basic XML escaping method. Replaces quotes, less-than, greater-than,
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * apostrophe, and ampersand characters with their corresponding entities.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @param {String} text The text to encode.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @return {String} The XML-escaped text.
5a4557e8de2951a2796676b5ec4b6a90caa5be14Mark Andrews return text.replace(/[<>"'&]/g, function(value){
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein switch(value){
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * Returns test results formatted as a JSON string. Requires JSON utility.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @param {Object} result The results object created by TestRunner.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @return {String} A JSON-formatted string of results.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @method JSON
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * Returns test results formatted as an XML string.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @param {Object} result The results object created by TestRunner.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @return {String} An XML-formatted string of results.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @method XML
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein var xml = "<" + results.type + " name=\"" + xmlEscape(results.name) + "\"";
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein xml += " duration=\"" + results.duration + "\"";
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein xml += " result=\"" + results.result + "\" message=\"" + xmlEscape(results.message) + "\">";
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein xml += " passed=\"" + results.passed + "\" failed=\"" + results.failed + "\" ignored=\"" + results.ignored + "\" total=\"" + results.total + "\">";
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein if (results[prop] && typeof results[prop] == "object" && !(results[prop] instanceof Array)){
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein return "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" + serializeToXML(results);
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * Returns test results formatted in JUnit XML format.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @param {Object} result The results object created by TestRunner.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @return {String} An XML-formatted string of results.
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein * @method JUnitXML
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein //equivalent to testcase in JUnit
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein case "test":
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein xml = "<testcase name=\"" + xmlEscape(results.name) + "\" time=\"" + (results.duration/1000) + "\">";
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein xml += "<failure message=\"" + xmlEscape(results.message) + "\"><![CDATA[" + results.message + "]]></failure>";
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein //equivalent to testsuite in JUnit
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein case "testcase":
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein xml = "<testsuite name=\"" + xmlEscape(results.name) + "\" tests=\"" + results.total + "\" failures=\"" + results.failed + "\" time=\"" + (results.duration/1000) + "\">";
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein if (results[prop] && typeof results[prop] == "object" && !(results[prop] instanceof Array)){
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein //no JUnit equivalent, don't output anything
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein case "testsuite":
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein if (results[prop] && typeof results[prop] == "object" && !(results[prop] instanceof Array)){
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein //top-level, equivalent to testsuites in JUnit
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein case "report":
60e5e10f8d2e2b0c41e8abad38cacd867caa6ab2Rob Austein if (results[prop] && typeof results[prop] == "object" && !(results[prop] instanceof Array)){
return xml;
* For more information, see <a href="http://testanything.org/">Test Anything Protocol</a>.
text = "#Begin testcase " + results.name + "(" + results.failed + " failed of " + results.total + ")\n";
text = "#Begin testsuite " + results.name + "(" + results.failed + " failed of " + results.total + ")\n";
return text;