[testrunner] delete ancient junit compatible format support
Testrunner has ancient support for JUnit compatible XML output. This CL removes this old feature. R=mstarzinger@chromium.org,jgruber@chromium.org,jkummerow@chromium.org CC=machenbach@chromium.org Bug: v8:8728 Change-Id: I7e1beb011dbaec3aa1a27398a5c52abdd778eaf0 Reviewed-on: https://chromium-review.googlesource.com/c/1430065 Reviewed-by: Jakob Gruber <jgruber@chromium.org> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org> Commit-Queue: Tamer Tas <tmrts@chromium.org> Cr-Commit-Position: refs/heads/master@{#59045}
This commit is contained in:
parent
cf88fe3207
commit
bd019bdb72
@ -318,9 +318,6 @@ class BaseTestRunner(object):
|
||||
"color, mono)")
|
||||
parser.add_option("--json-test-results",
|
||||
help="Path to a file for storing json results.")
|
||||
parser.add_option("--junitout", help="File name of the JUnit output")
|
||||
parser.add_option("--junittestsuite", default="v8tests",
|
||||
help="The testsuite name in the JUnit output file")
|
||||
parser.add_option("--exit-after-n-failures", type="int", default=100,
|
||||
help="Exit after the first N failures instead of "
|
||||
"running all tests. Pass 0 to disable this feature.")
|
||||
@ -759,9 +756,6 @@ class BaseTestRunner(object):
|
||||
|
||||
def _create_progress_indicators(self, options):
|
||||
procs = [PROGRESS_INDICATORS[options.progress]()]
|
||||
if options.junitout:
|
||||
procs.append(progress.JUnitTestProgressIndicator(options.junitout,
|
||||
options.junittestsuite))
|
||||
if options.json_test_results:
|
||||
procs.append(progress.JsonTestProgressIndicator(
|
||||
options.json_test_results,
|
||||
|
@ -1,49 +0,0 @@
|
||||
# Copyright 2013 the V8 project authors. All rights reserved.
|
||||
# Redistribution and use in source and binary forms, with or without
|
||||
# modification, are permitted provided that the following conditions are
|
||||
# met:
|
||||
#
|
||||
# * Redistributions of source code must retain the above copyright
|
||||
# notice, this list of conditions and the following disclaimer.
|
||||
# * Redistributions in binary form must reproduce the above
|
||||
# copyright notice, this list of conditions and the following
|
||||
# disclaimer in the documentation and/or other materials provided
|
||||
# with the distribution.
|
||||
# * Neither the name of Google Inc. nor the names of its
|
||||
# contributors may be used to endorse or promote products derived
|
||||
# from this software without specific prior written permission.
|
||||
#
|
||||
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
|
||||
import xml.etree.ElementTree as xml
|
||||
|
||||
|
||||
class JUnitTestOutput:
|
||||
def __init__(self, test_suite_name):
|
||||
self.root = xml.Element("testsuite")
|
||||
self.root.attrib["name"] = test_suite_name
|
||||
|
||||
def HasRunTest(self, test_name, test_cmd, test_duration, test_failure):
|
||||
testCaseElement = xml.Element("testcase")
|
||||
testCaseElement.attrib["name"] = test_name
|
||||
testCaseElement.attrib["cmd"] = test_cmd
|
||||
testCaseElement.attrib["time"] = str(round(test_duration, 3))
|
||||
if len(test_failure):
|
||||
failureElement = xml.Element("failure")
|
||||
failureElement.text = test_failure
|
||||
testCaseElement.append(failureElement)
|
||||
self.root.append(testCaseElement)
|
||||
|
||||
def FinishAndWrite(self, f):
|
||||
xml.ElementTree(self.root).write(f, "UTF-8")
|
@ -8,7 +8,6 @@ import sys
|
||||
import time
|
||||
|
||||
from . import base
|
||||
from ..local import junit_output
|
||||
|
||||
|
||||
def print_failure_header(test):
|
||||
@ -244,45 +243,6 @@ class MonochromeProgressIndicator(CompactProgressIndicator):
|
||||
print ("\r" + (" " * last_length) + "\r"),
|
||||
|
||||
|
||||
class JUnitTestProgressIndicator(ProgressIndicator):
|
||||
def __init__(self, junitout, junittestsuite):
|
||||
super(JUnitTestProgressIndicator, self).__init__()
|
||||
self._requirement = base.DROP_PASS_STDOUT
|
||||
|
||||
self.outputter = junit_output.JUnitTestOutput(junittestsuite)
|
||||
if junitout:
|
||||
self.outfile = open(junitout, "w")
|
||||
else:
|
||||
self.outfile = sys.stdout
|
||||
|
||||
def _on_result_for(self, test, result):
|
||||
# TODO(majeski): Support for dummy/grouped results
|
||||
fail_text = ""
|
||||
output = result.output
|
||||
if result.has_unexpected_output:
|
||||
stdout = output.stdout.strip()
|
||||
if len(stdout):
|
||||
fail_text += "stdout:\n%s\n" % stdout
|
||||
stderr = output.stderr.strip()
|
||||
if len(stderr):
|
||||
fail_text += "stderr:\n%s\n" % stderr
|
||||
fail_text += "Command: %s" % result.cmd.to_string()
|
||||
if output.HasCrashed():
|
||||
fail_text += "exit code: %d\n--- CRASHED ---" % output.exit_code
|
||||
if output.HasTimedOut():
|
||||
fail_text += "--- TIMEOUT ---"
|
||||
self.outputter.HasRunTest(
|
||||
test_name=str(test),
|
||||
test_cmd=result.cmd.to_string(relative=True),
|
||||
test_duration=output.duration,
|
||||
test_failure=fail_text)
|
||||
|
||||
def finished(self):
|
||||
self.outputter.FinishAndWrite(self.outfile)
|
||||
if self.outfile != sys.stdout:
|
||||
self.outfile.close()
|
||||
|
||||
|
||||
class JsonTestProgressIndicator(ProgressIndicator):
|
||||
def __init__(self, json_test_results, arch, mode):
|
||||
super(JsonTestProgressIndicator, self).__init__()
|
||||
|
Loading…
Reference in New Issue
Block a user