[virt-tools-list] [PATCH virt-viewer 2/2] Move tests under /tests directory

Fabiano Fidêncio fidencio at redhat.com
Fri Mar 11 14:44:09 UTC 2016


On Wed, Mar 9, 2016 at 2:21 PM, Pavel Grunt <pgrunt at redhat.com> wrote:
> Keep tests separated from the code
> ---
>  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            |  30 +++++++++++
>  tests/test-monitor-mapping.c | 119 +++++++++++++++++++++++++++++++++++++++++++
>  tests/test-version-compare.c |  61 ++++++++++++++++++++++
>  8 files changed, 212 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 aaa111d..5380b9c 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..470733b
> --- /dev/null
> +++ b/tests/Makefile.am
> @@ -0,0 +1,30 @@
> +NULL =
> +
> +AM_CPPFLAGS =                                                                  \
> +       -DLOCALE_DIR=\""$(datadir)/locale"\"            \
> +       -I$(top_srcdir)/src/                                            \
> +       -I$(top_srcdir)/tests/                                          \
> +       $(GLIB2_CFLAGS)                                                         \
> +       $(GTK_CFLAGS)                                                           \
> +       $(LIBXML2_CFLAGS)                                                       \
> +       $(WARN_CFLAGS)                                                          \
> +       $(NULL)

Pavel, I know you basically copied & pasted the old code here. But do
we need {GTK,LIBXML2}_CFLAGS here? Our tests are not using none of
those if I'm not mistaken.

I would accept a first patch removing these unneeded CPPFLAGS/LIBS.

Also, can we have the "\" aligned?

> +
> +LDADD=                                                                                 \
> +       $(top_builddir)/src/libvirt-viewer-util.la      \
> +       $(GLIB2_LIBS)                                                           \
> +       $(GTK_LIBS)                                                                     \
> +       $(LIBXML2_LIBS)                                                         \
> +       $(NULL)
> +

Same here.

> +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.5.0
>
> _______________________________________________
> virt-tools-list mailing list
> virt-tools-list at redhat.com
> https://www.redhat.com/mailman/listinfo/virt-tools-list

Reviewed-by: Fabiano Fidêncio <fidencio at redhat.com>




More information about the virt-tools-list mailing list