All of lore.kernel.org
 help / color / mirror / Atom feed
From: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
To: Emanuele Giuseppe Esposito <eesposit@redhat.com>, qemu-block@nongnu.org
Cc: Kevin Wolf <kwolf@redhat.com>,
	Eduardo Habkost <ehabkost@redhat.com>,
	qemu-devel@nongnu.org, Max Reitz <mreitz@redhat.com>,
	Cleber Rosa <crosa@redhat.com>,
	Paolo Bonzini <pbonzini@redhat.com>, John Snow <jsnow@redhat.com>
Subject: Re: [PATCH v4 05/15] qemu-iotests: delay QMP socket timers
Date: Fri, 28 May 2021 20:06:43 +0300	[thread overview]
Message-ID: <5bde3128-e972-3653-308b-4faa4eb52bb6@virtuozzo.com> (raw)
In-Reply-To: <20210520075236.44723-6-eesposit@redhat.com>

20.05.2021 10:52, Emanuele Giuseppe Esposito wrote:
> Attaching gdbserver implies that the qmp socket
> should wait indefinitely for an answer from QEMU.
> 
> Signed-off-by: Emanuele Giuseppe Esposito <eesposit@redhat.com>
> ---
>   tests/qemu-iotests/iotests.py | 10 ++++++----
>   1 file changed, 6 insertions(+), 4 deletions(-)
> 
> diff --git a/tests/qemu-iotests/iotests.py b/tests/qemu-iotests/iotests.py
> index d667fde6f8..cf1ca60376 100644
> --- a/tests/qemu-iotests/iotests.py
> +++ b/tests/qemu-iotests/iotests.py
> @@ -478,11 +478,13 @@ def __init__(self, seconds, errmsg="Timeout"):
>           self.seconds = seconds
>           self.errmsg = errmsg
>       def __enter__(self):
> -        signal.signal(signal.SIGALRM, self.timeout)
> -        signal.setitimer(signal.ITIMER_REAL, self.seconds)
> +        if not qemu_gdb:
> +            signal.signal(signal.SIGALRM, self.timeout)
> +            signal.setitimer(signal.ITIMER_REAL, self.seconds)
>           return self
>       def __exit__(self, exc_type, value, traceback):
> -        signal.setitimer(signal.ITIMER_REAL, 0)
> +        if not qemu_gdb:
> +            signal.setitimer(signal.ITIMER_REAL, 0)
>           return False
>       def timeout(self, signum, frame):
>           raise Exception(self.errmsg)

So, you just make the class do nothing.. I'd prefer something like this:

@contextmanager
def NoTimeout:
    yield

if qemu_gdb:
   Timeout = NoTimeout


anyway:

Reviewed-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>


> @@ -576,7 +578,7 @@ class VM(qtest.QEMUQtestMachine):
>   
>       def __init__(self, path_suffix=''):
>           name = "qemu%s-%d" % (path_suffix, os.getpid())
> -        timer = 15.0
> +        timer = 15.0 if not qemu_gdb else None
>           super().__init__(qemu_prog, qemu_opts, name=name,
>                            test_dir=test_dir,
>                            socket_scm_helper=socket_scm_helper,
> 


Still, it's not simple to avoid any kind of timeouts. The most annoying would be timeouts in event_wait() / events_wait()

-- 
Best regards,
Vladimir


  reply	other threads:[~2021-05-28 17:07 UTC|newest]

Thread overview: 50+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-05-20  7:52 [PATCH v4 00/15] qemu_iotests: improve debugging options Emanuele Giuseppe Esposito
2021-05-20  7:52 ` [PATCH v4 01/15] python: qemu: add timer parameter for qmp.accept socket Emanuele Giuseppe Esposito
2021-05-26 11:13   ` Vladimir Sementsov-Ogievskiy
2021-06-02 23:23   ` John Snow
2021-06-03  8:06     ` Emanuele Giuseppe Esposito
2021-06-03 19:02       ` John Snow
2021-06-04  8:48         ` Emanuele Giuseppe Esposito
2021-05-20  7:52 ` [PATCH v4 02/15] python: qemu: pass the wrapper field from QEMUQtestmachine to QEMUMachine Emanuele Giuseppe Esposito
2021-05-26 11:16   ` Vladimir Sementsov-Ogievskiy
2021-05-20  7:52 ` [PATCH v4 03/15] docs/devel/testing: add debug section to the QEMU iotests chapter Emanuele Giuseppe Esposito
2021-05-26 11:18   ` Vladimir Sementsov-Ogievskiy
2021-05-20  7:52 ` [PATCH v4 04/15] qemu-iotests: add option to attach gdbserver Emanuele Giuseppe Esposito
2021-05-26 11:24   ` Vladimir Sementsov-Ogievskiy
2021-05-26 12:48     ` Paolo Bonzini
2021-05-26 13:25       ` Vladimir Sementsov-Ogievskiy
2021-05-26 17:23         ` Emanuele Giuseppe Esposito
2021-05-26 19:15   ` Vladimir Sementsov-Ogievskiy
2021-05-27 11:06     ` Emanuele Giuseppe Esposito
2021-05-27 12:17       ` Vladimir Sementsov-Ogievskiy
2021-05-28 16:26   ` Vladimir Sementsov-Ogievskiy
2021-05-20  7:52 ` [PATCH v4 05/15] qemu-iotests: delay QMP socket timers Emanuele Giuseppe Esposito
2021-05-28 17:06   ` Vladimir Sementsov-Ogievskiy [this message]
2021-06-03 11:03     ` Emanuele Giuseppe Esposito
2021-06-03 12:25       ` Vladimir Sementsov-Ogievskiy
2021-06-03 12:52         ` Emanuele Giuseppe Esposito
2021-05-20  7:52 ` [PATCH v4 06/15] qemu_iotests: insert gdbserver command line as wrapper for qemu binary Emanuele Giuseppe Esposito
2021-05-28 17:07   ` Vladimir Sementsov-Ogievskiy
2021-05-20  7:52 ` [PATCH v4 07/15] qemu-iotests: add gdbserver option to script tests too Emanuele Giuseppe Esposito
2021-05-28 17:09   ` Vladimir Sementsov-Ogievskiy
2021-05-20  7:52 ` [PATCH v4 08/15] docs/devel/testing: add -gdb option to the debugging section of QEMU iotests Emanuele Giuseppe Esposito
2021-05-28 17:16   ` Vladimir Sementsov-Ogievskiy
2021-05-28 20:31     ` Emanuele Giuseppe Esposito
2021-05-20  7:52 ` [PATCH v4 09/15] qemu-iotests: extend the check script to support valgrind for python tests Emanuele Giuseppe Esposito
2021-05-28 17:24   ` Vladimir Sementsov-Ogievskiy
2021-05-28 20:31     ` Emanuele Giuseppe Esposito
2021-05-20  7:52 ` [PATCH v4 10/15] qemu-iotests: extent QMP socket timeout when using valgrind Emanuele Giuseppe Esposito
2021-05-28 17:27   ` Vladimir Sementsov-Ogievskiy
2021-05-20  7:52 ` [PATCH v4 11/15] qemu-iotests: allow valgrind to read/delete the generated log file Emanuele Giuseppe Esposito
2021-05-28 17:39   ` Vladimir Sementsov-Ogievskiy
2021-05-20  7:52 ` [PATCH v4 12/15] qemu-iotests: insert valgrind command line as wrapper for qemu binary Emanuele Giuseppe Esposito
2021-05-28 17:41   ` Vladimir Sementsov-Ogievskiy
2021-05-20  7:52 ` [PATCH v4 13/15] docs/devel/testing: add -valgrind option to the debug section of QEMU iotests Emanuele Giuseppe Esposito
2021-05-28 17:42   ` Vladimir Sementsov-Ogievskiy
2021-05-20  7:52 ` [PATCH v4 14/15] qemu-iotests: add option to show qemu binary logs on stdout Emanuele Giuseppe Esposito
2021-05-28 17:52   ` Vladimir Sementsov-Ogievskiy
2021-05-28 20:32     ` Emanuele Giuseppe Esposito
2021-05-20  7:52 ` [PATCH v4 15/15] docs/devel/testing: add -p option to the debug section of QEMU iotests Emanuele Giuseppe Esposito
2021-05-28 17:53   ` Vladimir Sementsov-Ogievskiy
2021-05-26 11:32 ` [PATCH v4 00/15] qemu_iotests: improve debugging options Vladimir Sementsov-Ogievskiy
2021-05-26 17:18   ` Emanuele Giuseppe Esposito

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=5bde3128-e972-3653-308b-4faa4eb52bb6@virtuozzo.com \
    --to=vsementsov@virtuozzo.com \
    --cc=crosa@redhat.com \
    --cc=eesposit@redhat.com \
    --cc=ehabkost@redhat.com \
    --cc=jsnow@redhat.com \
    --cc=kwolf@redhat.com \
    --cc=mreitz@redhat.com \
    --cc=pbonzini@redhat.com \
    --cc=qemu-block@nongnu.org \
    --cc=qemu-devel@nongnu.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.