dom/imptests/parseFailures.py
author Mike Hommey <mh+mozilla@glandium.org>
Thu, 06 Dec 2012 17:06:37 +0100
changeset 115160 008f2249f16d5e704fdd712c2fdee49ad8604119
parent 114704 1e998904dbf4834df1dc48da42012573dc3ef1ea
child 123218 c1b0d8399be92a0a541fddec5e580196e7b83e32
permissions -rw-r--r--
Bug 818092 - Properly use CC/CXX from mozconfig on non-cross-compile Mac builds. r=ted

# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.

from __future__ import print_function, unicode_literals

import collections
import json
import os
import sys

import writeMakefile

def extractLines(fp):
    lines = []
    watch = False
    for line in fp:
        line = line.decode('utf-8')
        if line == '@@@ @@@ Failures\n':
            watch = True
        elif watch:
            watch = False
            idx = line.index('@@@')
            lines.append((line[:idx], line[idx + 3:]))
    return lines

def ensuredir(path):
    dir = path[:path.rfind('/')]
    if not os.path.exists(dir):
        os.makedirs(dir)

def dumpFailures(lines):
    files = []
    for url, objstr in lines:
        if objstr == '{}\n':
            continue

        # Avoid overly large diffs.
        if 'editing/' in url:
            sep = ':'
        else:
            sep = ': '

        jsonpath = 'failures/' + url + '.json'
        files.append(jsonpath)
        ensuredir(jsonpath)
        obj = json.loads(objstr, object_pairs_hook=collections.OrderedDict)
        formattedobjstr = json.dumps(obj, indent=2, separators=(',', sep)) + '\n'
        formattedobj = formattedobjstr.encode('utf-8')
        fp = open(jsonpath, 'wb')
        fp.write(formattedobj)
        fp.close()
    return files

def writeMakefiles(files):
    pathmap = {}
    for path in files:
        dirp, leaf = path.rsplit('/', 1)
        pathmap.setdefault(dirp, []).append(leaf)

    for k, v in pathmap.items():
        resultstr = writeMakefile.substMakefile('parseFailures.py', [], v)
        result = resultstr.encode('utf-8')

        fp = open(k + '/Makefile.in', 'wb')
        fp.write(result)
        fp.close()

def main(logPath):
    fp = open(logPath, 'rb')
    lines = extractLines(fp)
    fp.close()

    files = dumpFailures(lines)
    writeMakefiles(files)

if __name__ == '__main__':
    if len(sys.argv) < 2:
        print("Please pass the path to the logfile from which failures should be extracted.")
    main(sys.argv[1])