tests/unit: cleanups for test-io-channel-command

This test is hanging under heavy load when the two socats race while
trying to create the socket. I've tried various approaches to avoid
the race but it seems "creat=0" won't stop socat trying to create a
pipe if it executes first. In the end I just use a small sleep which
seems to be reliable enough on the load situations I've tried.

While I was there I also properly created a tmpdir for the socket to
live in which is cleaned up at the end of the test.

Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
Cc: Thomas Huth <thuth@redhat.com>
Cc: Marc-André Lureau <marcandre.lureau@redhat.com>
Cc: Juan Quintela <quintela@redhat.com>
Message-Id: <20221027183637.2772968-30-alex.bennee@linaro.org>
This commit is contained in:
Alex Bennée 2022-10-27 19:36:35 +01:00
parent 14fd492b89
commit 68406d1085

View File

@ -19,6 +19,7 @@
*/ */
#include "qemu/osdep.h" #include "qemu/osdep.h"
#include <glib/gstdio.h>
#include "io/channel-command.h" #include "io/channel-command.h"
#include "io-channel-helpers.h" #include "io-channel-helpers.h"
#include "qapi/error.h" #include "qapi/error.h"
@ -26,32 +27,32 @@
#define TEST_FIFO "test-io-channel-command.fifo" #define TEST_FIFO "test-io-channel-command.fifo"
#define SOCAT_SRC "PIPE:" TEST_FIFO ",wronly"
#define SOCAT_DST "PIPE:" TEST_FIFO ",rdonly"
static char *socat = NULL; static char *socat = NULL;
static void test_io_channel_command_fifo(bool async) static void test_io_channel_command_fifo(bool async)
{ {
g_autofree gchar *tmpdir = g_dir_make_tmp("qemu-test-io-channel.XXXXXX", NULL);
g_autofree gchar *fifo = g_strdup_printf("%s/%s", tmpdir, TEST_FIFO);
g_autoptr(GString) srcargs = g_string_new(socat);
g_autoptr(GString) dstargs = g_string_new(socat);
g_auto(GStrv) srcargv;
g_auto(GStrv) dstargv;
QIOChannel *src, *dst; QIOChannel *src, *dst;
QIOChannelTest *test; QIOChannelTest *test;
const char *srcargv[] = {
socat, "-", SOCAT_SRC, NULL,
};
const char *dstargv[] = {
socat, SOCAT_DST, "-", NULL,
};
if (!socat) { g_string_append_printf(srcargs, " - PIPE:%s,wronly", fifo);
g_test_skip("socat is not found in PATH"); g_string_append_printf(dstargs, " PIPE:%s,rdonly -", fifo);
return;
}
unlink(TEST_FIFO); srcargv = g_strsplit(srcargs->str, " ", -1);
src = QIO_CHANNEL(qio_channel_command_new_spawn(srcargv, dstargv = g_strsplit(dstargs->str, " ", -1);
src = QIO_CHANNEL(qio_channel_command_new_spawn((const char **) srcargv,
O_WRONLY, O_WRONLY,
&error_abort)); &error_abort));
dst = QIO_CHANNEL(qio_channel_command_new_spawn(dstargv, /* try to avoid a race to create the socket */
g_usleep(1000);
dst = QIO_CHANNEL(qio_channel_command_new_spawn((const char **) dstargv,
O_RDONLY, O_RDONLY,
&error_abort)); &error_abort));
@ -62,17 +63,27 @@ static void test_io_channel_command_fifo(bool async)
object_unref(OBJECT(src)); object_unref(OBJECT(src));
object_unref(OBJECT(dst)); object_unref(OBJECT(dst));
unlink(TEST_FIFO); g_rmdir(tmpdir);
} }
static void test_io_channel_command_fifo_async(void) static void test_io_channel_command_fifo_async(void)
{ {
if (!socat) {
g_test_skip("socat is not found in PATH");
return;
}
test_io_channel_command_fifo(true); test_io_channel_command_fifo(true);
} }
static void test_io_channel_command_fifo_sync(void) static void test_io_channel_command_fifo_sync(void)
{ {
if (!socat) {
g_test_skip("socat is not found in PATH");
return;
}
test_io_channel_command_fifo(false); test_io_channel_command_fifo(false);
} }