From b17127349fbdb219752656f4004735d90adca3af Mon Sep 17 00:00:00 2001 From: Marcel Holtmann Date: Sat, 11 Jan 2014 20:12:50 -0800 Subject: [PATCH] tools: Add management test cases for secure connections support --- tools/mgmt-tester.c | 143 +++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 140 insertions(+), 3 deletions(-) diff --git a/tools/mgmt-tester.c b/tools/mgmt-tester.c index d5ab24a5a..4053a3732 100644 --- a/tools/mgmt-tester.c +++ b/tools/mgmt-tester.c @@ -1243,6 +1243,114 @@ static const struct generic_data set_ssp_on_invalid_index_test = { .expect_status = MGMT_STATUS_INVALID_INDEX, }; +static uint16_t settings_powered_ssp[] = { MGMT_OP_SET_SSP, + MGMT_OP_SET_POWERED, 0 }; + +static const char set_sc_on_param[] = { 0x01 }; +static const char set_sc_only_on_param[] = { 0x02 }; +static const char set_sc_invalid_param[] = { 0x03 }; +static const char set_sc_garbage_param[] = { 0x01, 0x00 }; +static const char set_sc_settings_param_1[] = { 0xc0, 0x08, 0x00, 0x00 }; +static const char set_sc_settings_param_2[] = { 0xc1, 0x08, 0x00, 0x00 }; +static const char set_sc_on_write_sc_support_param[] = { 0x01 }; + +static const struct generic_data set_sc_on_success_test_1 = { + .setup_settings = settings_ssp, + .send_opcode = MGMT_OP_SET_SECURE_CONN, + .send_param = set_sc_on_param, + .send_len = sizeof(set_sc_on_param), + .expect_status = MGMT_STATUS_SUCCESS, + .expect_param = set_sc_settings_param_1, + .expect_len = sizeof(set_sc_settings_param_1), + .expect_settings_set = MGMT_SETTING_SECURE_CONN, +}; + +static const struct generic_data set_sc_on_success_test_2 = { + .setup_settings = settings_powered_ssp, + .send_opcode = MGMT_OP_SET_SECURE_CONN, + .send_param = set_sc_on_param, + .send_len = sizeof(set_sc_on_param), + .expect_status = MGMT_STATUS_SUCCESS, + .expect_param = set_sc_settings_param_2, + .expect_len = sizeof(set_sc_settings_param_2), + .expect_settings_set = MGMT_SETTING_SECURE_CONN, + .expect_hci_command = BT_HCI_CMD_WRITE_SECURE_CONN_SUPPORT, + .expect_hci_param = set_sc_on_write_sc_support_param, + .expect_hci_len = sizeof(set_sc_on_write_sc_support_param), +}; + +static const struct generic_data set_sc_on_invalid_param_test_1 = { + .setup_settings = settings_ssp, + .send_opcode = MGMT_OP_SET_SECURE_CONN, + .expect_status = MGMT_STATUS_INVALID_PARAMS, +}; + +static const struct generic_data set_sc_on_invalid_param_test_2 = { + .setup_settings = settings_ssp, + .send_opcode = MGMT_OP_SET_SECURE_CONN, + .send_param = set_sc_invalid_param, + .send_len = sizeof(set_sc_invalid_param), + .expect_status = MGMT_STATUS_INVALID_PARAMS, +}; + +static const struct generic_data set_sc_on_invalid_param_test_3 = { + .setup_settings = settings_ssp, + .send_opcode = MGMT_OP_SET_SECURE_CONN, + .send_param = set_sc_garbage_param, + .send_len = sizeof(set_sc_garbage_param), + .expect_status = MGMT_STATUS_INVALID_PARAMS, +}; + +static const struct generic_data set_sc_on_invalid_index_test = { + .setup_settings = settings_ssp, + .send_index_none = true, + .send_opcode = MGMT_OP_SET_SECURE_CONN, + .send_param = set_sc_on_param, + .send_len = sizeof(set_sc_on_param), + .expect_status = MGMT_STATUS_INVALID_INDEX, +}; + +static const struct generic_data set_sc_on_not_supported_test_1 = { + .setup_settings = settings_ssp, + .send_opcode = MGMT_OP_SET_SECURE_CONN, + .send_param = set_sc_on_param, + .send_len = sizeof(set_sc_on_param), + .expect_status = MGMT_STATUS_NOT_SUPPORTED, +}; + +static const struct generic_data set_sc_on_not_supported_test_2 = { + .setup_settings = settings_powered_ssp, + .send_opcode = MGMT_OP_SET_SECURE_CONN, + .send_param = set_sc_on_param, + .send_len = sizeof(set_sc_on_param), + .expect_status = MGMT_STATUS_NOT_SUPPORTED, +}; + +static const struct generic_data set_sc_only_on_success_test_1 = { + .setup_settings = settings_ssp, + .send_opcode = MGMT_OP_SET_SECURE_CONN, + .send_param = set_sc_only_on_param, + .send_len = sizeof(set_sc_only_on_param), + .expect_status = MGMT_STATUS_SUCCESS, + .expect_param = set_sc_settings_param_1, + .expect_len = sizeof(set_sc_settings_param_1), + .expect_settings_set = MGMT_SETTING_SECURE_CONN, +}; + +static const struct generic_data set_sc_only_on_success_test_2 = { + .setup_settings = settings_powered_ssp, + .send_opcode = MGMT_OP_SET_SECURE_CONN, + .send_param = set_sc_only_on_param, + .send_len = sizeof(set_sc_only_on_param), + .expect_status = MGMT_STATUS_SUCCESS, + .expect_param = set_sc_settings_param_2, + .expect_len = sizeof(set_sc_settings_param_2), + .expect_settings_set = MGMT_SETTING_SECURE_CONN, + .expect_hci_command = BT_HCI_CMD_WRITE_SECURE_CONN_SUPPORT, + .expect_hci_param = set_sc_on_write_sc_support_param, + .expect_hci_len = sizeof(set_sc_on_write_sc_support_param), +}; + static const char set_hs_on_param[] = { 0x01 }; static const char set_hs_invalid_param[] = { 0x02 }; static const char set_hs_garbage_param[] = { 0x01, 0x00 }; @@ -1478,9 +1586,6 @@ static const struct generic_data set_bredr_off_failure_test_3 = { .expect_status = MGMT_STATUS_INVALID_PARAMS, }; -static uint16_t settings_powered_ssp[] = { MGMT_OP_SET_SSP, - MGMT_OP_SET_POWERED, 0 }; - static const char set_local_name_param[260] = { 'T', 'e', 's', 't', ' ', 'n', 'a', 'm', 'e' }; static const char write_local_name_hci[248] = { 'T', 'e', 's', 't', ' ', @@ -3203,6 +3308,38 @@ int main(int argc, char *argv[]) &set_ssp_on_invalid_index_test, NULL, test_command_generic); + test_bredrle("Set Secure Connections on - Success 1", + &set_sc_on_success_test_1, + NULL, test_command_generic); + test_bredrle("Set Secure Connections on - Success 2", + &set_sc_on_success_test_2, + NULL, test_command_generic); + test_bredrle("Set Secure Connections on - Invalid params 1", + &set_sc_on_invalid_param_test_1, + NULL, test_command_generic); + test_bredrle("Set Secure Connections on - Invalid params 2", + &set_sc_on_invalid_param_test_2, + NULL, test_command_generic); + test_bredrle("Set Secure Connections on - Invalid params 3", + &set_sc_on_invalid_param_test_3, + NULL, test_command_generic); + test_bredrle("Set Secure Connections on - Invalid index", + &set_sc_on_invalid_index_test, + NULL, test_command_generic); + test_bredr("Set Secure Connections on - Not supported 1", + &set_sc_on_not_supported_test_1, + NULL, test_command_generic); + test_bredr("Set Secure Connections on - Not supported 2", + &set_sc_on_not_supported_test_2, + NULL, test_command_generic); + + test_bredrle("Set Secure Connections Only on - Success 1", + &set_sc_only_on_success_test_1, + NULL, test_command_generic); + test_bredrle("Set Secure Connections Only on - Success 2", + &set_sc_only_on_success_test_2, + NULL, test_command_generic); + test_bredrle("Set High Speed on - Success", &set_hs_on_success_test, NULL, test_command_generic); -- 2.47.3