summaryrefslogtreecommitdiff
path: root/android/tester-socket.c
diff options
context:
space:
mode:
authorJakub Tyszkowski <jakub.tyszkowski@tieto.com>2014-07-24 10:38:01 +0200
committerJohan Hedberg <johan.hedberg@intel.com>2014-07-24 13:14:07 +0300
commitc603589f743b09a2e4338954659df5e75088be75 (patch)
tree8c28f09046fd0f677bda71417e36dbadec007380 /android/tester-socket.c
parent85ef0439b9e9ea1d179e15c52d29bfd23d683d26 (diff)
downloadbluez-c603589f743b09a2e4338954659df5e75088be75.tar.gz
android/tester-ng: Add socket listen - close than listen case
This checks for another successfull listen after closing previous fd.
Diffstat (limited to 'android/tester-socket.c')
-rw-r--r--android/tester-socket.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/android/tester-socket.c b/android/tester-socket.c
index 337e1172b..5994a3db4 100644
--- a/android/tester-socket.c
+++ b/android/tester-socket.c
@@ -136,6 +136,29 @@ done:
schedule_action_verification(step);
}
+static void socket_close_channel_action(void)
+{
+ struct test_data *data = tester_get_data();
+ struct step *current_data_step = queue_peek_head(data->steps);
+ struct bt_action_data *action_data = current_data_step->set_data;
+ struct step *step = g_new0(struct step, 1);
+
+ if (!*action_data->fd) {
+ tester_warn("Ups no action_data->fd");
+
+ step->action_status = BT_STATUS_FAIL;
+ goto done;
+ }
+
+ close(*action_data->fd);
+ *action_data->fd = -1;
+
+ step->action_status = BT_STATUS_SUCCESS;
+
+done:
+ schedule_action_verification(step);
+}
+
static struct test_case test_cases[] = {
TEST_CASE_BREDRLE("Socket Init",
ACTION_SUCCESS(dummy_action, NULL),
@@ -181,6 +204,19 @@ static struct test_case test_cases[] = {
ACTION_SUCCESS(bluetooth_disable_action, NULL),
CALLBACK_STATE(CB_BT_ADAPTER_STATE_CHANGED, BT_STATE_OFF),
),
+ TEST_CASE_BREDRLE("Socket Listen - Close and Listen again",
+ ACTION_SUCCESS(bluetooth_enable_action, NULL),
+ CALLBACK_STATE(CB_BT_ADAPTER_STATE_CHANGED, BT_STATE_ON),
+ ACTION_SUCCESS(socket_listen_action, &btsock_param),
+ ACTION_SUCCESS(socket_verify_fd_action, &btsock_param),
+ ACTION_SUCCESS(socket_verify_channel_action, &btsock_param),
+ ACTION_SUCCESS(socket_close_channel_action, &btsock_param),
+ ACTION_SUCCESS(socket_listen_action, &btsock_param),
+ ACTION_SUCCESS(socket_verify_fd_action, &btsock_param),
+ ACTION_SUCCESS(socket_verify_channel_action, &btsock_param),
+ ACTION_SUCCESS(bluetooth_disable_action, NULL),
+ CALLBACK_STATE(CB_BT_ADAPTER_STATE_CHANGED, BT_STATE_OFF),
+ ),
};
struct queue *get_socket_tests(void)