On Fri, Mar 11, 2016 at 6:13 PM, Pavel Grunt <pgrunt@xxxxxxxxxx> wrote: > Keep tests separated from the code > --- > v2: > used space before '\' > removed unneeded CFLAGS and LDADDs > CFLAGS for gtk and glib are needed because virt-viewer-util includes gtk header > --- > Makefile.am | 2 +- > configure.ac | 1 + > src/Makefile.am | 40 --------------- > src/test-monitor-mapping.c | 119 ------------------------------------------- > src/test-version-compare.c | 61 ---------------------- > tests/Makefile.am | 26 ++++++++++ > tests/test-monitor-mapping.c | 119 +++++++++++++++++++++++++++++++++++++++++++ > tests/test-version-compare.c | 61 ++++++++++++++++++++++ > 8 files changed, 208 insertions(+), 221 deletions(-) > delete mode 100644 src/test-monitor-mapping.c > delete mode 100644 src/test-version-compare.c > create mode 100644 tests/Makefile.am > create mode 100644 tests/test-monitor-mapping.c > create mode 100644 tests/test-version-compare.c > > diff --git a/Makefile.am b/Makefile.am > index 769fa21..49ed54c 100644 > --- a/Makefile.am > +++ b/Makefile.am > @@ -2,7 +2,7 @@ NULL = > > ACLOCAL_AMFLAGS = -I m4 > > -SUBDIRS = icons src man po data > +SUBDIRS = icons src man po data tests > > AM_DISTCHECK_CONFIGURE_FLAGS = --disable-update-mimedb > EXTRA_DIST = \ > diff --git a/configure.ac b/configure.ac > index e1c9b1b..6d8475b 100644 > --- a/configure.ac > +++ b/configure.ac > @@ -255,6 +255,7 @@ AC_CONFIG_FILES([ > po/Makefile.in > src/Makefile > src/virt-viewer.rc > + tests/Makefile > virt-viewer.spec > ]) > AC_OUTPUT > diff --git a/src/Makefile.am b/src/Makefile.am > index 40c5876..8fdb0e9 100644 > --- a/src/Makefile.am > +++ b/src/Makefile.am > @@ -139,46 +139,6 @@ libvirt_viewer_la_CFLAGS = \ > $(COMMON_CFLAGS) \ > $(NULL) > > -check_PROGRAMS = test-version-compare test-monitor-mapping > -TESTS = $(check_PROGRAMS) > -test_version_compare_SOURCES = \ > - test-version-compare.c \ > - $(NULL) > -test_version_compare_LDFLAGS = \ > - $(GLIB2_LIBS) \ > - $(GTK_LIBS) \ > - $(LIBXML2_LIBS) \ > - $(NULL) > -test_version_compare_CFLAGS = \ > - -DLOCALE_DIR=\""$(datadir)/locale"\" \ > - $(GLIB2_CFLAGS) \ > - $(GTK_CFLAGS) \ > - $(LIBXML2_CFLAGS) \ > - $(WARN_CFLAGS) \ > - $(NULL) > -test_version_compare_LDADD = \ > - libvirt-viewer-util.la \ > - $(NULL) > - > -test_monitor_mapping_SOURCES = \ > - test-monitor-mapping.c \ > - $(NULL) > -test_monitor_mapping_LDFLAGS = \ > - $(GLIB2_LIBS) \ > - $(GTK_LIBS) \ > - $(LIBXML2_LIBS) \ > - $(NULL) > -test_monitor_mapping_CFLAGS = \ > - -DLOCALE_DIR=\""$(datadir)/locale"\" \ > - $(GLIB2_CFLAGS) \ > - $(GTK_CFLAGS) \ > - $(LIBXML2_CFLAGS) \ > - $(WARN_CFLAGS) \ > - $(NULL) > -test_monitor_mapping_LDADD = \ > - libvirt-viewer-util.la \ > - $(NULL) > - > if HAVE_LIBVIRT > bin_PROGRAMS += virt-viewer > virt_viewer_SOURCES = \ > diff --git a/src/test-monitor-mapping.c b/src/test-monitor-mapping.c > deleted file mode 100644 > index 004aa51..0000000 > --- a/src/test-monitor-mapping.c > +++ /dev/null > @@ -1,119 +0,0 @@ > -/* -*- 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 <virt-viewer-util.h> > - > -gboolean doDebug = FALSE; > - > -/** > - * is_valid_monitor_mapping: > - * @mapping: a value for the "monitor-mapping" key > - * > - * Tests the validity of the settings file for the "monitor-mapping" key: > - * [test-monitor-mapping] > - * monitor-mapping=@mapping > - * > - * Returns: %TRUE if the mapping is valid > - */ > -static gboolean > -is_valid_monitor_mapping(const gchar *mapping) > -{ > - GKeyFile *key_file; > - gboolean valid; > - const gint nmonitors = 4; > - const gchar *group_name = "test-monitor-mapping"; > - const gchar *key = "monitor-mapping"; > - const gchar *key_data_fmt = "[%s]\n%s=%s\n"; > - gchar *key_data = g_strdup_printf(key_data_fmt, group_name, key, mapping); > - > - key_file = g_key_file_new(); > - valid = g_key_file_load_from_data(key_file, key_data, -1, G_KEY_FILE_NONE, NULL); > - if (valid) { > - gsize nmappings; > - gchar **mappings = g_key_file_get_string_list(key_file, group_name, key, &nmappings, NULL); > - GHashTable *map = virt_viewer_parse_monitor_mappings(mappings, nmappings, nmonitors); > - > - valid = (map != NULL); > - > - g_strfreev(mappings); > - g_clear_pointer(&map, g_hash_table_unref); > - } > - > - g_key_file_free(key_file); > - g_free(key_data); > - return valid; > -} > - > -int main(void) > -{ > - /* valid monitor mappings */ > - g_assert_true(is_valid_monitor_mapping("1:1")); > - g_assert_true(is_valid_monitor_mapping("1:1;2:2")); > - g_assert_true(is_valid_monitor_mapping("1:1;2:2;3:3;")); > - g_assert_true(is_valid_monitor_mapping("1:2;2:1;3:3;4:4")); > - g_assert_true(is_valid_monitor_mapping("4:1;3:2;2:3;1:4")); > - > - /* invalid monitors mappings */ > - /* zero ids */ > - g_assert_false(is_valid_monitor_mapping("0:0")); > - /* negative guest display id */ > - g_assert_false(is_valid_monitor_mapping("-1:1")); > - /* negative client monitor id */ > - g_assert_false(is_valid_monitor_mapping("1:-1")); > - /* negative guest display & client monitor id */ > - g_assert_false(is_valid_monitor_mapping("-1:-1")); > - /* high guest display id */ > - g_assert_false(is_valid_monitor_mapping("100:1")); > - /* high client monitor id */ > - g_assert_false(is_valid_monitor_mapping("1:100")); > - /* missing guest display id */ > - g_assert_false(is_valid_monitor_mapping("1:1;3:3")); > - /* guest display id used twice */ > - g_assert_false(is_valid_monitor_mapping("1:1;1:2")); > - /* client monitor id used twice */ > - g_assert_false(is_valid_monitor_mapping("1:1;2:1")); > - /* floating point guest display id */ > - g_assert_false(is_valid_monitor_mapping("1.111:1")); > - /* floating point client monitor id */ > - g_assert_false(is_valid_monitor_mapping("1:1.111")); > - /* empty mapping */ > - g_assert_false(is_valid_monitor_mapping("")); > - g_assert_false(is_valid_monitor_mapping(";")); > - /* missing guest display id */ > - g_assert_false(is_valid_monitor_mapping(":1")); > - /* missing client monitor id */ > - g_assert_false(is_valid_monitor_mapping("1:")); > - /* missing guest display & client monitor id */ > - g_assert_false(is_valid_monitor_mapping(":")); > - /*missing colon */ > - g_assert_false(is_valid_monitor_mapping("11")); > - /*missing semicolon */ > - g_assert_false(is_valid_monitor_mapping("1:12:2")); > - /* strings */ > - g_assert_false(is_valid_monitor_mapping("1:a")); > - g_assert_false(is_valid_monitor_mapping("a:1")); > - g_assert_false(is_valid_monitor_mapping("a:a")); > - g_assert_false(is_valid_monitor_mapping("monitor mapping")); > - > - return 0; > -} > diff --git a/src/test-version-compare.c b/src/test-version-compare.c > deleted file mode 100644 > index f14887b..0000000 > --- a/src/test-version-compare.c > +++ /dev/null > @@ -1,61 +0,0 @@ > -/* -*- Mode: C; c-basic-offset: 4; indent-tabs-mode: nil -*- */ > -/* > - * Virt Viewer: A virtual machine console viewer > - * > - * Copyright (C) 2015 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 <virt-viewer-util.h> > - > -gboolean doDebug = FALSE; > - > -int main(void) > -{ > - g_assert(virt_viewer_compare_buildid("1-1", "1-1") == 0); > - g_assert(virt_viewer_compare_buildid("1-1", "1-1.1") < 0); > - g_assert(virt_viewer_compare_buildid("1-1", "1-2") < 0); > - g_assert(virt_viewer_compare_buildid("1-3", "1-2") > 0); > - g_assert(virt_viewer_compare_buildid("2-3", "1-2") > 0); > - g_assert(virt_viewer_compare_buildid("2-3", "3-2") < 0); > - g_assert(virt_viewer_compare_buildid("2-3", "3-4") < 0); > - g_assert(virt_viewer_compare_buildid("4-3", "3-4") > 0); > - > - g_assert(virt_viewer_compare_buildid("4.0-", "3-4") > 0); > - g_assert(virt_viewer_compare_buildid("4.0-", "3.4-4") > 0); > - g_assert(virt_viewer_compare_buildid(".0-", "3.4-4") < 0); > - g_assert(virt_viewer_compare_buildid("4-", "3-4") > 0); > - g_assert(virt_viewer_compare_buildid("4-3", "3-") > 0); > - g_assert(virt_viewer_compare_buildid("-3", "3-4") < 0); > - g_assert(virt_viewer_compare_buildid("4-3", "-4") > 0); > - g_assert(virt_viewer_compare_buildid("-3", "-4") < 0); > - g_assert(virt_viewer_compare_buildid("4", "3-4") > 0); > - g_assert(virt_viewer_compare_buildid("4-3", "3") > 0); > - g_assert(virt_viewer_compare_buildid("3", "3-4") < 0); > - g_assert(virt_viewer_compare_buildid("4-3", "4") > 0); > - g_assert(virt_viewer_compare_buildid("-3", "-4") < 0); > - > - /* These trigger runtime warnings */ > - g_assert(virt_viewer_compare_buildid("-3", "-") > 0); > - g_assert(virt_viewer_compare_buildid("", "-") == 0); > - g_assert(virt_viewer_compare_buildid("", "") == 0); > - g_assert(virt_viewer_compare_buildid("", NULL) == 0); > - g_assert(virt_viewer_compare_buildid(NULL, NULL) == 0); > - > - return 0; > -} > diff --git a/tests/Makefile.am b/tests/Makefile.am > new file mode 100644 > index 0000000..e2c9bba > --- /dev/null > +++ b/tests/Makefile.am > @@ -0,0 +1,26 @@ > +NULL = > + > +AM_CPPFLAGS = \ > + -DLOCALE_DIR=\""$(datadir)/locale"\" \ > + -I$(top_srcdir)/src/ \ > + -I$(top_srcdir)/tests/ \ > + $(GLIB2_CFLAGS) \ > + $(GTK_CFLAGS) \I I don't think we need GTK_CFLAGS. If we do, why? And no need to add GLIB2_LIBS to the LDFLAGS? > + $(WARN_CFLAGS) \ > + $(NULL) > + > +LDADD= \ > + $(top_builddir)/src/libvirt-viewer-util.la \ > + $(NULL) > + > +TESTS = test-version-compare test-monitor-mapping > +check_PROGRAMS = $(TESTS) > +test_version_compare_SOURCES = \ > + test-version-compare.c \ > + $(NULL) > + > +test_monitor_mapping_SOURCES = \ > + test-monitor-mapping.c \ > + $(NULL) > + > +-include $(top_srcdir)/git.mk > diff --git a/tests/test-monitor-mapping.c b/tests/test-monitor-mapping.c > new file mode 100644 > index 0000000..004aa51 > --- /dev/null > +++ b/tests/test-monitor-mapping.c > @@ -0,0 +1,119 @@ > +/* -*- 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 <virt-viewer-util.h> > + > +gboolean doDebug = FALSE; > + > +/** > + * is_valid_monitor_mapping: > + * @mapping: a value for the "monitor-mapping" key > + * > + * Tests the validity of the settings file for the "monitor-mapping" key: > + * [test-monitor-mapping] > + * monitor-mapping=@mapping > + * > + * Returns: %TRUE if the mapping is valid > + */ > +static gboolean > +is_valid_monitor_mapping(const gchar *mapping) > +{ > + GKeyFile *key_file; > + gboolean valid; > + const gint nmonitors = 4; > + const gchar *group_name = "test-monitor-mapping"; > + const gchar *key = "monitor-mapping"; > + const gchar *key_data_fmt = "[%s]\n%s=%s\n"; > + gchar *key_data = g_strdup_printf(key_data_fmt, group_name, key, mapping); > + > + key_file = g_key_file_new(); > + valid = g_key_file_load_from_data(key_file, key_data, -1, G_KEY_FILE_NONE, NULL); > + if (valid) { > + gsize nmappings; > + gchar **mappings = g_key_file_get_string_list(key_file, group_name, key, &nmappings, NULL); > + GHashTable *map = virt_viewer_parse_monitor_mappings(mappings, nmappings, nmonitors); > + > + valid = (map != NULL); > + > + g_strfreev(mappings); > + g_clear_pointer(&map, g_hash_table_unref); > + } > + > + g_key_file_free(key_file); > + g_free(key_data); > + return valid; > +} > + > +int main(void) > +{ > + /* valid monitor mappings */ > + g_assert_true(is_valid_monitor_mapping("1:1")); > + g_assert_true(is_valid_monitor_mapping("1:1;2:2")); > + g_assert_true(is_valid_monitor_mapping("1:1;2:2;3:3;")); > + g_assert_true(is_valid_monitor_mapping("1:2;2:1;3:3;4:4")); > + g_assert_true(is_valid_monitor_mapping("4:1;3:2;2:3;1:4")); > + > + /* invalid monitors mappings */ > + /* zero ids */ > + g_assert_false(is_valid_monitor_mapping("0:0")); > + /* negative guest display id */ > + g_assert_false(is_valid_monitor_mapping("-1:1")); > + /* negative client monitor id */ > + g_assert_false(is_valid_monitor_mapping("1:-1")); > + /* negative guest display & client monitor id */ > + g_assert_false(is_valid_monitor_mapping("-1:-1")); > + /* high guest display id */ > + g_assert_false(is_valid_monitor_mapping("100:1")); > + /* high client monitor id */ > + g_assert_false(is_valid_monitor_mapping("1:100")); > + /* missing guest display id */ > + g_assert_false(is_valid_monitor_mapping("1:1;3:3")); > + /* guest display id used twice */ > + g_assert_false(is_valid_monitor_mapping("1:1;1:2")); > + /* client monitor id used twice */ > + g_assert_false(is_valid_monitor_mapping("1:1;2:1")); > + /* floating point guest display id */ > + g_assert_false(is_valid_monitor_mapping("1.111:1")); > + /* floating point client monitor id */ > + g_assert_false(is_valid_monitor_mapping("1:1.111")); > + /* empty mapping */ > + g_assert_false(is_valid_monitor_mapping("")); > + g_assert_false(is_valid_monitor_mapping(";")); > + /* missing guest display id */ > + g_assert_false(is_valid_monitor_mapping(":1")); > + /* missing client monitor id */ > + g_assert_false(is_valid_monitor_mapping("1:")); > + /* missing guest display & client monitor id */ > + g_assert_false(is_valid_monitor_mapping(":")); > + /*missing colon */ > + g_assert_false(is_valid_monitor_mapping("11")); > + /*missing semicolon */ > + g_assert_false(is_valid_monitor_mapping("1:12:2")); > + /* strings */ > + g_assert_false(is_valid_monitor_mapping("1:a")); > + g_assert_false(is_valid_monitor_mapping("a:1")); > + g_assert_false(is_valid_monitor_mapping("a:a")); > + g_assert_false(is_valid_monitor_mapping("monitor mapping")); > + > + return 0; > +} > diff --git a/tests/test-version-compare.c b/tests/test-version-compare.c > new file mode 100644 > index 0000000..f14887b > --- /dev/null > +++ b/tests/test-version-compare.c > @@ -0,0 +1,61 @@ > +/* -*- Mode: C; c-basic-offset: 4; indent-tabs-mode: nil -*- */ > +/* > + * Virt Viewer: A virtual machine console viewer > + * > + * Copyright (C) 2015 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 <virt-viewer-util.h> > + > +gboolean doDebug = FALSE; > + > +int main(void) > +{ > + g_assert(virt_viewer_compare_buildid("1-1", "1-1") == 0); > + g_assert(virt_viewer_compare_buildid("1-1", "1-1.1") < 0); > + g_assert(virt_viewer_compare_buildid("1-1", "1-2") < 0); > + g_assert(virt_viewer_compare_buildid("1-3", "1-2") > 0); > + g_assert(virt_viewer_compare_buildid("2-3", "1-2") > 0); > + g_assert(virt_viewer_compare_buildid("2-3", "3-2") < 0); > + g_assert(virt_viewer_compare_buildid("2-3", "3-4") < 0); > + g_assert(virt_viewer_compare_buildid("4-3", "3-4") > 0); > + > + g_assert(virt_viewer_compare_buildid("4.0-", "3-4") > 0); > + g_assert(virt_viewer_compare_buildid("4.0-", "3.4-4") > 0); > + g_assert(virt_viewer_compare_buildid(".0-", "3.4-4") < 0); > + g_assert(virt_viewer_compare_buildid("4-", "3-4") > 0); > + g_assert(virt_viewer_compare_buildid("4-3", "3-") > 0); > + g_assert(virt_viewer_compare_buildid("-3", "3-4") < 0); > + g_assert(virt_viewer_compare_buildid("4-3", "-4") > 0); > + g_assert(virt_viewer_compare_buildid("-3", "-4") < 0); > + g_assert(virt_viewer_compare_buildid("4", "3-4") > 0); > + g_assert(virt_viewer_compare_buildid("4-3", "3") > 0); > + g_assert(virt_viewer_compare_buildid("3", "3-4") < 0); > + g_assert(virt_viewer_compare_buildid("4-3", "4") > 0); > + g_assert(virt_viewer_compare_buildid("-3", "-4") < 0); > + > + /* These trigger runtime warnings */ > + g_assert(virt_viewer_compare_buildid("-3", "-") > 0); > + g_assert(virt_viewer_compare_buildid("", "-") == 0); > + g_assert(virt_viewer_compare_buildid("", "") == 0); > + g_assert(virt_viewer_compare_buildid("", NULL) == 0); > + g_assert(virt_viewer_compare_buildid(NULL, NULL) == 0); > + > + return 0; > +} > -- > 2.7.2 > > _______________________________________________ > virt-tools-list mailing list > virt-tools-list@xxxxxxxxxx > https://www.redhat.com/mailman/listinfo/virt-tools-list You don't need the resend the patches. A small diff on top of this one is enough. Best Regards, -- Fabiano Fidêncio _______________________________________________ virt-tools-list mailing list virt-tools-list@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/virt-tools-list