diff options
author | Luiz Augusto von Dentz <luiz.von.dentz@intel.com> | 2014-12-05 14:17:16 +0200 |
---|---|---|
committer | Luiz Augusto von Dentz <luiz.von.dentz@intel.com> | 2014-12-12 12:24:10 -0200 |
commit | 5b34d4bcecfd7d272749f6c6daccfe8309d44f4f (patch) | |
tree | d7c4f8fbc9ca8a5cc0ec278373133826c6b89301 /unit/test-mgmt.c | |
parent | 14ee81e7371091047d2643b36bb191b67f867cc1 (diff) | |
download | bluez-5b34d4bcecfd7d272749f6c6daccfe8309d44f4f.tar.gz |
unit/test-mgmt: Add /mgmt/response/2 test
This tests if an error can be received.
Diffstat (limited to 'unit/test-mgmt.c')
-rw-r--r-- | unit/test-mgmt.c | 38 |
1 files changed, 30 insertions, 8 deletions
diff --git a/unit/test-mgmt.c b/unit/test-mgmt.c index ead088c06..7bff8285e 100644 --- a/unit/test-mgmt.c +++ b/unit/test-mgmt.c @@ -54,6 +54,7 @@ struct handler { uint16_t cmd_size; const void *rsp_data; uint16_t rsp_size; + uint8_t rsp_status; bool match_prefix; enum action action; }; @@ -185,7 +186,8 @@ static void execute_context(struct context *context) static void add_action(struct context *context, const void *cmd_data, uint16_t cmd_size, const void *rsp_data, uint16_t rsp_size, - bool match_prefix, enum action action) + uint8_t rsp_status, bool match_prefix, + enum action action) { struct handler *handler = g_new0(struct handler, 1); @@ -193,6 +195,7 @@ static void add_action(struct context *context, handler->cmd_size = cmd_size; handler->rsp_data = rsp_data; handler->rsp_size = rsp_size; + handler->rsp_status = rsp_status; handler->match_prefix = match_prefix; handler->action = action; @@ -208,6 +211,7 @@ struct command_test_data { uint16_t cmd_size; const void *rsp_data; uint16_t rsp_size; + uint8_t rsp_status; }; static const unsigned char read_version_command[] = @@ -223,6 +227,7 @@ static const struct command_test_data command_test_1 = { .cmd_size = sizeof(read_version_command), .rsp_data = read_version_response, .rsp_size = sizeof(read_version_response), + .rsp_status = MGMT_STATUS_SUCCESS, }; static const unsigned char read_info_command[] = @@ -235,14 +240,28 @@ static const struct command_test_data command_test_2 = { .cmd_size = sizeof(read_info_command), }; +static const unsigned char invalid_index_response[] = + { 0x02, 0x00, 0xff, 0xff, 0x03, 0x00, + 0x01, 0x00, 0x11 }; + +static const struct command_test_data command_test_3 = { + .opcode = MGMT_OP_READ_VERSION, + .index = MGMT_INDEX_NONE, + .cmd_data = read_version_command, + .cmd_size = sizeof(read_version_command), + .rsp_data = invalid_index_response, + .rsp_size = sizeof(invalid_index_response), + .rsp_status = MGMT_STATUS_INVALID_INDEX, +}; + static void test_command(gconstpointer data) { const struct command_test_data *test = data; struct context *context = create_context(); add_action(context, test->cmd_data, test->cmd_size, - test->rsp_data, test->rsp_size, - false, ACTION_PASSED); + test->rsp_data, test->rsp_size, test->rsp_status, + false, ACTION_PASSED); mgmt_send(context->mgmt_client, test->opcode, test->index, test->length, test->param, @@ -251,12 +270,13 @@ static void test_command(gconstpointer data) execute_context(context); } -static void success_cb(uint8_t status, uint16_t length, const void *param, +static void response_cb(uint8_t status, uint16_t length, const void *param, void *user_data) { struct context *context = user_data; + struct handler *handler = context->handler_list->data; - g_assert_cmpint(status, ==, MGMT_STATUS_SUCCESS); + g_assert_cmpint(status, ==, handler->rsp_status); context_quit(context); } @@ -267,12 +287,12 @@ static void test_response(gconstpointer data) struct context *context = create_context(); add_action(context, test->cmd_data, test->cmd_size, - test->rsp_data, test->rsp_size, - false, ACTION_RESPOND); + test->rsp_data, test->rsp_size, test->rsp_status, + false, ACTION_RESPOND); mgmt_send(context->mgmt_client, test->opcode, test->index, test->length, test->param, - success_cb, context, NULL); + response_cb, context, NULL); execute_context(context); } @@ -286,6 +306,8 @@ int main(int argc, char *argv[]) g_test_add_data_func("/mgmt/response/1", &command_test_1, test_response); + g_test_add_data_func("/mgmt/response/2", &command_test_3, + test_response); return g_test_run(); } |