#!/usr/bin/env python # Copyright (C) 2012 Bastian Kleineidam from __future__ import print_function import sys import os import stat import time sys.path.append(os.path.join(os.path.dirname(__file__), "..")) from dosagelib.scraper import get_scrapers htmltemplate = """ Dosage test results

Dosage test results from %(date)s

%(content)s
""" def get_mtime (filename): """Return modification time of filename.""" return os.stat(filename)[stat.ST_MTIME] def strdate(t): return time.strftime("%d.%m.%Y", time.localtime(t)) def get_test_name(line): classname = line.split('::')[1][4:] for scraper in get_scrapers(): if scraper.__name__ == classname: try: url = scraper.starter() except Exception: url = None return scraper.get_name(), url raise ValueError("Scraper %r not found" % classname) def get_test(line): name, url = get_test_name(line) result = "OK" if line.startswith(". ") else "FAILED" return [name, url, result, ""] def get_content(filename): tests = [] with open(filename, "r") as f: print("Tests parsed: 0", end=" ", file=sys.stderr) num_tests = 0 for line in f: if line.startswith((". ", "F ")) and "test_comics" in line: num_tests += 1 try: tests.append(get_test(line)) add_reason = line.startswith("F ") except Exception as msg: print("WARNING:", msg, file=sys.stderr) elif add_reason and line.startswith(" E "): reason = line[3:].strip() tests[-1][-1] = reason if num_tests % 5 == 0: print(num_tests, end=" ", file=sys.stderr) tests.sort() res = [] for name, url, result, reason in tests: css = result.lower() if len(name) > 25 and '/' in name: name = name.replace('/', '/ ') if url: inner = '%s %s' % (url, reason, css, name, result) else: inner = '%s %s' % (reason, css, name, result) res.append('
%s
' % inner) return os.linesep.join(res) def main(args): filename = args[0] modified = get_mtime(filename) content = get_content(filename) attrs = {"date": strdate(modified), "content": content} print(htmltemplate % attrs) return 0 if __name__ == '__main__': sys.exit(main(sys.argv[1:]))