summaryrefslogtreecommitdiffstats
path: root/unit/test-sms.c
diff options
context:
space:
mode:
authorDenis Kenzior <denkenz@gmail.com>2009-06-14 02:00:39 -0500
committerDenis Kenzior <denkenz@gmail.com>2009-06-14 02:02:16 -0500
commite9a0e82e53318120bebd8b0b7a09202872604f83 (patch)
tree6ae2640fad7a4f73311cbd3871497c1576f94799 /unit/test-sms.c
parentc5511db5c56c75f496223bbc1fa52b7a1fc30bbf (diff)
downloadofono-e9a0e82e53318120bebd8b0b7a09202872604f83.tar.bz2
Add Unit test for SMS re-assembly code
Diffstat (limited to 'unit/test-sms.c')
-rw-r--r--unit/test-sms.c83
1 files changed, 83 insertions, 0 deletions
diff --git a/unit/test-sms.c b/unit/test-sms.c
index da71c346..d3cd39f1 100644
--- a/unit/test-sms.c
+++ b/unit/test-sms.c
@@ -584,6 +584,88 @@ static void test_udh_iter()
g_free(utf8);
}
+static const char *assembly_pdu1 = "038121F350048155550119906041001222048C0500"
+ "031E0301041804420430043A002C002004100"
+ "43B0435043A04410430043D04340440002000"
+ "200441043B044304480430043B00200437043"
+ "000200434043204350440044C044E00200020"
+ "04380020002004320441043500200431043E0"
+ "43B044C044804350020043F04400435043804"
+ "41043F043E043B043D044F043B0441044F002"
+ "000200433043D0435";
+static int assembly_pdu_len1 = 155;
+
+static const char *assembly_pdu2 = "038121F350048155550119906041001222048C0500"
+ "031E03020432043E043C002E000A041D04300"
+ "43A043E043D04350446002C0020043D043500"
+ "200432002004410438043B043004450020043"
+ "40430043B043504350020044204350440043F"
+ "04350442044C002C0020043E043D002004410"
+ "44204400435043C043804420435043B044C04"
+ "3D043E002004320431043504360430043B002"
+ "004320020043A043E";
+static int assembly_pdu_len2 = 155;
+
+static const char *assembly_pdu3 = "038121F350048155550119906041001222044A0500"
+ "031E0303043C043D043004420443002C00200"
+ "43F043E043704300431044B0432000A043404"
+ "3004360435002C002004470442043E0020002"
+ "00431044B043B0020043D04300433002E";
+static int assembly_pdu_len3 = 89;
+
+static void test_assembly()
+{
+ unsigned char pdu[164];
+ long pdu_len;
+ struct sms sms;
+ struct sms_assembly *assembly = sms_assembly_new();
+ guint16 ref;
+ guint8 max;
+ guint8 seq;
+ GSList *l;
+
+ decode_hex_own_buf(assembly_pdu1, -1, &pdu_len, 0, pdu);
+ sms_decode(pdu, pdu_len, FALSE, assembly_pdu_len1, &sms);
+
+ sms_extract_concatenation(&sms, &ref, &max, &seq);
+ l = sms_assembly_add_fragment(assembly, &sms, time(NULL),
+ &sms.deliver.oaddr, ref, max, seq);
+
+ g_assert(g_slist_length(assembly->assembly_list) == 1);
+ g_assert(l == NULL);
+
+ sms_assembly_expire(assembly, time(NULL) + 40);
+
+ g_assert(g_slist_length(assembly->assembly_list) == 0);
+
+ sms_extract_concatenation(&sms, &ref, &max, &seq);
+ l = sms_assembly_add_fragment(assembly, &sms, time(NULL),
+ &sms.deliver.oaddr, ref, max, seq);
+ g_assert(g_slist_length(assembly->assembly_list) == 1);
+ g_assert(l == NULL);
+
+ decode_hex_own_buf(assembly_pdu2, -1, &pdu_len, 0, pdu);
+ sms_decode(pdu, pdu_len, FALSE, assembly_pdu_len2, &sms);
+
+ sms_extract_concatenation(&sms, &ref, &max, &seq);
+ l = sms_assembly_add_fragment(assembly, &sms, time(NULL),
+ &sms.deliver.oaddr, ref, max, seq);
+ g_assert(l == NULL);
+
+ decode_hex_own_buf(assembly_pdu3, -1, &pdu_len, 0, pdu);
+ sms_decode(pdu, pdu_len, FALSE, assembly_pdu_len3, &sms);
+
+ sms_extract_concatenation(&sms, &ref, &max, &seq);
+ l = sms_assembly_add_fragment(assembly, &sms, time(NULL),
+ &sms.deliver.oaddr, ref, max, seq);
+ g_assert(l != NULL);
+
+ g_slist_foreach(l, (GFunc)g_free, NULL);
+ g_slist_free(l);
+
+ sms_assembly_free(assembly);
+}
+
int main(int argc, char **argv)
{
g_test_init(&argc, &argv, NULL);
@@ -594,6 +676,7 @@ int main(int argc, char **argv)
g_test_add_func("/testsms/Test Simple Submit", test_simple_submit);
g_test_add_func("/testsms/Test Submit Encode", test_submit_encode);
g_test_add_func("/testsms/Test UDH Iterator", test_udh_iter);
+ g_test_add_func("/testsms/Test Assembly", test_assembly);
return g_test_run();
}