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:
parent
14fd492b89
commit
68406d1085
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user