aboutsummaryrefslogtreecommitdiff
path: root/src/tests/test-modem-helpers.c
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@aleksander.es>2016-10-11 16:27:51 +0200
committerAleksander Morgado <aleksander@aleksander.es>2016-10-12 11:29:52 +0200
commitaca6bb1c02ddc16d88fb8c9fd934466eb7debf5c (patch)
tree157c9d96d8331e00dfe3b090a89b084e71e98886 /src/tests/test-modem-helpers.c
parentb34f147ba27b9d328a17bee092d0d21bd20eb200 (diff)
modem-helpers: new +CFUN? response parser
Diffstat (limited to 'src/tests/test-modem-helpers.c')
-rw-r--r--src/tests/test-modem-helpers.c68
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 ();