From: Peter Xu <peterx@redhat.com>
To: Eric Blake <eblake@redhat.com>
Cc: qemu-devel@nongnu.org, Stefan Hajnoczi <shajnocz@redhat.com>,
"Daniel P . Berrange" <berrange@redhat.com>,
Paolo Bonzini <pbonzini@redhat.com>, Fam Zheng <famz@redhat.com>,
Juan Quintela <quintela@redhat.com>,
mdroth@linux.vnet.ibm.com, Laurent Vivier <lvivier@redhat.com>,
Markus Armbruster <armbru@redhat.com>,
marcandre.lureau@redhat.com,
"Dr . David Alan Gilbert" <dgilbert@redhat.com>
Subject: Re: [Qemu-devel] [PATCH v8 23/23] tests: qmp-test: add oob test
Date: Mon, 12 Mar 2018 11:56:44 +0800 [thread overview]
Message-ID: <20180312035644.GD5234@xz-mi> (raw)
In-Reply-To: <c4fbae90-a94e-be08-49c8-607d7ec5465c@redhat.com>
On Sat, Mar 10, 2018 at 08:49:42PM -0600, Eric Blake wrote:
> On 03/09/2018 03:00 AM, Peter Xu wrote:
> > Test the new OOB capability. Here we used the new "x-oob-test" command.
> > Firstly, we send a lock=true and oob=false command to hang the main
>
> s/Firstly/First/
>
> > thread. Then send another lock=false and oob=true command (which will
> > be run inside parser this time) to free that hanged command.
> >
> > Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
> > Signed-off-by: Peter Xu <peterx@redhat.com>
> > ---
> > tests/qmp-test.c | 65 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> > 1 file changed, 65 insertions(+)
> >
>
> > + /* Now, enable OOB in current QMP session, it should success. */
>
> s/success/succeed/
>
> > +
> > + /*
> > + * Firstly send the "x-oob-test" command with lock=true and
>
> s/Firstly/First/
>
> > + * oob=false, it should hang the dispatcher and main thread;
> > + * later, we send another lock=false with oob=true to continue
> > + * that thread processing. Finally we should receive replies from
> > + * both commands.
> > + */
> > + qmp_async("{ 'execute': 'x-oob-test',"
> > + " 'arguments': { 'lock': true }, "
> > + " 'id': 'lock-cmd'}");
> > + qmp_async("{ 'execute': 'x-oob-test', "
> > + " 'arguments': { 'lock': false }, "
> > + " 'control': { 'run-oob': true }, "
> > + " 'id': 'unlock-cmd' }");
> > +
> > + /* Ignore all events. Wait for 2 acks */
> > + while (acks < 2) {
> > + resp = qmp_receive();
> > + cmd_id = qdict_get_str(resp, "id");
> > + if (!g_strcmp0(cmd_id, "lock-cmd") ||
> > + !g_strcmp0(cmd_id, "unlock-cmd")) {
> > + acks++;
> > + }
> > + QDECREF(resp);
> > + }
>
> Can you make the reply order deterministic? Perhaps by having the lock
> command insert a sleep after locking but before replying, so that the unlock
> always gets to reply first? But that can be a followup.
Yes, I could. I'm just afraid that sleep might be undeterministic too
in some extreme cases, since IMHO it'll still depend on other things
(e.g., the scheduler of host, resources/workload on the host, etc.) to
make sure the order of the two commands will be exactly what we want.
So, even if current test seems to be undetermistic on the order of
received responses, IMHO it's very good on the other hand that it is
very determinstic on the test result...
>
> Reviewed-by: Eric Blake <eblake@redhat.com>
Thanks,
--
Peter Xu
next prev parent reply other threads:[~2018-03-12 3:57 UTC|newest]
Thread overview: 78+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-03-09 8:59 [Qemu-devel] [PATCH v8 00/23] QMP: out-of-band (OOB) execution support Peter Xu
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 01/23] docs: update QMP documents for OOB commands Peter Xu
2018-03-09 17:13 ` Eric Blake
2018-03-12 3:32 ` Peter Xu
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 02/23] qobject: introduce qstring_get_try_str() Peter Xu
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 03/23] qobject: introduce qobject_get_try_str() Peter Xu
2018-03-09 20:10 ` Eric Blake
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 04/23] qobject: let object_property_get_str() use new API Peter Xu
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 05/23] monitor: move skip_flush into monitor_data_init Peter Xu
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 06/23] monitor: move the cur_mon hack deeper for QMP Peter Xu
2018-03-10 23:13 ` Eric Blake
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 07/23] monitor: unify global init Peter Xu
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 08/23] monitor: let mon_list be tail queue Peter Xu
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 09/23] monitor: allow using IO thread for parsing Peter Xu
2018-03-10 23:19 ` Eric Blake
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 10/23] qmp: introduce QMPCapability Peter Xu
2018-03-11 1:25 ` Eric Blake
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 11/23] monitor: introduce monitor_qmp_respond() Peter Xu
2018-03-11 1:35 ` Eric Blake
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 12/23] monitor: let suspend_cnt be thread safe Peter Xu
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 13/23] monitor: let suspend/resume work even with QMPs Peter Xu
2018-03-11 1:53 ` Eric Blake
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 14/23] monitor: separate QMP parser and dispatcher Peter Xu
2018-03-11 2:00 ` Eric Blake
2018-03-21 18:01 ` Marc-André Lureau
2018-03-21 20:09 ` Dr. David Alan Gilbert
2018-03-21 20:33 ` Eric Blake
2018-03-21 23:32 ` Marc-André Lureau
2018-03-22 5:00 ` Peter Xu
2018-03-22 13:24 ` Eric Blake
2018-03-23 16:18 ` Marc-André Lureau
2018-03-26 8:07 ` Peter Xu
2018-03-26 8:33 ` Marc-André Lureau
2018-03-26 9:08 ` Peter Xu
2018-03-26 9:46 ` Marc-André Lureau
2018-03-28 4:02 ` Peter Xu
2018-04-04 13:58 ` Marc-André Lureau
2018-04-08 3:02 ` Peter Xu
2018-04-09 9:19 ` Marc-André Lureau
2018-04-10 7:15 ` Peter Xu
2018-04-10 7:56 ` Peter Xu
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 15/23] qmp: add new event "command-dropped" Peter Xu
2018-03-11 2:03 ` Eric Blake
2018-03-09 8:59 ` [Qemu-devel] [PATCH v8 16/23] monitor: send event when command queue full Peter Xu
2018-03-11 2:11 ` Eric Blake
2018-03-09 9:00 ` [Qemu-devel] [PATCH v8 17/23] qapi: introduce new cmd option "allow-oob" Peter Xu
2018-03-11 2:27 ` Eric Blake
2018-03-12 3:35 ` Peter Xu
2018-03-09 9:00 ` [Qemu-devel] [PATCH v8 18/23] qmp: support out-of-band (oob) execution Peter Xu
2018-03-11 2:37 ` Eric Blake
2018-03-22 10:22 ` Marc-André Lureau
2018-03-23 5:18 ` Peter Xu
2018-03-23 10:03 ` Marc-André Lureau
2018-03-09 9:00 ` [Qemu-devel] [PATCH v8 19/23] qmp: isolate responses into io thread Peter Xu
2018-03-22 12:00 ` Marc-André Lureau
2018-03-23 5:50 ` Peter Xu
2018-03-23 10:00 ` Marc-André Lureau
2018-03-09 9:00 ` [Qemu-devel] [PATCH v8 20/23] monitor: enable IO thread for (qmp & !mux) typed Peter Xu
2018-03-23 12:10 ` Christian Borntraeger
2018-03-23 12:25 ` Peter Xu
2018-03-23 12:44 ` Christian Borntraeger
2018-03-23 13:01 ` Peter Xu
2018-03-23 13:21 ` Peter Maydell
2018-03-23 13:23 ` Christian Borntraeger
2018-03-23 13:39 ` Peter Xu
2018-03-09 9:00 ` [Qemu-devel] [PATCH v8 21/23] qmp: add command "x-oob-test" Peter Xu
2018-03-11 2:42 ` Eric Blake
2018-03-09 9:00 ` [Qemu-devel] [PATCH v8 22/23] tests: qmp-test: verify command batching Peter Xu
2018-03-11 2:45 ` Eric Blake
2018-03-12 3:43 ` Peter Xu
2018-03-09 9:00 ` [Qemu-devel] [PATCH v8 23/23] tests: qmp-test: add oob test Peter Xu
2018-03-11 2:49 ` Eric Blake
2018-03-12 3:56 ` Peter Xu [this message]
2018-03-11 2:59 ` [Qemu-devel] [PATCH v8 00/23] QMP: out-of-band (OOB) execution support Eric Blake
2018-03-12 4:14 ` Peter Xu
2018-03-12 12:01 ` Eric Blake
2018-03-12 12:55 ` Daniel P. Berrangé
2018-03-13 2:06 ` Peter Xu
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=20180312035644.GD5234@xz-mi \
--to=peterx@redhat.com \
--cc=armbru@redhat.com \
--cc=berrange@redhat.com \
--cc=dgilbert@redhat.com \
--cc=eblake@redhat.com \
--cc=famz@redhat.com \
--cc=lvivier@redhat.com \
--cc=marcandre.lureau@redhat.com \
--cc=mdroth@linux.vnet.ibm.com \
--cc=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=quintela@redhat.com \
--cc=shajnocz@redhat.com \
/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).