diff options
author | Denis Kenzior <denkenz@gmail.com> | 2009-09-08 16:43:53 -0500 |
---|---|---|
committer | Denis Kenzior <denkenz@gmail.com> | 2009-09-08 16:43:53 -0500 |
commit | 21f5f0cf92682f5b62fc7691f456f28f8430f0da (patch) | |
tree | d34cbecf695fa7d0857b9aa949fd473089e8a6ce /unit/test-sms.c | |
parent | 3449b2c0b5f100c8b1838867061664dd1e117c25 (diff) | |
download | ofono-21f5f0cf92682f5b62fc7691f456f28f8430f0da.tar.bz2 |
Add unit test for sms assembly serialization
Diffstat (limited to 'unit/test-sms.c')
-rw-r--r-- | unit/test-sms.c | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/unit/test-sms.c b/unit/test-sms.c index 961c6b87..fa989e4c 100644 --- a/unit/test-sms.c +++ b/unit/test-sms.c @@ -1007,6 +1007,58 @@ static void test_cbs_assembly() cbs_assembly_free(assembly); } +static void test_serialize_assembly() +{ + unsigned char pdu[164]; + long pdu_len; + struct sms sms; + struct sms_assembly *assembly = sms_assembly_new("1234"); + 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); + + if (g_test_verbose()) { + g_print("Ref: %u\n", ref); + g_print("Max: %u\n", max); + g_print("From: %s\n", + sms_address_to_string(&sms.deliver.oaddr)); + } + + 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); + + sms_assembly_free(assembly); + + assembly = sms_assembly_new("1234"); + + 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); + + sms_assembly_free(assembly); +} + int main(int argc, char **argv) { g_test_init(&argc, &argv, NULL); @@ -1025,5 +1077,8 @@ int main(int argc, char **argv) test_cbs_encode_decode); g_test_add_func("/testsms/Test CBS Assembly", test_cbs_assembly); + g_test_add_func("/testsms/Test SMS Assembly Serialize", + test_serialize_assembly); + return g_test_run(); } |