aboutsummaryrefslogtreecommitdiff
path: root/src/tests/test-modem-helpers.c
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@aleksander.es>2016-10-05 13:45:41 +0200
committerAleksander Morgado <aleksander@aleksander.es>2016-10-12 13:24:08 +0200
commitdf6f6d1f37dfeb27c27cf54e6181df9eaf162322 (patch)
tree35c01851d51c7fd071e7eeecfaad8a589d00e7c8 /src/tests/test-modem-helpers.c
parent9b3549e375af5d80fa9986cdbddfa51fe16dfe3e (diff)
modem-helpers: new +CESQ response parser
Diffstat (limited to 'src/tests/test-modem-helpers.c')
-rw-r--r--src/tests/test-modem-helpers.c76
1 files changed, 76 insertions, 0 deletions
diff --git a/src/tests/test-modem-helpers.c b/src/tests/test-modem-helpers.c
index ab54cd55..da5416d1 100644
--- a/src/tests/test-modem-helpers.c
+++ b/src/tests/test-modem-helpers.c
@@ -3081,6 +3081,7 @@ test_cgcontrdp_response (void)
}
/*****************************************************************************/
+<<<<<<< HEAD
/* Test CFUN? response */
typedef struct {
@@ -3111,6 +3112,79 @@ test_cfun_response (void)
g_assert_no_error (error);
g_assert (success);
g_assert_cmpuint (cfun_query_tests[i].state, ==, state);
+=======
+/* Test +CESQ responses */
+
+typedef struct {
+ const gchar *str;
+ guint rxlev;
+ guint ber;
+ guint rscp;
+ guint ecn0;
+ guint rsrq;
+ guint rsrp;
+} CesqResponseTest;
+
+static const CesqResponseTest cesq_response_tests[] = {
+ {
+ .str = "+CESQ: 99,99,255,255,20,80",
+ .rxlev = 99,
+ .ber = 99,
+ .rscp = 255,
+ .ecn0 = 255,
+ .rsrq = 20,
+ .rsrp = 80
+ },
+ {
+ .str = "+CESQ: 99,99,95,40,255,255",
+ .rxlev = 99,
+ .ber = 99,
+ .rscp = 95,
+ .ecn0 = 40,
+ .rsrq = 255,
+ .rsrp = 255
+ },
+ {
+ .str = "+CESQ: 10,6,255,255,255,255",
+ .rxlev = 10,
+ .ber = 6,
+ .rscp = 255,
+ .ecn0 = 255,
+ .rsrq = 255,
+ .rsrp = 255
+ }
+};
+
+static void
+test_cesq_response (void)
+{
+ guint i;
+
+ for (i = 0; i < G_N_ELEMENTS (cesq_response_tests); i++) {
+ GError *error = NULL;
+ gboolean success;
+ guint rxlev = G_MAXUINT;
+ guint ber = G_MAXUINT;
+ guint rscp = G_MAXUINT;
+ guint ecn0 = G_MAXUINT;
+ guint rsrq = G_MAXUINT;
+ guint rsrp = G_MAXUINT;
+
+ success = mm_3gpp_parse_cesq_response (cesq_response_tests[i].str,
+ &rxlev, &ber,
+ &rscp, &ecn0,
+ &rsrq, &rsrp,
+ &error);
+ g_assert_no_error (error);
+ g_assert (success);
+
+ g_assert_cmpuint (cesq_response_tests[i].rxlev, ==, rxlev);
+ g_assert_cmpuint (cesq_response_tests[i].ber, ==, ber);
+ g_assert_cmpuint (cesq_response_tests[i].rscp, ==, rscp);
+ g_assert_cmpuint (cesq_response_tests[i].ecn0, ==, ecn0);
+ g_assert_cmpuint (cesq_response_tests[i].rsrq, ==, rsrq);
+ g_assert_cmpuint (cesq_response_tests[i].rsrp, ==, rsrp);
+>>>>>>> fa0bc3bc... modem-helpers: new +CESQ response parser
}
}
@@ -3380,6 +3454,8 @@ int main (int argc, char **argv)
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_cesq_response, NULL));
+
g_test_suite_add (suite, TESTCASE (test_parse_uint_list, NULL));
result = g_test_run ();