From cc291810aab621012df19bf947d4bcd04249d269 Mon Sep 17 00:00:00 2001 From: Anderson Lizardo Date: Thu, 10 Jan 2013 21:22:01 -0400 Subject: [PATCH] unit: Add {TEXT,URL}_STR{8,16} tests for sdp_extract_attr() These tests are for valid data. Other tests might be added later to check for error paths, but will require separate macros. {TEXT,URL}_STR32 cannot be tested with the same macros because sdp_extract_attr() does not support them. They will be tested separately with other SDP library functions. As example of failure output, if commit 504a0cf46ad89cab8005ce9cffb22e41048f6a30 is reverted for testing, the STR16 test will fail with: ERROR:unit/test-sdp.c:776:test_sdp_de_attr: assertion failed (test->input_size == size): (7 == 11) --- unit/test-sdp.c | 78 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) diff --git a/unit/test-sdp.c b/unit/test-sdp.c index 8d48c71d2..e02fa956b 100644 --- a/unit/test-sdp.c +++ b/unit/test-sdp.c @@ -85,6 +85,29 @@ struct test_data { #define define_ssa(name, args...) define_test("/TP/SERVER/SSA/" name, 48, args) #define define_brw(name, args...) define_test("/TP/SERVER/BRW/" name, 672, args) +/* SDP Data Element (DE) tests */ +struct test_data_de { + const void *input_data; + size_t input_size; + sdp_data_t expected; +}; + +#define exp_data(_dtd, val_type, val_data) \ + ((const sdp_data_t) { \ + .dtd = _dtd, \ + .val.val_type = val_data, \ + }) + +#define define_test_de_attr(name, input, exp) \ + do { \ + static struct test_data_de data; \ + data.input_data = input; \ + data.input_size = sizeof(input); \ + data.expected = exp; \ + g_test_add_data_func("/sdp/DE/ATTR/" name, &data, \ + test_sdp_de_attr); \ + } while (0) + struct context { GMainLoop *main_loop; guint server_source; @@ -736,6 +759,34 @@ static void test_sdp(gconstpointer data) g_free(test->pdu_list); } +static void test_sdp_de_attr(gconstpointer data) +{ + const struct test_data_de *test = data; + sdp_data_t *d; + int size = 0; + + d = sdp_extract_attr(test->input_data, test->input_size, &size, NULL); + g_assert(d != NULL); + g_assert_cmpuint(test->input_size, ==, size); + g_assert_cmpuint(test->expected.dtd, ==, d->dtd); + + if (g_test_verbose() == TRUE) + g_print("DTD=0x%02x\n", d->dtd); + + switch (d->dtd) { + case SDP_TEXT_STR8: + case SDP_TEXT_STR16: + case SDP_URL_STR8: + case SDP_URL_STR16: + g_assert_cmpstr(test->expected.val.str, ==, d->val.str); + break; + default: + g_assert_not_reached(); + } + + sdp_data_free(d); +} + int main(int argc, char *argv[]) { g_test_init(&argc, &argv, NULL); @@ -2691,5 +2742,32 @@ int main(int argc, char *argv[]) 0x08, 0x09, 0x00, 0x01, 0x35, 0x03, 0x19, 0x11, 0x06, 0x00)); + /* + * SDP Data Element (DE) tests + * + * Test extraction of valid DEs supported by sdp_extract_attr(). + */ + define_test_de_attr("TEXT_STR8/empty", + raw_data(0x25, 0x00), + exp_data(SDP_TEXT_STR8, str, "")); + define_test_de_attr("TEXT_STR8", + raw_data(0x25, 0x04, 0x41, 0x42, 0x43, 0x44), + exp_data(SDP_TEXT_STR8, str, "ABCD")); + define_test_de_attr("TEXT_STR16", + raw_data(0x26, 0x00, 0x04, 0x41, 0x42, 0x43, 0x44), + exp_data(SDP_TEXT_STR16, str, "ABCD")); + define_test_de_attr("URL_STR8", + raw_data(0x45, 0x15, 0x68, 0x74, 0x74, 0x70, 0x3a, + 0x2f, 0x2f, 0x77, 0x77, 0x77, 0x2e, 0x62, 0x6c, + 0x75, 0x65, 0x7a, 0x2e, 0x6f, 0x72, 0x67, + 0x2f), + exp_data(SDP_URL_STR8, str, "http://www.bluez.org/")); + define_test_de_attr("URL_STR16", + raw_data(0x46, 0x00, 0x15, 0x68, 0x74, 0x74, 0x70, + 0x3a, 0x2f, 0x2f, 0x77, 0x77, 0x77, 0x2e, 0x62, + 0x6c, 0x75, 0x65, 0x7a, 0x2e, 0x6f, 0x72, 0x67, + 0x2f), + exp_data(SDP_URL_STR16, str, "http://www.bluez.org/")); + return g_test_run(); } -- 2.47.3