Merge "Output subcommand help on argument errors"

This commit is contained in:
Zuul 2021-03-10 22:31:57 +00:00 committed by Gerrit Code Review
commit 2a433d9404

View File

@ -97,10 +97,10 @@ class ZuulClient():
return subparsers return subparsers
def parseArguments(self, args=None): def parseArguments(self, args=None):
parser = self.createParser() self.parser = self.createParser()
self.args = parser.parse_args(args) self.args = self.parser.parse_args(args)
if not getattr(self.args, 'func', None): if not getattr(self.args, 'func', None):
parser.print_help() self.parser.print_help()
sys.exit(1) sys.exit(1)
if self.args.func == self.enqueue_ref: if self.args.func == self.enqueue_ref:
# if oldrev or newrev is set, ensure they're not the same # if oldrev or newrev is set, ensure they're not the same
@ -144,12 +144,23 @@ class ZuulClient():
logging.basicConfig(level=logging.DEBUG) logging.basicConfig(level=logging.DEBUG)
def _main(self, args=None): def _main(self, args=None):
# TODO make func return specific return codes
try:
self.parseArguments(args) self.parseArguments(args)
if not self.args.zuul_url: if not self.args.zuul_url:
self.readConfig() self.readConfig()
self.setup_logging() self.setup_logging()
# TODO make func return specific return codes ret = self.args.func()
if self.args.func(): except ArgumentException:
if self.args.func:
name = self.args.func.__name__
parser = getattr(self, 'cmd_' + name, self.parser)
else:
parser = self.parser
parser.print_help()
print()
raise
if ret:
return 0 return 0
else: else:
return 1 return 1
@ -199,6 +210,7 @@ class ZuulClient():
'(default: scheduler\'s default_hold_expiration value)'), '(default: scheduler\'s default_hold_expiration value)'),
required=False, type=int) required=False, type=int)
cmd_autohold.set_defaults(func=self.autohold) cmd_autohold.set_defaults(func=self.autohold)
self.cmd_autohold = cmd_autohold
def autohold(self): def autohold(self):
if self.args.change and self.args.ref: if self.args.change and self.args.ref:
@ -229,6 +241,7 @@ class ZuulClient():
required=False, default='') required=False, default='')
cmd_autohold_delete.add_argument('id', metavar='REQUEST_ID', cmd_autohold_delete.add_argument('id', metavar='REQUEST_ID',
help='the hold request ID') help='the hold request ID')
self.cmd_autohold_delete = cmd_autohold_delete
def autohold_delete(self): def autohold_delete(self):
client = self.get_client() client = self.get_client()
@ -243,6 +256,7 @@ class ZuulClient():
required=False, default='') required=False, default='')
cmd_autohold_info.add_argument('id', metavar='REQUEST_ID', cmd_autohold_info.add_argument('id', metavar='REQUEST_ID',
help='the hold request ID') help='the hold request ID')
self.cmd_autohold_info = cmd_autohold_info
def autohold_info(self): def autohold_info(self):
client = self.get_client() client = self.get_client()
@ -273,6 +287,7 @@ class ZuulClient():
cmd_autohold_list.add_argument('--tenant', help='tenant name', cmd_autohold_list.add_argument('--tenant', help='tenant name',
required=False, default='') required=False, default='')
cmd_autohold_list.set_defaults(func=self.autohold_list) cmd_autohold_list.set_defaults(func=self.autohold_list)
self.cmd_autohold_list = cmd_autohold_list
def autohold_list(self): def autohold_list(self):
client = self.get_client() client = self.get_client()
@ -314,6 +329,7 @@ class ZuulClient():
cmd_enqueue.add_argument('--change', help='change id', cmd_enqueue.add_argument('--change', help='change id',
required=True) required=True)
cmd_enqueue.set_defaults(func=self.enqueue) cmd_enqueue.set_defaults(func=self.enqueue)
self.cmd_enqueue = cmd_enqueue
def enqueue(self): def enqueue(self):
client = self.get_client() client = self.get_client()
@ -326,7 +342,7 @@ class ZuulClient():
return r return r
def add_enqueue_ref_subparser(self, subparsers): def add_enqueue_ref_subparser(self, subparsers):
cmd_enqueue = subparsers.add_parser( cmd_enqueue_ref = subparsers.add_parser(
'enqueue-ref', help='enqueue a ref', 'enqueue-ref', help='enqueue a ref',
formatter_class=argparse.RawDescriptionHelpFormatter, formatter_class=argparse.RawDescriptionHelpFormatter,
description=textwrap.dedent('''\ description=textwrap.dedent('''\
@ -335,19 +351,20 @@ class ZuulClient():
Directly enqueue a trigger event. This is usually used Directly enqueue a trigger event. This is usually used
to manually "replay" a trigger received from an external to manually "replay" a trigger received from an external
source such as gerrit.''')) source such as gerrit.'''))
cmd_enqueue.add_argument('--tenant', help='tenant name', cmd_enqueue_ref.add_argument('--tenant', help='tenant name',
required=False, default='') required=False, default='')
cmd_enqueue.add_argument('--pipeline', help='pipeline name', cmd_enqueue_ref.add_argument('--pipeline', help='pipeline name',
required=True) required=True)
cmd_enqueue.add_argument('--project', help='project name', cmd_enqueue_ref.add_argument('--project', help='project name',
required=True) required=True)
cmd_enqueue.add_argument('--ref', help='ref name', cmd_enqueue_ref.add_argument('--ref', help='ref name',
required=True) required=True)
cmd_enqueue.add_argument( cmd_enqueue_ref.add_argument(
'--oldrev', help='old revision', default=None) '--oldrev', help='old revision', default=None)
cmd_enqueue.add_argument( cmd_enqueue_ref.add_argument(
'--newrev', help='new revision', default=None) '--newrev', help='new revision', default=None)
cmd_enqueue.set_defaults(func=self.enqueue_ref) cmd_enqueue_ref.set_defaults(func=self.enqueue_ref)
self.cmd_enqueue_ref = cmd_enqueue_ref
def enqueue_ref(self): def enqueue_ref(self):
client = self.get_client() client = self.get_client()
@ -376,6 +393,7 @@ class ZuulClient():
cmd_dequeue.add_argument('--ref', help='ref name', cmd_dequeue.add_argument('--ref', help='ref name',
default=None) default=None)
cmd_dequeue.set_defaults(func=self.dequeue) cmd_dequeue.set_defaults(func=self.dequeue)
self.cmd_dequeue = cmd_dequeue
def dequeue(self): def dequeue(self):
client = self.get_client() client = self.get_client()
@ -398,6 +416,7 @@ class ZuulClient():
cmd_promote.add_argument('--changes', help='change ids', cmd_promote.add_argument('--changes', help='change ids',
required=True, nargs='+') required=True, nargs='+')
cmd_promote.set_defaults(func=self.promote) cmd_promote.set_defaults(func=self.promote)
self.cmd_promote = cmd_promote
def promote(self): def promote(self):
client = self.get_client() client = self.get_client()
@ -485,6 +504,7 @@ class ZuulClient():
'supplied, the value will be written ' 'supplied, the value will be written '
'to standard output.') 'to standard output.')
cmd_encrypt.set_defaults(func=self.encrypt) cmd_encrypt.set_defaults(func=self.encrypt)
self.cmd_encrypt = cmd_encrypt
def encrypt(self): def encrypt(self):
if self.args.project is None and self.args.public_key is None: if self.args.project is None and self.args.public_key is None: