summaryrefslogtreecommitdiff
path: root/android/tester-gatt.c
diff options
context:
space:
mode:
authorGrzegorz Kolodziejczyk <grzegorz.kolodziejczyk@tieto.com>2014-10-06 16:27:43 +0200
committerSzymon Janc <szymon.janc@tieto.com>2014-10-10 10:57:14 +0200
commit70640ac1ac0dee6fe3688600475ce79e5406521a (patch)
tree1591c677e56f9465a695e7fa0260b0cc527d3e93 /android/tester-gatt.c
parent65917ac8b4f0580bd522bb9df488419b81a0c333 (diff)
downloadbluez-70640ac1ac0dee6fe3688600475ce79e5406521a.tar.gz
android/tester: Add GATT server start service test cases
This adds start service by server test cases.
Diffstat (limited to 'android/tester-gatt.c')
-rw-r--r--android/tester-gatt.c100
1 files changed, 100 insertions, 0 deletions
diff --git a/android/tester-gatt.c b/android/tester-gatt.c
index 0f0258756..332459055 100644
--- a/android/tester-gatt.c
+++ b/android/tester-gatt.c
@@ -37,6 +37,10 @@
#define CONN1_ID 1
#define CONN2_ID 2
+#define GATT_SERVER_TRANSPORT_LE 0x00
+#define GATT_SERVER_TRANSPORT_BREDR 0x01
+#define GATT_SERVER_TRANSPORT_LE_BREDR 0x02
+
static struct queue *list; /* List of gatt test cases */
static int srvc1_handle;
@@ -149,6 +153,12 @@ struct add_desc_data {
int permissions;
};
+struct start_srvc_data {
+ int app_id;
+ int *srvc_handle;
+ int transport;
+};
+
static bt_bdaddr_t emu_remote_bdaddr_val = {
.address = { 0x00, 0xaa, 0x01, 0x01, 0x00, 0x00 },
};
@@ -492,6 +502,30 @@ static struct add_desc_data add_desc_data_1 = {
.permissions = 0
};
+static struct start_srvc_data start_srvc_data_1 = {
+ .app_id = APP1_ID,
+ .srvc_handle = &srvc1_handle,
+ .transport = GATT_SERVER_TRANSPORT_LE_BREDR
+};
+
+static struct start_srvc_data start_srvc_data_2 = {
+ .app_id = APP1_ID,
+ .srvc_handle = &srvc1_handle,
+ .transport = GATT_SERVER_TRANSPORT_LE
+};
+
+static struct start_srvc_data start_bad_srvc_data_1 = {
+ .app_id = APP1_ID,
+ .srvc_handle = &srvc_bad_handle,
+ .transport = GATT_SERVER_TRANSPORT_LE
+};
+
+static struct start_srvc_data start_bad_srvc_data_2 = {
+ .app_id = APP1_ID,
+ .srvc_handle = &srvc1_handle,
+ .transport = -1
+};
+
struct set_read_params {
btgatt_read_params_t *params;
btgatt_srvc_id_t *srvc_id;
@@ -1338,6 +1372,21 @@ static void gatt_client_write_descriptor_action(void)
schedule_action_verification(step);
}
+static void gatt_server_start_srvc_action(void)
+{
+ struct test_data *data = tester_get_data();
+ struct step *current_data_step = queue_peek_head(data->steps);
+ struct start_srvc_data *start_srvc_data = current_data_step->set_data;
+ struct step *step = g_new0(struct step, 1);
+
+ step->action_status = data->if_gatt->server->start_service(
+ start_srvc_data->app_id,
+ *start_srvc_data->srvc_handle,
+ start_srvc_data->transport);
+
+ 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();
@@ -2868,6 +2917,57 @@ static struct test_case test_cases[] = {
CALLBACK_GATTS_DESCRIPTOR_ADDED(GATT_STATUS_FAILURE, APP2_ID,
&app2_uuid, NULL, NULL, NULL),
),
+ TEST_CASE_BREDRLE("Gatt Server - Start Service Successful BREDRLE",
+ 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_1),
+ CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID,
+ &service_add_1, NULL,
+ &srvc1_handle),
+ ACTION_SUCCESS(gatt_server_start_srvc_action,
+ &start_srvc_data_1),
+ CALLBACK_GATTS_SERVICE_STARTED(GATT_STATUS_SUCCESS, APP1_ID,
+ &srvc1_handle),
+ ),
+ TEST_CASE_BREDRLE("Gatt Server - Start Service Successful LE",
+ 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_1),
+ CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID,
+ &service_add_1, NULL,
+ &srvc1_handle),
+ ACTION_SUCCESS(gatt_server_start_srvc_action,
+ &start_srvc_data_2),
+ CALLBACK_GATTS_SERVICE_STARTED(GATT_STATUS_SUCCESS, APP1_ID,
+ &srvc1_handle),
+ ),
+ TEST_CASE_BREDRLE("Gatt Server - Start Service 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_1),
+ CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID,
+ &service_add_1, NULL, NULL),
+ ACTION_FAIL(gatt_server_start_srvc_action,
+ &start_bad_srvc_data_1),
+ CALLBACK_GATTS_SERVICE_STARTED(GATT_STATUS_FAILURE, APP1_ID,
+ NULL),
+ ),
+ TEST_CASE_BREDRLE("Gatt Server - Start Service wrong server transport",
+ 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_1),
+ CALLBACK_GATTS_SERVICE_ADDED(GATT_STATUS_SUCCESS, APP1_ID,
+ &service_add_1, NULL,
+ &srvc1_handle),
+ ACTION_FAIL(gatt_server_start_srvc_action,
+ &start_bad_srvc_data_2),
+ CALLBACK_GATTS_SERVICE_STARTED(GATT_STATUS_FAILURE, APP1_ID,
+ &srvc1_handle),
+ ),
};
struct queue *get_gatt_tests(void)