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

Side by Side Diff: sky/tools/skypy/skyserver.py

Issue 840973002: Make skydb just a ctl-style helper (e.g. apachectl) (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Fix load comand Created 5 years, 11 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 | « sky/tools/skydb ('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
1 # Copyright 2014 The Chromium Authors. All rights reserved. 1 # Copyright 2014 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 import socket 5 import socket
6 import subprocess 6 import subprocess
7 import logging 7 import logging
8 import os.path 8 import os.path
9 9
10 class SkyServer(object): 10 class SkyServer(object):
11 def __init__(self, paths, port, configuration, root): 11 def __init__(self, paths, port, configuration, root):
12 self.paths = paths 12 self.paths = paths
13 self.port = port 13 self.port = port
14 self.configuration = configuration 14 self.configuration = configuration
15 self.root = root 15 self.root = root
16 self.server = None 16 self.server = None
17 17
18 @staticmethod 18 @staticmethod
19 def _port_in_use(port): 19 def _port_in_use(port):
20 sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) 20 sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
21 return sock.connect_ex(('localhost', port)) == 0 21 return sock.connect_ex(('localhost', port)) == 0
22 22
23 @staticmethod 23 @staticmethod
24 def _download_server_if_necessary(paths): 24 def _download_server_if_necessary(paths):
25 subprocess.call(os.path.join(paths.sky_tools_directory, 25 subprocess.call(os.path.join(paths.sky_tools_directory,
26 'download_sky_server')) 26 'download_sky_server'))
27 return os.path.join(paths.src_root, 'out', 'downloads', 'sky_server') 27 return os.path.join(paths.src_root, 'out', 'downloads', 'sky_server')
28 28
29 def __enter__(self): 29 def start(self):
30 if self._port_in_use(self.port): 30 if self._port_in_use(self.port):
31 logging.warn( 31 logging.warn(
32 'Port %s already in use, assuming custom sky_server started.' % 32 'Port %s already in use, assuming custom sky_server started.' %
33 self.port) 33 self.port)
34 return 34 return
35 35
36 server_path = self._download_server_if_necessary(self.paths) 36 server_path = self._download_server_if_necessary(self.paths)
37 server_command = [ 37 server_command = [
38 server_path, 38 server_path,
39 '-t', self.configuration, 39 '-t', self.configuration,
40 self.root, 40 self.root,
41 str(self.port), 41 str(self.port),
42 ] 42 ]
43 self.server = subprocess.Popen(server_command) 43 self.server = subprocess.Popen(server_command)
44 return self.server.pid
45
46 def stop(self):
47 if self.server:
48 self.server.terminate()
49
50 def __enter__(self):
51 self.start()
44 52
45 def __exit__(self, exc_type, exc_value, traceback): 53 def __exit__(self, exc_type, exc_value, traceback):
46 if self.server: 54 self.stop()
47 self.server.terminate()
48 55
49 def path_as_url(self, path): 56 def path_as_url(self, path):
50 return self.url_for_path(self.port, self.root, path) 57 return self.url_for_path(self.port, self.root, path)
51 58
52 @staticmethod 59 @staticmethod
53 def url_for_path(port, root, path): 60 def url_for_path(port, root, path):
54 relative_path = os.path.relpath(path, root) 61 relative_path = os.path.relpath(path, root)
55 return 'http://localhost:%s/%s' % (port, relative_path) 62 return 'http://localhost:%s/%s' % (port, relative_path)
OLDNEW
« no previous file with comments | « sky/tools/skydb ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698