[Spice-devel] [PATCH spice v3 2/3] Add test for codecs parsing

Frediano Ziglio fziglio at redhat.com
Thu Nov 17 09:23:05 UTC 2016


> 
> With Glib2.34 test invalid codec strings
> ---
> Added more good and bad variants
> ---
>  server/tests/Makefile.am                 |   1 +
>  server/tests/spice-codecs-parsing-test.c | 118
>  +++++++++++++++++++++++++++++++
>  2 files changed, 119 insertions(+)
>  create mode 100644 server/tests/spice-codecs-parsing-test.c
> 
> diff --git a/server/tests/Makefile.am b/server/tests/Makefile.am
> index 8580a9a..37b9f88 100644
> --- a/server/tests/Makefile.am
> +++ b/server/tests/Makefile.am
> @@ -37,6 +37,7 @@ LDADD =								\
>  	$(NULL)
>  
>  check_PROGRAMS =				\
> +	spice-codecs-parsing-test		\
>  	spice-options-test			\
>  	stat_test				\
>  	stream-test				\
> diff --git a/server/tests/spice-codecs-parsing-test.c
> b/server/tests/spice-codecs-parsing-test.c
> new file mode 100644
> index 0000000..9db321d
> --- /dev/null
> +++ b/server/tests/spice-codecs-parsing-test.c
> @@ -0,0 +1,118 @@
> +/* -*- Mode: C; c-basic-offset: 4; indent-tabs-mode: nil -*- */
> +/*
> +   Copyright (C) 2016 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/>.
> +*/
> +#include <config.h>
> +#include <glib.h>
> +#include <spice.h>
> +
> +/* GLIB_CHECK_VERSION(2, 40, 0) */
> +#ifndef g_assert_nonnull
> +#define g_assert_nonnull g_assert
> +#endif
> +
> +static void codecs_good(void)
> +{
> +    guint i;
> +    const gchar *codecs[] = {
> +        "",
> +        ";",
> +        ";;;;",
> +        "spice:mjpeg",
> +        "spice:mjpeg;;;",
> +        "spice:mjpeg;;spice:mjpeg;;;",
> +        ";;spice:mjpeg;;spice:mjpeg;;;",
> +#if defined(HAVE_GSTREAMER_1_0) || defined(HAVE_GSTREAMER_0_10)
> +        "gstreamer:mjpeg;gstreamer:h264;gstreamer:vp8;",
> +        ";;spice:mjpeg;;gstreamer:mjpeg;gstreamer:h264;gstreamer:vp8;",
> +#endif
> +    };
> +
> +    SpiceServer *server = spice_server_new();
> +
> +    g_assert_nonnull(server);
> +
> +    for (i = 0; i < G_N_ELEMENTS(codecs); ++i) {
> +        g_assert_cmpint(spice_server_set_video_codecs(server, codecs[i]),
> ==, 0);
> +    }
> +
> +    spice_server_destroy(server);
> +}
> +
> +/* g_test_expect_message is available since Glib 2.34 */
> +#if GLIB_CHECK_VERSION(2, 34, 0)
> +static void codecs_bad(void)
> +{
> +    guint i;
> +    const struct {
> +        const gchar *codecs;
> +        const gchar *error_message;
> +    } test_cases[] = {
> +        {
> +            ";:;",
> +            "*spice: invalid encoder:codec value*",
> +        },{
> +            "::::",
> +            "*spice: invalid encoder:codec value*",
> +        },{
> +            "missingcolon",
> +            "*spice: invalid encoder:codec value*",
> +        },{
> +            ":missing_encoder",
> +            "*spice: invalid encoder:codec value*",
> +        },{
> +            "missing_value:;",
> +            "*spice: invalid encoder:codec value*",
> +        },{
> +            "unknown_encoder:mjpeg",
> +            "*spice: unknown video encoder unknown_encoder",
> +        },{
> +            "spice:unknown_codec",
> +            "*spice: unknown video codec unknown_codec",
> +        },
> +#if !defined(HAVE_GSTREAMER_1_0) && !defined(HAVE_GSTREAMER_0_10)
> +        {
> +            "gstreamer:mjpeg",
> +            "*spice: unsupported video encoder gstreamer",
> +        }
> +#endif
> +    };
> +
> +    SpiceServer *server = spice_server_new();
> +
> +    g_assert_nonnull(server);
> +
> +    for (i = 0; i < G_N_ELEMENTS(test_cases); ++i) {
> +        g_test_expect_message(G_LOG_DOMAIN, G_LOG_LEVEL_WARNING,
> test_cases[i].error_message);
> +        g_assert_cmpint(spice_server_set_video_codecs(server,
> test_cases[i].codecs), ==, 0);
> +        g_test_assert_expected_messages();
> +    }
> +
> +    spice_server_destroy(server);
> +}
> +#endif
> +
> +int main(int argc, char *argv[])
> +{
> +    g_test_init(&argc, &argv, NULL);
> +
> +    g_test_add_func("/server/codecs-good", codecs_good);
> +#if GLIB_CHECK_VERSION(2, 34, 0)
> +    g_test_add_func("/server/codecs-bad", codecs_bad);
> +#endif
> +
> +    return g_test_run();
> +}

Acked-by: Frediano Ziglio <fziglio at redhat.com>

Note that this test crash if the patch I sent couple of minutes ago
is not applied

Frediano


More information about the Spice-devel mailing list