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

Unified Diff: devserver.py

Issue 3459002: Revert devserver update to fix factory install. (Closed) Base URL: http://git.chromium.org/git/dev-util.git
Patch Set: Created 10 years, 3 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « autoupdate_unittest.py ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: devserver.py
diff --git a/devserver.py b/devserver.py
index 2af67068df343fc3d1c7939811cfd0d48f807963..73aa3ba717328545ae6b5ac07114cdb507f09d68 100644
--- a/devserver.py
+++ b/devserver.py
@@ -1,16 +1,14 @@
-# Copyright (c) 2009-2010 The Chromium OS Authors. All rights reserved.
+# Copyright (c) 2009 The Chromium OS Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
+import autoupdate
+import buildutil
import optparse
import os
import sys
import web
-import autoupdate
-import buildutil
-
-# Sets up global to share between classes.
global updater
updater = None
@@ -19,7 +17,6 @@ class index:
def GET(self):
return render.index(None)
-
class update:
"""
Processes updates from the client machine. If an update is found, the url
@@ -28,7 +25,6 @@ class update:
def POST(self, args=None):
return updater.HandleUpdatePing(web.data(), args)
-
class build:
"""
builds the package specified by the pkg parameter and returns the name
@@ -46,7 +42,6 @@ class build:
if err != 0:
raise Exception('failed to execute %s' % emerge_command)
-
def OverrideWSGIServer(server_address, wsgi_app):
"""Creates a CherryPyWSGIServer instance.
@@ -61,23 +56,6 @@ def OverrideWSGIServer(server_address, wsgi_app):
return CherryPyWSGIServer(server_address, wsgi_app, server_name="localhost",
timeout=600)
-def _PrepareToServeUpdatesOnly(image_dir):
- """Sets up symlink to image_dir for serving purposes."""
- assert os.path.exists(image_dir), '%s must exist.' % image_dir
- # If we're serving out of an archived build dir (e.g. a
- # buildbot), prepare this webserver's magic 'static/' dir with a
- # link to the build archive.
- web.debug('Preparing autoupdate for "serve updates only" mode.')
- if os.path.exists('static/archive'):
- if image_dir != os.readlink('static/archive'):
- web.debug('removing stale symlink to %s' % image_dir)
- os.unlink('static/archive')
- os.symlink(image_dir, 'static/archive')
- else:
- os.symlink(image_dir, 'static/archive')
- web.debug('archive dir: %s ready to be used to serve images.' % image_dir)
-
-
if __name__ == '__main__':
usage = 'usage: %prog [options]'
parser = optparse.OptionParser(usage)
@@ -88,58 +66,62 @@ if __name__ == '__main__':
default='MementoSoftwareUpdate')
parser.add_option('--factory_config', dest='factory_config',
help='Config file for serving images from factory floor.')
- parser.add_option('--image', dest='image',
- help='Force update using this image.')
parser.add_option('-t', action='store_true', dest='test_image')
parser.add_option('-u', '--urlbase', dest='urlbase',
help='base URL, other than devserver, for update images.')
parser.add_option('--validate_factory_config', action="store_true",
dest='validate_factory_config',
help='Validate factory config file, then exit.')
- # Clean up the args, due to httpserver's hardcoded use of sys.argv.
- options, sys.argv = parser.parse_args(sys.argv)
+ options, args = parser.parse_args()
+ # clean up the args, due to httpserver's hardcoded use of sys.argv
+ if options.archive_dir:
+ sys.argv.remove('--archive_dir')
+ sys.argv.remove(options.archive_dir)
+ if '--client_prefix' in sys.argv:
+ sys.argv.remove('--client_prefix')
+ sys.argv.remove(options.client_prefix)
+ if options.factory_config:
+ sys.argv.remove('--factory_config')
+ sys.argv.remove(options.factory_config)
+ if options.test_image:
+ sys.argv.remove('-t')
+ if options.urlbase:
+ sys.argv.remove('-u')
+ sys.argv.remove(options.urlbase)
+ if options.validate_factory_config:
+ sys.argv.remove('--validate_factory_config')
root_dir = os.path.realpath('%s/../..' %
os.path.dirname(os.path.abspath(sys.argv[0])))
-
- serve_only = False
-
if options.archive_dir:
static_dir = os.path.realpath(options.archive_dir)
- _PrepareToServeUpdatesOnly(static_dir)
- serve_only = True
+ assert os.path.exists(static_dir), '%s must exist.' % options.archive_dir
+ web.debug('using archive dir: %s' % static_dir)
else:
static_dir = os.path.realpath('%s/static' %
os.path.dirname(os.path.abspath(sys.argv[0])))
web.debug('dev root is %s' % root_dir)
os.system('mkdir -p %s' % static_dir)
-
- web.debug('Serving from %s' % static_dir)
+ web.debug('Serving images from %s' % static_dir)
updater = autoupdate.Autoupdate(
root_dir=root_dir,
static_dir=static_dir,
- serve_only=serve_only,
+ serve_only=options.archive_dir,
urlbase=options.urlbase,
test_image=options.test_image,
factory_config_path=options.factory_config,
- client_prefix=options.client_prefix,
- forced_image=options.image)
-
- if options.factory_config:
- updater.ImportFactoryConfigFile(factory_config_path,
- validate_factory_config)
-
- if not options.validate_factory_config:
- # We do not need to run the dev server for validating the factory config.
- # TODO(nsanders): Write unit test to validate.
- urls = ('/', 'index',
- '/update', 'update',
- '/update/(.+)', 'update',
- '/build', 'build')
-
- # Overrides the default WSGIServer routine -- see OverrideWSGIServer.
- web.httpserver.WSGIServer = OverrideWSGIServer
- app = web.application(urls, globals(), autoreload=True)
- render = web.template.render('templates/')
- app.run()
+ validate_factory_config=options.validate_factory_config,
+ client_prefix=options.client_prefix)
+ if options.validate_factory_config:
+ sys.exit(0)
+ urls = ('/', 'index',
+ '/update', 'update',
+ '/update/(.+)', 'update',
+ '/build', 'build')
+
+ # Overrides the default WSGIServer routine -- see OverrideWSGIServer.
+ web.httpserver.WSGIServer = OverrideWSGIServer
+ app = web.application(urls, globals(), autoreload=True)
+ render = web.template.render('templates/')
+ app.run()
« no previous file with comments | « autoupdate_unittest.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698