From 66a8983a5dfa1719ba824ff8ed81aefa8e58fdaa Mon Sep 17 00:00:00 2001 From: Mattia Rizzolo Date: Sun, 21 Jun 2015 13:54:47 +0000 Subject: reproducible: scheduler: accept an -i option to schedule all package affected by a given issue. Also allow passing 0 package to the script --- bin/reproducible_remote_scheduler.py | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) (limited to 'bin') diff --git a/bin/reproducible_remote_scheduler.py b/bin/reproducible_remote_scheduler.py index db4bce4f..580d6882 100755 --- a/bin/reproducible_remote_scheduler.py +++ b/bin/reproducible_remote_scheduler.py @@ -28,7 +28,9 @@ parser.add_argument('-m', '--message', default='', nargs='+', ' about the scheduling') parser.add_argument('-s', '--suite', required=True, help='Specify the suite to schedule in') -parser.add_argument('packages', metavar='package', nargs='+', +parser.add_argument('-i', '--issue', required=False, + help='Schedule all packages with this issue(s)') +parser.add_argument('packages', metavar='package', nargs='*', help='list of packages to reschedule') scheduling_args = parser.parse_known_args()[0] @@ -64,6 +66,7 @@ except KeyError: suite = scheduling_args.suite reason = ' '.join(scheduling_args.message) +issue = scheduling_args.issue packages = scheduling_args.packages artifacts = scheduling_args.artifacts notify = not scheduling_args.no_notify or scheduling_args.noisy @@ -76,6 +79,7 @@ log.debug('Artifacts: ' + str(artifacts)) log.debug('Notify: ' + str(notify)) log.debug('Debug url: ' + str(debug_url)) log.debug('Architecture: ' + defaultarch) +log.debug('Issue: ' + issue if issue else str(None)) log.debug('Suite: ' + suite) log.debug('Packages: ' + ' '.join(packages)) @@ -84,6 +88,16 @@ if suite not in SUITES: log.critical('Please chose between ' + ', '.join(SUITES)) sys.exit(1) +if issue: + log.info('Querying packages with given issues in the given suite...') + query = 'SELECT s.name ' + \ + 'FROM sources AS s JOIN notes AS n ON n.package_id=s.id ' + \ + 'WHERE n.issues like "%{issue}%" and s.suite = "{suite}"' + results = query_db(query.format(issue=issue, suite=suite)) + results = [x for (x,) in results] + log.info('Selected packages: ' + ' '.join(results)) + packages.extend(results) + if len(packages) > 50 and notify: log.critical(bcolors.RED + bcolors.BOLD) call(['figlet', 'No.']) -- cgit v1.2.3-70-g09d2