blob: 505d87ee95f3061e7d332609c88af6b3b15684d8 [file] [log] [blame]
Eric Boren522efc42019-04-16 15:15:21 -04001#!/usr/bin/env python
2#
3# Copyright 2019 Google Inc.
4#
5# Use of this source code is governed by a BSD-style license that can be
6# found in the LICENSE file.
7
8
Eric Borenf19ef9b2019-04-17 12:32:07 -04009import os
10import re
Eric Boren522efc42019-04-16 15:15:21 -040011import subprocess
12import sys
13
14from infra import git
15from infra import go
16
Eric Borenf19ef9b2019-04-17 12:32:07 -040017_TOOLS_DIR = os.path.dirname(os.path.abspath(__file__))
18_REPO_ROOT = os.path.realpath(os.path.join(_TOOLS_DIR, os.pardir))
19_INFRA_BOTS = os.path.join(_REPO_ROOT, 'infra', 'bots')
20sys.path.insert(0, _INFRA_BOTS)
21import git_utils
22
Eric Boren522efc42019-04-16 15:15:21 -040023
24REFS_HEADS_PREFIX = 'refs/heads/'
25CHROME_REF_PREFIX = REFS_HEADS_PREFIX + 'chrome/m'
Eric Borenf19ef9b2019-04-17 12:32:07 -040026SK_MILESTONE_H = os.path.join('include', 'core', 'SkMilestone.h')
27SK_MILESTONE_TMPL = r'#define SK_MILESTONE %s'
28SK_MILESTONE_RE = SK_MILESTONE_TMPL % r'(\d+)'
29SKIA_REPO = 'https://skia.googlesource.com/skia.git'
Eric Boren31013702020-05-13 13:48:55 -040030SUPPORTED_CHROME_BRANCHES = 3
Eric Borenf19ef9b2019-04-17 12:32:07 -040031UPDATE_MILESTONE_COMMIT_MSG = '''Update Skia milestone to %d'''
Eric Boren522efc42019-04-16 15:15:21 -040032
33
Eric Borenf19ef9b2019-04-17 12:32:07 -040034def get_current_milestone():
35 '''Read SkMilestone.h and parse out the current milestone.'''
36 sk_milestone = os.path.join(_REPO_ROOT, SK_MILESTONE_H)
37 with open(sk_milestone, 'r') as f:
38 contents = f.read()
39 for line in contents.splitlines():
40 m = re.match(SK_MILESTONE_RE, line)
41 if m:
42 return int(m.groups()[0])
43 print >> sys.stderr, (
44 'Failed to parse %s; has the format changed?' % SK_MILESTONE_H)
45 sys.exit(1)
Eric Boren522efc42019-04-16 15:15:21 -040046
47
Eric Borenf19ef9b2019-04-17 12:32:07 -040048def create_new_branch(new_branch, branch_at):
49 '''Create a temporary checkout of the repo, create the new branch and push.'''
50 b = new_branch[len(REFS_HEADS_PREFIX):]
51 with git_utils.NewGitCheckout(SKIA_REPO, local=_REPO_ROOT):
52 git.git('checkout', '-b', b)
53 git.git('reset', '--hard', branch_at)
54 git.git('push', '--set-upstream', 'origin', b)
55
56
57def update_milestone(m):
58 '''Update SkMilestone.h to match the given milestone number.'''
59 with git_utils.NewGitCheckout(SKIA_REPO, local=_REPO_ROOT):
60 with git_utils.GitBranch(
61 'update_milestone', UPDATE_MILESTONE_COMMIT_MSG % m):
62 with open(SK_MILESTONE_H, 'r+') as f:
63 contents = re.sub(
64 SK_MILESTONE_RE, SK_MILESTONE_TMPL % str(m), f.read(), flags=re.M)
65 f.seek(0)
66 f.write(contents)
67 f.truncate()
68 git.git('diff')
69
70
71def update_infra_config(old_branch, new_branch):
72 '''Create a CL to add infra support for the new branch and remove the old.'''
Eric Boren522efc42019-04-16 15:15:21 -040073 owner = git.git('config', 'user.email').rstrip()
74 if not owner:
Eric Borenf19ef9b2019-04-17 12:32:07 -040075 print >> sys.stderr, ('No configured git user; please run '
76 '"git config user.email <your email>".')
Eric Boren522efc42019-04-16 15:15:21 -040077 sys.exit(1)
Eric Boren46e2d8d2019-12-05 14:29:38 -050078 go.mod_download()
79 go.install(go.INFRA_GO+'/go/supported_branches/cmd/new-branch')
Eric Boren522efc42019-04-16 15:15:21 -040080 subprocess.check_call(['new-branch',
Eric Boren6fed6d32019-06-04 12:36:43 -040081 '--branch', new_branch[len(REFS_HEADS_PREFIX):],
82 '--delete', old_branch[len(REFS_HEADS_PREFIX):],
Eric Boren06a72572019-04-18 08:54:33 -040083 '--owner', owner,
84 '--exclude-trybots=chromium.*',
Eric Boren7e9dc422019-12-04 07:18:57 -050085 '--exclude-trybots=.*Android_Framework.*',
Ravi Mistry262796e2020-02-28 12:29:53 -050086 '--exclude-trybots=.*G3_Framework.*',
Eric Borenfafb4772021-01-08 09:06:54 -050087 '--exclude-trybots=.*CanvasKit.*',
88 '--exclude-trybots=.*PathKit.*',
Eric Boren7e9dc422019-12-04 07:18:57 -050089 '--submit'])
Eric Boren522efc42019-04-16 15:15:21 -040090
91
Eric Borenf19ef9b2019-04-17 12:32:07 -040092def main():
Eric Boren6fed6d32019-06-04 12:36:43 -040093 if len(sys.argv) != 2 or '--help' in sys.argv or '-h' in sys.argv:
Eric Borenf19ef9b2019-04-17 12:32:07 -040094 print >> sys.stderr, 'Usage: %s <commit hash for branch>' % sys.argv[0]
95 sys.exit(1)
Eric Boren06a72572019-04-18 08:54:33 -040096 go.check()
Eric Borenf19ef9b2019-04-17 12:32:07 -040097 branch_at = sys.argv[1]
98 m = get_current_milestone()
99 new_branch = '%s%d' % (CHROME_REF_PREFIX, m)
100 old_branch = '%s%d' % (CHROME_REF_PREFIX, m-SUPPORTED_CHROME_BRANCHES)
101 print 'Creating branch %s and removing support (eg. CQ) for %s' % (
102 new_branch, old_branch)
103 create_new_branch(new_branch, branch_at)
104 update_milestone(m+1)
105 update_infra_config(old_branch, new_branch)
106
107
Eric Boren522efc42019-04-16 15:15:21 -0400108if __name__ == '__main__':
109 main()