[Spice-commits] server/tests
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Thu May 7 08:13:28 UTC 2020
server/tests/Makefile.am | 2
server/tests/meson.build | 1
server/tests/test-dispatcher.cpp | 147 +++++++++++++++++++++++++++++++++++++++
3 files changed, 150 insertions(+)
New commits:
commit a21e66b7b38d36f9de34fad3edcb39896d1ede75
Author: Frediano Ziglio <fziglio at redhat.com>
Date: Sat Mar 14 09:37:10 2020 +0000
test-dispatcher: Test dispatcher
Test that dispatcher work.
Signed-off-by: Frediano Ziglio <freddy77 at gmail.com>
diff --git a/server/tests/Makefile.am b/server/tests/Makefile.am
index 0ccc2c36..19058037 100644
--- a/server/tests/Makefile.am
+++ b/server/tests/Makefile.am
@@ -56,6 +56,7 @@ LDADD = \
check_PROGRAMS = \
test-codecs-parsing \
+ test-dispatcher \
test-options \
test-stat \
test-agent-msg-filter \
@@ -81,6 +82,7 @@ endif
test_channel_SOURCES = test-channel.cpp
test_stream_device_SOURCES = test-stream-device.cpp
+test_dispatcher_SOURCES = test-dispatcher.cpp
if !OS_WIN32
check_PROGRAMS += \
diff --git a/server/tests/meson.build b/server/tests/meson.build
index cef187eb..4f150a0b 100644
--- a/server/tests/meson.build
+++ b/server/tests/meson.build
@@ -39,6 +39,7 @@ endforeach
tests = [
['test-codecs-parsing', true],
+ ['test-dispatcher', true, 'cpp'],
['test-options', true],
['test-stat', true],
['test-agent-msg-filter', true],
diff --git a/server/tests/test-dispatcher.cpp b/server/tests/test-dispatcher.cpp
new file mode 100644
index 00000000..0ec88f1f
--- /dev/null
+++ b/server/tests/test-dispatcher.cpp
@@ -0,0 +1,147 @@
+/* -*- Mode: C; c-basic-offset: 4; indent-tabs-mode: nil -*- */
+/*
+ Copyright (C) 2020 Red Hat, Inc.
+
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ This library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with this library; if not, see <http://www.gnu.org/licenses/>.
+*/
+/**
+ * Test Dispatcher class and speed
+ */
+
+#include <config.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+#include "basic-event-loop.h"
+#include "test-glib-compat.h"
+#include "reds.h"
+#include "dispatcher.h"
+#include "win-alarm.h"
+
+// iterations to run for each test, useful also to check the speed
+static unsigned iterations = 100;
+
+static SpiceCoreInterface *core;
+static SpiceCoreInterfaceInternal core_int;
+static red::shared_ptr<Dispatcher> dispatcher;
+static SpiceWatch *watch;
+// incremental number we use during the test, each message sent is incremented
+static unsigned num;
+typedef int TestFixture;
+
+static void test_dispatcher_setup(TestFixture *fixture, gconstpointer user_data)
+{
+ num = 0;
+ dispatcher.reset();
+ g_assert_null(core);
+ core = basic_event_loop_init();
+ g_assert_nonnull(core);
+ core_int = core_interface_adapter;
+ core_int.public_interface = core;
+ dispatcher = red::make_shared<Dispatcher>(10);
+ // TODO not create Reds, just the internal interface ??
+ watch = dispatcher->create_watch(&core_int);
+}
+
+static void test_dispatcher_teardown(TestFixture *fixture, gconstpointer user_data)
+{
+ g_assert_nonnull(core);
+
+ red_watch_remove(watch);
+ watch = NULL;
+ dispatcher.reset();
+ basic_event_loop_destroy();
+ core = NULL;
+}
+
+// test message to sent
+struct Msg {
+ uint64_t num;
+ void *dummy;
+};
+
+// message handler to mark stop, stop the event loop
+static void msg_end(void *, Msg *msg)
+{
+ g_assert_cmpint(num, ==, iterations);
+ basic_event_loop_quit();
+}
+
+// message handler to check message number
+static void msg_check(void *, Msg *msg)
+{
+ g_assert_cmpint(msg->num, ==, num);
+ ++num;
+}
+
+static void *thread_proc(void *arg)
+{
+ // the argument is number of messages with NACK to send
+ int n_nack = GPOINTER_TO_INT(arg);
+ g_assert_cmpint(n_nack, >=, 0);
+ g_assert_cmpint(n_nack, <=, 10);
+
+ auto start = spice_get_monotonic_time_ns();
+
+ // repeat sending messages
+ for (unsigned n = 0; n < iterations; ++n) {
+ Msg msg{n, NULL};
+ dispatcher->send_message_custom(msg_check, &msg, (n % 10) >= n_nack);
+ }
+
+ // one last sync to wait
+ Msg msg{0, NULL};
+ dispatcher->send_message_custom(msg_end, &msg, true);
+
+ // measure time
+ auto cost = spice_get_monotonic_time_ns() - start;
+
+ printf("With ACK/NACK %d/%d time spent %gus each over %u iterations\n",
+ 10 - n_nack, n_nack,
+ cost / 1000.0 / iterations, iterations);
+ return NULL;
+}
+
+static void test_dispatcher(TestFixture *fixture, gconstpointer user_data)
+{
+ pthread_t th;
+
+ g_assert_cmpint(pthread_create(&th, NULL, thread_proc, (void *) user_data), ==, 0);
+
+ // start all test
+ alarm(20);
+ basic_event_loop_mainloop();
+ alarm(0);
+
+ pthread_join(th, NULL);
+}
+
+int main(int argc, char *argv[])
+{
+ g_test_init(&argc, &argv, NULL);
+
+ // override number of iteration passing a parameter
+ if (argc >= 2 && atoi(argv[1]) > 10) {
+ iterations = atoi(argv[1]);
+ }
+
+ for (int i = 0; i <= 10; ++i) {
+ char name[64];
+ sprintf(name, "/server/dispatcher/%d", i);
+ g_test_add(name, TestFixture, GINT_TO_POINTER(i), test_dispatcher_setup,
+ test_dispatcher, test_dispatcher_teardown);
+ }
+
+ return g_test_run();
+}
More information about the Spice-commits
mailing list