election/openstack_election/cmds/check_all_candidacies.py
Tony Breeds 6f4af2b46f Add --limit to check_all_candidacies
The default of only showing one validating commit/change is great for
the first official.  For the 2nd or later official it's hard to find unique
commits to validate.

Add the --limit option to make this easier.

Change-Id: I37a04a16877ecebaf763b72bb040755082241bec
2016-09-13 14:41:38 +10:00

69 lines
2.6 KiB
Python
Executable File

# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
from __future__ import absolute_import
from __future__ import print_function
from __future__ import unicode_literals
import argparse
from openstack_election import check_candidacy
from openstack_election import utils
def get_reviews():
return utils.get_reviews('is:open project:%s file:^%s/%s/.*' %
(utils.ELECTION_REPO, utils.CANDIDATE_PATH,
utils.SERIES_NAME))
def main():
description = ('Check if the owner of open changes are valid candidates as'
' described in the change')
parser = argparse.ArgumentParser(description)
parser.add_argument('--limit', dest='limit', type=int, default=1,
help=('How many validating changes to report. '
'A negative value means report many. '
'Default: %(default)s'))
parser.add_argument('--tag', dest='tag', default=utils.PROJECTS_TAG,
help=('The governance tag to validate against. '
'Default: %(default)s'))
args = parser.parse_args()
for review in get_reviews():
if review['status'] != 'NEW':
continue
print('Checking %s/%d' %
(utils.GERRIT_BASE, review['_number']))
if not len(utils.candidate_files(review)):
print("[E] No candidacy added")
continue
owner = review.get('owner', {})
try:
found = check_candidacy.check_candidacy_review(review['change_id'],
tag=args.tag,
limit=args.limit,
review=review)
except Exception as exc:
print("[E] %s\n\n" % (exc))
else:
if found:
print('SUCESS: %s is a valid candidate\n\n' %
(owner['email']))
else:
print('[E]: %s is not a valid candidate\n\n' %
(owner['email']))
return 0