| Index: sky/tools/webkitpy/layout_tests/port/win.py
|
| diff --git a/sky/tools/webkitpy/layout_tests/port/win.py b/sky/tools/webkitpy/layout_tests/port/win.py
|
| deleted file mode 100644
|
| index f20649701f37f49f2ca69fc81eae00c7ac0d285d..0000000000000000000000000000000000000000
|
| --- a/sky/tools/webkitpy/layout_tests/port/win.py
|
| +++ /dev/null
|
| @@ -1,246 +0,0 @@
|
| -# Copyright (C) 2010 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.
|
| -
|
| -"""Windows implementation of the Port interface."""
|
| -
|
| -import errno
|
| -import os
|
| -import logging
|
| -
|
| -try:
|
| - import _winreg
|
| -except ImportError as e:
|
| - _winreg = None
|
| - WindowsError = Exception # this shuts up pylint.
|
| -
|
| -from webkitpy.layout_tests.breakpad.dump_reader_win import DumpReaderWin
|
| -from webkitpy.layout_tests.models import test_run_results
|
| -from webkitpy.layout_tests.port import base
|
| -from webkitpy.layout_tests.servers import crash_service
|
| -
|
| -
|
| -_log = logging.getLogger(__name__)
|
| -
|
| -
|
| -class WinPort(base.Port):
|
| - port_name = 'win'
|
| -
|
| - # FIXME: Figure out how to unify this with base.TestConfiguration.all_systems()?
|
| - SUPPORTED_VERSIONS = ('xp', 'win7')
|
| -
|
| - FALLBACK_PATHS = { 'win7': [ 'win' ]}
|
| - FALLBACK_PATHS['xp'] = ['win-xp'] + FALLBACK_PATHS['win7']
|
| -
|
| - DEFAULT_BUILD_DIRECTORIES = ('build', 'out')
|
| -
|
| - BUILD_REQUIREMENTS_URL = 'http://www.chromium.org/developers/how-tos/build-instructions-windows'
|
| -
|
| - @classmethod
|
| - def determine_full_port_name(cls, host, options, port_name):
|
| - if port_name.endswith('win'):
|
| - assert host.platform.is_win()
|
| - # We don't maintain separate baselines for vista, so we pretend it is win7.
|
| - if host.platform.os_version in ('vista', '7sp0', '7sp1', 'future'):
|
| - version = 'win7'
|
| - else:
|
| - version = host.platform.os_version
|
| - port_name = port_name + '-' + version
|
| - return port_name
|
| -
|
| - def __init__(self, host, port_name, **kwargs):
|
| - super(WinPort, self).__init__(host, port_name, **kwargs)
|
| - self._version = port_name[port_name.index('win-') + len('win-'):]
|
| - assert self._version in self.SUPPORTED_VERSIONS, "%s is not in %s" % (self._version, self.SUPPORTED_VERSIONS)
|
| - if not self.get_option('disable_breakpad'):
|
| - self._dump_reader = DumpReaderWin(host, self._build_path())
|
| - self._crash_service = None
|
| - self._crash_service_available = None
|
| -
|
| - def additional_drt_flag(self):
|
| - flags = super(WinPort, self).additional_drt_flag()
|
| - flags += ['--enable-direct-write']
|
| - if not self.get_option('disable_breakpad'):
|
| - flags += ['--enable-crash-reporter', '--crash-dumps-dir=%s' % self._dump_reader.crash_dumps_directory()]
|
| - return flags
|
| -
|
| - def check_httpd(self):
|
| - res = super(WinPort, self).check_httpd()
|
| - if self.uses_apache():
|
| - # In order to run CGI scripts on Win32 that use unix shebang lines, we need to
|
| - # create entries in the registry that remap the extensions (.pl and .cgi) to the
|
| - # appropriate Win32 paths. The command line arguments must match the command
|
| - # line arguments in the shebang line exactly.
|
| - if _winreg:
|
| - res = self._check_reg(r'.cgi\Shell\ExecCGI\Command') and res
|
| - res = self._check_reg(r'.pl\Shell\ExecCGI\Command') and res
|
| - else:
|
| - _log.warning("Could not check the registry; http may not work correctly.")
|
| -
|
| - return res
|
| -
|
| - def _check_reg(self, sub_key):
|
| - # see comments in check_httpd(), above, for why this routine exists and what it's doing.
|
| - try:
|
| - # Note that we HKCR is a union of HKLM and HKCR (with the latter
|
| - # overridding the former), so reading from HKCR ensures that we get
|
| - # the value if it is set in either place. See als comments below.
|
| - hkey = _winreg.OpenKey(_winreg.HKEY_CLASSES_ROOT, sub_key)
|
| - args = _winreg.QueryValue(hkey, '').split()
|
| - _winreg.CloseKey(hkey)
|
| -
|
| - # In order to keep multiple checkouts from stepping on each other, we simply check that an
|
| - # existing entry points to a valid path and has the right command line.
|
| - if len(args) == 2 and self._filesystem.exists(args[0]) and args[0].endswith('perl.exe') and args[1] == '-wT':
|
| - return True
|
| - except WindowsError, e:
|
| - if e.errno != errno.ENOENT:
|
| - raise e
|
| - # The key simply probably doesn't exist.
|
| - pass
|
| -
|
| - # Note that we write to HKCU so that we don't need privileged access
|
| - # to the registry, and that will get reflected in HKCR when it is read, above.
|
| - cmdline = self.path_from_chromium_base('third_party', 'perl', 'perl', 'bin', 'perl.exe') + ' -wT'
|
| - hkey = _winreg.CreateKeyEx(_winreg.HKEY_CURRENT_USER, 'Software\\Classes\\' + sub_key, 0, _winreg.KEY_WRITE)
|
| - _winreg.SetValue(hkey, '', _winreg.REG_SZ, cmdline)
|
| - _winreg.CloseKey(hkey)
|
| - return True
|
| -
|
| - def setup_test_run(self):
|
| - super(WinPort, self).setup_test_run()
|
| -
|
| - if not self.get_option('disable_breakpad'):
|
| - assert not self._crash_service, 'Already running a crash service'
|
| - if self._crash_service_available == None:
|
| - self._crash_service_available = self._check_crash_service_available()
|
| - if not self._crash_service_available:
|
| - return
|
| - service = crash_service.CrashService(self, self._dump_reader.crash_dumps_directory())
|
| - service.start()
|
| - self._crash_service = service
|
| -
|
| - def clean_up_test_run(self):
|
| - super(WinPort, self).clean_up_test_run()
|
| -
|
| - if self._crash_service:
|
| - self._crash_service.stop()
|
| - self._crash_service = None
|
| -
|
| - def setup_environ_for_server(self, server_name=None):
|
| - env = super(WinPort, self).setup_environ_for_server(server_name)
|
| -
|
| - # FIXME: This is a temporary hack to get the cr-win bot online until
|
| - # someone from the cr-win port can take a look.
|
| - apache_envvars = ['SYSTEMDRIVE', 'SYSTEMROOT', 'TEMP', 'TMP']
|
| - for key, value in os.environ.items():
|
| - if key not in env and key in apache_envvars:
|
| - env[key] = value
|
| -
|
| - # Put the cygwin directory first in the path to find cygwin1.dll.
|
| - env["PATH"] = "%s;%s" % (self.path_from_chromium_base("third_party", "cygwin", "bin"), env["PATH"])
|
| - # Configure the cygwin directory so that pywebsocket finds proper
|
| - # python executable to run cgi program.
|
| - env["CYGWIN_PATH"] = self.path_from_chromium_base("third_party", "cygwin", "bin")
|
| - if self.get_option('register_cygwin'):
|
| - setup_mount = self.path_from_chromium_base("third_party", "cygwin", "setup_mount.bat")
|
| - self._executive.run_command([setup_mount]) # Paths are all absolute, so this does not require a cwd.
|
| - return env
|
| -
|
| - def _modules_to_search_for_symbols(self):
|
| - # FIXME: we should return the path to the ffmpeg equivalents to detect if we have the mp3 and aac codecs installed.
|
| - # See https://bugs.webkit.org/show_bug.cgi?id=89706.
|
| - return []
|
| -
|
| - def check_build(self, needs_http, printer):
|
| - result = super(WinPort, self).check_build(needs_http, printer)
|
| -
|
| - self._crash_service_available = self._check_crash_service_available()
|
| - if not self._crash_service_available:
|
| - result = test_run_results.UNEXPECTED_ERROR_EXIT_STATUS
|
| -
|
| - if result:
|
| - _log.error('For complete Windows build requirements, please see:')
|
| - _log.error('')
|
| - _log.error(' http://dev.chromium.org/developers/how-tos/build-instructions-windows')
|
| - return result
|
| -
|
| - def operating_system(self):
|
| - return 'win'
|
| -
|
| - def relative_test_filename(self, filename):
|
| - path = filename[len(self.layout_tests_dir()) + 1:]
|
| - return path.replace('\\', '/')
|
| -
|
| - def uses_apache(self):
|
| - val = self.get_option('use_apache')
|
| - if val is None:
|
| - return True
|
| - return val
|
| -
|
| - def path_to_apache(self):
|
| - return self.path_from_chromium_base('third_party', 'apache-win32', 'bin', 'httpd.exe')
|
| -
|
| - def path_to_apache_config_file(self):
|
| - return self._filesystem.join(self.layout_tests_dir(), 'http', 'conf', 'win-httpd.conf')
|
| -
|
| - #
|
| - # PROTECTED ROUTINES
|
| - #
|
| -
|
| - def _path_to_driver(self, configuration=None):
|
| - binary_name = '%s.exe' % self.driver_name()
|
| - return self._build_path_with_configuration(configuration, binary_name)
|
| -
|
| - def _path_to_crash_service(self):
|
| - binary_name = 'content_shell_crash_service.exe'
|
| - return self._build_path(binary_name)
|
| -
|
| - def _path_to_image_diff(self):
|
| - binary_name = 'image_diff.exe'
|
| - return self._build_path(binary_name)
|
| -
|
| - def _path_to_wdiff(self):
|
| - return self.path_from_chromium_base('third_party', 'cygwin', 'bin', 'wdiff.exe')
|
| -
|
| - def _check_crash_service_available(self):
|
| - """Checks whether the crash service binary is present."""
|
| - result = self._check_file_exists(self._path_to_crash_service(), "content_shell_crash_service.exe")
|
| - if not result:
|
| - _log.error(" Could not find crash service, unexpected crashes won't be symbolized.")
|
| - _log.error(' Did you build the target blink_tests?')
|
| - _log.error('')
|
| - return result
|
| -
|
| - def look_for_new_crash_logs(self, crashed_processes, start_time):
|
| - if self.get_option('disable_breakpad'):
|
| - return None
|
| - return self._dump_reader.look_for_new_crash_logs(crashed_processes, start_time)
|
| -
|
| - def clobber_old_port_specific_results(self):
|
| - if not self.get_option('disable_breakpad'):
|
| - self._dump_reader.clobber_old_results()
|
|
|