aboutsummaryrefslogtreecommitdiff
path: root/libmm-glib/tests/test-common-helpers.c
diff options
context:
space:
mode:
Diffstat (limited to 'libmm-glib/tests/test-common-helpers.c')
-rw-r--r--libmm-glib/tests/test-common-helpers.c529
1 files changed, 529 insertions, 0 deletions
diff --git a/libmm-glib/tests/test-common-helpers.c b/libmm-glib/tests/test-common-helpers.c
new file mode 100644
index 00000000..a54fe2d8
--- /dev/null
+++ b/libmm-glib/tests/test-common-helpers.c
@@ -0,0 +1,529 @@
+/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
+/*
+ * 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:
+ *
+ * Copyright (C) 2012 Google, Inc.
+ */
+
+#include <glib.h>
+
+#include <libmm-common.h>
+
+/********************* KEY VALUE PARSER TESTS *********************/
+
+typedef struct {
+ const gchar *key;
+ const gchar *value;
+} KeyValueEntry;
+
+/* ---- Expected cases ---- */
+
+typedef struct {
+ const KeyValueEntry *entries;
+ guint n_entries;
+ guint i;
+} CommonKeyValueTestContext;
+
+static gboolean
+common_key_value_test_foreach (const gchar *key,
+ const gchar *value,
+ CommonKeyValueTestContext *ctx)
+{
+ g_assert_cmpuint (ctx->i, <, ctx->n_entries);
+
+ g_assert_cmpstr (key, ==, ctx->entries[ctx->i].key);
+ g_assert_cmpstr (value, ==, ctx->entries[ctx->i].value);
+ ctx->i++;
+
+ return TRUE;
+}
+
+static void
+common_key_value_test (const gchar *str,
+ const KeyValueEntry *entries,
+ guint n_entries)
+{
+ GError *error = NULL;
+ CommonKeyValueTestContext ctx;
+
+ ctx.entries = entries;
+ ctx.n_entries = n_entries;
+ ctx.i = 0;
+
+ mm_common_parse_key_value_string (str,
+ &error,
+ (MMParseKeyValueForeachFn)common_key_value_test_foreach,
+ &ctx);
+ g_assert_no_error (error);
+ g_assert_cmpuint (ctx.i, ==, ctx.n_entries);
+}
+
+static void
+key_value_test_standard (void)
+{
+ const gchar *str =
+ "key1=value1,"
+ "key2=value2,"
+ "key3=value3";
+ const KeyValueEntry entries[] = {
+ { "key1", "value1" },
+ { "key2", "value2" },
+ { "key3", "value3" }
+ };
+
+ common_key_value_test (str, entries, G_N_ELEMENTS (entries));
+}
+
+static void
+key_value_test_spaces (void)
+{
+ const gchar *str =
+ " key1 = value1 , "
+ "\t\tkey2\t=\tvalue2\t,\t"
+ "\n\nkey3\n=\nvalue3\n";
+ const KeyValueEntry entries[] = {
+ { "key1", "value1" },
+ { "key2", "value2" },
+ { "key3", "value3" }
+ };
+
+ common_key_value_test (str, entries, G_N_ELEMENTS (entries));
+}
+
+static void
+key_value_test_double_quotes (void)
+{
+ const gchar *str =
+ "key1=\"this is a string\","
+ "key2=\"and so is this\"";
+ const KeyValueEntry entries[] = {
+ { "key1", "this is a string" },
+ { "key2", "and so is this" }
+ };
+
+ common_key_value_test (str, entries, G_N_ELEMENTS (entries));
+}
+
+static void
+key_value_test_single_quotes (void)
+{
+ const gchar *str =
+ "key1='this is a string',"
+ "key2='and so is this'";
+ const KeyValueEntry entries[] = {
+ { "key1", "this is a string" },
+ { "key2", "and so is this" }
+ };
+
+ common_key_value_test (str, entries, G_N_ELEMENTS (entries));
+}
+
+static void
+key_value_test_empty_value (void)
+{
+ const gchar *str =
+ "key1=,"
+ "key2=\"\"";
+ const KeyValueEntry entries[] = {
+ { "key1", "" },
+ { "key2", "" }
+ };
+
+ common_key_value_test (str, entries, G_N_ELEMENTS (entries));
+}
+
+static void
+key_value_test_empty_string (void)
+{
+ const gchar *str = "";
+ const KeyValueEntry entries[] = { };
+
+ common_key_value_test (str, entries, G_N_ELEMENTS (entries));
+}
+
+/* ---- Unexpected cases ---- */
+
+static gboolean
+common_key_value_error_test_foreach (const gchar *key,
+ const gchar *value,
+ gpointer none)
+{
+ /* no op */
+ return TRUE;
+}
+
+static void
+common_key_value_error_test (const gchar *str)
+{
+ GError *error = NULL;
+
+ mm_common_parse_key_value_string (str,
+ &error,
+ (MMParseKeyValueForeachFn)common_key_value_error_test_foreach,
+ NULL);
+
+ /* We don't really care about the specific error type */
+ g_assert (error != NULL);
+ g_error_free (error);
+}
+
+static void
+key_value_error_test_no_first_key (void)
+{
+ common_key_value_error_test ("=value1");
+}
+
+static void
+key_value_error_test_no_key (void)
+{
+ common_key_value_error_test ("key1=value1,"
+ "=value2");
+}
+
+static void
+key_value_error_test_missing_double_quotes_0 (void)
+{
+ common_key_value_error_test ("key1=\"value1");
+}
+
+static void
+key_value_error_test_missing_double_quotes_1 (void)
+{
+ common_key_value_error_test ("key1=\"value1,"
+ "key2=\"value2\"");
+}
+
+static void
+key_value_error_test_missing_double_quotes_2 (void)
+{
+ common_key_value_error_test ("key1=\"value1\","
+ "key2=\"value2");
+}
+
+static void
+key_value_error_test_missing_single_quotes_0 (void)
+{
+ common_key_value_error_test ("key1='value1");
+}
+
+static void
+key_value_error_test_missing_single_quotes_1 (void)
+{
+ common_key_value_error_test ("key1='value1,"
+ "key2='value2'");
+}
+
+static void
+key_value_error_test_missing_single_quotes_2 (void)
+{
+ common_key_value_error_test ("key1='value1',"
+ "key2='value2");
+}
+
+static void
+key_value_error_test_missing_comma_0 (void)
+{
+ common_key_value_error_test ("key1=value1 "
+ "key2=value2");
+}
+
+static void
+key_value_error_test_missing_comma_1 (void)
+{
+ common_key_value_error_test ("key1=\"value1\" "
+ "key2=\"value2\"");
+}
+
+static void
+key_value_error_test_missing_comma_2 (void)
+{
+ common_key_value_error_test ("key1='value1' "
+ "key2='value2'");
+}
+
+/********************* BAND ARRAY TESTS *********************/
+
+static void
+common_band_array_cmp_test (gboolean equal,
+ const MMModemBand *bands_a,
+ guint n_bands_a,
+ const MMModemBand *bands_b,
+ guint n_bands_b)
+{
+ GArray *a;
+ GArray *b;
+
+ a = g_array_sized_new (FALSE, FALSE, sizeof (MMModemBand), n_bands_a);
+ g_array_append_vals (a, bands_a, n_bands_a);
+
+ b = g_array_sized_new (FALSE, FALSE, sizeof (MMModemBand), n_bands_b);
+ g_array_append_vals (b, bands_b, n_bands_b);
+
+ g_assert_cmpuint (equal, ==, mm_common_bands_garray_cmp (a, b));
+ g_assert_cmpuint (equal, ==, mm_common_bands_garray_cmp (b, a));
+
+ g_array_unref (a);
+ g_array_unref (b);
+}
+
+static void
+band_array_cmp_test_equal_empty (void)
+{
+ const MMModemBand a[] = { };
+ const MMModemBand b[] = { };
+
+ common_band_array_cmp_test (TRUE, a, G_N_ELEMENTS (a), b, G_N_ELEMENTS (b));
+}
+
+static void
+band_array_cmp_test_equal_one (void)
+{
+ const MMModemBand a[] = { MM_MODEM_BAND_EGSM };
+ const MMModemBand b[] = { MM_MODEM_BAND_EGSM };
+
+ common_band_array_cmp_test (TRUE, a, G_N_ELEMENTS (a), b, G_N_ELEMENTS (b));
+}
+
+static void
+band_array_cmp_test_equal_multiple_same_order (void)
+{
+ const MMModemBand a[] = { MM_MODEM_BAND_EGSM, MM_MODEM_BAND_DCS, MM_MODEM_BAND_PCS };
+ const MMModemBand b[] = { MM_MODEM_BAND_EGSM, MM_MODEM_BAND_DCS, MM_MODEM_BAND_PCS };
+
+ common_band_array_cmp_test (TRUE, a, G_N_ELEMENTS (a), b, G_N_ELEMENTS (b));
+}
+
+static void
+band_array_cmp_test_equal_multiple_different_order (void)
+{
+ const MMModemBand a[] = { MM_MODEM_BAND_EGSM, MM_MODEM_BAND_DCS, MM_MODEM_BAND_PCS };
+ const MMModemBand b[] = { MM_MODEM_BAND_DCS, MM_MODEM_BAND_PCS, MM_MODEM_BAND_EGSM };
+
+ common_band_array_cmp_test (TRUE, a, G_N_ELEMENTS (a), b, G_N_ELEMENTS (b));
+}
+
+static void
+band_array_cmp_test_different_one (void)
+{
+ const MMModemBand a[] = { MM_MODEM_BAND_EGSM };
+ const MMModemBand b[] = { MM_MODEM_BAND_DCS };
+
+ common_band_array_cmp_test (FALSE, a, G_N_ELEMENTS (a), b, G_N_ELEMENTS (b));
+}
+
+static void
+band_array_cmp_test_different_none (void)
+{
+ const MMModemBand a[] = { };
+ const MMModemBand b[] = { MM_MODEM_BAND_EGSM };
+
+ common_band_array_cmp_test (FALSE, a, G_N_ELEMENTS (a), b, G_N_ELEMENTS (b));
+}
+
+static void
+band_array_cmp_test_different_multiple_1 (void)
+{
+ const MMModemBand a[] = { MM_MODEM_BAND_EGSM };
+ const MMModemBand b[] = { MM_MODEM_BAND_EGSM, MM_MODEM_BAND_DCS };
+
+ common_band_array_cmp_test (FALSE, a, G_N_ELEMENTS (a), b, G_N_ELEMENTS (b));
+}
+
+static void
+band_array_cmp_test_different_multiple_2 (void)
+{
+ const MMModemBand a[] = { MM_MODEM_BAND_EGSM };
+ const MMModemBand b[] = { MM_MODEM_BAND_DCS, MM_MODEM_BAND_EGSM };
+
+ common_band_array_cmp_test (FALSE, a, G_N_ELEMENTS (a), b, G_N_ELEMENTS (b));
+}
+
+/********************* FIELD PARSERS TESTS *********************/
+
+static void
+field_parser_int (void)
+{
+ gint num;
+ gchar *str;
+
+ /* Failures */
+
+ g_assert (mm_get_int_from_str (NULL, &num) == FALSE);
+
+ g_assert (mm_get_int_from_str ("", &num) == FALSE);
+
+ g_assert (mm_get_int_from_str ("a", &num) == FALSE);
+
+ g_assert (mm_get_int_from_str ("a100", &num) == FALSE);
+
+ g_assert (mm_get_int_from_str ("100a", &num) == FALSE);
+
+ str = g_strdup_printf ("%" G_GINT64_FORMAT, (gint64)G_MAXINT + 1);
+ g_assert (mm_get_int_from_str (str, &num) == FALSE);
+ g_free (str);
+
+ str = g_strdup_printf ("%" G_GINT64_FORMAT, (gint64)(G_MININT) - 1);
+ g_assert (mm_get_int_from_str (str, &num) == FALSE);
+ g_free (str);
+
+ /* Successes */
+
+ g_assert (mm_get_int_from_str ("0", &num) == TRUE);
+ g_assert_cmpint (num, ==, 0);
+
+ g_assert (mm_get_int_from_str ("-100", &num) == TRUE);
+ g_assert_cmpint (num, ==, -100);
+
+ g_assert (mm_get_int_from_str ("100", &num) == TRUE);
+ g_assert_cmpint (num, ==, 100);
+
+ str = g_strdup_printf ("%" G_GINT64_FORMAT, (gint64)G_MAXINT);
+ g_assert (mm_get_int_from_str (str, &num) == TRUE);
+ g_assert_cmpint (num, ==, G_MAXINT);
+ g_free (str);
+
+ str = g_strdup_printf ("%" G_GINT64_FORMAT, (gint64)G_MININT);
+ g_assert (mm_get_int_from_str (str, &num) == TRUE);
+ g_assert_cmpint (num, ==, G_MININT);
+ g_free (str);
+}
+
+static void
+field_parser_uint (void)
+{
+ gchar *str;
+ guint num;
+
+ /* Failures */
+
+ g_assert (mm_get_uint_from_str (NULL, &num) == FALSE);
+
+ g_assert (mm_get_uint_from_str ("", &num) == FALSE);
+
+ g_assert (mm_get_uint_from_str ("a", &num) == FALSE);
+
+ g_assert (mm_get_uint_from_str ("a100", &num) == FALSE);
+
+ g_assert (mm_get_uint_from_str ("100a", &num) == FALSE);
+
+ g_assert (mm_get_uint_from_str ("-100", &num) == FALSE);
+
+ str = g_strdup_printf ("%" G_GUINT64_FORMAT, (guint64)(G_MAXUINT) + 1);
+ g_assert (mm_get_uint_from_str (str, &num) == FALSE);
+ g_free (str);
+
+ /* Successes */
+
+ g_assert (mm_get_uint_from_str ("0", &num) == TRUE);
+ g_assert_cmpuint (num, ==, 0);
+
+ g_assert (mm_get_uint_from_str ("100", &num) == TRUE);
+ g_assert_cmpuint (num, ==, 100);
+
+ str = g_strdup_printf ("%" G_GUINT64_FORMAT, (guint64)G_MAXUINT);
+ g_assert (mm_get_uint_from_str (str, &num) == TRUE);
+ g_assert_cmpuint (num, ==, G_MAXUINT);
+ g_free (str);
+}
+
+static void
+field_parser_double (void)
+{
+ gchar *str;
+ gdouble num;
+
+ /* Failures */
+
+ g_assert (mm_get_double_from_str (NULL, &num) == FALSE);
+
+ g_assert (mm_get_double_from_str ("", &num) == FALSE);
+
+ g_assert (mm_get_double_from_str ("a", &num) == FALSE);
+
+ g_assert (mm_get_double_from_str ("a100", &num) == FALSE);
+
+ g_assert (mm_get_double_from_str ("100a", &num) == FALSE);
+
+ /* Successes */
+
+ g_assert (mm_get_double_from_str ("-100", &num) == TRUE);
+ g_assert (num - (-100.0) < 0000000.1);
+
+ g_assert (mm_get_double_from_str ("-100.7567", &num) == TRUE);
+ g_assert (num - (-100.7567) < 0000000.1);
+
+ g_assert (mm_get_double_from_str ("0", &num) == TRUE);
+ g_assert (num < 0000000.1);
+
+ g_assert (mm_get_double_from_str ("-0.0", &num) == TRUE);
+ g_assert (num < 0000000.1);
+
+ g_assert (mm_get_double_from_str ("0.0", &num) == TRUE);
+ g_assert (num < 0000000.1);
+
+ g_assert (mm_get_double_from_str ("100", &num) == TRUE);
+ g_assert (num - (100.0) < 0000000.1);
+
+ g_assert (mm_get_double_from_str ("100.7567", &num) == TRUE);
+ g_assert (num - (100.7567) < 0000000.1);
+
+ str = g_strdup_printf ("%lf", (gdouble)G_MINDOUBLE);
+ g_assert (mm_get_double_from_str (str, &num) == TRUE);
+ g_assert (num - G_MINDOUBLE < 0000000.1);
+ g_free (str);
+
+ str = g_strdup_printf ("%lf", (gdouble)G_MAXDOUBLE);
+ g_assert (mm_get_double_from_str (str, &num) == TRUE);
+ g_assert (num - G_MAXDOUBLE < 0000000.1);
+ g_free (str);
+}
+
+/**************************************************************/
+
+int main (int argc, char **argv)
+{
+ g_type_init ();
+ g_test_init (&argc, &argv, NULL);
+
+ g_test_add_func ("/MM/Common/KeyValue/standard", key_value_test_standard);
+ g_test_add_func ("/MM/Common/KeyValue/spaces", key_value_test_spaces);
+ g_test_add_func ("/MM/Common/KeyValue/double-quotes", key_value_test_double_quotes);
+ g_test_add_func ("/MM/Common/KeyValue/single-quotes", key_value_test_single_quotes);
+ g_test_add_func ("/MM/Common/KeyValue/empty-value", key_value_test_empty_value);
+ g_test_add_func ("/MM/Common/KeyValue/empty-string", key_value_test_empty_string);
+
+ g_test_add_func ("/MM/Common/KeyValue/Error/no-first-key", key_value_error_test_no_first_key);
+ g_test_add_func ("/MM/Common/KeyValue/Error/no-key", key_value_error_test_no_key);
+ g_test_add_func ("/MM/Common/KeyValue/Error/missing-double-quotes-0", key_value_error_test_missing_double_quotes_0);
+ g_test_add_func ("/MM/Common/KeyValue/Error/missing-double-quotes-1", key_value_error_test_missing_double_quotes_1);
+ g_test_add_func ("/MM/Common/KeyValue/Error/missing-double-quotes-2", key_value_error_test_missing_double_quotes_2);
+ g_test_add_func ("/MM/Common/KeyValue/Error/missing-single-quotes-0", key_value_error_test_missing_single_quotes_0);
+ g_test_add_func ("/MM/Common/KeyValue/Error/missing-single-quotes-1", key_value_error_test_missing_single_quotes_1);
+ g_test_add_func ("/MM/Common/KeyValue/Error/missing-single-quotes-2", key_value_error_test_missing_single_quotes_2);
+ g_test_add_func ("/MM/Common/KeyValue/Error/missing-comma-0", key_value_error_test_missing_comma_0);
+ g_test_add_func ("/MM/Common/KeyValue/Error/missing-comma-1", key_value_error_test_missing_comma_1);
+ g_test_add_func ("/MM/Common/KeyValue/Error/missing-comma-2", key_value_error_test_missing_comma_2);
+
+ g_test_add_func ("/MM/Common/BandArray/Cmp/equal-empty", band_array_cmp_test_equal_empty);
+ g_test_add_func ("/MM/Common/BandArray/Cmp/equal-one", band_array_cmp_test_equal_one);
+ g_test_add_func ("/MM/Common/BandArray/Cmp/equal-multiple-same-order", band_array_cmp_test_equal_multiple_same_order);
+ g_test_add_func ("/MM/Common/BandArray/Cmp/equal-multiple-different-order", band_array_cmp_test_equal_multiple_different_order);
+ g_test_add_func ("/MM/Common/BandArray/Cmp/different-one", band_array_cmp_test_different_one);
+ g_test_add_func ("/MM/Common/BandArray/Cmp/different-none", band_array_cmp_test_different_none);
+ g_test_add_func ("/MM/Common/BandArray/Cmp/different-multiple-1", band_array_cmp_test_different_multiple_1);
+ g_test_add_func ("/MM/Common/BandArray/Cmp/different-multiple-2", band_array_cmp_test_different_multiple_2);
+
+ g_test_add_func ("/MM/Common/FieldParsers/Int", field_parser_int);
+ g_test_add_func ("/MM/Common/FieldParsers/Uint", field_parser_uint);
+ g_test_add_func ("/MM/Common/FieldParsers/Double", field_parser_double);
+
+ return g_test_run ();
+}