From 51c28d0f79cfebae60982b824abbfbdf2d730f68 Mon Sep 17 00:00:00 2001 From: Aleksander Morgado Date: Tue, 6 Mar 2012 13:09:34 +0100 Subject: modem-helpers: new +CNUM response parser and tests --- src/tests/test-modem-helpers.c | 105 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 105 insertions(+) (limited to 'src/tests/test-modem-helpers.c') diff --git a/src/tests/test-modem-helpers.c b/src/tests/test-modem-helpers.c index db2933e8..0d789ab6 100644 --- a/src/tests/test-modem-helpers.c +++ b/src/tests/test-modem-helpers.c @@ -1307,6 +1307,105 @@ test_cpms_response_cinterion (void *f, gpointer d) g_assert (is_storage_supported (mem3, MM_SMS_STORAGE_MT)); } +/*****************************************************************************/ +/* Test CNUM responses */ + +static void +test_cnum_results (const gchar *desc, + const gchar *reply, + const GStrv expected) +{ + GStrv results; + GError *error = NULL; + guint i; + + g_print ("\nTesting +CNUM response (%s)...\n", desc); + + results = mm_3gpp_parse_cnum_response (reply, &error); + g_assert (results); + g_assert_no_error (error); + g_assert_cmpuint (g_strv_length (results), ==, g_strv_length (expected)); + + for (i = 0; results[i]; i++) { + guint j; + + for (j = 0; expected[j]; j++) { + if (g_str_equal (results[i], expected[j])) + break; + } + + /* Ensure the result is found in the expected list */ + g_assert (expected[j]); + } + + g_strfreev (results); +} + +static void +test_cnum_response_generic (void *f, gpointer d) +{ + const gchar *reply = "+CNUM: \"something\",\"1234567890\",161"; + const gchar *expected[] = { + "1234567890", + NULL + }; + + test_cnum_results ("Generic", reply, (GStrv)expected); +} + +static void +test_cnum_response_generic_without_detail (void *f, gpointer d) +{ + const gchar *reply = "+CNUM: ,\"1234567890\",161"; + const gchar *expected[] = { + "1234567890", + NULL + }; + + test_cnum_results ("Generic, without detail", reply, (GStrv)expected); +} + +static void +test_cnum_response_generic_detail_unquoted (void *f, gpointer d) +{ + const gchar *reply = "+CNUM: something,\"1234567890\",161"; + const gchar *expected[] = { + "1234567890", + NULL + }; + + test_cnum_results ("Generic, detail unquoted", reply, (GStrv)expected); +} + +static void +test_cnum_response_generic_international_number (void *f, gpointer d) +{ + const gchar *reply = "+CNUM: something,\"+34600000001\",145"; + const gchar *expected[] = { + "+34600000001", + NULL + }; + + test_cnum_results ("Generic, international number", reply, (GStrv)expected); +} + +static void +test_cnum_response_generic_multiple_numbers (void *f, gpointer d) +{ + const gchar *reply = + "+CNUM: something,\"+34600000001\",145\r\n" + "+CNUM: ,\"+34600000002\",145\r\n" + "+CNUM: \"another\",\"1234567890\",161"; + const gchar *expected[] = { + "+34600000001", + "+34600000002", + "1234567890", + NULL + }; + + test_cnum_results ("Generic, multiple numbers", reply, (GStrv)expected); +} + /*****************************************************************************/ void @@ -1408,6 +1507,12 @@ int main (int argc, char **argv) g_test_suite_add (suite, TESTCASE (test_cgdcont_response_nokia, NULL)); + g_test_suite_add (suite, TESTCASE (test_cnum_response_generic, NULL)); + g_test_suite_add (suite, TESTCASE (test_cnum_response_generic_without_detail, NULL)); + g_test_suite_add (suite, TESTCASE (test_cnum_response_generic_detail_unquoted, NULL)); + g_test_suite_add (suite, TESTCASE (test_cnum_response_generic_international_number, NULL)); + g_test_suite_add (suite, TESTCASE (test_cnum_response_generic_multiple_numbers, NULL)); + result = g_test_run (); reg_test_data_free (reg_data); -- cgit v1.2.3-70-g09d2