summaryrefslogtreecommitdiff
path: root/android/tester-gatt.c
diff options
context:
space:
mode:
authorGrzegorz Kolodziejczyk <grzegorz.kolodziejczyk@tieto.com>2014-10-06 14:54:01 +0200
committerSzymon Janc <szymon.janc@tieto.com>2014-10-06 16:01:58 +0200
commitecd374f9911eae1269592bd5875d3bd8155c30e6 (patch)
treef5269e4d577e84b3ddc6686d3cb8fb73ffc09f47 /android/tester-gatt.c
parent5040ae422bd94235e08016ee6913c4bdc41c44b2 (diff)
downloadbluez-ecd374f9911eae1269592bd5875d3bd8155c30e6.tar.gz
android/tester: Add GATT server add include service test cases
This adds include service add by server test cases.
Diffstat (limited to 'android/tester-gatt.c')
-rw-r--r--android/tester-gatt.c79
1 files changed, 79 insertions, 0 deletions
diff --git a/android/tester-gatt.c b/android/tester-gatt.c
index 61fa9002b..f4b12b4bb 100644
--- a/android/tester-gatt.c
+++ b/android/tester-gatt.c
@@ -39,6 +39,9 @@
static struct queue *list; /* List of gatt test cases */
+static int srvc1_handle;
+static int inc_srvc1_handle;
+
static bt_uuid_t app1_uuid = {
.uu = { 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01,
0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01 },
@@ -115,6 +118,11 @@ struct add_service_data {
int num_handles;
};
+struct add_included_service_data {
+ int app_id;
+ int *inc_srvc_handle;
+ int *srvc_handle;
+};
static bt_bdaddr_t emu_remote_bdaddr_val = {
.address = { 0x00, 0xaa, 0x01, 0x01, 0x00, 0x00 },
};
@@ -355,6 +363,12 @@ static struct add_service_data add_service_data_3 = {
.num_handles = 1
};
+static struct add_service_data add_service_data_4 = {
+ .app_id = APP1_ID,
+ .service = &service_add_1,
+ .num_handles = 2
+};
+
static struct add_service_data add_bad_service_data_1 = {
.app_id = APP1_ID,
.service = &service_add_1,
@@ -367,6 +381,20 @@ static struct add_service_data add_sec_service_data_1 = {
.num_handles = 1
};
+static int srvc_bad_handle = -1;
+
+static struct add_included_service_data add_inc_service_data_1 = {
+ .app_id = APP1_ID,
+ .inc_srvc_handle = &inc_srvc1_handle,
+ .srvc_handle = &srvc1_handle
+};
+
+static struct add_included_service_data add_bad_inc_service_data_1 = {
+ .app_id = APP1_ID,
+ .inc_srvc_handle = &srvc_bad_handle,
+ .srvc_handle = &srvc1_handle
+};
+
struct set_read_params {
btgatt_read_params_t *params;
btgatt_srvc_id_t *srvc_id;
@@ -1081,6 +1109,22 @@ static void gatt_server_add_service_action(void)
schedule_action_verification(step);
}
+static void gatt_server_add_inc_service_action(void)
+{
+ struct test_data *data = tester_get_data();
+ struct step *current_data_step = queue_peek_head(data->steps);
+ struct add_included_service_data *add_inc_srvc_data =
+ current_data_step->set_data;
+ struct step *step = g_new0(struct step, 1);
+
+ step->action_status = data->if_gatt->server->add_included_service(
+ add_inc_srvc_data->app_id,
+ *add_inc_srvc_data->srvc_handle,
+ *add_inc_srvc_data->inc_srvc_handle);
+
+ 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();
@@ -2390,6 +2434,41 @@ static struct test_case test_cases[] = {
CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID,
&included_1, NULL, NULL),
),
+ TEST_CASE_BREDRLE("Gatt Server - Add Included Service 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_4),
+ CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID,
+ &service_add_1, NULL,
+ &srvc1_handle),
+ ACTION_SUCCESS(gatt_server_add_service_action,
+ &add_service_data_4),
+ CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID,
+ &service_add_1, NULL,
+ &inc_srvc1_handle),
+ ACTION_SUCCESS(gatt_server_add_inc_service_action,
+ &add_inc_service_data_1),
+ CALLBACK_GATTS_INC_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID,
+ &srvc1_handle, NULL),
+ ),
+ TEST_CASE_BREDRLE("Gatt Server - Add Inc. Service with wrong 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_4),
+ CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID,
+ &service_add_1, NULL,
+ &srvc1_handle),
+ ACTION_SUCCESS(gatt_server_add_service_action,
+ &add_service_data_4),
+ CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID,
+ &service_add_1, NULL, NULL),
+ ACTION_FAIL(gatt_server_add_inc_service_action,
+ &add_bad_inc_service_data_1),
+ CALLBACK_GATTS_INC_SERVICE_ADDED(GATT_STATUS_FAILURE, APP1_ID,
+ &srvc1_handle, NULL),
+ ),
};
struct queue *get_gatt_tests(void)