diff options
author | Grzegorz Kolodziejczyk <grzegorz.kolodziejczyk@tieto.com> | 2014-10-06 14:54:03 +0200 |
---|---|---|
committer | Szymon Janc <szymon.janc@tieto.com> | 2014-10-06 16:02:04 +0200 |
commit | cd21d88d9a8f79a9ef98c4bc61e5c0d797ae9896 (patch) | |
tree | 16d6551e271d9af4b08dfdb633eb232e3f9e35d8 /android/tester-gatt.c | |
parent | 4856dd3625f9f8776957ea6f93d0b5699fb3a64a (diff) | |
download | bluez-cd21d88d9a8f79a9ef98c4bc61e5c0d797ae9896.tar.gz |
android/tester: Add GATT server add descriptor test cases
This adds descriptor add by server test cases.
Diffstat (limited to 'android/tester-gatt.c')
-rw-r--r-- | android/tester-gatt.c | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/android/tester-gatt.c b/android/tester-gatt.c index 6ad9bfe59..e86e929a9 100644 --- a/android/tester-gatt.c +++ b/android/tester-gatt.c @@ -131,6 +131,13 @@ struct add_char_data { int permissions; }; +struct add_desc_data { + int app_id; + int *srvc_handle; + bt_uuid_t *uuid; + int permissions; +}; + static bt_bdaddr_t emu_remote_bdaddr_val = { .address = { 0x00, 0xaa, 0x01, 0x01, 0x00, 0x00 }, }; @@ -383,6 +390,12 @@ static struct add_service_data add_service_data_5 = { .num_handles = 3 }; +static struct add_service_data add_service_data_6 = { + .app_id = APP1_ID, + .service = &service_add_1, + .num_handles = 4 +}; + static struct add_service_data add_bad_service_data_1 = { .app_id = APP1_ID, .service = &service_add_1, @@ -425,6 +438,27 @@ static struct add_char_data add_bad_char_data_1 = { .permissions = 0 }; +static struct add_desc_data add_bad_desc_data_1 = { + .app_id = APP1_ID, + .srvc_handle = &srvc_bad_handle, + .uuid = &app2_uuid, + .permissions = 0 +}; + +static struct add_desc_data add_bad_desc_data_2 = { + .app_id = APP2_ID, + .srvc_handle = &srvc1_handle, + .uuid = &app2_uuid, + .permissions = 0 +}; + +static struct add_desc_data add_desc_data_1 = { + .app_id = APP1_ID, + .srvc_handle = &srvc1_handle, + .uuid = &app2_uuid, + .permissions = 0 +}; + struct set_read_params { btgatt_read_params_t *params; btgatt_srvc_id_t *srvc_id; @@ -1172,6 +1206,22 @@ static void gatt_server_add_char_action(void) schedule_action_verification(step); } +static void gatt_server_add_desc_action(void) +{ + struct test_data *data = tester_get_data(); + struct step *current_data_step = queue_peek_head(data->steps); + struct add_desc_data *add_desc_data = current_data_step->set_data; + struct step *step = g_new0(struct step, 1); + + step->action_status = data->if_gatt->server->add_descriptor( + add_desc_data->app_id, + *add_desc_data->srvc_handle, + add_desc_data->uuid, + add_desc_data->permissions); + + schedule_action_verification(step); +} + static void gatt_cid_hook_cb(const void *data, uint16_t len, void *user_data) { struct test_data *t_data = tester_get_data(); @@ -2543,6 +2593,58 @@ static struct test_case test_cases[] = { APP1_ID, &app1_uuid, NULL, NULL, NULL), ), + TEST_CASE_BREDRLE("Gatt Server - Add Single Descriptor Successful", + ACTION_SUCCESS(gatt_server_register_action, &app1_uuid), + CALLBACK_STATUS(CB_GATTS_REGISTER_SERVER, BT_STATUS_SUCCESS), + ACTION_SUCCESS(gatt_server_add_service_action, + &add_service_data_6), + CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID, + &service_add_1, NULL, + &srvc1_handle), + ACTION_SUCCESS(gatt_server_add_char_action, &add_char_data_1), + CALLBACK_GATTS_CHARACTERISTIC_ADDED(GATT_STATUS_SUCCESS, + APP1_ID, &app1_uuid, + &srvc1_handle, NULL, + NULL), + ACTION_SUCCESS(gatt_server_add_desc_action, &add_desc_data_1), + CALLBACK_GATTS_DESCRIPTOR_ADDED(GATT_STATUS_SUCCESS, APP1_ID, + &app2_uuid, &srvc1_handle, + NULL, NULL), + ), + TEST_CASE_BREDRLE("Gatt Server - Add Desc. wrong service handle", + ACTION_SUCCESS(gatt_server_register_action, &app1_uuid), + CALLBACK_STATUS(CB_GATTS_REGISTER_SERVER, BT_STATUS_SUCCESS), + ACTION_SUCCESS(gatt_server_add_service_action, + &add_service_data_6), + CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID, + &service_add_1, NULL, + &srvc1_handle), + ACTION_SUCCESS(gatt_server_add_char_action, &add_char_data_1), + CALLBACK_GATTS_CHARACTERISTIC_ADDED(GATT_STATUS_SUCCESS, + APP1_ID, &app1_uuid, + &srvc1_handle, NULL, + NULL), + ACTION_FAIL(gatt_server_add_desc_action, &add_bad_desc_data_1), + CALLBACK_GATTS_DESCRIPTOR_ADDED(GATT_STATUS_FAILURE, APP1_ID, + &app2_uuid, NULL, NULL, NULL), + ), + TEST_CASE_BREDRLE("Gatt Server - Add Desc. wrong app ID", + ACTION_SUCCESS(gatt_server_register_action, &app1_uuid), + CALLBACK_STATUS(CB_GATTS_REGISTER_SERVER, BT_STATUS_SUCCESS), + ACTION_SUCCESS(gatt_server_add_service_action, + &add_service_data_6), + CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID, + &service_add_1, NULL, + &srvc1_handle), + ACTION_SUCCESS(gatt_server_add_char_action, &add_char_data_1), + CALLBACK_GATTS_CHARACTERISTIC_ADDED(GATT_STATUS_SUCCESS, + APP1_ID, &app1_uuid, + &srvc1_handle, NULL, + NULL), + ACTION_FAIL(gatt_server_add_desc_action, &add_bad_desc_data_2), + CALLBACK_GATTS_DESCRIPTOR_ADDED(GATT_STATUS_FAILURE, APP2_ID, + &app2_uuid, NULL, NULL, NULL), + ), }; struct queue *get_gatt_tests(void) |