diff options
author | Pawel Hajdan, Jr <phajdan.jr@gentoo.org> | 2017-07-10 22:28:50 +0200 |
---|---|---|
committer | Pawel Hajdan, Jr <phajdan.jr@gentoo.org> | 2017-07-10 22:28:50 +0200 |
commit | 064b7b3dbf4277b9c57add479a478386504fc0d2 (patch) | |
tree | 86ce96e6a71db9cfaccccbca1c1dee90ca9c2881 /stabilization-candidates.py | |
parent | stabilization-candidates: update for git (diff) | |
download | arch-tools-master.tar.gz arch-tools-master.tar.bz2 arch-tools-master.zip |
Diffstat (limited to 'stabilization-candidates.py')
-rwxr-xr-x | stabilization-candidates.py | 26 |
1 files changed, 17 insertions, 9 deletions
diff --git a/stabilization-candidates.py b/stabilization-candidates.py index 2537ab4..0cedac4 100755 --- a/stabilization-candidates.py +++ b/stabilization-candidates.py @@ -7,6 +7,7 @@ import optparse import os.path import random import re +import socket import subprocess import xmlrpc.client @@ -14,7 +15,7 @@ from portage.package.ebuild.getmaskingstatus import getmaskingstatus from portage.xml.metadata import MetaDataXML import portage.versions -from common import login +from common import login, retry if __name__ == "__main__": parser = optparse.OptionParser() @@ -139,19 +140,26 @@ if __name__ == "__main__": continue # Do not risk trying to stabilize a package with known bugs. - params = {} - params['Bugzilla_token'] = login_data['token'] - params['summary'] = cp - bugs = [x for x in bugzilla.Bug.search(params)['bugs'] if x['is_open'] and x['severity'] not in ['enhancement', 'QA']] + @retry(socket.error) + def get_package_bugs(): + params = {} + params['Bugzilla_token'] = login_data['token'] + params['summary'] = cp + return [x for x in bugzilla.Bug.search(params)['bugs'] + if x['is_open'] and x['severity'] not in ['enhancement', 'QA']] + bugs = get_package_bugs() if bugs: print('has bugs') continue # Protection against filing a stabilization bug twice. - params = {} - params['Bugzilla_token'] = login_data['token'] - params['summary'] = best_candidate - bugs = bugzilla.Bug.search(params)['bugs'] + @retry(socket.error) + def get_package_bugs(): + params = {} + params['Bugzilla_token'] = login_data['token'] + params['summary'] = best_candidate + return bugzilla.Bug.search(params)['bugs'] + bugs = get_package_bugs() if bugs: print('version has bugs') continue |