All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] android/tester: Don't verify test conditions if test is done
@ 2014-03-14 12:54 Jakub Tyszkowski
  2014-03-14 13:47 ` Szymon Janc
  0 siblings, 1 reply; 2+ messages in thread
From: Jakub Tyszkowski @ 2014-03-14 12:54 UTC (permalink / raw)
  To: linux-bluetooth; +Cc: Jakub Tyszkowski

This avoids callbacks still being called when test result is already
decided and teardown procedure has already been triggered.
---
 android/android-tester.c | 30 +++++++++++++++++-------------
 1 file changed, 17 insertions(+), 13 deletions(-)

diff --git a/android/android-tester.c b/android/android-tester.c
index f552584..bab92a1 100644
--- a/android/android-tester.c
+++ b/android/android-tester.c
@@ -102,8 +102,8 @@ struct test_data {
 
 	int conditions_left;
 
-	/* Set to true if test conditions are initialized */
-	bool test_init_done;
+	/* Set to true if test conditions should be verified */
+	bool test_checks_valid;
 
 	bool test_result_set;
 
@@ -295,7 +295,7 @@ static void check_cb_count(void)
 {
 	struct test_data *data = tester_get_data();
 
-	if (!data->test_init_done)
+	if (!data->test_checks_valid)
 		return;
 
 	if (data->cb_count == 0) {
@@ -352,7 +352,7 @@ static void test_property_init(struct test_data *data)
 
 static void init_test_conditions(struct test_data *data)
 {
-	data->test_init_done = true;
+	data->test_checks_valid = true;
 
 	data->conditions_left = 4;
 
@@ -731,13 +731,13 @@ static gboolean adapter_state_changed(gpointer user_data)
 	const struct generic_data *test = data->test_data;
 	struct bt_cb_data *cb_data = user_data;
 
-	if (data->test_init_done &&
+	if (data->test_checks_valid &&
 			test->expected_hal_cb.adapter_state_changed_cb) {
 		test->expected_hal_cb.adapter_state_changed_cb(cb_data->state);
 		goto cleanup;
 	}
 
-	if (!data->test_init_done && cb_data->state == BT_STATE_ON)
+	if (!data->test_checks_valid && cb_data->state == BT_STATE_ON)
 		setup_powered_emulated_remote();
 
 cleanup:
@@ -1062,7 +1062,7 @@ static gboolean device_found(gpointer user_data)
 	const struct generic_data *test = data->test_data;
 	struct bt_cb_data *cb_data = user_data;
 
-	if (data->test_init_done && test->expected_hal_cb.device_found_cb)
+	if (data->test_checks_valid && test->expected_hal_cb.device_found_cb)
 		test->expected_hal_cb.device_found_cb(cb_data->num,
 								cb_data->props);
 
@@ -1099,7 +1099,8 @@ static gboolean adapter_properties(gpointer user_data)
 	const struct generic_data *test = data->test_data;
 	struct bt_cb_data *cb_data = user_data;
 
-	if (data->test_init_done && test->expected_hal_cb.adapter_properties_cb)
+	if (data->test_checks_valid &&
+				test->expected_hal_cb.adapter_properties_cb)
 		test->expected_hal_cb.adapter_properties_cb(cb_data->status,
 						cb_data->num, cb_data->props);
 
@@ -1162,7 +1163,7 @@ static gboolean remote_device_properties(gpointer user_data)
 	const struct generic_data *test = data->test_data;
 	struct bt_cb_data *cb_data = user_data;
 
-	if (data->test_init_done &&
+	if (data->test_checks_valid &&
 			test->expected_hal_cb.remote_device_properties_cb)
 		test->expected_hal_cb.remote_device_properties_cb(
 					cb_data->status, &cb_data->bdaddr,
@@ -1257,7 +1258,8 @@ static gboolean bond_state_changed(gpointer user_data)
 	const struct generic_data *test = data->test_data;
 	struct bt_cb_data *cb_data = user_data;
 
-	if (data->test_init_done && test->expected_hal_cb.bond_state_changed_cb)
+	if (data->test_checks_valid &&
+				test->expected_hal_cb.bond_state_changed_cb)
 		test->expected_hal_cb.bond_state_changed_cb(cb_data->status,
 					&cb_data->bdaddr, cb_data->state);
 
@@ -1313,7 +1315,7 @@ static gboolean pin_request(gpointer user_data)
 	const struct generic_data *test = data->test_data;
 	struct bt_cb_data *cb_data = user_data;
 
-	if (data->test_init_done && test->expected_hal_cb.pin_request_cb)
+	if (data->test_checks_valid && test->expected_hal_cb.pin_request_cb)
 		test->expected_hal_cb.pin_request_cb(&cb_data->bdaddr,
 						&cb_data->bdname, cb_data->cod);
 
@@ -1392,8 +1394,7 @@ static gboolean ssp_request(gpointer user_data)
 	const struct generic_data *test = data->test_data;
 	struct bt_cb_data *cb_data = user_data;
 
-	if (data->test_init_done &&
-				test->expected_hal_cb.ssp_request_cb)
+	if (data->test_checks_valid && test->expected_hal_cb.ssp_request_cb)
 		test->expected_hal_cb.ssp_request_cb(&cb_data->bdaddr,
 					&cb_data->bdname, cb_data->cod,
 					cb_data->ssp_variant, cb_data->passkey);
@@ -2636,6 +2637,9 @@ static void teardown(const void *test_data)
 		data->if_bluetooth = NULL;
 	}
 
+	/* Test result already known, no need to check further */
+	data->test_checks_valid = false;
+
 	if (data->expected_properties_list)
 		g_slist_free(data->expected_properties_list);
 
-- 
1.9.0


^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH] android/tester: Don't verify test conditions if test is done
  2014-03-14 12:54 [PATCH] android/tester: Don't verify test conditions if test is done Jakub Tyszkowski
@ 2014-03-14 13:47 ` Szymon Janc
  0 siblings, 0 replies; 2+ messages in thread
From: Szymon Janc @ 2014-03-14 13:47 UTC (permalink / raw)
  To: Jakub Tyszkowski; +Cc: linux-bluetooth

Hi Jakub,

On Friday 14 of March 2014 13:54:44 Jakub Tyszkowski wrote:
> This avoids callbacks still being called when test result is already
> decided and teardown procedure has already been triggered.
> ---
>  android/android-tester.c | 30 +++++++++++++++++-------------
>  1 file changed, 17 insertions(+), 13 deletions(-)
> 
> diff --git a/android/android-tester.c b/android/android-tester.c
> index f552584..bab92a1 100644
> --- a/android/android-tester.c
> +++ b/android/android-tester.c
> @@ -102,8 +102,8 @@ struct test_data {
>  
>  	int conditions_left;
>  
> -	/* Set to true if test conditions are initialized */
> -	bool test_init_done;
> +	/* Set to true if test conditions should be verified */
> +	bool test_checks_valid;
>  
>  	bool test_result_set;
>  
> @@ -295,7 +295,7 @@ static void check_cb_count(void)
>  {
>  	struct test_data *data = tester_get_data();
>  
> -	if (!data->test_init_done)
> +	if (!data->test_checks_valid)
>  		return;
>  
>  	if (data->cb_count == 0) {
> @@ -352,7 +352,7 @@ static void test_property_init(struct test_data *data)
>  
>  static void init_test_conditions(struct test_data *data)
>  {
> -	data->test_init_done = true;
> +	data->test_checks_valid = true;
>  
>  	data->conditions_left = 4;
>  
> @@ -731,13 +731,13 @@ static gboolean adapter_state_changed(gpointer user_data)
>  	const struct generic_data *test = data->test_data;
>  	struct bt_cb_data *cb_data = user_data;
>  
> -	if (data->test_init_done &&
> +	if (data->test_checks_valid &&
>  			test->expected_hal_cb.adapter_state_changed_cb) {
>  		test->expected_hal_cb.adapter_state_changed_cb(cb_data->state);
>  		goto cleanup;
>  	}
>  
> -	if (!data->test_init_done && cb_data->state == BT_STATE_ON)
> +	if (!data->test_checks_valid && cb_data->state == BT_STATE_ON)
>  		setup_powered_emulated_remote();
>  
>  cleanup:
> @@ -1062,7 +1062,7 @@ static gboolean device_found(gpointer user_data)
>  	const struct generic_data *test = data->test_data;
>  	struct bt_cb_data *cb_data = user_data;
>  
> -	if (data->test_init_done && test->expected_hal_cb.device_found_cb)
> +	if (data->test_checks_valid && test->expected_hal_cb.device_found_cb)
>  		test->expected_hal_cb.device_found_cb(cb_data->num,
>  								cb_data->props);
>  
> @@ -1099,7 +1099,8 @@ static gboolean adapter_properties(gpointer user_data)
>  	const struct generic_data *test = data->test_data;
>  	struct bt_cb_data *cb_data = user_data;
>  
> -	if (data->test_init_done && test->expected_hal_cb.adapter_properties_cb)
> +	if (data->test_checks_valid &&
> +				test->expected_hal_cb.adapter_properties_cb)
>  		test->expected_hal_cb.adapter_properties_cb(cb_data->status,
>  						cb_data->num, cb_data->props);
>  
> @@ -1162,7 +1163,7 @@ static gboolean remote_device_properties(gpointer user_data)
>  	const struct generic_data *test = data->test_data;
>  	struct bt_cb_data *cb_data = user_data;
>  
> -	if (data->test_init_done &&
> +	if (data->test_checks_valid &&
>  			test->expected_hal_cb.remote_device_properties_cb)
>  		test->expected_hal_cb.remote_device_properties_cb(
>  					cb_data->status, &cb_data->bdaddr,
> @@ -1257,7 +1258,8 @@ static gboolean bond_state_changed(gpointer user_data)
>  	const struct generic_data *test = data->test_data;
>  	struct bt_cb_data *cb_data = user_data;
>  
> -	if (data->test_init_done && test->expected_hal_cb.bond_state_changed_cb)
> +	if (data->test_checks_valid &&
> +				test->expected_hal_cb.bond_state_changed_cb)
>  		test->expected_hal_cb.bond_state_changed_cb(cb_data->status,
>  					&cb_data->bdaddr, cb_data->state);
>  
> @@ -1313,7 +1315,7 @@ static gboolean pin_request(gpointer user_data)
>  	const struct generic_data *test = data->test_data;
>  	struct bt_cb_data *cb_data = user_data;
>  
> -	if (data->test_init_done && test->expected_hal_cb.pin_request_cb)
> +	if (data->test_checks_valid && test->expected_hal_cb.pin_request_cb)
>  		test->expected_hal_cb.pin_request_cb(&cb_data->bdaddr,
>  						&cb_data->bdname, cb_data->cod);
>  
> @@ -1392,8 +1394,7 @@ static gboolean ssp_request(gpointer user_data)
>  	const struct generic_data *test = data->test_data;
>  	struct bt_cb_data *cb_data = user_data;
>  
> -	if (data->test_init_done &&
> -				test->expected_hal_cb.ssp_request_cb)
> +	if (data->test_checks_valid && test->expected_hal_cb.ssp_request_cb)
>  		test->expected_hal_cb.ssp_request_cb(&cb_data->bdaddr,
>  					&cb_data->bdname, cb_data->cod,
>  					cb_data->ssp_variant, cb_data->passkey);
> @@ -2636,6 +2637,9 @@ static void teardown(const void *test_data)
>  		data->if_bluetooth = NULL;
>  	}
>  
> +	/* Test result already known, no need to check further */
> +	data->test_checks_valid = false;
> +
>  	if (data->expected_properties_list)
>  		g_slist_free(data->expected_properties_list);
>  
> 

Applied. Thanks.

-- 
Best regards, 
Szymon Janc

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2014-03-14 13:47 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-03-14 12:54 [PATCH] android/tester: Don't verify test conditions if test is done Jakub Tyszkowski
2014-03-14 13:47 ` Szymon Janc

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.