From f276b27885d77add550e16a560108aab8a994f2c Mon Sep 17 00:00:00 2001 From: Murali Nandigama Date: Thu, 13 May 2010 14:32:28 -0700 Subject: [PATCH] clean-up --- PREREQS | 6 - README | 3 - cleanup.sh | 2 - dbschema.py | 121 ---- log_parser.py | 203 ------- mappings.py | 95 ---- sample-logs/leaks-log.txt | 268 --------- topfails/PREREQS | 6 - topfails/README | 3 - topfails/__init__.py | 0 topfails/cleanup.sh | 2 - topfails/dbschema.py | 121 ---- topfails/images/img5846075.png | Bin 15027 -> 0 bytes topfails/images/nav12971480a.gif | Bin 3265 -> 0 bytes topfails/images/nav12971480i.gif | Bin 2959 -> 0 bytes topfails/images/nav12971481a.gif | Bin 3286 -> 0 bytes topfails/images/nav12971481i.gif | Bin 2970 -> 0 bytes topfails/images/nav12971482a.gif | Bin 3278 -> 0 bytes topfails/images/nav12971482i.gif | Bin 2977 -> 0 bytes topfails/images/nav12971483a.gif | Bin 3387 -> 0 bytes topfails/images/nav12971483i.gif | Bin 3043 -> 0 bytes topfails/images/nav12971484a.gif | Bin 3083 -> 0 bytes topfails/images/nav12971484i.gif | Bin 2769 -> 0 bytes topfails/log_parser.py | 203 ------- topfails/manage.py | 11 - topfails/mappings.py | 95 ---- topfails/settings.py | 86 --- topfails/templates/base.html | 121 ---- topfails/templates/viewer/Help.html | 21 - topfails/templates/viewer/README | 5 - topfails/templates/viewer/changeset.html | 9 - topfails/templates/viewer/changesets.html | 9 - topfails/templates/viewer/failswindow.html | 10 - topfails/templates/viewer/index.html | 15 - topfails/templates/viewer/latest.html | 15 - topfails/templates/viewer/test.html | 13 - topfails/templates/viewer/test.html.orig | 27 - topfails/templates/viewer/tests.html | 14 - topfails/templates/viewer/timeline.html | 72 --- topfails/templates/viewer/topfails.html | 10 - topfails/templates/viewer/topfails.rar | Bin 280990 -> 0 bytes topfails/templates/viewer/tree.html | 9 - topfails/templates/viewer/trees.html | 10 - topfails/topfails/__init__.py | 0 topfails/topfails/images/img5846075.png | Bin 15027 -> 0 bytes topfails/topfails/images/nav12971480a.gif | Bin 3265 -> 0 bytes topfails/topfails/images/nav12971480i.gif | Bin 2959 -> 0 bytes topfails/topfails/images/nav12971481a.gif | Bin 3286 -> 0 bytes topfails/topfails/images/nav12971481i.gif | Bin 2970 -> 0 bytes topfails/topfails/images/nav12971482a.gif | Bin 3278 -> 0 bytes topfails/topfails/images/nav12971482i.gif | Bin 2977 -> 0 bytes topfails/topfails/images/nav12971483a.gif | Bin 3387 -> 0 bytes topfails/topfails/images/nav12971483i.gif | Bin 3043 -> 0 bytes topfails/topfails/images/nav12971484a.gif | Bin 3083 -> 0 bytes topfails/topfails/images/nav12971484i.gif | Bin 2769 -> 0 bytes topfails/topfails/manage.py | 11 - topfails/topfails/settings.py | 86 --- topfails/topfails/templates/base.html | 121 ---- topfails/topfails/templates/viewer/Help.html | 21 - topfails/topfails/templates/viewer/README | 5 - .../topfails/templates/viewer/changeset.html | 9 - .../topfails/templates/viewer/changesets.html | 9 - .../templates/viewer/failswindow.html | 10 - topfails/topfails/templates/viewer/index.html | 15 - .../topfails/templates/viewer/latest.html | 15 - topfails/topfails/templates/viewer/test.html | 13 - .../topfails/templates/viewer/test.html.orig | 27 - topfails/topfails/templates/viewer/tests.html | 14 - .../topfails/templates/viewer/timeline.html | 72 --- .../topfails/templates/viewer/topfails.html | 10 - .../topfails/templates/viewer/topfails.rar | Bin 280990 -> 0 bytes topfails/topfails/templates/viewer/tree.html | 9 - topfails/topfails/templates/viewer/trees.html | 10 - topfails/topfails/urls.py | 20 - topfails/topfails/viewer/__init__.py | 0 topfails/topfails/viewer/models.py | 115 ---- topfails/topfails/viewer/views.py | 107 ---- topfails/unittest-log.py | 532 ------------------ topfails/urls.py | 20 - topfails/viewer/__init__.py | 0 topfails/viewer/models.py | 115 ---- topfails/viewer/views.py | 107 ---- unittest-log.py | 532 ------------------ 83 files changed, 3590 deletions(-) delete mode 100644 PREREQS delete mode 100644 README delete mode 100755 cleanup.sh delete mode 100755 dbschema.py delete mode 100644 log_parser.py delete mode 100755 mappings.py delete mode 100644 sample-logs/leaks-log.txt delete mode 100644 topfails/PREREQS delete mode 100644 topfails/README delete mode 100644 topfails/__init__.py delete mode 100755 topfails/cleanup.sh delete mode 100755 topfails/dbschema.py delete mode 100755 topfails/images/img5846075.png delete mode 100755 topfails/images/nav12971480a.gif delete mode 100755 topfails/images/nav12971480i.gif delete mode 100755 topfails/images/nav12971481a.gif delete mode 100755 topfails/images/nav12971481i.gif delete mode 100755 topfails/images/nav12971482a.gif delete mode 100755 topfails/images/nav12971482i.gif delete mode 100755 topfails/images/nav12971483a.gif delete mode 100755 topfails/images/nav12971483i.gif delete mode 100755 topfails/images/nav12971484a.gif delete mode 100755 topfails/images/nav12971484i.gif delete mode 100644 topfails/log_parser.py delete mode 100755 topfails/manage.py delete mode 100755 topfails/mappings.py delete mode 100644 topfails/settings.py delete mode 100755 topfails/templates/base.html delete mode 100755 topfails/templates/viewer/Help.html delete mode 100644 topfails/templates/viewer/README delete mode 100755 topfails/templates/viewer/changeset.html delete mode 100755 topfails/templates/viewer/changesets.html delete mode 100644 topfails/templates/viewer/failswindow.html delete mode 100755 topfails/templates/viewer/index.html delete mode 100755 topfails/templates/viewer/latest.html delete mode 100755 topfails/templates/viewer/test.html delete mode 100755 topfails/templates/viewer/test.html.orig delete mode 100755 topfails/templates/viewer/tests.html delete mode 100755 topfails/templates/viewer/timeline.html delete mode 100755 topfails/templates/viewer/topfails.html delete mode 100755 topfails/templates/viewer/topfails.rar delete mode 100755 topfails/templates/viewer/tree.html delete mode 100755 topfails/templates/viewer/trees.html delete mode 100644 topfails/topfails/__init__.py delete mode 100755 topfails/topfails/images/img5846075.png delete mode 100755 topfails/topfails/images/nav12971480a.gif delete mode 100755 topfails/topfails/images/nav12971480i.gif delete mode 100755 topfails/topfails/images/nav12971481a.gif delete mode 100755 topfails/topfails/images/nav12971481i.gif delete mode 100755 topfails/topfails/images/nav12971482a.gif delete mode 100755 topfails/topfails/images/nav12971482i.gif delete mode 100755 topfails/topfails/images/nav12971483a.gif delete mode 100755 topfails/topfails/images/nav12971483i.gif delete mode 100755 topfails/topfails/images/nav12971484a.gif delete mode 100755 topfails/topfails/images/nav12971484i.gif delete mode 100755 topfails/topfails/manage.py delete mode 100644 topfails/topfails/settings.py delete mode 100755 topfails/topfails/templates/base.html delete mode 100755 topfails/topfails/templates/viewer/Help.html delete mode 100644 topfails/topfails/templates/viewer/README delete mode 100755 topfails/topfails/templates/viewer/changeset.html delete mode 100755 topfails/topfails/templates/viewer/changesets.html delete mode 100644 topfails/topfails/templates/viewer/failswindow.html delete mode 100755 topfails/topfails/templates/viewer/index.html delete mode 100755 topfails/topfails/templates/viewer/latest.html delete mode 100755 topfails/topfails/templates/viewer/test.html delete mode 100755 topfails/topfails/templates/viewer/test.html.orig delete mode 100755 topfails/topfails/templates/viewer/tests.html delete mode 100755 topfails/topfails/templates/viewer/timeline.html delete mode 100755 topfails/topfails/templates/viewer/topfails.html delete mode 100755 topfails/topfails/templates/viewer/topfails.rar delete mode 100755 topfails/topfails/templates/viewer/tree.html delete mode 100755 topfails/topfails/templates/viewer/trees.html delete mode 100644 topfails/topfails/urls.py delete mode 100644 topfails/topfails/viewer/__init__.py delete mode 100644 topfails/topfails/viewer/models.py delete mode 100644 topfails/topfails/viewer/views.py delete mode 100755 topfails/unittest-log.py delete mode 100644 topfails/urls.py delete mode 100644 topfails/viewer/__init__.py delete mode 100644 topfails/viewer/models.py delete mode 100644 topfails/viewer/views.py delete mode 100755 unittest-log.py diff --git a/PREREQS b/PREREQS deleted file mode 100644 index 65358f3..0000000 --- a/PREREQS +++ /dev/null @@ -1,6 +0,0 @@ -At the minimum, you should set the following environment variables - -Assuming you are using BASH shell - -export dbuser= -export dbpasswd= diff --git a/README b/README deleted file mode 100644 index 5302e9b..0000000 --- a/README +++ /dev/null @@ -1,3 +0,0 @@ -This is the README for the topfails application. - -Please read the 'PREREQS' document which will explain about the environment variables to be set in order to run the django application. diff --git a/cleanup.sh b/cleanup.sh deleted file mode 100755 index fd9a17d..0000000 --- a/cleanup.sh +++ /dev/null @@ -1,2 +0,0 @@ -rm `find . -name \*.pyc` -rm `find . -name \*~` diff --git a/dbschema.py b/dbschema.py deleted file mode 100755 index 868ea13..0000000 --- a/dbschema.py +++ /dev/null @@ -1,121 +0,0 @@ -# ***** BEGIN LICENSE BLOCK ***** -# Version: MPL 1.1/GPL 2.0/LGPL 2.1 -# -# The contents of this file are subject to the Mozilla Public License Version -# 1.1 (the "License"); you may not use this file except in compliance with -# the License. You may obtain a copy of the License at -# http://www.mozilla.org/MPL/ -# -# Software distributed under the License is distributed on an "AS IS" basis, -# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License -# for the specific language governing rights and limitations under the -# License. -# -# The Original Code is TopFails site code. -# -# The Initial Developer of the Original Code is -# Mozilla foundation -# Portions created by the Initial Developer are Copyright (C) 2010 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Murali Nandigama -# -# Alternatively, the contents of this file may be used under the terms of -# either the GNU General Public License Version 2 or later (the "GPL"), or -# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), -# in which case the provisions of the GPL or the LGPL are applicable instead -# of those above. If you wish to allow use of your version of this file only -# under the terms of either the GPL or the LGPL, and not to allow others to -# use your version of this file under the terms of the MPL, indicate your -# decision by deleting the provisions above and replace them with the notice -# and other provisions required by the GPL or the LGPL. If you do not delete -# the provisions above, a recipient may use your version of this file under -# the terms of any one of the MPL, the GPL or the LGPL. -# -# ***** END LICENSE BLOCK ***** - -# -# DB schema maintenance functions. -# - -import logging - -__all__ = \ - [ - "CreateDBSchema" - ] - -def CreateDBSchema(conn): - logging.info("Executing CreateDBSchema()") - - - conn.execute(""" - CREATE TABLE viewer_tree ( - id integer AUTO_INCREMENT NOT NULL PRIMARY KEY, - name varchar(45) NOT NULL - ) - """) - - conn.execute(""" - CREATE TABLE viewer_build ( - id integer AUTO_INCREMENT NOT NULL PRIMARY KEY, - os integer NOT NULL, - tree_id integer NOT NULL, - starttime integer, - status integer NOT NULL, - changeset varchar(80) NOT NULL, - logfile varchar(300) NOT NULL - ) - """) - - conn.execute(""" - ALTER TABLE viewer_build - ADD CONSTRAINT tree_id_refs_id_11e44bee - FOREIGN KEY (tree_id) - REFERENCES viewer_tree (id) - """) - - conn.execute(""" - CREATE TABLE viewer_test ( - id integer AUTO_INCREMENT NOT NULL PRIMARY KEY, - name varchar(300) NOT NULL - ) - """) - - conn.execute(""" - CREATE TABLE viewer_testfailure ( - id integer AUTO_INCREMENT NOT NULL PRIMARY KEY, - build_id integer NOT NULL, - test_id integer NOT NULL, - failtext varchar(400) NOT NULL - ) - """) - - conn.execute(""" - ALTER TABLE viewer_testfailure - ADD CONSTRAINT test_id_refs_id_1cc1b9e6 - FOREIGN KEY (test_id) - REFERENCES viewer_test (id) - """) - - conn.execute(""" - ALTER TABLE viewer_testfailure - ADD CONSTRAINT build_id_refs_id_112c09cb - FOREIGN KEY (build_id) - REFERENCES viewer_build (id) - """) - - conn.execute(""" - CREATE INDEX viewer_build_tree_id ON viewer_build (tree_id) - """) - - conn.execute(""" - CREATE INDEX viewer_testfailure_build_id ON viewer_testfailure (build_id) - """) - - conn.execute(""" - CREATE INDEX viewer_testfailure_test_id ON viewer_testfailure (test_id) - """) - - diff --git a/log_parser.py b/log_parser.py deleted file mode 100644 index d1e5f11..0000000 --- a/log_parser.py +++ /dev/null @@ -1,203 +0,0 @@ -# ***** BEGIN LICENSE BLOCK ***** -# Version: MPL 1.1/GPL 2.0/LGPL 2.1 -# -# The contents of this file are subject to the Mozilla Public License Version -# 1.1 (the "License"); you may not use this file except in compliance with -# the License. You may obtain a copy of the License at -# http://www.mozilla.org/MPL/ -# -# Software distributed under the License is distributed on an "AS IS" basis, -# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License -# for the specific language governing rights and limitations under the -# License. -# -# The Original Code is TopFails site code. -# -# The Initial Developer of the Original Code is -# Mozilla foundation -# Portions created by the Initial Developer are Copyright (C) 2010 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Jeff Hammel -# Murali Nandigama -# -# Alternatively, the contents of this file may be used under the terms of -# either the GNU General Public License Version 2 or later (the "GPL"), or -# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), -# in which case the provisions of the GPL or the LGPL are applicable instead -# of those above. If you wish to allow use of your version of this file only -# under the terms of either the GPL or the LGPL, and not to allow others to -# use your version of this file under the terms of the MPL, indicate your -# decision by deleting the provisions above and replace them with the notice -# and other provisions required by the GPL or the LGPL. If you do not delete -# the provisions above, a recipient may use your version of this file under -# the terms of any one of the MPL, the GPL or the LGPL. -# -# ***** END LICENSE BLOCK ***** - -# TODO: document what all of the cases are, e.g -# -# - harness completes and automation.py hangs: -# "'62521 INFO TEST-PASS | /tests/content/xbl/test/test_bug542406.xhtml | Field three readonly?\n', -# '62523 INFO Passed: 60569\n', -# '62524 INFO Failed: 44\n', -# '62525 INFO Todo: 770\n', -# '62526 INFO SimpleTest FINISHED\n', -# 'TEST-UNEXPECTED-FAIL | automation.py | application timed out after 330 seconds with no output\n', -# "Can't trigger Breakpad, just killing process\n", -# 'INFO | automation.py | Application ran for: 0:24:44.270038\n', -# 'INFO | automation.py | Reading PID log: /var/folders/H5/H5TD8hgwEqKq9hgKlayjWU+++TM/-Tmp-/tmpEjNEf2pidlog\n', -# "WARNING | automationutils.processLeakLog() | refcount logging is off, so leaks can't be detected!\n", -# '\n', -# 'INFO | runtests.py | Running tests: end.\n', -# 'program finished with exit code 247\n', -# 'elapsedTime=1496.639870\n'," -# -# - leak at harness closure: see sample-logs/leaks-log.txt - -import re - -class LogParser(object): - """abstract base class for parsing unittest logs""" - - # 'TestFailed' expected log format is "result | test | optional text". - testfailedRe = re.compile(r"(TEST-UNEXPECTED-.*|PROCESS-CRASH) \| (.*) \|(.*)") - - def get_potentialTestName(self, line): - """return potential test name [None by default]""" - return None - - def processTestName(self, test, reason, potentialTestName, lines, idx): - """substitute the potential name for the test (if applicable)""" - - # for process crash, take the test-runner (automation) as the test failure - # (as already reported in test) and reset the potentialTestName to None - if 'PROCESS-CRASH' in reason: - return test, idx - - # an automation.py failure will ALWAYS be followed by a - # automationutils.processLeakLog line; so send a None here - # which will cause the parsing to continue and don't record this failure - if 'automation.py' in test: - return None, idx - - if 'automationutils.processLeakLog' and (potentialTestName is not None): - len_lines = len(lines) - while (idx+1) < len_lines and ('automationutils.processLeakLog' in lines[idx+1]): - idx += 1 - return potentialTestName, idx - - # if these conditions are not met, return - # the test name and potentialTestName untouched - return test, idx # no name substitution - - def parse(self, fp): - """ - parse the file, returning the test failures: - {'test': test, 'text': text, 'reason': mgroup(1)} ] - -fp: file-like object - """ - # Look for test failures. - failures = [] - lines = fp.readlines() - potentialTestName = None - - idx = 0 - while idx < len(lines): - line = lines[idx] - - # get the potential real name for reporting - # a test for an automation.py or automationutils.processLeakLog failure - potentialTestName = self.get_potentialTestName(line) or potentialTestName - - # test to see if the line is a failure - m = self.testfailedRe.match(line) - if not m: - idx += 1 - continue - - # reason for failure [TEST-UNEXPECTED-.* or PROCESS-CRASH] - reason = m.group(1).rstrip() - - # name of the test - test = m.group(2).strip() or "[unittest-log.py: no logged test]" - - # fail log text - text = m.group(3).strip() or "[unittest-log.py: no logged text]" - - # test to see if the harness hangs after a run completion - if lines[idx-1].strip().endswith('FINISHED'): - text = 'harness hangs after end of test run (or something)' - else: - # substitute potentialTestName for the test name if - # test is automation.py or automationutils.processLeakLog - test, idx = self.processTestName(test, reason, potentialTestName, lines, idx) - - if test is None: # don't add this test (and don't reset potentialTestName) - idx += 1 - continue - - # reset potentialTestName - potentialTestName = None - - # Code bits below try to change back slash to forward slash - # and get rid of varibale prepends to the /test/../.. names - if test.find('\\') != -1: - test = test.replace('\\','/') - if test.find('/') != -1: - tup=test.partition('build/') - if len(tup[2]) > 2: - test=tup[2] - else : - test=tup[0] - - # append interesting data to failures return value - failures.append({'test': test, 'text': text, 'reason': reason}) - - # increment the line counter - idx += 1 - - return failures - -class ReftestParser(LogParser): - """ - applies to - - Reftest - - Crashtest - - JSReftest - """ - - def get_potentialTestName(self, line): - """ - If it is jsreftest,crashtest we see 'INFO | Loading' in line - as the potential real test name - """ - if "INFO | Loading" in line: - return line.split('INFO | Loading ', 1)[-1] - - -class MochitestParser(LogParser): - """ - applies to - - Mochitest-plain - - Mochitest-chrome - - Mochitest-browserchrome - - Mochitest-a11y - """ - - def get_potentialTestName(self, line): - """Check all lines if they have INFO Running""" - if "INFO Running" in line: - return line.split('INFO Running ', 1)[-1].rstrip('.') # strip trailing ellipsis - - -class XPCshellParser(LogParser): - """ - parser XPCShell results - """ - -class CheckParser(LogParser): - """ - parses results from `make check` (C compiled code tests) - """ diff --git a/mappings.py b/mappings.py deleted file mode 100755 index f243633..0000000 --- a/mappings.py +++ /dev/null @@ -1,95 +0,0 @@ -#!/usr/bin/env python -""" -Build name: - [type of build] - -Examples: - -The builder: build (e.g. 'Linux mozilla-central build') --- in this case [type of build] is the string 'build' - -A debug test: debug test --- in this case [type of build] is the string 'debug test ' - -An opt test: opt test - -A leak test: leak test - -Talos: - talos (e.g. 'Rev3 Fedora 12x64 mozilla-central talos') --or- - talos (e.g. 'Rev3 Fedora 12x64 mozilla-central talos cold') - -Currently, the mappings are coded here (in python); this has the restriction -that the mappings cannot be (intelligently) programmatically updated. -If it is desired that the mappings may be undated programmatically -(e.g. from the command line), then a [presumedly text-ish] storage method -should be used for these mappings, e.g. an .ini file - -So.... - -All of this data lives in the buildbot-configs. -See http://hg.mozilla.org/build/buildbot-configs/file/tip/mozilla2/config.py -The mappings are duplicated here for expediency. - - - what really should happen is that this config file should be imported and - used here. In order for this to happen: - - the config.py file should be refactored so that it is consumable (and probably the entire buildbot-configs as well) - - buildbot-configs (or whatever this piece is refactored into) should - become a real python package or otherwise installable/depended upon -""" - -import re - -# OS mappings -OSes = [ 'Linux', - 'Linux x86-64', - 'OS X 10.5.2', - 'OS X 10.6.2', - 'Rev3 Fedora 12', - 'Rev3 Fedora 12x64', - 'Rev3 MacOSX Leopard 10.5.8', - 'Rev3 MacOSX Snow Leopard 10.6.2', - 'Rev3 WINNT 5.1', - 'Rev3 WINNT 6.1', - 'WINNT 5.2' ] -OS_to_index = dict([(OS, index) for index, OS in enumerate(OSes)]) -index_to_OS = dict([(index, OS) for index, OS in enumerate(OSes)]) -OSdata = { 'Linux': {'name': 'Linux', 'bits': 32 }, - 'Rev3 Fedora 12': { 'name': 'Fedora', 'bits': 32}, - 'Rev3 Fedora 12x64': { 'name': 'Fedora', 'bits': 64}, - 'Linux x86-64': { 'name': 'Linux', 'bits': 64}, - 'OS X 10.5.2': { 'name': 'MAC OSX', 'bits': 32}, - 'OS X 10.6.2': { 'name': 'MAC OSX', 'bits': 64}, - 'Rev3 MacOSX Leopard 10.5.8': { 'name': 'MAC OSX', 'bits': 32}, - 'Rev3 MacOSX Snow Leopard 10.6.2': { 'name': 'MAC OSX', 'bits': 64}, - 'Rev3 WINNT 5.1': { 'name': 'Windows', 'bits': 32}, - 'Rev3 WINNT 6.1': { 'name': 'Windows', 'bits': 64}, - 'WINNT 5.2': { 'name': 'Windows', 'bits': 32}, - } - -# branch objects -# branches = [ 'mozilla-central', -# 'mozilla-1.9.2', -# 'comm-central', -# 'comm-central-trunk' -# ] -trees = { 'Firefox': 'mozilla-central', - 'Firefox3.6': 'mozilla-1.9.2', - 'Thunderbird': 'comm-central', - 'SeaMonkey': 'comm-central-trunk', - } - -build_name_regex = r'(?P%s) (?P%s) (?P.*)' % ('|'.join(OSes), '|'.join(trees.values())) -build_name_regex = re.compile(build_name_regex) -def parse_build_name(name): - match = re.match(build_name_regex, name) - if match is None: - return None - return match.groupdict() - -if __name__ == '__main__': - import sys - for arg in sys.argv[1:]: - print parse_build_name(arg) - diff --git a/sample-logs/leaks-log.txt b/sample-logs/leaks-log.txt deleted file mode 100644 index 28f03f1..0000000 --- a/sample-logs/leaks-log.txt +++ /dev/null @@ -1,268 +0,0 @@ -Build Error Summary - -s: talos-r3-leopard-007 -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 725395 bytes during test execution -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 2 instances of AsyncStatement with size 48 bytes each (96 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 213 instances of AtomImpl with size 20 bytes each (4260 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of BackstagePass with size 24 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of CSSImportRuleImpl with size 48 bytes each (144 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 53 instances of CSSImportantRule with size 16 bytes each (848 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 27 instances of CSSNameSpaceRuleImpl with size 44 bytes each (1188 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 547 instances of CSSStyleRuleImpl with size 48 bytes each (26256 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of Connection with size 100 bytes each (300 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of DR_State with size 40 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of History with size 44 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of HoldJSObjects with size 4 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of ImageObserver with size 8 bytes each (24 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of LiteralImpl with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 15 instances of Loader with size 192 bytes each (2880 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of MatchAutoCompleteFunction with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of NameSpaceManagerImpl with size 48 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of PrincipalHolder with size 16 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of RDFServiceImpl with size 276 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 13 instances of RuleHash with size 172 bytes each (2236 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of Service with size 36 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 69 instances of Statement with size 60 bytes each (4140 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of StatementParams with size 24 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 2 instances of StringAdopt with size 1 bytes each (2 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 4 instances of URIAndPrincipalHashKey with size 12 bytes each (48 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of UploadLastDir with size 56 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of XPCContext with size 40 bytes each (560 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 55 instances of XPCNativeInterface with size 24 bytes each (1320 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 55 instances of XPCNativeMember with size 12 bytes each (660 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 50 instances of XPCNativeScriptableInfo with size 8 bytes each (400 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of XPCNativeScriptableShared with size 116 bytes each (696 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 22 instances of XPCNativeSet with size 8 bytes each (176 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 124 instances of XPCWrappedNative with size 56 bytes each (6944 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 52 instances of XPCWrappedNativeProto with size 32 bytes each (1664 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 46 instances of XPCWrappedNativeScope with size 64 bytes each (2944 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 23 instances of gfxFont with size 72 bytes each (1656 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 10 instances of gfxFontEntry with size 44 bytes each (440 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 8 instances of gfxGlyphExtents with size 40 bytes each (320 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 57 instances of gfxTextRun with size 96 bytes each (5472 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 11 instances of gfxTextRunFactory with size 12 bytes each (132 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of imgCacheEntry with size 32 bytes each (96 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of imgContainer with size 144 bytes each (432 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of imgLoader with size 44 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of imgRequest with size 152 bytes each (456 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of imgRequestProxy with size 44 bytes each (132 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of mozStorageFunctionGetUnreversedHost with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsAnnotationService with size 80 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 197 instances of nsAtomList with size 8 bytes each (1576 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 356 instances of nsAttrSelector with size 32 bytes each (11392 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsBaseURLParser with size 12 bytes each (36 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsBasicDecoderSupport with size 20 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsBidiKeyboard with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsBinaryOutputStream with size 20 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 15 instances of nsBindingManager with size 256 bytes each (3840 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 2 instances of nsBoxLayout with size 12 bytes each (24 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsBufferedOutputStream with size 60 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsBufferedStream with size 44 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSAural with size 136 bytes each (816 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSBreaks with size 32 bytes each (192 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSColor with size 52 bytes each (312 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSColumn with size 48 bytes each (288 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSContent with size 24 bytes each (144 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 12 instances of nsCSSCornerSizes with size 64 bytes each (768 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 547 instances of nsCSSDeclaration with size 32 bytes each (17504 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSDisplay with size 188 bytes each (1128 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSFont with size 88 bytes each (528 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSList with size 56 bytes each (336 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSMargin with size 596 bytes each (3576 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 4 instances of nsCSSMediaRule with size 40 bytes each (160 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSPage with size 24 bytes each (144 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSPosition with size 96 bytes each (576 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 61 instances of nsCSSRect with size 32 bytes each (1952 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 581 instances of nsCSSRule with size 20 bytes each (11620 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 12 instances of nsCSSRuleProcessor with size 28 bytes each (336 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSSVG with size 252 bytes each (1512 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsCSSScanner with size 1008 bytes each (3024 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1636 instances of nsCSSSelector with size 40 bytes each (65440 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1166 instances of nsCSSSelectorList with size 12 bytes each (13992 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 22 instances of nsCSSStyleSheet with size 72 bytes each (1584 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 21 instances of nsCSSStyleSheetInner with size 80 bytes each (1680 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSTable with size 64 bytes each (384 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSText with size 100 bytes each (600 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSUserInterface with size 60 bytes each (360 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSValue::Array with size 12 bytes each (72 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsCSSValue::Image with size 36 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 152 instances of nsCSSValue::URL with size 24 bytes each (3648 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 275 instances of nsCSSValueList with size 12 bytes each (3300 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSValueListRect with size 16 bytes each (96 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 93 instances of nsCSSValuePair with size 16 bytes each (1488 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 12 instances of nsCSSValuePairList with size 20 bytes each (240 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsCSSXUL with size 56 bytes each (336 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 886 instances of nsCStringKey with size 20 bytes each (17720 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 5 instances of nsCategoryObserver with size 60 bytes each (300 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsCharsetAlias2 with size 28 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsCharsetConverterManager with size 20 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 8 instances of nsChildContentList with size 20 bytes each (160 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsCollationMacUC with size 36 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 18 instances of nsCommentNode with size 56 bytes each (1008 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsConsoleMessage with size 24 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsConsoleService with size 80 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsContentPolicy with size 36 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsDNSService with size 48 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsDOMClassInfo with size 20 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsDOMDocumentType with size 104 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsDOMEventGroup with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsDOMStorageManager with size 52 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsDOMThreadService with size 152 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsDateTimeFormatMac with size 40 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsDeque with size 52 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsDocShell::InterfaceRequestorProxy with size 16 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsDocument with size 668 bytes each (9352 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsDownloadManager with size 64 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsEntropyCollector with size 1048 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsErrorService with size 132 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsEventListenerManager with size 96 bytes each (576 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsEventListenerThisTranslator with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsExceptionManager with size 24 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsExtensibleStringBundle with size 20 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsExternalHelperAppService with size 48 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 2 instances of nsFastLoadFileWriter with size 232 bytes each (464 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsFastLoadService with size 80 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsFileOutputStream with size 28 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsFileStream with size 24 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsFocusManager with size 52 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsFrameList with size 8 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 19 instances of nsGenericDOMDataNode with size 52 bytes each (988 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 285 instances of nsGenericElement with size 48 bytes each (13680 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsGenericFactory with size 20 bytes each (60 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 2 instances of nsGlobalChromeWindow with size 476 bytes each (952 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 2 instances of nsGlobalWindow with size 468 bytes each (936 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsGlobalWindowObserver with size 16 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsHTMLCSSStyleSheet with size 24 bytes each (336 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsHTMLDNSPrefetch::nsDeferrals with size 4136 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsHTMLDNSPrefetch::nsListener with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsHTMLInputElement with size 136 bytes each (408 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsHTMLSpanElement with size 52 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsHTMLStyleSheet with size 76 bytes each (1064 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsHTMLStyleSheet::GenericTableRule with size 12 bytes each (168 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsHTMLTextAreaElement with size 88 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1256 instances of nsHashKey with size 8 bytes each (10048 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 15 instances of nsHashPropertyBag with size 48 bytes each (720 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 250 instances of nsHashtable with size 44 bytes each (11000 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 581 instances of nsHtml5AttributeName with size 16 bytes each (9296 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 391 instances of nsHtml5ElementName with size 28 bytes each (10948 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsHtml5HtmlAttributes with size 24 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsIDNService with size 64 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsIOService with size 124 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsIdleServiceDaily with size 20 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsIdleServiceX with size 32 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsImageFrame::IconLoad with size 36 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsIsOfflineSQLFunction with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsJAR with size 1172 bytes each (3516 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsJARChannel with size 188 bytes each (2632 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsJARInputStream with size 120 bytes each (1680 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsJARInputThunk with size 56 bytes each (784 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsJARProtocolHandler with size 28 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsJARURI with size 44 bytes each (616 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsJISx4051LineBreaker with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 13 instances of nsJSContext with size 64 bytes each (832 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 2 instances of nsJSEventListener with size 32 bytes each (64 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 41 instances of nsJSID with size 36 bytes each (1476 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsLanguageAtomService with size 56 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsLayoutStatics with size 1 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsLayoutStylesheetCache with size 36 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsLoadGroup with size 8 bytes each (24 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 38 instances of nsLocalFile with size 1048 bytes each (39824 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 7 instances of nsMediaList with size 24 bytes each (168 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsMetaCharsetObserver with size 40 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsNativeThemeCocoa with size 40 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsNavBookmarks with size 224 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsNavHistory with size 508 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsNetworkLinkService with size 28 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 187 instances of nsNodeInfo with size 32 bytes each (5984 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 16 instances of nsNodeInfoManager with size 40 bytes each (640 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 18 instances of nsNullPrincipal with size 36 bytes each (648 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 18 instances of nsNullPrincipalURI with size 36 bytes each (648 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsObserverEntry with size 468 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsObserverService with size 48 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsOnloadBlocker with size 12 bytes each (168 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsParserService with size 68 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 24 instances of nsPersistentProperties with size 80 bytes each (1920 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 5 instances of nsPrefBranch with size 52 bytes each (260 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3162 instances of nsPrefOldCallback with size 32 bytes each (101184 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsPrefService with size 36 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 122 instances of nsPrincipal with size 76 bytes each (9272 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsPrivateBrowsingObserver with size 24 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsProperties with size 8 bytes each (24 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 416 instances of nsPseudoClassList with size 16 bytes each (6656 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsRDFResource with size 28 bytes each (84 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsRadioVisitor with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsRangeUtils with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsRect with size 16 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsRepeatService with size 24 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsReverseStringSQLFunction with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsSameOriginChecker with size 16 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsSampleWordBreaker with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 87 instances of nsScriptError with size 72 bytes each (6264 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsScriptLoader with size 48 bytes each (672 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsScriptLoaderObserverProxy with size 16 bytes each (224 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsScriptNameSpaceManager with size 40 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsScriptSecurityManager with size 92 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 4 instances of nsSimpleURI with size 8 bytes each (32 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsSocketTransportService with size 1684 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 512 instances of nsStandardURL with size 184 bytes each (94208 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 4 instances of nsStaticCaseInsensitiveNameTable with size 48 bytes each (192 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6002 instances of nsStringBuffer with size 8 bytes each (48016 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 23 instances of nsStringBundle with size 40 bytes each (920 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsStringBundleService with size 112 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsSupportsArray with size 56 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsSupportsCStringImpl with size 24 bytes each (72 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsSystemPrincipal with size 36 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1462 instances of nsTArray_base with size 4 bytes each (5848 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 19 instances of nsTextFragment with size 8 bytes each (152 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsThread with size 72 bytes each (216 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 5 instances of nsTimerImpl with size 60 bytes each (300 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 112 instances of nsURIHashKey with size 8 bytes each (896 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsUnicodeNormalizer with size 12 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 9 instances of nsVariant with size 48 bytes each (432 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 265 instances of nsVoidArray with size 4 bytes each (1060 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 24 instances of nsWeakReference with size 16 bytes each (384 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 12 instances of nsXBLDocGlobalObject with size 28 bytes each (336 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsXBLDocumentInfo with size 44 bytes each (616 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 22 instances of nsXBLEventHandler with size 16 bytes each (352 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 31 instances of nsXBLInsertionPointEntry with size 20 bytes each (620 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 7 instances of nsXBLKeyEventHandler with size 24 bytes each (168 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsXBLParameter with size 8 bytes each (112 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 39 instances of nsXBLProtoImpl with size 32 bytes each (1248 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 31 instances of nsXBLProtoImplField with size 24 bytes each (744 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 90 instances of nsXBLProtoImplMethod with size 20 bytes each (1800 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 125 instances of nsXBLProtoImplProperty with size 28 bytes each (3500 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 74 instances of nsXBLPrototypeBinding with size 60 bytes each (4440 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsXBLPrototypeResources with size 12 bytes each (168 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 2 instances of nsXBLResource with size 20 bytes each (40 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsXBLResourceLoader with size 36 bytes each (504 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsXBLService with size 56 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 72 instances of nsXBLTextWithLineNumber with size 8 bytes each (576 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 24 instances of nsXBLUncompiledMethod with size 16 bytes each (384 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 14 instances of nsXMLDocument with size 672 bytes each (9408 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 133 instances of nsXMLElement with size 52 bytes each (6916 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 47 instances of nsXPCComponents with size 60 bytes each (2820 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 44 instances of nsXPCComponents_Classes with size 20 bytes each (880 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsXPCComponents_Constructor with size 20 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 42 instances of nsXPCComponents_ID with size 20 bytes each (840 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 44 instances of nsXPCComponents_Interfaces with size 28 bytes each (1232 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 29 instances of nsXPCComponents_Results with size 20 bytes each (580 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 37 instances of nsXPCComponents_Utils with size 24 bytes each (888 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 2 instances of nsXPCComponents_utils_Sandbox with size 16 bytes each (32 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsXPCWrappedJS with size 60 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsXPCWrappedJSClass with size 44 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsXPConnect with size 104 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsXTFService with size 44 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 147 instances of nsXULElement with size 60 bytes each (8820 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsXULFastLoadFileIO with size 28 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsXULPopupManager with size 68 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 391 instances of nsXULPrototypeAttribute with size 12 bytes each (4692 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsXULPrototypeCache with size 176 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 147 instances of nsXULPrototypeElement with size 32 bytes each (4704 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 3 instances of nsZipArchive with size 1060 bytes each (3180 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 6 instances of nsZipHandle with size 16 bytes each (96 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of nsZipReaderCache with size 76 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of xpcPerThreadData with size 48 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of xptiFile with size 32 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 57 instances of xptiInterfaceInfo with size 20 bytes each (1140 bytes total) -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of xptiInterfaceInfoManager with size 100 bytes -TEST-UNEXPECTED-FAIL | automationutils.processLeakLog() | leaked 1 instance of xptiWorkingSet with size 52 bytes diff --git a/topfails/PREREQS b/topfails/PREREQS deleted file mode 100644 index 65358f3..0000000 --- a/topfails/PREREQS +++ /dev/null @@ -1,6 +0,0 @@ -At the minimum, you should set the following environment variables - -Assuming you are using BASH shell - -export dbuser= -export dbpasswd= diff --git a/topfails/README b/topfails/README deleted file mode 100644 index 5302e9b..0000000 --- a/topfails/README +++ /dev/null @@ -1,3 +0,0 @@ -This is the README for the topfails application. - -Please read the 'PREREQS' document which will explain about the environment variables to be set in order to run the django application. diff --git a/topfails/__init__.py b/topfails/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/topfails/cleanup.sh b/topfails/cleanup.sh deleted file mode 100755 index fd9a17d..0000000 --- a/topfails/cleanup.sh +++ /dev/null @@ -1,2 +0,0 @@ -rm `find . -name \*.pyc` -rm `find . -name \*~` diff --git a/topfails/dbschema.py b/topfails/dbschema.py deleted file mode 100755 index 868ea13..0000000 --- a/topfails/dbschema.py +++ /dev/null @@ -1,121 +0,0 @@ -# ***** BEGIN LICENSE BLOCK ***** -# Version: MPL 1.1/GPL 2.0/LGPL 2.1 -# -# The contents of this file are subject to the Mozilla Public License Version -# 1.1 (the "License"); you may not use this file except in compliance with -# the License. You may obtain a copy of the License at -# http://www.mozilla.org/MPL/ -# -# Software distributed under the License is distributed on an "AS IS" basis, -# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License -# for the specific language governing rights and limitations under the -# License. -# -# The Original Code is TopFails site code. -# -# The Initial Developer of the Original Code is -# Mozilla foundation -# Portions created by the Initial Developer are Copyright (C) 2010 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Murali Nandigama -# -# Alternatively, the contents of this file may be used under the terms of -# either the GNU General Public License Version 2 or later (the "GPL"), or -# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), -# in which case the provisions of the GPL or the LGPL are applicable instead -# of those above. If you wish to allow use of your version of this file only -# under the terms of either the GPL or the LGPL, and not to allow others to -# use your version of this file under the terms of the MPL, indicate your -# decision by deleting the provisions above and replace them with the notice -# and other provisions required by the GPL or the LGPL. If you do not delete -# the provisions above, a recipient may use your version of this file under -# the terms of any one of the MPL, the GPL or the LGPL. -# -# ***** END LICENSE BLOCK ***** - -# -# DB schema maintenance functions. -# - -import logging - -__all__ = \ - [ - "CreateDBSchema" - ] - -def CreateDBSchema(conn): - logging.info("Executing CreateDBSchema()") - - - conn.execute(""" - CREATE TABLE viewer_tree ( - id integer AUTO_INCREMENT NOT NULL PRIMARY KEY, - name varchar(45) NOT NULL - ) - """) - - conn.execute(""" - CREATE TABLE viewer_build ( - id integer AUTO_INCREMENT NOT NULL PRIMARY KEY, - os integer NOT NULL, - tree_id integer NOT NULL, - starttime integer, - status integer NOT NULL, - changeset varchar(80) NOT NULL, - logfile varchar(300) NOT NULL - ) - """) - - conn.execute(""" - ALTER TABLE viewer_build - ADD CONSTRAINT tree_id_refs_id_11e44bee - FOREIGN KEY (tree_id) - REFERENCES viewer_tree (id) - """) - - conn.execute(""" - CREATE TABLE viewer_test ( - id integer AUTO_INCREMENT NOT NULL PRIMARY KEY, - name varchar(300) NOT NULL - ) - """) - - conn.execute(""" - CREATE TABLE viewer_testfailure ( - id integer AUTO_INCREMENT NOT NULL PRIMARY KEY, - build_id integer NOT NULL, - test_id integer NOT NULL, - failtext varchar(400) NOT NULL - ) - """) - - conn.execute(""" - ALTER TABLE viewer_testfailure - ADD CONSTRAINT test_id_refs_id_1cc1b9e6 - FOREIGN KEY (test_id) - REFERENCES viewer_test (id) - """) - - conn.execute(""" - ALTER TABLE viewer_testfailure - ADD CONSTRAINT build_id_refs_id_112c09cb - FOREIGN KEY (build_id) - REFERENCES viewer_build (id) - """) - - conn.execute(""" - CREATE INDEX viewer_build_tree_id ON viewer_build (tree_id) - """) - - conn.execute(""" - CREATE INDEX viewer_testfailure_build_id ON viewer_testfailure (build_id) - """) - - conn.execute(""" - CREATE INDEX viewer_testfailure_test_id ON viewer_testfailure (test_id) - """) - - diff --git a/topfails/images/img5846075.png b/topfails/images/img5846075.png deleted file mode 100755 index 46f50cc660f09d320519e54f57d510df4361806c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15027 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 JPDHLkV1gn#OzHpt diff --git a/topfails/images/nav12971480a.gif b/topfails/images/nav12971480a.gif deleted file mode 100755 index 1954c8a13f9a2afc79c0cccb296f1d42fb49d5e5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3265 zcmWkwXHb&~6MjQN0tum)NHa7G0tbo#1-S%4&{I?tMCByNC!<*4KoRAH5V{4y!pA9c z0Td$5SWfX2Nuvmdpdbf_CDIN_ebX!N$G0;(v$MNDo@bxknT^`MEjTFo8Q=`4004p@ z5CoT&mNXiTPN!3;R8T4)5C{wggI=#68yk~KrE0ZWXV9|QY`I)6lgU&njaV$!>$S_K zR4UcV<%C+J(~3kQ4u>O`%G64YL8n(KmTM}lUib0iN0~ydP$<+&om37Ag+hr$!WRmp zav79L7V-u9R6u9YLy$qR$k*vKO1VNP7D0w(PjYcJxOQF;xZ4U^gZd9`bTD1lQ+XNz^KtNY(HEOk134+jV zxH78o89PZaA>a$?LN-~>A@lj)#o)3Ut(yE25tpn>1*Fnp zP$t!KKn(?0f}rIYL8(XO^8f4H)zzg`%U-{J&Ec?^Y}SVlA3lzb84SzPY4rxRN~2V( zm0G20VPT=Mu@Rz_%D^^}Xh`;mAb+&6xVShfDvHPBX*eQ9^)i??1&1u3ERl#>^zFma zc7jAC69@+Mt#A1gMN-xg+47bMA41g+o0^&q9y}Nq7dJgUosf_q;3TQp0vVfJQc{wb zn5ge~CvD#dRkunz2-1#?8m?F*d8eWPV8=#*phd$L(rC03Cr*I>lxn#WP$HHuJNQm2 zX@e+ba;X#)i+q4(`~NKfCJ+$vIfKZckqRA8O=QsAl1W(eQ-RM|m?(GWVDD9#l*b;d z4M;oR=|2`cqN~uubkDLGGOODBq9XP`DUE|Aex`ohm;TMezneIv^}_;=?yir%>FqmU zHSd=cga9hh0F2U_@HqCt9mQh&qkSBs4AOXUd`sW}+R{Izx3=T(%j_XHoR2?B$KFU+sRF?9RkM_d@;!BwZo8}G;;D%4fO4c%j*lH8~$qj`qP^(o#4av++C6_xzmdLy))gPS3Jt&zhp!K zFkcE8Z{q7Y5pE=}>LVK&+aD(v`PKx~<(gTqaYH(1FSsG`XHD1?PirO_wWf)_6}6%| z+WpdT8hE5od|E{|f=@>?5t|kl8Vaz8wX=wb82oG%)^_`Bxlb5#YCrl&S@IP`&O))n z%GiYDYZf<-dsVN@jxM;es_A$tYIEiH2J>|-ok#Da^`2-b_gxHznPtr z9lhH&uzj9>+Z=M^HODANc2{yP~HYd!paVSguncUG9FT^`UzHr1z@{ z^wdL_$|DR8Gi0G*kjc)ZN!V6_0xsJ!Ya|1~8Q)XLSTUOcX9&ZmPCaq`HJQ}^?~W;i ziHYTi5cMv#Rrvf%w$GW)xjTm`&5JFA>Biz4PKCCzhPzqK?09C@aDb!mD@x@{?xz%AK@z(h2 z`j#{Aqi$mUge7>o6b>K5;a|ZFIRFX0b}aU%srZ!kb7tvZD?&uI>%u}sXTD})-2ZaO zBbpOzU72#254lS*`a97e#~e>Gm=wVL*$Pa??j_Aa^P?rj)b8sq=ck%2FivgFRVCAx z2ZftvTT@8Jc2!sIxtZ?`6Fwj!;&`r#4l-aD3NsO&OtNbMiqMA`RI5*4oMy>|#zcJH z-#VTW&jgJ8c`&b?0KDnRmDHR_z>Zm`8IR&P4rJttHy9~yNiI(wBw1j}J_{gcI>Pm@ zm{J&-Ct%MxhZv3={1!AS%U>Y3L`Rt=`&XTMdJ-fwjG!WVAaEUl`%#d80i zL$&$jk)>V;_d59g@~;S%9d@iQOiAknBr|sAw-AP_OlF?iqb#9jCBMVrO2U17cH|z8 zlWyd4z7OnH0Yb_KT*h`vXL8{s5XjB=UeW!OTsgFCl84_UZ3)W^^KI#|YJx zX!hGyDseA!WS^X8(nR6l&1mMPwPY70Im&A)8Q9UeHCt>#js9k30pICv(rUSO$6Qsf zkI7kA3m3Te)$+e$aTK#($l(@d6vRD8JSN+g3Zw0bsShX7ku=mM<3lFl6HM$X9yLr= z9^;pA8)H#}4rW`G`{sOXoyIfcdP(NH6CVIGg4LV<{&PIvQQn@h<#_nu+mX!sRt*`J zJ-Y`dO9BVZ*qZNZ+~k=C#QMt_YZ5rSW-RxRKE*W!#<4cp^GEAMwx-#F)}(sg=;YdG zwY$1Vo5Y<(1%BV2tp+MqKbMrZe#)wS;Id}xOxm6hsMoGO6ieSjvO?c;O*WexX(e3V zJXY+Q?ev?IaWXdd9}e2CnLF2>-p5N=pV8RVFDMDBJ~8>pl}ShT2!ljwWcVkb;^zGn zMj}I<+rG>ryj;xQ}hdH!x&)$z^w2tgT`#dlrS-$?EWy_H}A13cD$Bo75jNzmh`vQ*@)wXYKM_B}SQt-CX%-|CwQnhsXp z`;Buv!V^ineS&MW;X|;gKPCC%@GIC&Qt%c(6b-$b>9C_ zfDbYPtQ@)e`&lar&1LKy7={t$h`p}u#K&$3rwzj78|G#4F1<(H== zyssm?l5H!h$bEf!Wxk{7wixM+yS0d92s1Tdn=P$s{*-LBX3FD?Bp~@*>%oAWoH6?^ zkE@eglP3PWV0^<~UbOY~&o<{f*$y#}jK*lwL9f(3_`F}5|EA!Ue-o~6@3{^Pe~xVN zYNF4Nz$iXF|Eyu`K8~i``k5bF7k>L;u(2w_3LAU6JFY$T*h9BO%=g3TMIO#>EonkB z4zac7i^H&b*NLk;Q$8HHenw7%7tlyxbc<;)S4?7tC z-6hsf+YlB0dp^weAuc+zDCQ4;ux_gB57d43FvY!CeM560|Nhi`SVnlJ?s3GK*hB^_7Br0^K<5D3#E^jFJF`+0@V+tMj z>!=~cV>F{fZi7rsWlc|V#uLSKyn6qG_xJa^_F8-Yu)k~V?`N%jz}?l(_GB}#6<7fP z=|58GsuWp95D5Y=z#s_r_4Y|u5m*c(%TnpGbaZSKk-)G7K~@pz#@ecM^siB50f8lO z--|wY0YQGcn9L0)$YMWX(>L1BnJ(y{!(xcZg~4hlC?JRdg6-3Adl5+Q5U`6tXaR;7 z1n>fcNQCfoJ5&ua2Vh2*5Cj=49wK@xg1Jn3o8ZXNBccx?L;?vr7(;_Y@MOE7jSh2J zdqS37We=HtN9R@CFo$l15Aj^6f7W+1Yviw@87!*7SY+$ zFrUlhZzNjavv@GQOTg$7q+d&KpM;TVHj|4mI)wBNVQhSCI~|0?FpG;Yi`tO|zOajq z@K}5n$mkY=5BdBJ6w~d31-_t*0TwZwU7eu?gkQap5ka_2XnMl}v8NG%7zXJZYcMpx zywAMP=dz#&AS@O{or{7cLa>M}lpu^EI<&y&{{$jTN=}03+L=6^ zNnj>#gE=3WV}ywOb+K3O&F%)0rIKA zGWRCt%iDG_;%TU=Jsapg)+iNwuzs!$Zz;T1Pt&*wX#~8xnB(Np=d0WglPp9f1;UbW^GV_sgMVVF1$y(0ZM#>^&mjqvzsVI4aAhDF#4`&4D>F-^92B7EW!?LN5fBOaOcwPbmt8p0*qEzgL9{@6Tfa66Y;|dOD_VvoC ze7Vf|)AU~gC@FZC)-TSBXSLr{X;WNwA@+1ujqvLD!h4oHXmJh=N znxbT*_w)ct6^RWTtXCi%jX9HTg+W_W9S1N$wL1q5PuVweEc(kXG-{7;l|Wbu>Aa$5 zN!iXpv~7h&*ZTlLbmy|ir~Rl+TLsWw8x;D5XrzCik+wb)B6kI;KQRN<%FNX%VQNF!m0Wj&;poxYI<`|Wg}y~o-4 zy5gPe3lmUQ>0ZtsS56GIq8wBx90_+{1zr8h1c5G5(&N~pvN~jTLI< z;#G$w%`;DvRz+=ZegJA=`WD1cb+R+j(~FE5aroxrggQDfpZSF&uhMNZ_vyErPzs7-rr`}RJd5dcMf;_4nN;(tylH?B~P^| zs*2aA5Irjyv}0<><-|oJQW|9G7H|lUE`2M(bLbYMluUqnM=MX;WVnRP0-jeV?@CpWjXpHC_`3&XP=Ise7g!^9<+S;iM%fd&9%&d3`Kf zl~T83S~fRgI`80&hhK2#MDo!T6MzUhd_GozR;N|11WdhHo*Yf$ngx587CS6Qe<{Hp zH&{y0MxzO%H?Z@kRbww5F`uX5Z5BBes>7c4YMP7;Hn^p8<=Rd)J%ueGYU^97+1bI9 z7#+}w>PXH|EzH9i%mX?DwrM-`QWP}vDV7}}d$Du0Fk<4Hhwat?t^^Nw6H>f}$689` z4qmqPJoaO*Z5Oopd{U9-7Ra!o^;YGlu(Jfer>Pa!MjcLK$$CA&=KeqBJ~Rd!(+r;y zuKO_8eQ1|6MCH)A{y$C9HRYdmab#TD@W~A)BQWNGW^Zfi`qvuybE0C+=4%$G&Vu3d zgZ_No+l{#eO{V$X6Y<@x4c!GWdtab-*wve}%Z+|f0g+!WJDAnye6MY|T^H4Fcbko0 zEJo28a8jgeNa3Vc$l;~U5#M(Q=e#cNL4IiSrd)SKGdzzent8r@;!^kIIPuwsP_1V~ ze5gY3V4&`uqb;|L>>7UC(fiM74%Rt-^01s@pdIgKZcO&ONMT)og5Yl~EnBE6nDcjA zr6w!xGSc17bniwNT+yZ7B|Uco?sxJF8$<>=uT1uZ;0rQ3M|AXe%@0|c7G4=sJRRm9 zx!$LFzN96|CBk~LgBLqnP--8>H2t!TAO6VtR#3Cfu9uK^iIYtp*~l`ed*0WCgw%Lv zKhXH@?^*nao@blG@;)W@*zWO)k#0j$?O|FjNeT<)(rPyQeD}7v{`E@O3^VBS;8^RE zxVnokYY3kcyzyd{^bhZJ#xxS`zcu9CS_=)I*&5;Di*9Pb&|tx(ekUOm|3_~Opnu`J z;D+*%%K9P$zw&J^LOG?T@w)SIk!v$8St}PiUw%#)S)1Me3XE2yZy6yU*j0|oj#L~e z=`eELS*5LT9!VvpMFx_kD3$cSkzc-%*G9#cy?bqw%U*@KzLVYe?I@v0iqgE7tWbaa0Y`Cd%@%OI4+}o8a zhJaQU2hH3Y_b_lqtib6UYvO&ai*!Kyeo1)Ul^gdc@i-hIvo_X$BEG3==JVOBYg1g^ S_zuAjI4EKbtwdF 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 diff --git a/topfails/images/nav12971481i.gif b/topfails/images/nav12971481i.gif deleted file mode 100755 index a405a2fc2cad0ccd99adbd60fb1de1f84b5a2e30..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2970 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 diff --git a/topfails/images/nav12971482a.gif b/topfails/images/nav12971482a.gif deleted file mode 100755 index 4b4fb9ab2b71c11cc009791136612331303dcba6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3278 zcmWlYi9gf{1IB+dh8edcSIE(dk|gA68&as2)MDDipk|5CMG=N^Oj65Mv{XANB%@Kb zRMcE@Y^0J@XdGK(?)x6U*Zced&+~k~&*uq`+~dDJxd*TV#yFGMQYdP^wil z8jZ)}DP&5mS|bsOWePc$%T;OAA3uJSN~L0{L?Kg)Btp4V#$|Iv60usV0YR-?E)@s_ z92Q$9k#hMwwOR>kSL$eF3Mqv`0WpanCi&&dmmmfWVtfTWA(cv|)9D(OT7v=DT#go8 z{_x?0QYlwRq>`0Xp-8~v^E-W23Z+oU7YfB3N+O5Hm5L<_g-V41#1H*IOcIFklTC6I z7(mDu2nW!bhi~P@KwMlLhttmCu;gmhil0EV;##7U~w6X#nN<+aJhU1g(G{NEE9HmW@}U%oM5dIkEU)PA@0TgWeSLj28ih=yynp}xS?rd(m zlFF^9s7Odi;1PZ0U-*1FTHfUg)<2Nc141reNc1BR2xw|!U@UDH(#;DWSZWoG=o_nlq+>%Q~ zt-*)(^}P#dN}UOQRZCcE%fA(#`kwS>UTtsxMy$m!AX`(Sna-zvJIEG)w69`!n_r{#5R+7q zsx!G(<;@)EwK5%Y7O}~scqGIfi*`h~ufG`z zmDCQRp}Ll7=rVW0);k48=59`UcDYO^J;$>MDt5gk*%9v6I;8`*sf%zfJkc&p#PLtc z(NLXv6d4x4Vm6l;!`v5PVNs5YwZ;~aihF3B7u-rv2{KxD!kFbkNu(!0_yIq*c^;gQdF`*MDOHsU7%~#?Fz*@9j4X zKqq!B>)Du)p&xq-^biP(aUy&S^MLzg zHrFGo_rHb=Y#XcN1+WEnlk(W+WeuBZCT?y#(?(^5l0A2-=cylDd&k2joTsZVn;s-l zc+mRu&!H5{r|N&V7)2X}(2obr(djhIbS1($*ik-hS}j1rOwS6CtL=Tjcd*%<1>;ap z6eO9V;~YltpE>sjqj%xVrmpkw>+xC2|Li@Yp1$9=D+>3@zws@UyaYpdlWkb8 z{gSuB5yNv62a|4}n|DK%sCX~DJo8{~uyq>5JEKtY8W+Sm&2+!Sd01Svj;v!`1xFVG zM#ui{mwF^*@6ee^-4coh@Pr*Y-~N8Mtl~U<*e^#1pUR({WIF^h^U|`P+iXe`DHigs zCBVb1Dx9syvGs<4r(^9uye2d(2?1Cf{G`X%Me1AjpnXU=!9SfB;A|v!>;y<1y)bgY zkDw;GGYJdzU_dtSCqrAEt52NY4OmVks-_2N4y^I~)fQz!uIEzx`7_~Qrp+?RWW(xhdCzjvl za>h+96{*)AO)c)67U09pQm*aSK&?$;LS~w_RuPUcm{sA}!Wt^vk5s;4xkd*`7wYcE zhpmrNR;-V3v@9lAjJ+rO=C9`63f;KMAL(RL1CE`$!}uG}{s@5Y9WS-*A?$NR8q*27 z8_ftN@Q5^H>!t(o8b-5V%HGC&7-~tM*AKu~1|y#hUogWu{E>sRNslpwj?V+eqZA9o zZLU1y>oEjLqE&CGOhHM8bnDCsth{ggE_7(k+r5x_xAb zW$ECx=2SIq^xog&bDl!+v*0_)VW~d=2#D5`)CHHuwjs4QV*oIXQUhE&u;B~ z(sw$IZoG(!3_3x+npHzKa@WD0KrPso*OCj_jY;asJn|Kz4W*mzmyErHtUc9(@w;PF z9xeE2$_T!9#*|54&y8}82=cHsfnn@vB9p>k(yV2j2J@bDl5D13`H5Vsl~ zkgPxc|D>+gx<(o3`nCeSQ;?8k!%v?Z+6{N(qT$A! z-A=fpJr0|P{X@L{Vu~8Czvi`uTv?C$@_zE#tZ`R$s3caIpX3IW??*I}@Q%RTp~oHZ zqb&A?K-~STe{{FHv48s-ST>`^zP5;m^#^!DuhSZ*eNH_!u|6=Bx0amjLFygQemT90 z^p#&@zx`Vz@5^aiK?fM7Pc@TM6~{|Dv|nLi+d_KE{^1wqaS|dj;s>@A z| zS#ggONJ7lfTMMx5&)=12m9!lDZ@{zfY(9%M7&&&gy1~G1=oAqnSUqt-0s=5BAwQR${%#qGSKS{k{zb={1kk#1p=o_UX_4#-*x$ z@+#4fiOtX(akQrDMJq?L_og1Rz4kKyYzy2T0W&sOb<+Ur>`iPJZ(;SZvKN~@Z{S1n zN=rC$68zY7q@b?&x>>cPZ5AFGS;RWzeG%Ni5R)MnHUhdiJr@FrF9E&g7-%Tn>HVQg z;?BWkRt%_O2fYFwSC%~f(|>2{!~#MuzoxKO5av3&dR^oo@N?~KlEwv+1RJy>=Ph1X zEA9#3!RvNNOm;B}b;x{YiMWZ~`rh(_z><*c^6gWhe=~e(Ls1yD=#00kdd^;a*S5e( zXDz}WKth7C@BuTZ69I6uh8c{PhLB4=r%Jv3aXu*AHbv=1f1JBN?)7-7TQAPfy37ZU q^TwBYBXBzrWxi=;p;Kjns4^!r*nVbN6ryZTntmMt2sSeVg8m2AY2h3I diff --git a/topfails/images/nav12971482i.gif b/topfails/images/nav12971482i.gif deleted file mode 100755 index dfefd817c8d522450d5834246823827c98b62756..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2977 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 diff --git a/topfails/images/nav12971483i.gif b/topfails/images/nav12971483i.gif deleted file mode 100755 index 9d8e15f10e2334bd36f85b789960341b944ed73b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3043 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 diff --git a/topfails/images/nav12971484i.gif b/topfails/images/nav12971484i.gif deleted file mode 100755 index e95f4fc2ab52c2c7586765b7336321adeefa9cf5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2769 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 U-0GZ~klb+d7w#cbC;)KszXY9fMF0Q* diff --git a/topfails/log_parser.py b/topfails/log_parser.py deleted file mode 100644 index d1e5f11..0000000 --- a/topfails/log_parser.py +++ /dev/null @@ -1,203 +0,0 @@ -# ***** BEGIN LICENSE BLOCK ***** -# Version: MPL 1.1/GPL 2.0/LGPL 2.1 -# -# The contents of this file are subject to the Mozilla Public License Version -# 1.1 (the "License"); you may not use this file except in compliance with -# the License. You may obtain a copy of the License at -# http://www.mozilla.org/MPL/ -# -# Software distributed under the License is distributed on an "AS IS" basis, -# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License -# for the specific language governing rights and limitations under the -# License. -# -# The Original Code is TopFails site code. -# -# The Initial Developer of the Original Code is -# Mozilla foundation -# Portions created by the Initial Developer are Copyright (C) 2010 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Jeff Hammel -# Murali Nandigama -# -# Alternatively, the contents of this file may be used under the terms of -# either the GNU General Public License Version 2 or later (the "GPL"), or -# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), -# in which case the provisions of the GPL or the LGPL are applicable instead -# of those above. If you wish to allow use of your version of this file only -# under the terms of either the GPL or the LGPL, and not to allow others to -# use your version of this file under the terms of the MPL, indicate your -# decision by deleting the provisions above and replace them with the notice -# and other provisions required by the GPL or the LGPL. If you do not delete -# the provisions above, a recipient may use your version of this file under -# the terms of any one of the MPL, the GPL or the LGPL. -# -# ***** END LICENSE BLOCK ***** - -# TODO: document what all of the cases are, e.g -# -# - harness completes and automation.py hangs: -# "'62521 INFO TEST-PASS | /tests/content/xbl/test/test_bug542406.xhtml | Field three readonly?\n', -# '62523 INFO Passed: 60569\n', -# '62524 INFO Failed: 44\n', -# '62525 INFO Todo: 770\n', -# '62526 INFO SimpleTest FINISHED\n', -# 'TEST-UNEXPECTED-FAIL | automation.py | application timed out after 330 seconds with no output\n', -# "Can't trigger Breakpad, just killing process\n", -# 'INFO | automation.py | Application ran for: 0:24:44.270038\n', -# 'INFO | automation.py | Reading PID log: /var/folders/H5/H5TD8hgwEqKq9hgKlayjWU+++TM/-Tmp-/tmpEjNEf2pidlog\n', -# "WARNING | automationutils.processLeakLog() | refcount logging is off, so leaks can't be detected!\n", -# '\n', -# 'INFO | runtests.py | Running tests: end.\n', -# 'program finished with exit code 247\n', -# 'elapsedTime=1496.639870\n'," -# -# - leak at harness closure: see sample-logs/leaks-log.txt - -import re - -class LogParser(object): - """abstract base class for parsing unittest logs""" - - # 'TestFailed' expected log format is "result | test | optional text". - testfailedRe = re.compile(r"(TEST-UNEXPECTED-.*|PROCESS-CRASH) \| (.*) \|(.*)") - - def get_potentialTestName(self, line): - """return potential test name [None by default]""" - return None - - def processTestName(self, test, reason, potentialTestName, lines, idx): - """substitute the potential name for the test (if applicable)""" - - # for process crash, take the test-runner (automation) as the test failure - # (as already reported in test) and reset the potentialTestName to None - if 'PROCESS-CRASH' in reason: - return test, idx - - # an automation.py failure will ALWAYS be followed by a - # automationutils.processLeakLog line; so send a None here - # which will cause the parsing to continue and don't record this failure - if 'automation.py' in test: - return None, idx - - if 'automationutils.processLeakLog' and (potentialTestName is not None): - len_lines = len(lines) - while (idx+1) < len_lines and ('automationutils.processLeakLog' in lines[idx+1]): - idx += 1 - return potentialTestName, idx - - # if these conditions are not met, return - # the test name and potentialTestName untouched - return test, idx # no name substitution - - def parse(self, fp): - """ - parse the file, returning the test failures: - {'test': test, 'text': text, 'reason': mgroup(1)} ] - -fp: file-like object - """ - # Look for test failures. - failures = [] - lines = fp.readlines() - potentialTestName = None - - idx = 0 - while idx < len(lines): - line = lines[idx] - - # get the potential real name for reporting - # a test for an automation.py or automationutils.processLeakLog failure - potentialTestName = self.get_potentialTestName(line) or potentialTestName - - # test to see if the line is a failure - m = self.testfailedRe.match(line) - if not m: - idx += 1 - continue - - # reason for failure [TEST-UNEXPECTED-.* or PROCESS-CRASH] - reason = m.group(1).rstrip() - - # name of the test - test = m.group(2).strip() or "[unittest-log.py: no logged test]" - - # fail log text - text = m.group(3).strip() or "[unittest-log.py: no logged text]" - - # test to see if the harness hangs after a run completion - if lines[idx-1].strip().endswith('FINISHED'): - text = 'harness hangs after end of test run (or something)' - else: - # substitute potentialTestName for the test name if - # test is automation.py or automationutils.processLeakLog - test, idx = self.processTestName(test, reason, potentialTestName, lines, idx) - - if test is None: # don't add this test (and don't reset potentialTestName) - idx += 1 - continue - - # reset potentialTestName - potentialTestName = None - - # Code bits below try to change back slash to forward slash - # and get rid of varibale prepends to the /test/../.. names - if test.find('\\') != -1: - test = test.replace('\\','/') - if test.find('/') != -1: - tup=test.partition('build/') - if len(tup[2]) > 2: - test=tup[2] - else : - test=tup[0] - - # append interesting data to failures return value - failures.append({'test': test, 'text': text, 'reason': reason}) - - # increment the line counter - idx += 1 - - return failures - -class ReftestParser(LogParser): - """ - applies to - - Reftest - - Crashtest - - JSReftest - """ - - def get_potentialTestName(self, line): - """ - If it is jsreftest,crashtest we see 'INFO | Loading' in line - as the potential real test name - """ - if "INFO | Loading" in line: - return line.split('INFO | Loading ', 1)[-1] - - -class MochitestParser(LogParser): - """ - applies to - - Mochitest-plain - - Mochitest-chrome - - Mochitest-browserchrome - - Mochitest-a11y - """ - - def get_potentialTestName(self, line): - """Check all lines if they have INFO Running""" - if "INFO Running" in line: - return line.split('INFO Running ', 1)[-1].rstrip('.') # strip trailing ellipsis - - -class XPCshellParser(LogParser): - """ - parser XPCShell results - """ - -class CheckParser(LogParser): - """ - parses results from `make check` (C compiled code tests) - """ diff --git a/topfails/manage.py b/topfails/manage.py deleted file mode 100755 index bcdd55e..0000000 --- a/topfails/manage.py +++ /dev/null @@ -1,11 +0,0 @@ -#!/usr/bin/python -from django.core.management import execute_manager -try: - import settings # Assumed to be in the same directory. -except ImportError: - import sys - sys.stderr.write("Error: Can't find the file 'settings.py' in the directory containing %r. It appears you've customized things.\nYou'll have to run django-admin.py, passing it your settings module.\n(If the file settings.py does indeed exist, it's causing an ImportError somehow.)\n" % __file__) - sys.exit(1) - -if __name__ == "__main__": - execute_manager(settings) diff --git a/topfails/mappings.py b/topfails/mappings.py deleted file mode 100755 index f243633..0000000 --- a/topfails/mappings.py +++ /dev/null @@ -1,95 +0,0 @@ -#!/usr/bin/env python -""" -Build name: - [type of build] - -Examples: - -The builder: build (e.g. 'Linux mozilla-central build') --- in this case [type of build] is the string 'build' - -A debug test: debug test --- in this case [type of build] is the string 'debug test ' - -An opt test: opt test - -A leak test: leak test - -Talos: - talos (e.g. 'Rev3 Fedora 12x64 mozilla-central talos') --or- - talos (e.g. 'Rev3 Fedora 12x64 mozilla-central talos cold') - -Currently, the mappings are coded here (in python); this has the restriction -that the mappings cannot be (intelligently) programmatically updated. -If it is desired that the mappings may be undated programmatically -(e.g. from the command line), then a [presumedly text-ish] storage method -should be used for these mappings, e.g. an .ini file - -So.... - -All of this data lives in the buildbot-configs. -See http://hg.mozilla.org/build/buildbot-configs/file/tip/mozilla2/config.py -The mappings are duplicated here for expediency. - - - what really should happen is that this config file should be imported and - used here. In order for this to happen: - - the config.py file should be refactored so that it is consumable (and probably the entire buildbot-configs as well) - - buildbot-configs (or whatever this piece is refactored into) should - become a real python package or otherwise installable/depended upon -""" - -import re - -# OS mappings -OSes = [ 'Linux', - 'Linux x86-64', - 'OS X 10.5.2', - 'OS X 10.6.2', - 'Rev3 Fedora 12', - 'Rev3 Fedora 12x64', - 'Rev3 MacOSX Leopard 10.5.8', - 'Rev3 MacOSX Snow Leopard 10.6.2', - 'Rev3 WINNT 5.1', - 'Rev3 WINNT 6.1', - 'WINNT 5.2' ] -OS_to_index = dict([(OS, index) for index, OS in enumerate(OSes)]) -index_to_OS = dict([(index, OS) for index, OS in enumerate(OSes)]) -OSdata = { 'Linux': {'name': 'Linux', 'bits': 32 }, - 'Rev3 Fedora 12': { 'name': 'Fedora', 'bits': 32}, - 'Rev3 Fedora 12x64': { 'name': 'Fedora', 'bits': 64}, - 'Linux x86-64': { 'name': 'Linux', 'bits': 64}, - 'OS X 10.5.2': { 'name': 'MAC OSX', 'bits': 32}, - 'OS X 10.6.2': { 'name': 'MAC OSX', 'bits': 64}, - 'Rev3 MacOSX Leopard 10.5.8': { 'name': 'MAC OSX', 'bits': 32}, - 'Rev3 MacOSX Snow Leopard 10.6.2': { 'name': 'MAC OSX', 'bits': 64}, - 'Rev3 WINNT 5.1': { 'name': 'Windows', 'bits': 32}, - 'Rev3 WINNT 6.1': { 'name': 'Windows', 'bits': 64}, - 'WINNT 5.2': { 'name': 'Windows', 'bits': 32}, - } - -# branch objects -# branches = [ 'mozilla-central', -# 'mozilla-1.9.2', -# 'comm-central', -# 'comm-central-trunk' -# ] -trees = { 'Firefox': 'mozilla-central', - 'Firefox3.6': 'mozilla-1.9.2', - 'Thunderbird': 'comm-central', - 'SeaMonkey': 'comm-central-trunk', - } - -build_name_regex = r'(?P%s) (?P%s) (?P.*)' % ('|'.join(OSes), '|'.join(trees.values())) -build_name_regex = re.compile(build_name_regex) -def parse_build_name(name): - match = re.match(build_name_regex, name) - if match is None: - return None - return match.groupdict() - -if __name__ == '__main__': - import sys - for arg in sys.argv[1:]: - print parse_build_name(arg) - diff --git a/topfails/settings.py b/topfails/settings.py deleted file mode 100644 index 0e0f594..0000000 --- a/topfails/settings.py +++ /dev/null @@ -1,86 +0,0 @@ -# Django settings for topfails project. -import os - -DEBUG = True -TEMPLATE_DEBUG = DEBUG - -DBUSER = DBPASSWD = '' -if os.environ.has_key('dbuser'): - DBUSER=os.environ.get('dbuser') - #print DBUSER -if os.environ.has_key('dbpasswd'): - DBPASSWD=os.environ.get('dbpasswd') - #print DBPASSWD -ADMINS = ( - ('Murali Nandigama', 'murali.nandigama@gmail.com'), -) - -MANAGERS = ADMINS - -DATABASE_ENGINE = 'mysql' # 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'. -DATABASE_NAME = 'topfails' # Or path to database file if using sqlite3. -DATABASE_USER = DBUSER # Not used with sqlite3. -DATABASE_PASSWORD = DBPASSWD # Not used with sqlite3. -DATABASE_HOST = '' # Set to empty string for localhost. Not used with sqlite3. -DATABASE_PORT = '' # Set to empty string for default. Not used with sqlite3. - -# Local time zone for this installation. Choices can be found here: -# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name -# although not all choices may be available on all operating systems. -# If running in a Windows environment this must be set to the same as your -# system time zone. -TIME_ZONE = 'America/Chicago' - -# Language code for this installation. All choices can be found here: -# http://www.i18nguy.com/unicode/language-identifiers.html -LANGUAGE_CODE = 'en-us' - -SITE_ID = 1 - -# If you set this to False, Django will make some optimizations so as not -# to load the internationalization machinery. -USE_I18N = True - -# Absolute path to the directory that holds media. -# Example: "/home/media/media.lawrence.com/" -MEDIA_ROOT = '' - -# URL that handles the media served from MEDIA_ROOT. Make sure to use a -# trailing slash if there is a path component (optional in other cases). -# Examples: "http://media.lawrence.com", "http://example.com/media/" -MEDIA_URL = '' - -# URL prefix for admin media -- CSS, JavaScript and images. Make sure to use a -# trailing slash. -# Examples: "http://foo.com/media/", "/media/". -ADMIN_MEDIA_PREFIX = '/media/' - -# Make this unique, and don't share it with anybody. -SECRET_KEY = '^_5(02(8sng5+6+x=c$w+3(4xv+x^&b)2ty4y8m01(o7vz$o5_' - -# List of callables that know how to import templates from various sources. -TEMPLATE_LOADERS = ( - 'django.template.loaders.filesystem.load_template_source', - 'django.template.loaders.app_directories.load_template_source', -# 'django.template.loaders.eggs.load_template_source', -) - -MIDDLEWARE_CLASSES = ( - 'django.middleware.common.CommonMiddleware', - 'django.contrib.sessions.middleware.SessionMiddleware', - 'django.contrib.auth.middleware.AuthenticationMiddleware', -) - -ROOT_URLCONF = 'topfails.urls' - -TEMPLATE_DIRS = ( - './templates/' -) - -INSTALLED_APPS = ( - 'django.contrib.auth', - 'django.contrib.contenttypes', - 'django.contrib.sessions', - 'django.contrib.sites', - 'topfails.viewer' -) diff --git a/topfails/templates/base.html b/topfails/templates/base.html deleted file mode 100755 index 9494f49..0000000 --- a/topfails/templates/base.html +++ /dev/null @@ -1,121 +0,0 @@ - - - -Topfails - - - - - - - - -

- - - - - - - - - -
- Firefox Logo -
- -
-
-
Mozilla Tinderbox Topfails Dashboard
-
- - - - - - -
-{% block content %} -{% endblock %} -
- - diff --git a/topfails/templates/viewer/Help.html b/topfails/templates/viewer/Help.html deleted file mode 100755 index 75693b5..0000000 --- a/topfails/templates/viewer/Help.html +++ /dev/null @@ -1,21 +0,0 @@ -{% extends "base.html" %} -{% block content %} -
This web site provides the bird eye view of top failures and other details of Firefox unit tests  from the  Tinderbox daily runs.
-

-
Meaning of the Left navigation links
-
    -
  • Latest Failures : This link provides the list of latest failures from the Tinderbox.
  • -
  • Top 25 Failures : This link provides the list of top 25 failures from the entire history of the topfails database. Please note that this data is as complete as the first date we started collecting results. The data we have in the topfails database does not contain all the failures details from the Time ZERO of tinderbox runs.
  • -
  • All Failed Tests: This link displays all the known failures that are stored in the topfails DB.
  • -
  • Failures from X days: This is a link which allows you to query for failures from NOW till a specific period in the past.
  • -
-
      Example: 2d  =   2 days  in the past till  now
-
                          7h  =   7 hours in the past till now
-
                          5w =  5 weeks in the past till now
-
                          1m =  1 month in the past till now
-
                         10y =  10 years in the past till now
-
Example queries for advanced users 2 weeks 'Firefox' failures
-
Example queries for advanced users 2 days 'Firefox' failures
-
Example queries for advanced users 24 hours 'Firefox' failures
-
Example queries for advanced users 1 month 'Firefox' failures
-{% endblock %} diff --git a/topfails/templates/viewer/README b/topfails/templates/viewer/README deleted file mode 100644 index 1e69967..0000000 --- a/topfails/templates/viewer/README +++ /dev/null @@ -1,5 +0,0 @@ -I have done a very bad and crude hack to add a top level navigation page. Instead of storing images for top navigation page in the correct location , I am jammin gall the top site nav stuff in here. - -Should fix it when time permits. - - diff --git a/topfails/templates/viewer/changeset.html b/topfails/templates/viewer/changeset.html deleted file mode 100755 index ca8c307..0000000 --- a/topfails/templates/viewer/changeset.html +++ /dev/null @@ -1,9 +0,0 @@ -{% extends "base.html" %} -{% block content %} -

Changeset {{ changeset }}

-
    -{% for build in builds %} -
  • {{ build.tree }}: {{ build.get_os_display }}: {{ build.get_status_display }}
  • -{% endfor %} -
-{% endblock %} diff --git a/topfails/templates/viewer/changesets.html b/topfails/templates/viewer/changesets.html deleted file mode 100755 index f2208fa..0000000 --- a/topfails/templates/viewer/changesets.html +++ /dev/null @@ -1,9 +0,0 @@ -{% extends "base.html" %} -{% block content %} -

Changesets

-
    -{% for c in changesets %} -
  • {{ c }}
  • -{% endfor %} -
-{% endblock %} diff --git a/topfails/templates/viewer/failswindow.html b/topfails/templates/viewer/failswindow.html deleted file mode 100644 index cf534b5..0000000 --- a/topfails/templates/viewer/failswindow.html +++ /dev/null @@ -1,10 +0,0 @@ -{% extends "base.html" %} -{% block content %} -

Failed tests from last {{n}} {{d}} up to now

- - -{% for f in failures %} - -{% endfor %} -
CountTest name
{{ f.count }}{{ f.test__name }}
-{% endblock %} diff --git a/topfails/templates/viewer/index.html b/topfails/templates/viewer/index.html deleted file mode 100755 index ff2fdd9..0000000 --- a/topfails/templates/viewer/index.html +++ /dev/null @@ -1,15 +0,0 @@ -{% extends "base.html" %} -{% block content %} - -

Most recent test failures

-
    -{% for f in failures %} -
  • {{ f.build.startdate|date:"Y-m-d H:i" }} {{ f.build.tree.name }} {{ f.build.get_os_display }}: {{ f.name }}, - timeline - - {{ f.description }}
  • -{% endfor %} -
-{% endblock %} diff --git a/topfails/templates/viewer/latest.html b/topfails/templates/viewer/latest.html deleted file mode 100755 index 55fd43e..0000000 --- a/topfails/templates/viewer/latest.html +++ /dev/null @@ -1,15 +0,0 @@ -{% extends "base.html" %} -{% block content %} - -

Most recent test failures

-
    -{% for f in failures %} -
  • {{ f.build.startdate|date:"Y-m-d H:i" }} {{ f.build.tree.name }} {{ f.build.get_os_display }}: {{ f.test.name }} - - - {{ f.failtext }}
  • -{% endfor %} -
-{% endblock %} diff --git a/topfails/templates/viewer/test.html b/topfails/templates/viewer/test.html deleted file mode 100755 index 3c5b260..0000000 --- a/topfails/templates/viewer/test.html +++ /dev/null @@ -1,13 +0,0 @@ -{% extends "base.html" %} -{% block content %} -

Logfile links and Changeset links for {{ test }} failures

-[ Showing up to latest 10000 failures' related log links ]
-
-