From 0a2b1fd4b004cf6ec15453d8e1f711d1bb976a0b Mon Sep 17 00:00:00 2001 From: Colin Watson Date: Thu, 24 Jul 2014 15:28:12 +0100 Subject: [PATCH] Add a --distribution option; parameterise most mentions of "ubuntu" using it. --- autopkgtest.py | 8 +++++--- britney.py | 19 +++++++++++++------ excuse.py | 7 ++++++- 3 files changed, 24 insertions(+), 10 deletions(-) diff --git a/autopkgtest.py b/autopkgtest.py index 556b0e6..3bd769b 100644 --- a/autopkgtest.py +++ b/autopkgtest.py @@ -47,8 +47,9 @@ class AutoPackageTest(object): accepted. """ - def __init__(self, britney, series, debug=False): + def __init__(self, britney, distribution, series, debug=False): self.britney = britney + self.distribution = distribution self.series = series self.debug = debug self.read() @@ -64,11 +65,12 @@ class AutoPackageTest(object): print(dedent("""\ release: %s aptroot: ~/.chdist/%s-proposed-amd64/ - apturi: file:%s/mirror/ubuntu + apturi: file:%s/mirror/%s components: main restricted universe multiverse rsync_host: rsync://tachash.ubuntu-ci/adt/ datadir: ~/proposed-migration/autopkgtest/data""" % - (self.series, self.series, home)), file=rc_file) + (self.series, self.series, home, self.distribution)), + file=rc_file) @property def _request_path(self): diff --git a/britney.py b/britney.py index 2d0e53f..3efae53 100755 --- a/britney.py +++ b/britney.py @@ -371,6 +371,8 @@ class Britney(object): help="do not build the non-installability status, use the cache from file") parser.add_option("", "--print-uninst", action="store_true", dest="print_uninst", default=False, help="just print a summary of uninstallable packages") + parser.add_option("", "--distribution", action="store", dest="distribution", default="ubuntu", + help="set distribution name") parser.add_option("", "--series", action="store", dest="series", default=None, help="set distribution series name") (self.options, self.args) = parser.parse_args() @@ -1136,6 +1138,7 @@ class Britney(object): # otherwise, add a new excuse for its removal and return True src = self.sources['testing'][pkg] excuse = Excuse("-" + pkg) + excuse.set_distribution(self.options.distribution) excuse.set_vers(src[VERSION], None) src[MAINTAINER] and excuse.set_maint(src[MAINTAINER].strip()) src[SECTION] and excuse.set_section(src[SECTION].strip()) @@ -1172,6 +1175,7 @@ class Britney(object): # build the common part of the excuse, which will be filled by the code below ref = "%s/%s%s" % (src, arch, suite != 'unstable' and "_" + suite or "") excuse = Excuse(ref) + excuse.set_distribution(self.options.distribution) excuse.set_vers(source_t[VERSION], source_t[VERSION]) source_u[MAINTAINER] and excuse.set_maint(source_u[MAINTAINER].strip()) source_u[SECTION] and excuse.set_section(source_u[SECTION].strip()) @@ -1327,6 +1331,7 @@ class Britney(object): # build the common part of the excuse, which will be filled by the code below ref = "%s%s" % (src, suite != 'unstable' and "_" + suite or "") excuse = Excuse(ref) + excuse.set_distribution(self.options.distribution) excuse.set_vers(source_t and source_t[VERSION] or None, source_u[VERSION]) source_u[MAINTAINER] and excuse.set_maint(source_u[MAINTAINER].strip()) source_u[SECTION] and excuse.set_section(source_u[SECTION].strip()) @@ -1463,7 +1468,7 @@ class Britney(object): base = 'testing' else: base = 'stable' - text = "Not yet built on %s (relative to testing)" % (urllib.quote(src.split("/")[0]), urllib.quote(source_u[VERSION]), arch) + text = "Not yet built on %s (relative to testing)" % (self.options.distribution, urllib.quote(src.split("/")[0]), urllib.quote(source_u[VERSION]), arch) if arch in self.options.outofsync_arches.split(): text = text + " (but %s isn't keeping up, so never mind)" % (arch) @@ -1522,12 +1527,12 @@ class Britney(object): if maxver is not None and apt_pkg.version_compare(maxver, v) > 0: maybe_nbs = "; NBS?" break - oodtxt = oodtxt + "%s (from %s%s)" % \ - (", ".join(sorted(oodbins[v])), urllib.quote(src.split("/")[0]), urllib.quote(v), v, maybe_nbs) - text = "out of date on %s: %s" % \ - (urllib.quote(src.split("/")[0]), urllib.quote(source_u[VERSION]), arch, oodtxt) + (self.options.distribution, urllib.quote(src.split("/")[0]), urllib.quote(source_u[VERSION]), arch, oodtxt) if arch in self.options.outofsync_arches.split(): text = text + " (but %s isn't keeping up, so nevermind)" % (arch) @@ -1733,6 +1738,7 @@ class Britney(object): # add the removal of the package to upgrade_me and build a new excuse upgrade_me.append("-%s" % (src)) excuse = Excuse("-%s" % (src)) + excuse.set_distribution(self.options.distribution) excuse.set_vers(tsrcv, None) excuse.addhtml("Removal request by %s" % (item.user)) excuse.addhtml("Package is broken, will try to remove") @@ -1749,7 +1755,8 @@ class Britney(object): # trigger autopkgtests for valid candidates adt_debug = getattr(self.options, "adt_debug", "no") == "yes" autopkgtest = AutoPackageTest( - self, self.options.series, debug=adt_debug) + self, self.options.distribution, self.options.series, + debug=adt_debug) autopkgtest_packages = [] autopkgtest_excuses = [] autopkgtest_excludes = [] diff --git a/excuse.py b/excuse.py index a858ee0..963dd8e 100644 --- a/excuse.py +++ b/excuse.py @@ -51,6 +51,7 @@ class Excuse(object): self._is_valid = False self._dontinvalidate = False self.run_autopkgtest = False + self.distribution = "ubuntu" self.invalid_deps = [] self.deps = {} @@ -92,6 +93,10 @@ class Excuse(object): """Set the urgency of upload of the package""" self.urgency = date + def set_distribution(self, distribution): + """Set the distribution name""" + self.distribution = distribution + def add_dep(self, name, arch): """Add a dependency""" if name not in self.deps: self.deps[name]=[] @@ -121,7 +126,7 @@ class Excuse(object): def html(self): """Render the excuse in HTML""" - lp_pkg = "https://launchpad.net/ubuntu/+source/%s" % self.name.split("/")[0] + lp_pkg = "https://launchpad.net/%s/+source/%s" % (self.distribution, self.name.split("/")[0]) if self.ver[0] == "-": lp_old = self.ver[0] else: