mirror of
https://github.com/xemu-project/xemu.git
synced 2024-11-23 19:49:43 +00:00
78b27bade1
We have several callers that were formatting the argument strings themselves; consolidate this effort by adding new convenience functions directly in libqtest, and update some call-sites that can benefit from it. Note that the new functions qtest_startf() and qtest_vstartf() behave more like qtest_init() (the caller must assign global_qtest after the fact, rather than getting it implicitly set). This helps us prepare for future patches that get rid of the global variable, by explicitly highlighting which tests still depend on it now. Signed-off-by: Eric Blake <eblake@redhat.com> [thuth: Dropped the hunks that do not apply cleanly to qemu master yet and added the missing g_free(args) in qtest_vstartf()] Signed-off-by: Thomas Huth <thuth@redhat.com> Message-Id: <1508336428-20511-2-git-send-email-thuth@redhat.com> Acked-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Cornelia Huck <cohuck@redhat.com>
91 lines
2.4 KiB
C
91 lines
2.4 KiB
C
/*
|
|
* QTest testcase for filter-mirror
|
|
*
|
|
* Copyright (c) 2016 FUJITSU LIMITED
|
|
* Author: Zhang Chen <zhangchen.fnst@cn.fujitsu.com>
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or
|
|
* later. See the COPYING file in the top-level directory.
|
|
*/
|
|
|
|
#include "qemu/osdep.h"
|
|
#include "libqtest.h"
|
|
#include "qemu/iov.h"
|
|
#include "qemu/sockets.h"
|
|
#include "qemu/error-report.h"
|
|
#include "qemu/main-loop.h"
|
|
|
|
static void test_mirror(void)
|
|
{
|
|
int send_sock[2], recv_sock;
|
|
uint32_t ret = 0, len = 0;
|
|
char send_buf[] = "Hello! filter-mirror~";
|
|
char sock_path[] = "filter-mirror.XXXXXX";
|
|
char *recv_buf;
|
|
uint32_t size = sizeof(send_buf);
|
|
size = htonl(size);
|
|
const char *devstr = "e1000";
|
|
|
|
if (g_str_equal(qtest_get_arch(), "s390x")) {
|
|
devstr = "virtio-net-ccw";
|
|
}
|
|
|
|
ret = socketpair(PF_UNIX, SOCK_STREAM, 0, send_sock);
|
|
g_assert_cmpint(ret, !=, -1);
|
|
|
|
ret = mkstemp(sock_path);
|
|
g_assert_cmpint(ret, !=, -1);
|
|
|
|
global_qtest = qtest_startf(
|
|
"-netdev socket,id=qtest-bn0,fd=%d "
|
|
"-device %s,netdev=qtest-bn0,id=qtest-e0 "
|
|
"-chardev socket,id=mirror0,path=%s,server,nowait "
|
|
"-object filter-mirror,id=qtest-f0,netdev=qtest-bn0,queue=tx,outdev=mirror0 "
|
|
, send_sock[1], devstr, sock_path);
|
|
|
|
recv_sock = unix_connect(sock_path, NULL);
|
|
g_assert_cmpint(recv_sock, !=, -1);
|
|
|
|
struct iovec iov[] = {
|
|
{
|
|
.iov_base = &size,
|
|
.iov_len = sizeof(size),
|
|
}, {
|
|
.iov_base = send_buf,
|
|
.iov_len = sizeof(send_buf),
|
|
},
|
|
};
|
|
|
|
/* send a qmp command to guarantee that 'connected' is setting to true. */
|
|
qmp_discard_response("{ 'execute' : 'query-status'}");
|
|
ret = iov_send(send_sock[0], iov, 2, 0, sizeof(size) + sizeof(send_buf));
|
|
g_assert_cmpint(ret, ==, sizeof(send_buf) + sizeof(size));
|
|
close(send_sock[0]);
|
|
|
|
ret = qemu_recv(recv_sock, &len, sizeof(len), 0);
|
|
g_assert_cmpint(ret, ==, sizeof(len));
|
|
len = ntohl(len);
|
|
|
|
g_assert_cmpint(len, ==, sizeof(send_buf));
|
|
recv_buf = g_malloc(len);
|
|
ret = qemu_recv(recv_sock, recv_buf, len, 0);
|
|
g_assert_cmpstr(recv_buf, ==, send_buf);
|
|
|
|
g_free(recv_buf);
|
|
close(recv_sock);
|
|
unlink(sock_path);
|
|
}
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
int ret;
|
|
|
|
g_test_init(&argc, &argv, NULL);
|
|
|
|
qtest_add_func("/netfilter/mirror", test_mirror);
|
|
ret = g_test_run();
|
|
qtest_end();
|
|
|
|
return ret;
|
|
}
|