qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Robert Foley <robert.foley@linaro.org>
To: "Alex Bennée" <alex.bennee@linaro.org>
Cc: "Fam Zheng" <fam@euphon.net>,
	"Daniel P. Berrangé" <berrange@redhat.com>,
	"Richard Henderson" <richard.henderson@linaro.org>,
	"QEMU Developers" <qemu-devel@nongnu.org>,
	f4bug@amsat.org, "Emilio G. Cota" <cota@braap.org>,
	"Philippe Mathieu-Daudé" <philmd@redhat.com>,
	"Aurelien Jarno" <aurelien@aurel32.net>
Subject: Re: [PATCH v1 11/18] tests/vm: switch from optsparse to argparse
Date: Mon, 22 Jun 2020 13:11:55 -0400	[thread overview]
Message-ID: <CAEyhzFu3mY2rksON5wiJPY0x5aFGP3x0W+zhudC-ZmbKN427RA@mail.gmail.com> (raw)
In-Reply-To: <20200622143204.12921-12-alex.bennee@linaro.org>

Reviewed-by: Robert Foley <robert.foley@linaro.org>

On Mon, 22 Jun 2020 at 10:41, Alex Bennée <alex.bennee@linaro.org> wrote:
>
> optparse has been deprecated since version 3.2 and argparse is the
> blessed replacement. Take the opportunity to enhance our help output
> showing defaults when called.
>
> Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
> ---
>  tests/vm/basevm.py | 84 +++++++++++++++++++++++-----------------------
>  1 file changed, 42 insertions(+), 42 deletions(-)
>
> diff --git a/tests/vm/basevm.py b/tests/vm/basevm.py
> index 04d083409a5..93859362606 100644
> --- a/tests/vm/basevm.py
> +++ b/tests/vm/basevm.py
> @@ -23,7 +23,7 @@ from qemu.accel import kvm_available
>  from qemu.machine import QEMUMachine
>  import subprocess
>  import hashlib
> -import optparse
> +import argparse
>  import atexit
>  import tempfile
>  import shutil
> @@ -556,47 +556,47 @@ def parse_args(vmcls):
>          else:
>              return 1
>
> -    parser = optparse.OptionParser(
> -        description="VM test utility.  Exit codes: "
> -                    "0 = success, "
> -                    "1 = command line error, "
> -                    "2 = environment initialization failed, "
> -                    "3 = test command failed")
> -    parser.add_option("--debug", "-D", action="store_true",
> -                      help="enable debug output")
> -    parser.add_option("--image", "-i", default="%s.img" % vmcls.name,
> -                      help="image file name")
> -    parser.add_option("--force", "-f", action="store_true",
> -                      help="force build image even if image exists")
> -    parser.add_option("--jobs", type=int, default=get_default_jobs(),
> -                      help="number of virtual CPUs")
> -    parser.add_option("--verbose", "-V", action="store_true",
> -                      help="Pass V=1 to builds within the guest")
> -    parser.add_option("--build-image", "-b", action="store_true",
> -                      help="build image")
> -    parser.add_option("--build-qemu",
> -                      help="build QEMU from source in guest")
> -    parser.add_option("--build-target",
> -                      help="QEMU build target", default="check")
> -    parser.add_option("--build-path", default=None,
> -                      help="Path of build directory, "\
> -                           "for using build tree QEMU binary. ")
> -    parser.add_option("--interactive", "-I", action="store_true",
> -                      help="Interactively run command")
> -    parser.add_option("--snapshot", "-s", action="store_true",
> -                      help="run tests with a snapshot")
> -    parser.add_option("--genisoimage", default="genisoimage",
> -                      help="iso imaging tool")
> -    parser.add_option("--config", "-c", default=None,
> -                      help="Provide config yaml for configuration. "\
> -                           "See config_example.yaml for example.")
> -    parser.add_option("--efi-aarch64",
> -                      default="/usr/share/qemu-efi-aarch64/QEMU_EFI.fd",
> -                      help="Path to efi image for aarch64 VMs.")
> -    parser.add_option("--log-console", action="store_true",
> -                      help="Log console to file.")
> -    parser.disable_interspersed_args()
> -    return parser.parse_args()
> +    parser = argparse.ArgumentParser(
> +        formatter_class=argparse.ArgumentDefaultsHelpFormatter,
> +        description="Utility for provisioning VMs and running builds",
> +        epilog="""Remaining arguments are passed to the command.
> +        Exit codes: 0 = success, 1 = command line error,
> +        2 = environment initialization failed,
> +        3 = test command failed""")
> +    parser.add_argument("--debug", "-D", action="store_true",
> +                        help="enable debug output")
> +    parser.add_argument("--image", "-i", default="%s.img" % vmcls.name,
> +                        help="image file name")
> +    parser.add_argument("--force", "-f", action="store_true",
> +                        help="force build image even if image exists")
> +    parser.add_argument("--jobs", type=int, default=get_default_jobs(),
> +                        help="number of virtual CPUs")
> +    parser.add_argument("--verbose", "-V", action="store_true",
> +                        help="Pass V=1 to builds within the guest")
> +    parser.add_argument("--build-image", "-b", action="store_true",
> +                        help="build image")
> +    parser.add_argument("--build-qemu",
> +                        help="build QEMU from source in guest")
> +    parser.add_argument("--build-target",
> +                        help="QEMU build target", default="check")
> +    parser.add_argument("--build-path", default=None,
> +                        help="Path of build directory, "\
> +                        "for using build tree QEMU binary. ")
> +    parser.add_argument("--interactive", "-I", action="store_true",
> +                        help="Interactively run command")
> +    parser.add_argument("--snapshot", "-s", action="store_true",
> +                        help="run tests with a snapshot")
> +    parser.add_argument("--genisoimage", default="genisoimage",
> +                        help="iso imaging tool")
> +    parser.add_argument("--config", "-c", default=None,
> +                        help="Provide config yaml for configuration. "\
> +                        "See config_example.yaml for example.")
> +    parser.add_argument("--efi-aarch64",
> +                        default="/usr/share/qemu-efi-aarch64/QEMU_EFI.fd",
> +                        help="Path to efi image for aarch64 VMs.")
> +    parser.add_argument("--log-console", action="store_true",
> +                        help="Log console to file.")
> +    return parser.parse_known_args()
>
>  def main(vmcls, config=None):
>      try:
> --
> 2.20.1
>
>


  reply	other threads:[~2020-06-22 17:12 UTC|newest]

Thread overview: 33+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-06-22 14:31 [PATCH v1 00/18] testing/next (vm, gitlab) Alex Bennée
2020-06-22 14:31 ` [PATCH v1 01/18] iotests: Fix 051 output after qdev_init_nofail() removal Alex Bennée
2020-06-22 17:52   ` John Snow
2020-06-22 17:57     ` Philippe Mathieu-Daudé
2020-06-22 18:23     ` Alex Bennée
2020-06-22 14:31 ` [PATCH v1 02/18] tests/vm: pass args through to BaseVM's __init__ Alex Bennée
2020-06-22 14:31 ` [PATCH v1 03/18] tests/vm: Add configuration to basevm.py Alex Bennée
2020-06-22 14:31 ` [PATCH v1 04/18] tests/vm: Added configuration file support Alex Bennée
2020-06-22 14:31 ` [PATCH v1 05/18] tests/vm: Add common Ubuntu python module Alex Bennée
2020-06-22 14:31 ` [PATCH v1 06/18] tests/vm: Added a new script for ubuntu.aarch64 Alex Bennée
2020-06-22 14:31 ` [PATCH v1 07/18] tests/vm: Added a new script for centos.aarch64 Alex Bennée
2020-06-22 14:31 ` [PATCH v1 08/18] tests/vm: change scripts to use self._config Alex Bennée
2020-06-22 14:31 ` [PATCH v1 09/18] python/qemu: Add ConsoleSocket for optional use in QEMUMachine Alex Bennée
2020-06-22 14:31 ` [PATCH v1 10/18] tests/vm: Add workaround to consume console Alex Bennée
2020-06-22 14:31 ` [PATCH v1 11/18] tests/vm: switch from optsparse to argparse Alex Bennée
2020-06-22 17:11   ` Robert Foley [this message]
2020-06-22 17:20   ` Daniel P. Berrangé
2020-06-22 14:31 ` [PATCH v1 12/18] tests/vm: allow us to take advantage of MTTCG Alex Bennée
2020-06-22 14:52   ` Robert Foley
2020-06-26 18:30   ` Richard Henderson
2020-06-26 19:37     ` Alex Bennée
2020-06-29 14:41     ` Alex Bennée
2020-06-29 14:45       ` Philippe Mathieu-Daudé
2020-06-22 14:31 ` [PATCH v1 13/18] tests/docker: check for an parameters not empty string Alex Bennée
2020-06-22 14:46   ` Philippe Mathieu-Daudé
2020-06-29 16:15   ` Eric Blake
2020-06-22 14:32 ` [PATCH v1 14/18] .gitignore: un-ignore .gitlab-ci.d Alex Bennée
2020-06-22 16:29   ` Daniel P. Berrangé
2020-06-22 14:32 ` [PATCH v1 15/18] .gitlab: add acceptance testing to system builds Alex Bennée
2020-06-22 14:32 ` [PATCH v1 16/18] .gitlab: split fedora-misc-disabled Alex Bennée
2020-06-22 14:32 ` [PATCH v1 17/18] .gitlab: tag remaining jobs as builds Alex Bennée
2020-06-22 14:32 ` [PATCH v1 18/18] .gitlab: add avocado asset caching Alex Bennée
2020-06-22 14:45   ` Philippe Mathieu-Daudé

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=CAEyhzFu3mY2rksON5wiJPY0x5aFGP3x0W+zhudC-ZmbKN427RA@mail.gmail.com \
    --to=robert.foley@linaro.org \
    --cc=alex.bennee@linaro.org \
    --cc=aurelien@aurel32.net \
    --cc=berrange@redhat.com \
    --cc=cota@braap.org \
    --cc=f4bug@amsat.org \
    --cc=fam@euphon.net \
    --cc=philmd@redhat.com \
    --cc=qemu-devel@nongnu.org \
    --cc=richard.henderson@linaro.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).