1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
#! /usr/bin/python
# Copyright (C) 2012 Canonical Ltd.
# Author: Colin Watson <cjwatson@ubuntu.com>
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; version 3 of the License.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
"""Branch a set of Ubuntu seeds for the next release."""
from __future__ import print_function
from optparse import OptionParser
import os
import re
import subprocess
try:
from urllib.parse import urlparse
except ImportError:
from urlparse import urlparse
from launchpadlib.launchpad import Launchpad
def remote_branch(source):
# TODO: should really use bzrlib instead
info = subprocess.check_output(
["bzr", "info", source], universal_newlines=True)
for line in info.splitlines():
if "checkout of branch:" in line:
return line.split(": ")[1].rstrip("/")
else:
raise Exception("Unable to find remote branch for %s" % source)
def lp_branch(options, url):
return options.launchpad.branches.getByUniqueName(
unique_name=urlparse(url).path.lstrip("/"))
def branch(options, collection):
source = "%s.%s" % (collection, options.source_series)
dest = "%s.%s" % (collection, options.dest_series)
if os.path.exists(source):
subprocess.check_call(["bzr", "up", source])
remote_source = remote_branch(source)
remote_dest = os.path.join(os.path.dirname(remote_source), dest)
subprocess.check_call(["bzr", "branch", source, dest])
subprocess.check_call(["bzr", "push", "-d", dest, remote_dest])
subprocess.check_call(["bzr", "bind", ":push"], cwd=dest)
lp_source = lp_branch(options, remote_source)
lp_source.lifecycle_status = "Mature"
lp_source.lp_save()
lp_dest = lp_branch(options, remote_dest)
lp_dest.lifecycle_status = "Development"
lp_dest.lp_save()
re_include_source = re.compile(
r"^(include )(.*)\.%s" % options.source_series)
new_lines = []
message = []
with open(os.path.join(dest, "STRUCTURE")) as structure:
for line in structure:
match = re_include_source.match(line)
if match:
new_lines.append(re_include_source.sub(
r"\1\2.%s" % options.dest_series, line))
message.append(
"%s.%s -> %s.%s" %
(match.group(2), options.source_series,
match.group(2), options.dest_series))
else:
new_lines.append(line)
if message:
with open(os.path.join(dest, "STRUCTURE.new"), "w") as structure:
for line in new_lines:
print(line, end="", file=structure)
os.rename(
os.path.join(dest, "STRUCTURE.new"),
os.path.join(dest, "STRUCTURE"))
subprocess.check_call(
["bzr", "commit", "-m", "; ".join(message)], cwd=dest)
def main():
parser = OptionParser(usage="usage: %prog [options] collection ...")
parser.add_option(
"-l", "--launchpad", dest="launchpad_instance", default="production")
parser.add_option(
"--source-series",
help="source series (default: current stable release)")
parser.add_option(
"--dest-series",
help="destination series (default: series in pre-release freeze)")
options, args = parser.parse_args()
if not args:
parser.error("You must specify at least one seed collection.")
options.launchpad = Launchpad.login_with(
"branch-seeds", options.launchpad_instance)
distro = options.launchpad.distributions["ubuntu"]
if options.source_series is None:
options.source_series = [
series.name for series in distro.series
if series.status == "Current Stable Release"][0]
if options.dest_series is None:
options.dest_series = [
series.name for series in distro.series
if series.status == "Pre-release Freeze"][0]
for collection in args:
branch(options, collection)
main()
|