diff options
author | Aleksander Morgado <aleksander@aleksander.es> | 2016-10-11 16:27:51 +0200 |
---|---|---|
committer | Aleksander Morgado <aleksander@aleksander.es> | 2016-10-12 11:29:52 +0200 |
commit | aca6bb1c02ddc16d88fb8c9fd934466eb7debf5c (patch) | |
tree | 157c9d96d8331e00dfe3b090a89b084e71e98886 /src/tests/test-modem-helpers.c | |
parent | b34f147ba27b9d328a17bee092d0d21bd20eb200 (diff) |
modem-helpers: new +CFUN? response parser
Diffstat (limited to 'src/tests/test-modem-helpers.c')
-rw-r--r-- | src/tests/test-modem-helpers.c | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/src/tests/test-modem-helpers.c b/src/tests/test-modem-helpers.c index 14f32961..0d70f051 100644 --- a/src/tests/test-modem-helpers.c +++ b/src/tests/test-modem-helpers.c @@ -3059,6 +3059,71 @@ test_cgcontrdp_response (void) } /*****************************************************************************/ +/* Test CFUN? response */ + +typedef struct { + const gchar *str; + guint state; +} CfunQueryTest; + +static const CfunQueryTest cfun_query_tests[] = { + { "+CFUN: 1", 1 }, + { "+CFUN: 1,0", 1 }, + { "+CFUN: 0", 0 }, + { "+CFUN: 0,0", 0 }, + { "+CFUN: 19", 19 }, + { "+CFUN: 19,0", 19 }, +}; + +static void +test_cfun_response (void) +{ + guint i; + + for (i = 0; i < G_N_ELEMENTS (cfun_query_tests); i++) { + GError *error = NULL; + gboolean success; + guint state = G_MAXUINT; + + success = mm_3gpp_parse_cfun_query_response (cfun_query_tests[i].str, &state, &error); + g_assert_no_error (error); + g_assert (success); + g_assert_cmpuint (cfun_query_tests[i].state, ==, state); + } +} + +typedef struct { + const gchar *str; + MMModemPowerState state; +} CfunQueryGenericTest; + +static const CfunQueryGenericTest cfun_query_generic_tests[] = { + { "+CFUN: 1", MM_MODEM_POWER_STATE_ON }, + { "+CFUN: 1,0", MM_MODEM_POWER_STATE_ON }, + { "+CFUN: 0", MM_MODEM_POWER_STATE_OFF }, + { "+CFUN: 0,0", MM_MODEM_POWER_STATE_OFF }, + { "+CFUN: 4", MM_MODEM_POWER_STATE_LOW }, + { "+CFUN: 4,0", MM_MODEM_POWER_STATE_LOW }, +}; + +static void +test_cfun_generic_response (void) +{ + guint i; + + for (i = 0; i < G_N_ELEMENTS (cfun_query_generic_tests); i++) { + GError *error = NULL; + gboolean success; + MMModemPowerState state = MM_MODEM_POWER_STATE_UNKNOWN; + + success = mm_3gpp_parse_cfun_query_generic_response (cfun_query_generic_tests[i].str, &state, &error); + g_assert_no_error (error); + g_assert (success); + g_assert_cmpuint (cfun_query_generic_tests[i].state, ==, state); + } +} + +/*****************************************************************************/ typedef struct { gchar *str; @@ -3288,6 +3353,9 @@ int main (int argc, char **argv) g_test_suite_add (suite, TESTCASE (test_cgcontrdp_response, NULL)); + g_test_suite_add (suite, TESTCASE (test_cfun_response, NULL)); + g_test_suite_add (suite, TESTCASE (test_cfun_generic_response, NULL)); + g_test_suite_add (suite, TESTCASE (test_parse_uint_list, NULL)); result = g_test_run (); |