Teach push script to commit with roll account.

BUG=410721
LOG=n
TEST=script_test.py
TBR=tandrii@chromium.org

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

Cr-Commit-Position: refs/heads/master@{#25046}
git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@25046 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 4a9579fe
...@@ -105,14 +105,23 @@ class PushToCandidates(Step): ...@@ -105,14 +105,23 @@ class PushToCandidates(Step):
def RunStep(self): def RunStep(self):
print "Pushing lkgr %s to candidates." % self["lkgr"] print "Pushing lkgr %s to candidates." % self["lkgr"]
args = [
"--author", self._options.author,
"--reviewer", self._options.reviewer,
"--revision", self["lkgr"],
"--force",
]
if self._options.svn:
args.extend(["--svn", self._options.svn])
if self._options.svn_config:
args.extend(["--svn-config", self._options.svn_config])
if self._options.vc_interface:
args.extend(["--vc-interface", self._options.vc_interface])
# TODO(machenbach): Update the script before calling it. # TODO(machenbach): Update the script before calling it.
if self._options.push: if self._options.push:
self._side_effect_handler.Call( self._side_effect_handler.Call(push_to_trunk.PushToTrunk().Run, args)
push_to_trunk.PushToTrunk().Run,
["--author", self._options.author,
"--reviewer", self._options.reviewer,
"--revision", self["lkgr"],
"--force"])
class AutoPush(ScriptsBase): class AutoPush(ScriptsBase):
......
...@@ -405,7 +405,7 @@ class GitTagsOnlyMixin(VCInterface): ...@@ -405,7 +405,7 @@ class GitTagsOnlyMixin(VCInterface):
# is the case for all automated merge and push commits - also no title is # is the case for all automated merge and push commits - also no title is
# the prefix of another title). # the prefix of another title).
commit = None commit = None
for wait_interval in [3, 7, 15, 35]: for wait_interval in [3, 7, 15, 35, 35]:
self.step.Git("fetch") self.step.Git("fetch")
commit = self.step.GitLog(n=1, format="%H", grep=message, branch=remote) commit = self.step.GitLog(n=1, format="%H", grep=message, branch=remote)
if commit: if commit:
...@@ -425,9 +425,27 @@ class GitReadSvnWriteInterface(GitTagsOnlyMixin, GitSvnInterface): ...@@ -425,9 +425,27 @@ class GitReadSvnWriteInterface(GitTagsOnlyMixin, GitSvnInterface):
pass pass
class GitInterface(GitTagsOnlyMixin):
def Fetch(self):
self.step.Git("fetch")
def GitSvn(self, hsh, branch=""):
return ""
def SvnGit(self, rev, branch=""):
raise NotImplementedError()
def Land(self):
self.step.Git("push origin")
def CLLand(self):
self.step.GitCLLand()
VC_INTERFACES = { VC_INTERFACES = {
"git_svn": GitSvnInterface, "git_svn": GitSvnInterface,
"git_read_svn_write": GitReadSvnWriteInterface, "git_read_svn_write": GitReadSvnWriteInterface,
"git": GitInterface,
} }
......
...@@ -235,6 +235,10 @@ class GitRecipesMixin(object): ...@@ -235,6 +235,10 @@ class GitRecipesMixin(object):
self.Git( self.Git(
"cl dcommit -f --bypass-hooks", retry_on=lambda x: x is None, **kwargs) "cl dcommit -f --bypass-hooks", retry_on=lambda x: x is None, **kwargs)
def GitCLLand(self, **kwargs):
self.Git(
"cl land -f --bypass-hooks", retry_on=lambda x: x is None, **kwargs)
def GitDiff(self, loc1, loc2, **kwargs): def GitDiff(self, loc1, loc2, **kwargs):
return self.Git(MakeArgs(["diff", loc1, loc2]), **kwargs) return self.Git(MakeArgs(["diff", loc1, loc2]), **kwargs)
......
...@@ -362,7 +362,10 @@ class CommitSVN(Step): ...@@ -362,7 +362,10 @@ class CommitSVN(Step):
MESSAGE = "Commit to SVN." MESSAGE = "Commit to SVN."
def RunStep(self): def RunStep(self):
result = self.vc.Land() if self._options.svn:
self.SVNCommit("trunk", self["commit_title"])
else:
self.vc.Land()
class TagRevision(Step): class TagRevision(Step):
......
...@@ -849,6 +849,135 @@ Performance and stability improvements on all platforms.""", commit) ...@@ -849,6 +849,135 @@ Performance and stability improvements on all platforms.""", commit)
def testPushToTrunkForced(self): def testPushToTrunkForced(self):
self._PushToTrunk(force=True) self._PushToTrunk(force=True)
def testPushToTrunkGit(self):
svn_root = self.MakeEmptyTempDirectory()
TextToFile("", os.path.join(TEST_CONFIG["DEFAULT_CWD"], ".git"))
# The version file on bleeding edge has build level 5, while the version
# file from trunk has build level 4.
self.WriteFakeVersionFile(build=5)
TEST_CONFIG["CHANGELOG_ENTRY_FILE"] = self.MakeEmptyTempFile()
TEST_CONFIG["CHANGELOG_FILE"] = self.MakeEmptyTempFile()
bleeding_edge_change_log = "2014-03-17: Sentinel\n"
TextToFile(bleeding_edge_change_log, TEST_CONFIG["CHANGELOG_FILE"])
def ResetChangeLog():
"""On 'git co -b new_branch svn/trunk', and 'git checkout -- ChangeLog',
the ChangLog will be reset to its content on trunk."""
trunk_change_log = """1999-04-05: Version 3.22.4
Performance and stability improvements on all platforms.\n"""
TextToFile(trunk_change_log, TEST_CONFIG["CHANGELOG_FILE"])
def ResetToTrunk():
ResetChangeLog()
self.WriteFakeVersionFile()
def CheckSVNCommit():
commit = FileToText(TEST_CONFIG["COMMITMSG_FILE"])
self.assertEquals(
"""Version 3.22.5 (based on push_hash)
Log text 1 (issue 321).
Performance and stability improvements on all platforms.""", commit)
version = FileToText(
os.path.join(TEST_CONFIG["DEFAULT_CWD"], VERSION_FILE))
self.assertTrue(re.search(r"#define MINOR_VERSION\s+22", version))
self.assertTrue(re.search(r"#define BUILD_NUMBER\s+5", version))
self.assertFalse(re.search(r"#define BUILD_NUMBER\s+6", version))
self.assertTrue(re.search(r"#define PATCH_LEVEL\s+0", version))
self.assertTrue(re.search(r"#define IS_CANDIDATE_VERSION\s+0", version))
# Check that the change log on the trunk branch got correctly modified.
change_log = FileToText(TEST_CONFIG["CHANGELOG_FILE"])
self.assertEquals(
"""1999-07-31: Version 3.22.5
Log text 1 (issue 321).
Performance and stability improvements on all platforms.
1999-04-05: Version 3.22.4
Performance and stability improvements on all platforms.\n""",
change_log)
expectations = [
Cmd("git status -s -uno", ""),
Cmd("git status -s -b -uno", "## some_branch\n"),
Cmd("git fetch", ""),
Cmd("git branch", " branch1\n* branch2\n"),
Cmd("git branch", " branch1\n* branch2\n"),
Cmd(("git new-branch %s --upstream origin/master" %
TEST_CONFIG["BRANCHNAME"]),
""),
Cmd(("git log -1 --format=%H --grep="
"\"^Version [[:digit:]]*\.[[:digit:]]*\.[[:digit:]]* (based\" "
"origin/candidates"), "hash2\n"),
Cmd("git log -1 hash2", "Log message\n"),
Cmd("git log -1 --format=%s hash2",
"Version 3.4.5 (based on abc3)\n"),
Cmd("git checkout -f origin/master -- src/version.cc",
"", cb=self.WriteFakeVersionFile),
Cmd("git checkout -f hash2 -- src/version.cc", "",
cb=self.WriteFakeVersionFile),
Cmd("git log --format=%H abc3..push_hash", "rev1\n"),
Cmd("git log -1 --format=%s rev1", "Log text 1.\n"),
Cmd("git log -1 --format=%B rev1", "Text\nLOG=YES\nBUG=v8:321\nText\n"),
Cmd("git log -1 --format=%an rev1", "author1@chromium.org\n"),
Cmd("git fetch", ""),
Cmd("git checkout -f origin/master", ""),
Cmd("git diff origin/candidates push_hash", "patch content\n"),
Cmd(("git new-branch %s --upstream origin/candidates" %
TEST_CONFIG["TRUNKBRANCH"]), "", cb=ResetToTrunk),
Cmd("git apply --index --reject \"%s\"" % TEST_CONFIG["PATCH_FILE"], ""),
Cmd(("git checkout -f origin/candidates -- %s" %
TEST_CONFIG["CHANGELOG_FILE"]), "",
cb=ResetChangeLog),
Cmd("git checkout -f origin/candidates -- src/version.cc", "",
cb=self.WriteFakeVersionFile),
Cmd("git commit -aF \"%s\"" % TEST_CONFIG["COMMITMSG_FILE"], "",
cb=CheckSVNCommit),
# TODO(machenbach): Change test to pure git after flag day.
# Cmd("git push origin", ""),
Cmd("git diff HEAD^ HEAD", "patch content"),
Cmd("svn update", "", cwd=svn_root),
Cmd("svn status", "", cwd=svn_root),
Cmd("patch -d trunk -p1 -i %s" %
TEST_CONFIG["PATCH_FILE"], "Applied patch...", cwd=svn_root),
Cmd("svn commit --non-interactive --username=author@chromium.org "
"--config-dir=[CONFIG_DIR] "
"-m \"Version 3.22.5 (based on push_hash)\"",
"", cwd=svn_root),
Cmd("git fetch", ""),
Cmd("git log -1 --format=%H --grep="
"\"Version 3.22.5 (based on push_hash)\""
" origin/candidates", "hsh_to_tag"),
Cmd("git tag 3.22.5 hsh_to_tag", ""),
Cmd("git push origin 3.22.5", ""),
Cmd("git checkout -f some_branch", ""),
Cmd("git branch -D %s" % TEST_CONFIG["BRANCHNAME"], ""),
Cmd("git branch -D %s" % TEST_CONFIG["TRUNKBRANCH"], ""),
]
self.Expect(expectations)
args = ["-a", "author@chromium.org", "--revision", "push_hash",
"--vc-interface", "git", "-f", "-r", "reviewer@chromium.org",
"--svn", svn_root, "--svn-config", "[CONFIG_DIR]"]
PushToTrunk(TEST_CONFIG, self).Run(args)
cl = FileToText(TEST_CONFIG["CHANGELOG_FILE"])
self.assertTrue(re.search(r"^\d\d\d\d\-\d+\-\d+: Version 3\.22\.5", cl))
self.assertTrue(re.search(r" Log text 1 \(issue 321\).", cl))
self.assertTrue(re.search(r"1999\-04\-05: Version 3\.22\.4", cl))
# Note: The version file is on build number 5 again in the end of this test
# since the git command that merges to the bleeding edge branch is mocked
# out.
C_V8_22624_LOG = """V8 CL. C_V8_22624_LOG = """V8 CL.
git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@22624 123 git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@22624 123
...@@ -945,7 +1074,6 @@ def get_list(): ...@@ -945,7 +1074,6 @@ def get_list():
Cmd("git status -s -uno", ""), Cmd("git status -s -uno", ""),
Cmd("git status -s -b -uno", "## some_branch\n"), Cmd("git status -s -b -uno", "## some_branch\n"),
Cmd("git fetch", ""), Cmd("git fetch", ""),
Cmd("git svn fetch", ""),
URL("https://v8-status.appspot.com/current?format=json", URL("https://v8-status.appspot.com/current?format=json",
"{\"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")),
...@@ -957,7 +1085,8 @@ def get_list(): ...@@ -957,7 +1085,8 @@ def get_list():
"Version 3.4.5 (based on abc101)\n"), "Version 3.4.5 (based on abc101)\n"),
]) ])
auto_push.AutoPush(TEST_CONFIG, self).Run(AUTO_PUSH_ARGS + ["--push"]) auto_push.AutoPush(TEST_CONFIG, self).Run(
AUTO_PUSH_ARGS + ["--push", "--vc-interface", "git"])
state = json.loads(FileToText("%s-state.json" state = json.loads(FileToText("%s-state.json"
% TEST_CONFIG["PERSISTFILE_BASENAME"])) % TEST_CONFIG["PERSISTFILE_BASENAME"]))
......
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