[PATCH 3/9] unit/test-gatt: Add /TP/GAR/CL/BV-03-C-1 test

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Verify that a Generic Attribute Profile client can read a
Characteristic Value selected by UUID using a 16-bit UUID.
---
 unit/test-gatt.c | 157 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 157 insertions(+)

diff --git a/unit/test-gatt.c b/unit/test-gatt.c
index 9917ec9..3e94bc1 100644
--- a/unit/test-gatt.c
+++ b/unit/test-gatt.c
@@ -144,6 +144,41 @@ struct context {
 		raw_pdu(0x04, 0x08, 0x00, 0x08, 0x00),			\
 		raw_pdu(0x05, 0x01, 0x08, 0x00, 0x01, 0x29)
 
+#define SERVICE_DATA_2_PDU						\
+		raw_pdu(0x02, 0x00, 0x02),				\
+		raw_pdu(0x03, 0x00, 0x02),				\
+		raw_pdu(0x10, 0x01, 0x00, 0xff, 0xff, 0x00, 0x28),	\
+		raw_pdu(0x11, 0x06, 0x01, 0x00, 0x07, 0x00, 0x01, 0x18),\
+		raw_pdu(0x10, 0x08, 0x00, 0xff, 0xff, 0x00, 0x28),	\
+		raw_pdu(0x11, 0x06, 0x08, 0x00, 0x0b, 0x00, 0x0d, 0x18),\
+		raw_pdu(0x10, 0x0c, 0x00, 0xff, 0xff, 0x00, 0x28),	\
+		raw_pdu(0x01, 0x10, 0x0c, 0x00, 0x0a),			\
+		raw_pdu(0x10, 0x01, 0x00, 0xff, 0xff, 0x01, 0x28),	\
+		raw_pdu(0x01, 0x10, 0x01, 0x00, 0x0a),			\
+		raw_pdu(0x08, 0x01, 0x00, 0x07, 0x00, 0x02, 0x28),	\
+		raw_pdu(0x01, 0x08, 0x01, 0x00, 0x0a),			\
+		raw_pdu(0x08, 0x08, 0x00, 0x0b, 0x00, 0x02, 0x28),	\
+		raw_pdu(0x01, 0x08, 0x0b, 0x00, 0x0a),			\
+		raw_pdu(0x08, 0x01, 0x00, 0x07, 0x00, 0x03, 0x28),	\
+		raw_pdu(0x09, 0x07, 0x02, 0x00, 0x02, 0x03, 0x00, 0x00,	\
+				0x2a),					\
+		raw_pdu(0x08, 0x03, 0x00, 0x07, 0x00, 0x03, 0x28),	\
+		raw_pdu(0x09, 0x07, 0x05, 0x00, 0x02, 0x06, 0x00, 0x00,	\
+							0x2a),		\
+		raw_pdu(0x08, 0x06, 0x00, 0x07, 0x00, 0x03, 0x28),	\
+		raw_pdu(0x01, 0x08, 0x06, 0x00, 0x0a),			\
+		raw_pdu(0x04, 0x04, 0x00, 0x04, 0x00),			\
+		raw_pdu(0x05, 0x01, 0x04, 0x00, 0x01, 0x29),		\
+		raw_pdu(0x04, 0x07, 0x00, 0x07, 0x00),			\
+		raw_pdu(0x05, 0x01, 0x07, 0x00, 0x03, 0x29),		\
+		raw_pdu(0x08, 0x08, 0x00, 0x0b, 0x00, 0x03, 0x28),	\
+		raw_pdu(0x09, 0x07, 0x09, 0x00, 0x02, 0x0a, 0x00, 0x0d,	\
+				0x2b),					\
+		raw_pdu(0x08, 0x0a, 0x00, 0x0b, 0x00, 0x03, 0x28),	\
+		raw_pdu(0x01, 0x08, 0x0a, 0x00, 0x0a),			\
+		raw_pdu(0x04, 0x0b, 0x00, 0x0b, 0x00),			\
+		raw_pdu(0x05, 0x01, 0x0b, 0x00, 0x02, 0x29)
+
 static bt_uuid_t uuid_16 = {
 	.type = BT_UUID16,
 	.value.u16 = 0x1800
@@ -223,6 +258,76 @@ const struct gatt_service gatt_service_2 = {
 const struct gatt_service *service_data_1[] = {&gatt_service_1,
 							&gatt_service_2};
 
+const bt_gatt_service_t service_3 = {
+	.primary = true,
+	.start_handle = 0x0001,
+	.end_handle = 0x0007,
+	.uuid = {0x00, 0x00, 0x18, 0x01, 0x00, 0x00, 0x10, 0x00,
+			0x80, 0x00, 0x00, 0x80, 0x5f, 0x9b, 0x34, 0xfb}
+};
+
+const bt_gatt_service_t service_4 = {
+	.primary = true,
+	.start_handle = 0x0008,
+	.end_handle = 0x000b,
+	.uuid = {0x00, 0x00, 0x18, 0x0d, 0x00, 0x00, 0x10, 0x00,
+			0x80, 0x00, 0x00, 0x80, 0x5f, 0x9b, 0x34, 0xfb}
+};
+
+const bt_gatt_descriptor_t descriptor_3 = {
+	.handle = 0x0007,
+	.uuid = {0x00, 0x00, 0x29, 0x03, 0x00, 0x00, 0x10, 0x00,
+			0x80, 0x00, 0x00, 0x80, 0x5f, 0x9b, 0x34, 0xfb}
+};
+
+
+const bt_gatt_characteristic_t characteristic_3 = {
+	.start_handle = 0x0005,
+	.end_handle = 0x0007,
+	.value_handle = 0x0006,
+	.properties = 0x02,
+	.uuid = {0x00, 0x00, 0x2a, 0x00, 0x00, 0x00, 0x10, 0x00,
+			0x80, 0x00, 0x00, 0x80, 0x5f, 0x9b, 0x34, 0xfb},
+	.descs = &descriptor_3,
+	.num_descs = 1
+};
+
+const bt_gatt_descriptor_t descriptor_4 = {
+	.handle = 0x000b,
+	.uuid = {0x00, 0x00, 0x29, 0x02, 0x00, 0x00, 0x10, 0x00,
+			0x80, 0x00, 0x00, 0x80, 0x5f, 0x9b, 0x34, 0xfb}
+};
+
+const bt_gatt_characteristic_t characteristic_4 = {
+	.start_handle = 0x0009,
+	.end_handle = 0x000b,
+	.value_handle = 0x000a,
+	.properties = 0x02,
+	.uuid = {0x00, 0x00, 0x2b, 0x0d, 0x00, 0x00, 0x10, 0x00,
+			0x80, 0x00, 0x00, 0x80, 0x5f, 0x9b, 0x34, 0xfb},
+	.descs = &descriptor_4,
+	.num_descs = 1
+};
+
+const bt_gatt_characteristic_t *characteristics_3[] = {&characteristic_1,
+							&characteristic_3};
+const bt_gatt_characteristic_t *characteristics_4[] = {&characteristic_4};
+
+const struct gatt_service gatt_service_3 = {
+	.service = &service_3,
+	.num_chars = sizeof(characteristics_3) / sizeof(characteristics_3[0]),
+	.chars = characteristics_3
+};
+
+const struct gatt_service gatt_service_4 = {
+	.service = &service_4,
+	.num_chars = sizeof(characteristics_4) / sizeof(characteristics_4[0]),
+	.chars = characteristics_4
+};
+
+const struct gatt_service *service_data_2[] = {&gatt_service_3,
+							&gatt_service_4};
+
 static void test_debug(const char *str, void *user_data)
 {
 	const char *prefix = user_data;
@@ -559,6 +664,50 @@ const struct test_step test_read_4 = {
 	.expected_att_ecode = 0x08,
 };
 
+static void read_by_uuid_cb(bool success, uint8_t att_ecode,
+						struct read_by_uuid_res *result,
+						void *user_data)
+{
+	struct context *context = user_data;
+	const struct test_step *step = context->data->step;
+
+	g_assert(att_ecode == step->expected_att_ecode);
+
+	if (success && step->value) {
+		uint16_t handle;
+		uint8_t length;
+		uint8_t *value;
+
+		read_by_uuid_res_get(result, &handle, &length, &value);
+		g_assert(length == step->length);
+		g_assert(memcmp(value, step->value, length) == 0);
+	}
+
+	g_assert(read_by_uuid_res_next(result) == NULL);
+
+	context_quit(context);
+}
+
+static void test_read_by_uuid(struct context *context)
+{
+	const struct test_step *step = context->data->step;
+
+	g_assert(bt_gatt_client_read_by_uuid(context->client, step->handle,
+			step->end_handle, step->uuid, read_by_uuid_cb, context,
+			NULL));
+}
+
+const struct test_step test_read_by_uuid_1 = {
+	.handle = 0x0001,
+	.end_handle = 0xffff,
+	.func = test_read_by_uuid,
+	.expected_att_ecode = 0x0a,
+	.value = read_data_1,
+	.length = 0x03,
+	.uuid = {0x00, 0x00, 0x2b, 0x0d, 0x00, 0x00, 0x10, 0x00,
+			0x80, 0x00, 0x00, 0x80, 0x5F, 0x9B, 0x34, 0xFB}
+};
+
 static void test_client(gconstpointer data)
 {
 	struct context *context = create_context(512, data);
@@ -741,5 +890,13 @@ int main(int argc, char *argv[])
 			raw_pdu(0x0a, 0x03, 0x00),
 			raw_pdu(0x01, 0x0a, 0x03, 0x00, 0x08));
 
+	define_test_client("/TP/GAR/CL/BV-03-C-1", test_client, service_data_2,
+			&test_read_by_uuid_1,
+			SERVICE_DATA_2_PDU,
+			raw_pdu(0x08, 0x01, 0x00, 0xff, 0xff, 0x0d, 0x2b),
+			raw_pdu(0x09, 0x05, 0x0a, 0x00, 0x01, 0x02, 0x03),
+			raw_pdu(0x08, 0x0b, 0x00, 0xff, 0xff, 0x0d, 0x2b),
+			raw_pdu(0x01, 0x08, 0x0b, 0x00, 0x0a));
+
 	return g_test_run();
 }
-- 
1.9.3

--
To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux