Anton Shestakov <av6@dwimlabs.net>, Thu, 23 Jun 2016 14:58:09 +0800
checker: try and catch exceptions from execute() and somewhat finish the job
Exceptions coming from execute() are programming errors in checker.py, but jobs
still need to tell that they are finished (and failed) to be processed by
incoming.py.
incoming.py
Permissions: -rwxr-xr-x
from __future__ import absolute_import from datetime import datetime from urlparse import urlparse from tornado.escape import json_encode from candolint.models import database, Project, Change, Check rel = lambda *x: os.path.abspath(os.path.join(os.path.dirname(__file__), *x)) def parse_timestamp(value): return datetime.strptime(value, '%Y-%m-%dT%H:%M:%S+00:00') def parse_project_url(url): parts = [part for part in parsed.path.split('/') if part] name = '/'.join(parts[1:]) return domain, user, name def match_linter_output(line): m = re.match(r'^(.+):(\d+):\d+: ', line) item['filename'] = m.group(1) item['fileline'] = int(m.group(2)) # https://pep8.readthedocs.io/en/latest/intro.html#error-codes (r'^[EWFCN]\d{3}', 'warning'), (r'^\[error\]', 'error'), (r'^\[warning\]', 'warning'), (r'^\(E\d{3}\)', 'error'), (r'^\(W\d{3}\)', 'warning'), for regex, cls in patterns: m = re.match(regex, rest) return errors, warnings, item state = 'not even started' if line.startswith(meta_prefix): rest = line[len(meta_prefix):] m = re.match('^task: (\w+)$', rest) m = re.match('^job failed$', rest) m = re.match('^job (started|finished): ([\dT:+-]+)$', rest) if m.group(1) == 'started': started = parse_timestamp(m.group(2)) elif m.group(1) == 'finished': finished = parse_timestamp(m.group(2)) m = re.match('^project URL: (\S+)$', rest) m = re.match('^commit: (\d+):(\w+) (\w+)$', rest) m = re.match('^commit date: (.+)$', rest) m = re.match('^commit author: (.+)$', rest) m = re.match('^commit message: (.+)$', rest) de, dw, extra = match_linter_output(line) domain, user, name = parse_project_url(url) with database.transaction(): project, created = Project.create_or_get( change, created = Change.create_or_get( ordinal=Check.select().where(Check.project == project).count() + 1, lines=json_encode(result), database.init(rel('database.sqlite')) database.create_tables([Project, Change, Check], safe=True) logger = logging.getLogger('peewee') logger.setLevel(logging.DEBUG) logger.addHandler(logging.StreamHandler()) insert_check(list(fileinput.input())) if __name__ == '__main__':