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

Side by Side Diff: tools/safely-roll-webkit.py

Issue 7089012: Add safely-roll-webkit.py to streamline webkit rolls. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Renamed --commit to --use-commit-queue Created 9 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « tools/find_depot_tools.py ('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
(Empty)
1 #!/usr/bin/env python
2 # Copyright (c) 2011 The Chromium Authors. All rights reserved.
3 # Use of this source code is governed by a BSD-style license that can be
4 # found in the LICENSE file.
5
6 """Safely* rolls webkit.
7
8 * As safely as currently possible.
9 """
Dirk Pranke 2011/05/30 21:23:24 This comment isn't that helpful. I would replace i
M-A Ruel 2011/05/31 01:21:07 done
10
11 import logging
12 import optparse
13 import os
14 import re
15 import sys
16
17 import find_depot_tools
18 import scm
19 import subprocess2
20
21
22 def die_with_error(msg):
23 print >> sys.stderr, msg
24 sys.exit(1)
25
26
27 def process_deps(path, new_rev):
28 """Update webkit_revision to |new_issue|.
29
30 A bit hacky, could it be made better?
31 """
32 content = open(path).read()
33 old_line = r' "webkit_revision": "(\d+)",'
34 new_line = ' "webkit_revision": "%d",' % new_rev
Dirk Pranke 2011/05/30 21:23:24 Hm. I'd probably do this using readlines() for lin
M-A Ruel 2011/05/31 01:21:07 I prefer to keep the dumb logic here and change it
35 new_content = re.sub(old_line, new_line, content)
36 if new_content == content:
37 die_with_error('Failed to update the DEPS file')
38 open(path, 'w').write(new_content)
39
40
41 def main():
42 tool_dir = os.path.dirname(os.path.abspath(__file__))
43 parser = optparse.OptionParser(usage='<new webkit rev>')
44 parser.add_option('-v', '--verbose', action='count', default=0)
45 options, args = parser.parse_args()
46 logging.basicConfig(
47 level=
48 [logging.WARNING, logging.INFO, logging.DEBUG][
49 min(2, options.verbose)])
50 if len(args) != 1:
51 parser.error('Need only one arg: new webkit revision to roll to.')
52
53 root_dir = os.path.dirname(tool_dir)
54 os.chdir(root_dir)
55
56 new_rev = int(args[0])
57 msg = 'Roll webkit revision to %s' % new_rev
58 print msg
59
60 # Silence the editor.
61 os.environ['EDITOR'] = '/bin/true'
62
63 old_branch = scm.GIT.GetBranch(root_dir)
64 subprocess2.check_output(
65 ['git', 'checkout', '-b', 'webkit_roll', 'origin/trunk'])
66 try:
67 process_deps(os.path.join(root_dir, 'DEPS'), new_rev)
68 subprocess2.check_output(['git', 'commit', '-m', msg, 'DEPS'])
69 changed = subprocess2.check_output(
70 ['git', 'diff', 'origin/trunk', '--name-only']).splitlines()
71 if changed != ['DEPS']:
72 die_with_error('Make sure to be on a clean branch first')
73 subprocess2.check_call(['git', 'cl', 'upload', '--use-commit-queue'])
74 finally:
75 subprocess2.check_output(['git', 'checkout', old_branch])
76 subprocess2.check_output(['git', 'branch', '-D', 'webkit_roll'])
Dirk Pranke 2011/05/30 21:23:24 I personally don't like to delete branches until a
M-A Ruel 2011/05/31 01:21:07 By using check_call(git checkout -b) before the tr
77 return 0
78
79
80 if __name__ == '__main__':
81 sys.exit(main())
OLDNEW
« no previous file with comments | « tools/find_depot_tools.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698