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

Unified Diff: Tools/Scripts/webkitpy/tool/servers/gardeningserver.py

Issue 351873005: Remove support for local garden-o-matic (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 6 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 side-by-side diff with in-line comments
Download patch
Index: Tools/Scripts/webkitpy/tool/servers/gardeningserver.py
diff --git a/Tools/Scripts/webkitpy/tool/servers/gardeningserver.py b/Tools/Scripts/webkitpy/tool/servers/gardeningserver.py
deleted file mode 100644
index 53c636565f65bd0e01b62dccc0ecda35979b2eb5..0000000000000000000000000000000000000000
--- a/Tools/Scripts/webkitpy/tool/servers/gardeningserver.py
+++ /dev/null
@@ -1,135 +0,0 @@
-# Copyright (C) 2011 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:
-#
-# 1. Redistributions of source code must retain the above copyright
-# notice, this list of conditions and the following disclaimer.
-# 2. 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.
-#
-# 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 BaseHTTPServer
-import SocketServer
-import logging
-import json
-import os
-import re
-import sys
-import urllib
-
-from webkitpy.common.memoized import memoized
-from webkitpy.tool.servers.reflectionhandler import ReflectionHandler
-from webkitpy.layout_tests.port import builders
-
-
-_log = logging.getLogger(__name__)
-
-
-class GardeningHTTPServer(SocketServer.ThreadingMixIn, BaseHTTPServer.HTTPServer):
- def __init__(self, httpd_port, config):
- server_name = ''
- self.tool = config['tool']
- self.options = config['options']
- BaseHTTPServer.HTTPServer.__init__(self, (server_name, httpd_port), GardeningHTTPRequestHandler)
-
- def url(self, args=None):
- # We can't use urllib.encode() here because that encodes spaces as plus signs and the buildbots don't decode those properly.
- arg_string = ('?' + '&'.join("%s=%s" % (key, urllib.quote(value)) for (key, value) in args.items())) if args else ''
- return 'http://localhost:8127/garden-o-matic.html' + arg_string
-
-
-class GardeningHTTPRequestHandler(ReflectionHandler):
- REVISION_LIMIT = 100
- BLINK_SVN_URL = 'http://src.chromium.org/blink/trunk'
- CHROMIUM_SVN_DEPS_URL = 'http://src.chromium.org/chrome/trunk/src/DEPS'
- # "webkit_revision": "149598",
- BLINK_REVISION_REGEXP = re.compile(r'^ "webkit_revision": "(?P<revision>\d+)",$', re.MULTILINE);
-
- STATIC_FILE_NAMES = frozenset()
-
- STATIC_FILE_EXTENSIONS = ('.js', '.css', '.html', '.gif', '.png', '.ico')
-
- STATIC_FILE_DIRECTORY = os.path.join(
- os.path.dirname(__file__),
- '..',
- '..',
- '..',
- '..',
- 'GardeningServer')
-
- allow_cross_origin_requests = True
- debug_output = ''
-
- def ping(self):
- self._serve_text('pong')
-
- def _run_webkit_patch(self, command, input_string):
- PIPE = self.server.tool.executive.PIPE
- process = self.server.tool.executive.popen([self.server.tool.path()] + command, cwd=self.server.tool.scm().checkout_root, stdin=PIPE, stdout=PIPE, stderr=PIPE)
- process.stdin.write(input_string)
- output, error = process.communicate()
- return (process.returncode, output, error)
-
- def svnlog(self):
- self._serve_xml(self.server.tool.executive.run_command(['svn', 'log', '--xml', '--limit', self.REVISION_LIMIT, self.BLINK_SVN_URL]))
-
- def lastroll(self):
- deps_contents = self.server.tool.executive.run_command(['svn', 'cat', self.CHROMIUM_SVN_DEPS_URL])
- match = re.search(self.BLINK_REVISION_REGEXP, deps_contents)
- if not match:
- _log.error("Unable to produce last Blink roll revision")
- self._serve_text("0")
- return
-
- revision_line = match.group()
- revision = match.group("revision")
- self._serve_text(revision)
-
- def rebaselineall(self):
- command = ['rebaseline-json']
- if self.server.options.results_directory:
- command.extend(['--results-directory', self.server.options.results_directory])
- if not self.server.options.optimize:
- command.append('--no-optimize')
- if self.server.options.verbose:
- command.append('--verbose')
- json_input = self.read_entity_body()
-
- _log.debug("calling %s, input='%s'", command, json_input)
- return_code, output, error = self._run_webkit_patch(command, json_input)
- print >> sys.stderr, error
- json_result = {"return_code": return_code}
- if return_code:
- _log.error("rebaseline-json failed: %d, output='%s'" % (return_code, output))
- json_result["output"] = output
- else:
- _log.debug("rebaseline-json succeeded")
-
- self._serve_text(json.dumps(json_result))
-
- def localresult(self):
- path = self.query['path'][0]
- filesystem = self.server.tool.filesystem
-
- # Ensure that we're only serving files from inside the results directory.
- if not filesystem.isabs(path) and self.server.options.results_directory:
- fullpath = filesystem.abspath(filesystem.join(self.server.options.results_directory, path))
- if fullpath.startswith(filesystem.abspath(self.server.options.results_directory)):
- self._serve_file(fullpath, headers_only=(self.command == 'HEAD'))
- return
-
- self.send_response(403)

Powered by Google App Engine
This is Rietveld 408576698