a3ac4a90f8
If we run the tools (create-directories or check-all-candidacies) under python3 they'll fail with silly errors (like[1]). This is because we have a number of assumptions they we'll be running under python2 like: - pickle.protocol: we done specify one so if we write a pickle file from python3 we can't read it in python2. - urllib and urlparse: those modules change paths in python 2 or 3 so use the six helpers to get the bits we want. - Explicitly write files in binary format - Various str vs bytes issues - dict().keys() returns dict_keys under python3 explictly cast that to list() After addressing these issues we can run the tools under either python2 or python3. To make this easy to check create explicit ven2 and venv3 test environments, leaving all other testenvs to use the system default. [1] http://paste.openstack.org/show/593823/ Change-Id: I20334a52500847c810b486c9c8b108e75a5d6303
57 lines
2.3 KiB
Python
57 lines
2.3 KiB
Python
# 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 main():
|
|
description = ('Check thath the email address is a valid candidate for '
|
|
' the specified project')
|
|
parser = argparse.ArgumentParser(description)
|
|
parser.add_argument(dest='project_name',
|
|
help=('The Project the candidate is applying for'))
|
|
parser.add_argument(dest='email',
|
|
help=('An email address registered to the candidate'))
|
|
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.conf['tag'],
|
|
help=('The governance tag to validate against. '
|
|
'Default: %(default)s'))
|
|
|
|
args = parser.parse_args()
|
|
if args.limit < 0:
|
|
args.limit = 100
|
|
|
|
projects = utils.get_projects(tag=args.tag)
|
|
projects_list = list(projects.keys())
|
|
if args.project_name not in projects_list:
|
|
print('[E]: %s not found in: %s' %
|
|
(args.project_name, ','.join(projects_list)))
|
|
return 1
|
|
|
|
if check_candidacy.check_candidate(args.project_name, args.email,
|
|
projects, limit=args.limit):
|
|
print('SUCESS: %s is a valid candidate\n\n' % (args.email))
|
|
return 0
|
|
else:
|
|
print('[E]: %s is not a valid candidate\n\n' % (args.email))
|
|
return 1
|