Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(673)

Side by Side Diff: Tools/Scripts/webkitpy/layout_tests/servers/wptserve_http.py

Issue 1154373005: Introduce WPTServe for running W3C Blink Layout tests (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Nitfix round 2 Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « Tools/Scripts/webkitpy/layout_tests/servers/wpt_support/checkout.sh ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 # Copyright 2015 The Chromium Authors. All rights reserved.
Dirk Pranke 2015/06/09 01:21:33 We should probably just call this 'wptserve.py'. T
burnik 2015/06/09 18:54:44 Done.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
4
5 """Start and stop the WPTserve servers as they're used by the layout tests."""
6
7 import logging
8 import os
9 import socket
10
11 from webkitpy.layout_tests.servers import server_base
12
13
14 _log = logging.getLogger(__name__)
15
16
17 class WPTServeHTTP(server_base.ServerBase):
18 def __init__(self, port_obj, output_dir):
19 super(WPTServeHTTP, self).__init__(port_obj, output_dir)
20 # TODO(burnik): This should be the only place where we set up the ports.
21 secure_port, insecure_port = (8001, 8444)
22 self._name = 'wptserve'
23 self._log_prefixes = ('access_log', 'error_log')
24 self._mappings = [{'port': secure_port},
25 {'port': insecure_port, 'sslcert': True}]
26
27 # TODO(burnik): We can probably avoid PID files for WPT in the future.
28 self._pid_file = self._filesystem.join(self._runtime_path, '%s.pid' % se lf._name)
29
30 script_path = os.path.dirname(os.path.abspath(__file__))
31 self._path_to_wpt = os.path.abspath(os.path.join(script_path, "wpt_suppo rt", "wpt"))
32 self._executable = os.path.join(self._path_to_wpt, "serve")
33 self._path_to_wpt_config = os.path.join(self._path_to_wpt, "config.json" )
34 self._path_to_wpt_tests = os.path.abspath(os.path.join(self._port_obj.la yout_tests_dir(),
35 "imported", "web- platform-tests"))
36 self._wpt_config = {"host": "web-platform.test",
37 "doc_root": self._path_to_wpt_tests,
38 "insecure_port": secure_port,
39 "secure_port": insecure_port}
40 self._start_cmd = [self._executable, "--config", self._path_to_wpt_confi g]
41
42 def _spawn_process(self):
43 _log.debug('Starting %s server, cmd="%s"' % (self._name, str(self._start _cmd)))
44
45 # TODO(burnik): This config should probably be available in advance.
46 config = ('{'
47 '"host": "%(host)s",'
48 '"doc_root": "%(doc_root)s",'
49 '"ports":{'
50 '"http":[%(insecure_port)d, "auto"],'
51 '"https":[%(secure_port)d],'
52 '"ws":["auto"],'
53 '"wss":["auto"]}'
54 '}') % self._wpt_config
55 fs = self._port_obj.host.filesystem
56 fs.write_text_file(self._path_to_wpt_config, config)
57
58 self._process = self._executive.popen(self._start_cmd,
59 cwd=self._path_to_wpt,
60 shell=True,
61 stdout=self._executive.DEVNULL,
62 stderr=self._executive.DEVNULL,
63 preexec_fn=os.setsid)
64
65 # We probably won't need a PID file, but server_base needs it.
66 fs.write_text_file(self._pid_file, str(self._process.pid))
67 return self._process.pid
68
69 def stop(self):
70 self._stop_running_server()
71
72 def _stop_running_server(self):
73 # Clean up the pid file.
74 if self._pid and not self._executive.check_running_pid(self._pid):
75 self._filesystem.remove(self._pid_file)
76 return
77
78 self._executive.kill_process(self._pid)
OLDNEW
« no previous file with comments | « Tools/Scripts/webkitpy/layout_tests/servers/wpt_support/checkout.sh ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698