commented class definitions. moved HTML character escaping out of

2007-12-20 16:34:04  Tim Janik  <timj@imendio.com>

        * glib/gtester-report: commented class definitions. moved HTML character
        escaping out of javascript. fixed string->bool conversions. added performance
        results to test case "Details" window.



svn path=/trunk/; revision=6176
This commit is contained in:
16:34:04 Tim Janik 2007-12-20 15:35:21 +00:00 committed by Tim Janik
parent 877cc60f03
commit 798aaac34f
2 changed files with 38 additions and 9 deletions

View File

@ -1,3 +1,9 @@
2007-12-20 16:34:04 Tim Janik <timj@imendio.com>
* glib/gtester-report: commented class definitions. moved HTML character
escaping out of javascript. fixed string->bool conversions. added performance
results to test case "Details" window.
2007-12-20 Matthias Clasen <mclasen@redhat.com> 2007-12-20 Matthias Clasen <mclasen@redhat.com>
* glib/gchecksum.[hc] (g_checksum_new): Return NULL when * glib/gchecksum.[hc] (g_checksum_new): Return NULL when

View File

@ -69,6 +69,7 @@ def html_indent_string (n):
string += uncollapsible_space string += uncollapsible_space
return string return string
# TestBinary object, instantiated per test binary in the log file
class TestBinary: class TestBinary:
def __init__ (self, name): def __init__ (self, name):
self.name = name self.name = name
@ -79,6 +80,7 @@ class TestBinary:
self.file = '???' self.file = '???'
self.random_seed = '' self.random_seed = ''
# base class to handle processing/traversion of XML nodes
class TreeProcess: class TreeProcess:
def __init__ (self): def __init__ (self):
self.nest_level = 0 self.nest_level = 0
@ -101,6 +103,7 @@ class TreeProcess:
self.trampoline (child) self.trampoline (child)
self.nest_level += 1 self.nest_level += 1
# test report reader, this class collects some statistics and merges duplicate test binary runs
class ReportReader (TreeProcess): class ReportReader (TreeProcess):
def __init__ (self): def __init__ (self):
TreeProcess.__init__ (self) TreeProcess.__init__ (self)
@ -117,7 +120,7 @@ class ReportReader (TreeProcess):
result = attribute_as_text (node, 'result', 'status') result = attribute_as_text (node, 'result', 'status')
if result == 'success': if result == 'success':
self.last_binary.success_cases += 1 self.last_binary.success_cases += 1
if bool (attribute_as_text (node, 'skipped')): if bool (int (attribute_as_text (node, 'skipped') + '0')):
self.last_binary.skipped_cases += 1 self.last_binary.skipped_cases += 1
def handle_text (self, node): def handle_text (self, node):
pass pass
@ -141,6 +144,7 @@ class ReportReader (TreeProcess):
self.last_binary.random_seed = node_as_text (rseed) self.last_binary.random_seed = node_as_text (rseed)
self.process_children (node) self.process_children (node)
# HTML report generation class
class ReportWriter (TreeProcess): class ReportWriter (TreeProcess):
# Javascript/CSS snippet to toggle element visibility # Javascript/CSS snippet to toggle element visibility
cssjs = r''' cssjs = r'''
@ -164,11 +168,8 @@ class ReportWriter (TreeProcess):
} }
} }
message_array = Array(); message_array = Array();
function view_testlog (wname, file, random_seed, tcase, msgid) { function view_testlog (wname, file, random_seed, tcase, msgtitle, msgid) {
txt = message_array[msgid]; txt = message_array[msgid];
txt = txt.replace (/&/g, "&amp;");
txt = txt.replace (/</g, "&lt;");
txt = txt.replace (/>/g, "&gt;");
var w = window.open ("", // URI var w = window.open ("", // URI
wname, wname,
"resizable,scrollbars,status,width=790,height=400"); "resizable,scrollbars,status,width=790,height=400");
@ -176,7 +177,7 @@ class ReportWriter (TreeProcess):
doc.write ("<h2>File: " + file + "</h2>\n"); doc.write ("<h2>File: " + file + "</h2>\n");
doc.write ("<h3>Case: " + tcase + "</h3>\n"); doc.write ("<h3>Case: " + tcase + "</h3>\n");
doc.write ("<strong>Random Seed:</strong> <code>" + random_seed + "</code> <br /><br />\n"); doc.write ("<strong>Random Seed:</strong> <code>" + random_seed + "</code> <br /><br />\n");
doc.write ("<strong>Output: </strong><br />\n"); doc.write ("<strong>" + msgtitle + "</strong><br />\n");
doc.write ("<pre>"); doc.write ("<pre>");
doc.write (txt); doc.write (txt);
doc.write ("</pre>\n"); doc.write ("</pre>\n");
@ -202,7 +203,7 @@ class ReportWriter (TreeProcess):
def handle_text (self, node): def handle_text (self, node):
self.oprint (node.nodeValue) self.oprint (node.nodeValue)
def handle_testcase (self, node, binary): def handle_testcase (self, node, binary):
skipped = bool (attribute_as_text (node, 'skipped')) skipped = bool (int (attribute_as_text (node, 'skipped') + '0'))
if skipped: if skipped:
return # skipped tests are uninteresting for HTML reports return # skipped tests are uninteresting for HTML reports
path = attribute_as_text (node, 'path') path = attribute_as_text (node, 'path')
@ -216,6 +217,7 @@ class ReportWriter (TreeProcess):
duration = '-' # ignore bogus durations duration = '-' # ignore bogus durations
self.oprint ('<tr id="b%u_t%u_" keywords="%s all" class="HiddenSection">\n' % (self.bcounter, self.tcounter, result)) self.oprint ('<tr id="b%u_t%u_" keywords="%s all" class="HiddenSection">\n' % (self.bcounter, self.tcounter, result))
self.oprint ('<td>%s %s</td> <td align="right">%s</td> \n' % (html_indent_string (4), path, duration)) self.oprint ('<td>%s %s</td> <td align="right">%s</td> \n' % (html_indent_string (4), path, duration))
perflist = list_children (node, 'performance')
if result != 'success': if result != 'success':
rlist = list_children (node, 'error') rlist = list_children (node, 'error')
txt = '' txt = ''
@ -225,9 +227,29 @@ class ReportWriter (TreeProcess):
txt += '\n' txt += '\n'
txt = re.sub (r'"', r'\\"', txt) txt = re.sub (r'"', r'\\"', txt)
txt = re.sub (r'\n', r'\\n', txt) txt = re.sub (r'\n', r'\\n', txt)
txt = re.sub (r'&', r'&amp;', txt)
txt = re.sub (r'<', r'&lt;', txt)
self.oprint ('<script language="javascript" type="text/javascript">message_array["b%u_t%u_"] = "%s";</script>\n' % (self.bcounter, self.tcounter, txt)) self.oprint ('<script language="javascript" type="text/javascript">message_array["b%u_t%u_"] = "%s";</script>\n' % (self.bcounter, self.tcounter, txt))
self.oprint ('<td align="center"><a href="javascript:view_testlog (\'%s\', \'%s\', \'%s\', \'%s\', \'b%u_t%u_\')">Output</a></td>\n' % self.oprint ('<td align="center"><a href="javascript:view_testlog (\'%s\', \'%s\', \'%s\', \'%s\', \'Output:\', \'b%u_t%u_\')">Details</a></td>\n' %
('TestOutputWindow', binary.file, binary.random_seed, path, self.bcounter, self.tcounter)) ('TestResultWindow', binary.file, binary.random_seed, path, self.bcounter, self.tcounter))
elif perflist:
presults = []
for perf in perflist:
pmin = bool (int (attribute_as_text (perf, 'minimize')))
pmax = bool (int (attribute_as_text (perf, 'maximize')))
pval = float (attribute_as_text (perf, 'value'))
txt = node_as_text (perf)
txt = re.sub (r'&', r'&amp;', txt)
txt = re.sub (r'<', r'&gt;', txt)
txt = '<strong>Performace(' + (pmin and '<em>minimized</em>' or '<em>maximized</em>') + '):</strong> ' + txt.strip() + '<br />\n'
txt = re.sub (r'"', r'\\"', txt)
txt = re.sub (r'\n', r'\\n', txt)
presults += [ (pval, txt) ]
presults.sort()
ptxt = ''.join ([e[1] for e in presults])
self.oprint ('<script language="javascript" type="text/javascript">message_array["b%u_t%u_"] = "%s";</script>\n' % (self.bcounter, self.tcounter, ptxt))
self.oprint ('<td align="center"><a href="javascript:view_testlog (\'%s\', \'%s\', \'%s\', \'%s\', \'Test Results:\', \'b%u_t%u_\')">Details</a></td>\n' %
('TestResultWindow', binary.file, binary.random_seed, path, self.bcounter, self.tcounter))
else: else:
self.oprint ('<td align="center">-</td>\n') self.oprint ('<td align="center">-</td>\n')
self.oprint ('<td align="right" %s>%s</td>\n' % (rcolor, result)) self.oprint ('<td align="right" %s>%s</td>\n' % (rcolor, result))
@ -291,6 +313,7 @@ class ReportWriter (TreeProcess):
self.oprint ('</body>\n') self.oprint ('</body>\n')
self.oprint ('</html>\n') self.oprint ('</html>\n')
# main program handling
def parse_files_and_args (): def parse_files_and_args ():
from sys import argv, stdin from sys import argv, stdin
files = [] files = []