mirror of
https://git.launchpad.net/ubuntu-dev-tools
synced 2025-04-16 12:51:08 +00:00
requestsync: reindent remaining code and small cleanup
This commit is contained in:
parent
d5a19ca5a7
commit
966ab3727a
284
requestsync
284
requestsync
@ -26,87 +26,87 @@
|
||||
#
|
||||
# ##################################################################
|
||||
|
||||
import os
|
||||
import subprocess
|
||||
import sys
|
||||
from debian_bundle.changelog import Version
|
||||
from optparse import OptionParser
|
||||
from debian_bundle.changelog import Version
|
||||
|
||||
# ubuntu-dev-tools modules.
|
||||
import ubuntutools.lp.libsupport as lp_libsupport
|
||||
import ubuntutools.lp.udtexceptions as udtexceptions
|
||||
from ubuntutools.lp.lpapicache import Launchpad, LpApiWrapper, Distribution, PersonTeam
|
||||
# ubuntu-dev-tools modules
|
||||
from ubuntutools.lp import udtexceptions
|
||||
from ubuntutools.requestsync.common import *
|
||||
# https_proxy fix
|
||||
import ubuntutools.common
|
||||
|
||||
from ubuntutools.requestsync.mail import *
|
||||
from ubuntutools.requestsync.common import *
|
||||
from ubuntutools.requestsync.lp import postBug
|
||||
|
||||
#
|
||||
# entry point
|
||||
#
|
||||
|
||||
if __name__ == '__main__':
|
||||
# Our usage options.
|
||||
usage = "Usage: %prog [-d distro] [-k keyid] [-n] [--lp] [-s] [-e] "
|
||||
usage += "<source package> [<target release> [base version]]"
|
||||
optParser = OptionParser(usage)
|
||||
# Our usage options.
|
||||
usage = 'Usage: %prog [-d distro] [-k keyid] [-n] [--lp] [-s] [-e] ' \
|
||||
'<source package> [<target release> [base version]]'
|
||||
optParser = OptionParser(usage)
|
||||
|
||||
optParser.add_option("-d", type = "string",
|
||||
dest = "dist", default = "unstable",
|
||||
help = "Debian distribution to sync from.")
|
||||
optParser.add_option("-k", type = "string",
|
||||
dest = "keyid", default = None,
|
||||
help = "GnuPG key ID to use for signing report.")
|
||||
optParser.add_option("-n", action = "store_true",
|
||||
dest = "newpkg", default = False,
|
||||
help = "Whether package to sync is a new package in Ubuntu.")
|
||||
optParser.add_option("--lp", action = "store_true",
|
||||
dest = "lpbugs", default = False,
|
||||
help = "Specify whether to use the launchpadlib module for filing " \
|
||||
"report.")
|
||||
optParser.add_option("-s", action = "store_true",
|
||||
dest = "sponsor", default = False,
|
||||
help = "Force sponsorship requirement (shall be autodetected if not " \
|
||||
"specified).")
|
||||
optParser.add_option("-e", action = "store_true",
|
||||
dest = "ffe", default = False,
|
||||
help = "Use this after FeatureFreeze for non-bug fix syncs, changes " \
|
||||
"default subscription to the appropriate release team.")
|
||||
optParser.add_option('-d', type = 'string',
|
||||
dest = 'dist', default = 'unstable',
|
||||
help = 'Debian distribution to sync from.')
|
||||
optParser.add_option('-k', type = 'string',
|
||||
dest = 'keyid', default = None,
|
||||
help = 'GnuPG key ID to use for signing report (only used when emailing the sync request).')
|
||||
optParser.add_option('-n', action = 'store_true',
|
||||
dest = 'newpkg', default = False,
|
||||
help = 'Whether package to sync is a new package in Ubuntu.')
|
||||
optParser.add_option('--lp', action = 'store_true',
|
||||
dest = 'lpapi', default = False,
|
||||
help = 'Specify whether to use the LP API for filing the sync request.')
|
||||
optParser.add_option('-s', action = 'store_true',
|
||||
dest = 'sponsor', default = False,
|
||||
help = 'Force sponsorship')
|
||||
optParser.add_option('-e', action = 'store_true',
|
||||
dest = 'ffe', default = False,
|
||||
help = 'Use this after FeatureFreeze for non-bug fix syncs, changes ' \
|
||||
'default subscription to the appropriate release team.')
|
||||
|
||||
(options, args) = optParser.parse_args()
|
||||
(options, args) = optParser.parse_args()
|
||||
|
||||
newsource = options.newpkg
|
||||
sponsorship = options.sponsor
|
||||
keyid = options.keyid
|
||||
use_lp_bugs = options.lpbugs
|
||||
need_interaction = False
|
||||
distro = options.dist
|
||||
ffe = options.ffe
|
||||
if not len(args):
|
||||
optParser.print_help()
|
||||
sys.exit(1)
|
||||
|
||||
if not use_lp_bugs and not getEmailAddress():
|
||||
sys.exit(1)
|
||||
# import the needed requestsync module
|
||||
if options.lpapi:
|
||||
from ubuntutools.requestsync.lp import *
|
||||
from ubuntutools.lp.lpapicache import Distribution
|
||||
else:
|
||||
from ubuntutools.requestsync.mail import *
|
||||
if not getEmailAddress():
|
||||
sys.exit(1)
|
||||
|
||||
if len(args) == 0:
|
||||
optParser.print_help()
|
||||
sys.exit(1)
|
||||
newsource = options.newpkg
|
||||
sponsorship = options.sponsor
|
||||
keyid = options.keyid
|
||||
lpapi = options.lpapi
|
||||
need_interaction = False
|
||||
distro = options.dist
|
||||
ffe = options.ffe
|
||||
|
||||
if len(args) not in (2, 3): # no release specified, assume development release
|
||||
release = Distribution('ubuntu').getDevelopmentSeries().name
|
||||
print >> sys.stderr, ("Source package / target release missing - assuming %s " %
|
||||
release)
|
||||
else:
|
||||
release = args[1]
|
||||
if len(args) not in (2, 3): # no release specified, assume development release
|
||||
if options.lpapi:
|
||||
release = Distribution('ubuntu').getDevelopmentSeries().name
|
||||
print >> sys.stderr, 'W: Target release missing - assuming %s' % release
|
||||
else:
|
||||
print >> sys.stderr, 'E: Source package or target release missing. Exiting.'
|
||||
sys.exit(1)
|
||||
else:
|
||||
release = args[1]
|
||||
|
||||
srcpkg = args[0]
|
||||
force_base_ver = None
|
||||
srcpkg = args[0]
|
||||
force_base_ver = None
|
||||
|
||||
# Base version specified.
|
||||
if len(args) == 3: force_base_ver = args[2]
|
||||
|
||||
# Base version specified.
|
||||
if len(args) == 3: force_base_ver = args[2]
|
||||
(cur_ver, component) = ('0', 'universe') # Let's assume universe
|
||||
|
||||
(cur_ver, component) = ('0', 'universe') # Let's assume universe
|
||||
|
||||
# Find Ubuntu release's package version.
|
||||
try:
|
||||
ubuntusrcpkg = getUbuntuSrcPkg(srcpkg, release)
|
||||
@ -119,108 +119,98 @@ if __name__ == '__main__':
|
||||
raw_input_exit_on_ctrlc('Press [Enter] to continue or [Ctrl-C] to abort. ')
|
||||
newsource = True # TODO: set it for now, but check code if it's needed
|
||||
|
||||
debsrcpkg = getDebianSrcPkg(srcpkg, distro)
|
||||
debiancomponent = debsrcpkg.getComponent()
|
||||
# Find Debian release's package version.
|
||||
deb_version = debsrcpkg.getVersion()
|
||||
debsrcpkg = getDebianSrcPkg(srcpkg, distro)
|
||||
debiancomponent = debsrcpkg.getComponent()
|
||||
# Find Debian release's package version.
|
||||
deb_version = debsrcpkg.getVersion()
|
||||
|
||||
# Debian and Ubuntu versions are the same - stop.
|
||||
if deb_version == cur_ver:
|
||||
print 'The versions in Debian and Ubuntu are the same already (%s). Aborting.' % (deb_version,)
|
||||
sys.exit(1)
|
||||
# Debian and Ubuntu versions are the same - stop.
|
||||
if deb_version == cur_ver:
|
||||
print 'The versions in Debian and Ubuntu are the same already (%s). Aborting.' % (deb_version,)
|
||||
sys.exit(1)
|
||||
|
||||
# -s flag not specified - check if we do need sponsorship.
|
||||
if (not sponsorship):
|
||||
# -s flag not specified - check if we do need sponsorship.
|
||||
if (not sponsorship):
|
||||
if (not newsource):
|
||||
sponsorship = needsSponsorship(srcpkg, component)
|
||||
else:
|
||||
sponsorship = not PersonTeam.getMe().isLpTeamMember('motu') # assume going to universe
|
||||
|
||||
# Check for existing package reports.
|
||||
if (not newsource) and use_lp_bugs: checkExistingReports(srcpkg)
|
||||
# Check for existing package reports.
|
||||
if (not newsource) and use_lp_bugs: checkExistingReports(srcpkg)
|
||||
|
||||
# Generate bug report.
|
||||
subscribe = 'ubuntu-archive'
|
||||
status = 'confirmed'
|
||||
if sponsorship == True:
|
||||
status = 'new'
|
||||
if component in ['main', 'restricted']:
|
||||
subscribe = 'ubuntu-main-sponsors'
|
||||
else:
|
||||
subscribe = 'ubuntu-universe-sponsors'
|
||||
if ffe == True:
|
||||
status = 'new'
|
||||
if component in ['main', 'restricted']:
|
||||
subscribe = 'ubuntu-release'
|
||||
else:
|
||||
subscribe = 'motu-release'
|
||||
# Generate bug report.
|
||||
subscribe = 'ubuntu-archive'
|
||||
status = 'confirmed'
|
||||
if sponsorship == True:
|
||||
status = 'new'
|
||||
if component in ['main', 'restricted']:
|
||||
subscribe = 'ubuntu-main-sponsors'
|
||||
else:
|
||||
subscribe = 'ubuntu-universe-sponsors'
|
||||
if ffe == True:
|
||||
status = 'new'
|
||||
if component in ['main', 'restricted']:
|
||||
subscribe = 'ubuntu-release'
|
||||
else:
|
||||
subscribe = 'motu-release'
|
||||
|
||||
pkg_to_sync = '%s %s (%s) from Debian %s (%s)' % (srcpkg, deb_version, component, distro, debiancomponent)
|
||||
title = "Sync %s" % pkg_to_sync
|
||||
if ffe == True:
|
||||
title = "FFe: " + title
|
||||
report = "Please sync %s\n\n" % pkg_to_sync
|
||||
|
||||
pkg_to_sync = '%s %s (%s) from Debian %s (%s)' % (srcpkg, deb_version, component, distro, debiancomponent)
|
||||
title = "Sync %s" % pkg_to_sync
|
||||
if ffe == True:
|
||||
title = "FFe: " + title
|
||||
report = "Please sync %s\n\n" % pkg_to_sync
|
||||
|
||||
base_ver = cur_ver
|
||||
uidx = base_ver.find('ubuntu')
|
||||
if uidx > 0:
|
||||
base_ver = base_ver[:uidx]
|
||||
need_interaction = True
|
||||
base_ver = cur_ver
|
||||
uidx = base_ver.find('ubuntu')
|
||||
if uidx > 0:
|
||||
base_ver = base_ver[:uidx]
|
||||
need_interaction = True
|
||||
|
||||
print 'Changes have been made to the package in Ubuntu.'
|
||||
print 'Please edit the report and give an explanation.'
|
||||
print 'Press ENTER to start your editor. Press Control-C to abort now.'
|
||||
print 'Not saving the report file will abort the request, too.'
|
||||
raw_input_exit_on_ctrlc()
|
||||
report += 'Explanation of the Ubuntu delta and why it can be dropped:\n' + \
|
||||
'>>> ENTER_EXPLANATION_HERE <<<\n\n'
|
||||
print 'Changes have been made to the package in Ubuntu.'
|
||||
print 'Please edit the report and give an explanation.'
|
||||
print 'Press ENTER to start your editor. Press Control-C to abort now.'
|
||||
print 'Not saving the report file will abort the request, too.'
|
||||
raw_input_exit_on_ctrlc()
|
||||
report += 'Explanation of the Ubuntu delta and why it can be dropped:\n' + \
|
||||
'>>> ENTER_EXPLANATION_HERE <<<\n\n'
|
||||
|
||||
if ffe == True:
|
||||
need_interaction = True
|
||||
if ffe == True:
|
||||
need_interaction = True
|
||||
|
||||
print 'To approve FeatureFreeze exception, you need to state '
|
||||
print 'the reason why you feel it is necessary.'
|
||||
print 'Press ENTER to start your editor. Press Control-C to abort now.'
|
||||
print 'Not saving the report file will abort the request, too.'
|
||||
raw_input_exit_on_ctrlc()
|
||||
report += 'Explanation of FeatureFreeze exception:\n' + \
|
||||
'>>> ENTER_EXPLANATION_HERE <<<\n\n'
|
||||
print 'To approve FeatureFreeze exception, you need to state '
|
||||
print 'the reason why you feel it is necessary.'
|
||||
print 'Press ENTER to start your editor. Press Control-C to abort now.'
|
||||
print 'Not saving the report file will abort the request, too.'
|
||||
raw_input_exit_on_ctrlc()
|
||||
report += 'Explanation of FeatureFreeze exception:\n' + \
|
||||
'>>> ENTER_EXPLANATION_HERE <<<\n\n'
|
||||
|
||||
# Check if they have a per-package upload permission.
|
||||
if LpApiWrapper.isPerPackageUploader(srcpkg):
|
||||
report += 'Note that I have per-package upload permissions for %s.\n\n' % srcpkg
|
||||
|
||||
# Check if they have a per-package upload permission.
|
||||
if LpApiWrapper.isPerPackageUploader(srcpkg):
|
||||
report += 'Note that I have per-package upload permissions for %s.\n\n' % srcpkg
|
||||
uidx = base_ver.find('build')
|
||||
if uidx > 0:
|
||||
base_ver = base_ver[:uidx]
|
||||
|
||||
uidx = base_ver.find('build')
|
||||
if uidx > 0:
|
||||
base_ver = base_ver[:uidx]
|
||||
if force_base_ver:
|
||||
base_ver = force_base_ver
|
||||
|
||||
if force_base_ver:
|
||||
base_ver = force_base_ver
|
||||
if not newsource: report += 'Changelog since current %s version %s:\n\n' % (release, cur_ver)
|
||||
changelog = getDebianChangelog(debsrcpkg, Version(base_ver))
|
||||
if not changelog:
|
||||
sys.exit(1)
|
||||
report += changelog + '\n'
|
||||
|
||||
if not newsource: report += 'Changelog since current %s version %s:\n\n' % (release, cur_ver)
|
||||
changelog = getDebianChangelog(debsrcpkg, Version(base_ver))
|
||||
if not changelog:
|
||||
sys.exit(1)
|
||||
report += changelog + '\n'
|
||||
(title, report) = edit_report(title, report, changes_required = need_interaction)
|
||||
|
||||
(title, report) = edit_report(title, report, changes_required = need_interaction)
|
||||
|
||||
# Post sync request using Launchpad interface:
|
||||
srcpkg = not newsource and srcpkg or None
|
||||
if use_lp_bugs:
|
||||
# Map status to the values expected by lp-bugs
|
||||
mapping = {'new': 'New', 'confirmed': 'Confirmed'}
|
||||
if postBug(srcpkg, subscribe, mapping[status], title, report):
|
||||
sys.exit(0)
|
||||
# Abort on error:
|
||||
print 'Something went wrong. No sync request filed.'
|
||||
sys.exit(1)
|
||||
|
||||
# Mail sync request:
|
||||
if mailBug(srcpkg, subscribe, status, title, report, keyid):
|
||||
sys.exit(0)
|
||||
|
||||
print 'Something went wrong. No sync request filed.'
|
||||
sys.exit(1)
|
||||
# Post sync request using Launchpad interface:
|
||||
srcpkg = not newsource and srcpkg or None
|
||||
if options.lpapi:
|
||||
# Map status to the values expected by lp-bugs
|
||||
mapping = {'new': 'New', 'confirmed': 'Confirmed'}
|
||||
postBug(srcpkg, subscribe, mapping[status], title, report)
|
||||
else:
|
||||
# Mail sync request:
|
||||
mailBug(srcpkg, subscribe, status, title, report, keyid)
|
||||
|
Loading…
x
Reference in New Issue
Block a user