[virt-tools-list] [PATCH virt-viewer v2 3/5] tests: Add hotkeys test
Fabiano Fidêncio
fidencio at redhat.com
Mon May 30 23:13:59 UTC 2016
On Mon, May 30, 2016 at 5:08 PM, Pavel Grunt <pgrunt at redhat.com> wrote:
> Related: rhbz#1339572
> ---
> tests/Makefile.am | 12 ++++-
> tests/test-hotkeys.c | 123 +++++++++++++++++++++++++++++++++++++++++++++++++++
> 2 files changed, 134 insertions(+), 1 deletion(-)
> create mode 100644 tests/test-hotkeys.c
>
> diff --git a/tests/Makefile.am b/tests/Makefile.am
> index a1bdf85..bd13188 100644
> --- a/tests/Makefile.am
> +++ b/tests/Makefile.am
> @@ -2,6 +2,7 @@ NULL =
>
> AM_CPPFLAGS = \
> -DLOCALE_DIR=\""$(datadir)/locale"\" \
> + -DG_LOG_DOMAIN=\"virt-viewer\" \
> -I$(top_srcdir)/src/ \
> -I$(top_srcdir)/tests/ \
> $(GLIB2_CFLAGS) \
> @@ -16,7 +17,7 @@ LDADD= \
> $(LIBXML2_LIBS) \
> $(NULL)
>
> -TESTS = test-version-compare test-monitor-mapping
> +TESTS = test-version-compare test-monitor-mapping test-hotkeys
> check_PROGRAMS = $(TESTS)
> test_version_compare_SOURCES = \
> test-version-compare.c \
> @@ -26,6 +27,15 @@ test_monitor_mapping_SOURCES = \
> test-monitor-mapping.c \
> $(NULL)
>
> +test_hotkeys_SOURCES = \
> + test-hotkeys.c \
> + $(NULL)
> +
> +test_hotkeys_LDADD = \
> + $(top_builddir)/src/libvirt-viewer.la \
> + $(LDADD) \
> + $(NULL)
> +
> if OS_WIN32
> TESTS += redirect-test
> redirect_test_SOURCES = redirect-test.c
> diff --git a/tests/test-hotkeys.c b/tests/test-hotkeys.c
> new file mode 100644
> index 0000000..d3658f5
> --- /dev/null
> +++ b/tests/test-hotkeys.c
> @@ -0,0 +1,123 @@
> +/* -*- Mode: C; c-basic-offset: 4; indent-tabs-mode: nil -*- */
> +/*
> + * Virt Viewer: A virtual machine console viewer
> + *
> + * Copyright (C) 2016 Red Hat, Inc.
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License as published by
> + * the Free Software Foundation; either version 2 of the License, or
> + * (at your option) any later version.
> + *
> + * This program 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 General Public License for more details.
> + *
> + * You should have received a copy of the GNU General Public License
> + * along with this program; if not, write to the Free Software
> + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
> + */
> +
> +#include <config.h>
> +#include <glib.h>
> +#include <glib-object.h>
> +#include <gtk/gtk.h>
> +
> +#include "virt-viewer-app.h"
> +
> +G_BEGIN_DECLS
> +
> +#define VIRT_VIEWER_TEST_TYPE virt_viewer_test_get_type()
> +#define VIRT_VIEWER_TEST(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), VIRT_VIEWER_TEST_TYPE, VirtViewerTest))
> +#define VIRT_VIEWER_TEST_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), VIRT_VIEWER_TEST_TYPE, VirtViewerTestClass))
> +#define VIRT_VIEWER_TEST_IS(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), VIRT_VIEWER_TEST_TYPE))
> +#define VIRT_VIEWER_TEST_IS_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), VIRT_VIEWER_TEST_TYPE))
> +#define VIRT_VIEWER_TEST_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), VIRT_VIEWER_TEST_TYPE, VirtViewerTestClass))
> +
> +typedef struct {
> + VirtViewerApp parent;
> +} VirtViewerTest;
> +
> +typedef struct {
> + VirtViewerAppClass parent_class;
> +} VirtViewerTestClass;
> +
> +GType virt_viewer_test_get_type (void);
> +
> +G_DEFINE_TYPE (VirtViewerTest, virt_viewer_test, VIRT_VIEWER_TYPE_APP)
> +
> +VirtViewerTest *virt_viewer_test_new (void);
> +
> +G_END_DECLS
> +
> +static void
> +virt_viewer_test_class_init (VirtViewerTestClass *klass G_GNUC_UNUSED)
> +{
> +}
> +
> +static void
> +virt_viewer_test_init(VirtViewerTest *self G_GNUC_UNUSED)
> +{
> +}
> +
> +static void
> +test_hotkeys_good(void)
> +{
> + const gchar *hotkeys[] = {
> + "toggle-fullscreen=shift+f11",
> + "release-cursor=shift+f12,secure-attention=ctrl+shift+b",
> + "smartcard-insert=shift+I,smartcard-remove=shift+R",
> + };
> +
> + guint i;
> +
> + VirtViewerTest *viewer = g_object_new(VIRT_VIEWER_TEST_TYPE, NULL);
> + VirtViewerApp *app = VIRT_VIEWER_APP(viewer);
> + for (i = 0; i < G_N_ELEMENTS(hotkeys); i++) {
> + virt_viewer_app_set_hotkeys(app, hotkeys[i]);
> + }
> + g_object_unref(viewer);
> +}
> +
> +static void
> +test_hotkeys_bad(void)
> +{
> + const struct {
> + const gchar *hotkey_str;
> + const GLogLevelFlags log_level;
> + const gchar *message;
> + } hotkeys[] = {
> + {
> + "no_value",
> + G_LOG_LEVEL_WARNING,
> + "*code should not be reached"
> + },{
> + "toggle-fullscreen=A,unknown_command=B",
> + G_LOG_LEVEL_WARNING,
> + "Unknown hotkey command unknown_command"
> + },
> + };
> +
> + guint i;
> +
> + VirtViewerTest *viewer = g_object_new(VIRT_VIEWER_TEST_TYPE, NULL);
> + VirtViewerApp *app = VIRT_VIEWER_APP(viewer);
> + for (i = 0; i < G_N_ELEMENTS(hotkeys); i++) {
> + g_test_expect_message(G_LOG_DOMAIN, hotkeys[i].log_level, hotkeys[i].message);
> + virt_viewer_app_set_hotkeys(app, hotkeys[i].hotkey_str);
> + g_test_assert_expected_messages();
> + }
> + g_object_unref(viewer);
> +}
> +
> +int main(int argc, char* argv[])
> +{
> + gtk_init_check(&argc, &argv);
> + g_test_init(&argc, &argv, NULL);
> +
> + g_test_add_func("/virt-viewer/good-hotkeys", test_hotkeys_good);
> + g_test_add_func("/virt-viewer/bad-hotkeys", test_hotkeys_bad);
> +
> + return g_test_run();
> +}
> --
> 2.8.3
>
> _______________________________________________
> virt-tools-list mailing list
> virt-tools-list at redhat.com
> https://www.redhat.com/mailman/listinfo/virt-tools-list
See my comments to the patch 4/5.
If we really have to deal with "foo=", please, also add this to your tests.
ACK with this change, if needed.
Best Regards,
--
More information about the virt-tools-list
mailing list