Change auto-roll to auto-push for automatic trunk pushes.

The current script is only performing automatic pushes to trunk. This prepares for adding an auto-roll script that actually rolls to Chromium.

This also removes the v8-status updates, which are no longer necessary due to not touching bleeding edge any more.

BUG=
R=jarin@chromium.org

Review URL: https://codereview.chromium.org/196173018

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@20205 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 6704bbce
...@@ -55,7 +55,7 @@ class Preparation(Step): ...@@ -55,7 +55,7 @@ class Preparation(Step):
self.CommonPrepare() self.CommonPrepare()
class CheckAutoRollSettings(Step): class CheckAutoPushSettings(Step):
MESSAGE = "Checking settings file." MESSAGE = "Checking settings file."
def RunStep(self): def RunStep(self):
...@@ -114,26 +114,10 @@ class CheckLastPush(Step): ...@@ -114,26 +114,10 @@ class CheckLastPush(Step):
class PushToTrunk(Step): class PushToTrunk(Step):
MESSAGE = "Pushing to trunk if specified." MESSAGE = "Pushing to trunk if specified."
def PushTreeStatus(self, message):
if not self._options.status_password:
print "Skipping tree status update without password file."
return
params = {
"message": message,
"username": "v8-auto-roll@chromium.org",
"password": FileToText(self._options.status_password).strip(),
}
params = urllib.urlencode(params)
print "Pushing tree status: '%s'" % message
self.ReadURL("https://v8-status.appspot.com/status", params,
wait_plan=[5, 20])
def RunStep(self): def RunStep(self):
print "Pushing lkgr %s to trunk." % self["lkgr"] print "Pushing lkgr %s to trunk." % self["lkgr"]
self.PushTreeStatus("Tree is closed (preparing to push)")
# TODO(machenbach): Update the script before calling it. # TODO(machenbach): Update the script before calling it.
try:
if self._options.push: if self._options.push:
P = push_to_trunk.PushToTrunk P = push_to_trunk.PushToTrunk
self._side_effect_handler.Call( self._side_effect_handler.Call(
...@@ -142,19 +126,13 @@ class PushToTrunk(Step): ...@@ -142,19 +126,13 @@ class PushToTrunk(Step):
"--reviewer", self._options.reviewer, "--reviewer", self._options.reviewer,
"--revision", self["lkgr"], "--revision", self["lkgr"],
"--force"]) "--force"])
finally:
self.PushTreeStatus(self["tree_message"])
class AutoRoll(ScriptsBase): class AutoPush(ScriptsBase):
def _PrepareOptions(self, parser): def _PrepareOptions(self, parser):
parser.add_argument("-c", "--chromium",
help=("Deprecated."))
parser.add_argument("-p", "--push", parser.add_argument("-p", "--push",
help="Push to trunk. Dry run if unspecified.", help="Push to trunk. Dry run if unspecified.",
default=False, action="store_true") default=False, action="store_true")
parser.add_argument("--status-password",
help="A file with the password to the status app.")
def _ProcessOptions(self, options): def _ProcessOptions(self, options):
if not options.author or not options.reviewer: # pragma: no cover if not options.author or not options.reviewer: # pragma: no cover
...@@ -166,7 +144,7 @@ class AutoRoll(ScriptsBase): ...@@ -166,7 +144,7 @@ class AutoRoll(ScriptsBase):
def _Steps(self): def _Steps(self):
return [ return [
Preparation, Preparation,
CheckAutoRollSettings, CheckAutoPushSettings,
CheckTreeStatus, CheckTreeStatus,
FetchLKGR, FetchLKGR,
CheckLastPush, CheckLastPush,
...@@ -175,4 +153,4 @@ class AutoRoll(ScriptsBase): ...@@ -175,4 +153,4 @@ class AutoRoll(ScriptsBase):
if __name__ == "__main__": # pragma: no cover if __name__ == "__main__": # pragma: no cover
sys.exit(AutoRoll(CONFIG).Run()) sys.exit(AutoPush(CONFIG).Run())
...@@ -31,9 +31,9 @@ import tempfile ...@@ -31,9 +31,9 @@ import tempfile
import traceback import traceback
import unittest import unittest
import auto_roll import auto_push
from auto_roll import CheckLastPush from auto_push import CheckLastPush
from auto_roll import SETTINGS_LOCATION from auto_push import SETTINGS_LOCATION
import common_includes import common_includes
from common_includes import * from common_includes import *
import merge_to_branch import merge_to_branch
...@@ -67,9 +67,8 @@ TEST_CONFIG = { ...@@ -67,9 +67,8 @@ TEST_CONFIG = {
} }
AUTO_ROLL_ARGS = [ AUTO_PUSH_ARGS = [
"-a", "author@chromium.org", "-a", "author@chromium.org",
"-c", TEST_CONFIG[CHROMIUM],
"-r", "reviewer@chromium.org", "-r", "reviewer@chromium.org",
] ]
...@@ -840,13 +839,11 @@ Performance and stability improvements on all platforms.""", commit) ...@@ -840,13 +839,11 @@ Performance and stability improvements on all platforms.""", commit)
self._state["lkgr"] = "101" self._state["lkgr"] = "101"
self.assertRaises(Exception, lambda: self.RunStep(auto_roll.AutoRoll, self.assertRaises(Exception, lambda: self.RunStep(auto_push.AutoPush,
CheckLastPush, CheckLastPush,
AUTO_ROLL_ARGS)) AUTO_PUSH_ARGS))
def testAutoRoll(self): def testAutoPush(self):
password = self.MakeEmptyTempFile()
TextToFile("PW", password)
TEST_CONFIG[DOT_GIT_LOCATION] = self.MakeEmptyTempFile() TEST_CONFIG[DOT_GIT_LOCATION] = self.MakeEmptyTempFile()
TEST_CONFIG[SETTINGS_LOCATION] = "~/.doesnotexist" TEST_CONFIG[SETTINGS_LOCATION] = "~/.doesnotexist"
...@@ -855,12 +852,6 @@ Performance and stability improvements on all platforms.""", commit) ...@@ -855,12 +852,6 @@ Performance and stability improvements on all platforms.""", commit)
"{\"message\": \"Tree is throttled\"}"), "{\"message\": \"Tree is throttled\"}"),
URL("https://v8-status.appspot.com/lkgr", Exception("Network problem")), URL("https://v8-status.appspot.com/lkgr", Exception("Network problem")),
URL("https://v8-status.appspot.com/lkgr", "100"), URL("https://v8-status.appspot.com/lkgr", "100"),
URL("https://v8-status.appspot.com/status",
("username=v8-auto-roll%40chromium.org&"
"message=Tree+is+closed+%28preparing+to+push%29&password=PW"), ""),
URL("https://v8-status.appspot.com/status",
("username=v8-auto-roll%40chromium.org&"
"message=Tree+is+throttled&password=PW"), ""),
]) ])
self.ExpectGit([ self.ExpectGit([
...@@ -874,18 +865,17 @@ Performance and stability improvements on all platforms.""", commit) ...@@ -874,18 +865,17 @@ Performance and stability improvements on all platforms.""", commit)
"Version 3.4.5 (based on bleeding_edge revision r79)\n"), "Version 3.4.5 (based on bleeding_edge revision r79)\n"),
]) ])
auto_roll.AutoRoll(TEST_CONFIG, self).Run( auto_push.AutoPush(TEST_CONFIG, self).Run(AUTO_PUSH_ARGS + ["--push"])
AUTO_ROLL_ARGS + ["--status-password", password, "--push"])
state = json.loads(FileToText("%s-state.json" state = json.loads(FileToText("%s-state.json"
% TEST_CONFIG[PERSISTFILE_BASENAME])) % TEST_CONFIG[PERSISTFILE_BASENAME]))
self.assertEquals("100", state["lkgr"]) self.assertEquals("100", state["lkgr"])
def testAutoRollStoppedBySettings(self): def testAutoPushStoppedBySettings(self):
TEST_CONFIG[DOT_GIT_LOCATION] = self.MakeEmptyTempFile() TEST_CONFIG[DOT_GIT_LOCATION] = self.MakeEmptyTempFile()
TEST_CONFIG[SETTINGS_LOCATION] = self.MakeEmptyTempFile() TEST_CONFIG[SETTINGS_LOCATION] = self.MakeEmptyTempFile()
TextToFile("{\"enable_auto_roll\": false}", TEST_CONFIG[SETTINGS_LOCATION]) TextToFile("{\"enable_auto_push\": false}", TEST_CONFIG[SETTINGS_LOCATION])
self.ExpectReadURL([]) self.ExpectReadURL([])
...@@ -895,11 +885,11 @@ Performance and stability improvements on all platforms.""", commit) ...@@ -895,11 +885,11 @@ Performance and stability improvements on all platforms.""", commit)
Git("svn fetch", ""), Git("svn fetch", ""),
]) ])
def RunAutoRoll(): def RunAutoPush():
auto_roll.AutoRoll(TEST_CONFIG, self).Run(AUTO_ROLL_ARGS) auto_push.AutoPush(TEST_CONFIG, self).Run(AUTO_PUSH_ARGS)
self.assertRaises(Exception, RunAutoRoll) self.assertRaises(Exception, RunAutoPush)
def testAutoRollStoppedByTreeStatus(self): def testAutoPushStoppedByTreeStatus(self):
TEST_CONFIG[DOT_GIT_LOCATION] = self.MakeEmptyTempFile() TEST_CONFIG[DOT_GIT_LOCATION] = self.MakeEmptyTempFile()
TEST_CONFIG[SETTINGS_LOCATION] = "~/.doesnotexist" TEST_CONFIG[SETTINGS_LOCATION] = "~/.doesnotexist"
...@@ -914,9 +904,9 @@ Performance and stability improvements on all platforms.""", commit) ...@@ -914,9 +904,9 @@ Performance and stability improvements on all platforms.""", commit)
Git("svn fetch", ""), Git("svn fetch", ""),
]) ])
def RunAutoRoll(): def RunAutoPush():
auto_roll.AutoRoll(TEST_CONFIG, self).Run(AUTO_ROLL_ARGS) auto_push.AutoPush(TEST_CONFIG, self).Run(AUTO_PUSH_ARGS)
self.assertRaises(Exception, RunAutoRoll) self.assertRaises(Exception, RunAutoPush)
def testMergeToBranch(self): def testMergeToBranch(self):
TEST_CONFIG[ALREADY_MERGING_SENTINEL_FILE] = self.MakeEmptyTempFile() TEST_CONFIG[ALREADY_MERGING_SENTINEL_FILE] = self.MakeEmptyTempFile()
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment