mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
147 lines
5.3 KiB
Python
147 lines
5.3 KiB
Python
# Copyright (C) 2012 Google Inc. 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 logging
|
|
import optparse
|
|
import signal
|
|
import traceback
|
|
|
|
from webkitpy.common.host import Host
|
|
from webkitpy.layout_tests.models import test_expectations
|
|
from webkitpy.layout_tests.port import platform_options
|
|
|
|
|
|
# This mirrors what the shell normally does.
|
|
INTERRUPTED_EXIT_STATUS = signal.SIGINT + 128
|
|
|
|
# This is a randomly chosen exit code that can be tested against to
|
|
# indicate that an unexpected exception occurred.
|
|
EXCEPTIONAL_EXIT_STATUS = 254
|
|
|
|
_log = logging.getLogger(__name__)
|
|
|
|
|
|
def lint(host, options):
|
|
# FIXME: Remove this when we remove the --chromium flag (crbug.com/245504).
|
|
if options.platform == 'chromium':
|
|
options.platform = None
|
|
|
|
ports_to_lint = [host.port_factory.get(name) for name in host.port_factory.all_port_names(options.platform)]
|
|
files_linted = set()
|
|
lint_failed = False
|
|
|
|
for port_to_lint in ports_to_lint:
|
|
expectations_dict = port_to_lint.expectations_dict()
|
|
|
|
for expectations_file in expectations_dict.keys():
|
|
if expectations_file in files_linted:
|
|
continue
|
|
|
|
try:
|
|
test_expectations.TestExpectations(port_to_lint,
|
|
expectations_dict={expectations_file: expectations_dict[expectations_file]},
|
|
is_lint_mode=True)
|
|
except test_expectations.ParseError as e:
|
|
lint_failed = True
|
|
_log.error('')
|
|
for warning in e.warnings:
|
|
_log.error(warning)
|
|
_log.error('')
|
|
files_linted.add(expectations_file)
|
|
return lint_failed
|
|
|
|
|
|
def check_virtual_test_suites(host, options):
|
|
port = host.port_factory.get(options=options)
|
|
fs = host.filesystem
|
|
layout_tests_dir = port.layout_tests_dir()
|
|
virtual_suites = port.virtual_test_suites()
|
|
|
|
check_failed = False
|
|
for suite in virtual_suites:
|
|
comps = [layout_tests_dir] + suite.name.split('/') + ['README.txt']
|
|
path_to_readme = fs.join(*comps)
|
|
if not fs.exists(path_to_readme):
|
|
_log.error('tests/%s/README.txt is missing (each virtual suite must have one).' % suite.name)
|
|
check_failed = True
|
|
if check_failed:
|
|
_log.error('')
|
|
return check_failed
|
|
|
|
|
|
def set_up_logging(logging_stream):
|
|
logger = logging.getLogger()
|
|
logger.setLevel(logging.INFO)
|
|
handler = logging.StreamHandler(logging_stream)
|
|
logger.addHandler(handler)
|
|
return (logger, handler)
|
|
|
|
|
|
def tear_down_logging(logger, handler):
|
|
logger.removeHandler(handler)
|
|
|
|
|
|
def run_checks(host, options, logging_stream):
|
|
logger, handler = set_up_logging(logging_stream)
|
|
try:
|
|
lint_failed = lint(host, options)
|
|
check_failed = check_virtual_test_suites(host, options)
|
|
if lint_failed or check_failed:
|
|
_log.error('Lint failed.')
|
|
return 1
|
|
else:
|
|
_log.info('Lint succeeded.')
|
|
return 0
|
|
finally:
|
|
logger.removeHandler(handler)
|
|
|
|
|
|
def main(argv, _, stderr):
|
|
parser = optparse.OptionParser(option_list=platform_options(use_globs=True))
|
|
options, _ = parser.parse_args(argv)
|
|
|
|
if options.platform and 'test' in options.platform:
|
|
# It's a bit lame to import mocks into real code, but this allows the user
|
|
# to run tests against the test platform interactively, which is useful for
|
|
# debugging test failures.
|
|
from webkitpy.common.host_mock import MockHost
|
|
host = MockHost()
|
|
else:
|
|
host = Host()
|
|
|
|
try:
|
|
exit_status = run_checks(host, options, stderr)
|
|
except KeyboardInterrupt:
|
|
exit_status = INTERRUPTED_EXIT_STATUS
|
|
except Exception as e:
|
|
print >> stderr, '\n%s raised: %s' % (e.__class__.__name__, str(e))
|
|
traceback.print_exc(file=stderr)
|
|
exit_status = EXCEPTIONAL_EXIT_STATUS
|
|
|
|
return exit_status
|