[PATCH 12/14] tests: test set for ivi-shell notification normal use case in server side
Jon A. Cruz
jonc at osg.samsung.com
Wed Jun 24 10:04:22 PDT 2015
On 06/21/2015 11:36 PM, Nobuhiko Tanibata wrote:
> From: Nobuhiko Tanibata <NOBUHIKO_TANIBATA at xddp.denso.co.jp>
>
> These tests are implemented on test suite framework, which provides
> internal method validation.
> Following features are tested,
> - notification of adding ivi-layer
> - notification of creating ivi-layer
> - notification of removing ivi-layer
>
> Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA at xddp.denso.co.jp>
> Reviewed-by: Pekka Paalanen <pekka.paalanen at collabora.co.uk>
Looks good.
Reviewed-by: Jon A. Cruz <jonc at osg.samsung.com>
> ---
> tests/ivi_layout-internal-test.c | 152 +++++++++++++++++++++++++++++++++++++++
> 1 file changed, 152 insertions(+)
>
> diff --git a/tests/ivi_layout-internal-test.c b/tests/ivi_layout-internal-test.c
> index b82e9cb..d13c915 100644
> --- a/tests/ivi_layout-internal-test.c
> +++ b/tests/ivi_layout-internal-test.c
> @@ -39,6 +39,7 @@
> struct test_context {
> struct weston_compositor *compositor;
> const struct ivi_controller_interface *controller_interface;
> + uint32_t user_flags;
> };
>
> static void
> @@ -898,6 +899,154 @@ test_commit_changes_after_render_order_set_layer_destroy(
> #undef LAYER_NUM
> }
>
> +static void
> +test_layer_properties_changed_notification_callback(struct ivi_layout_layer *ivilayer,
> + const struct ivi_layout_layer_properties *prop,
> + enum ivi_layout_notification_mask mask,
> + void *userdata)
> +{
> + struct test_context *ctx = userdata;
> + const struct ivi_controller_interface *ctl = ctx->controller_interface;
> +
> + iassert(ctl->get_id_of_layer(ivilayer) == IVI_TEST_LAYER_ID(0));
> + iassert(prop->source_width == 200);
> + iassert(prop->source_height == 300);
> +
> + if (ctl->get_id_of_layer(ivilayer) == IVI_TEST_LAYER_ID(0) &&
> + prop->source_width == 200 && prop->source_height == 300)
> + ctx->user_flags = 1;
> +}
> +
> +static void
> +test_layer_properties_changed_notification(struct test_context *ctx)
> +{
> + const struct ivi_controller_interface *ctl = ctx->controller_interface;
> + struct ivi_layout_layer *ivilayer;
> +
> + ctx->user_flags = 0;
> +
> + ivilayer = ctl->layer_create_with_dimension(IVI_TEST_LAYER_ID(0), 200, 300);
> +
> + iassert(ctl->layer_add_notification(ivilayer, test_layer_properties_changed_notification_callback, ctx) == IVI_SUCCEEDED);
> +
> + ctl->commit_changes();
> +
> + iassert(ctx->user_flags == 0);
> +
> + iassert(ctl->layer_set_destination_rectangle(
> + ivilayer, 20, 30, 200, 300) == IVI_SUCCEEDED);
> +
> + ctl->commit_changes();
> +
> + iassert(ctx->user_flags == 1);
> +
> + ctx->user_flags = 0;
> + iassert(ctl->layer_set_destination_rectangle(
> + ivilayer, 20, 30, 200, 300) == IVI_SUCCEEDED);
> +
> + ctl->commit_changes();
> +
> + iassert(ctx->user_flags == 0);
> +
> + ctl->layer_remove_notification(ivilayer);
> +
> + ctx->user_flags = 0;
> + ctl->commit_changes();
> +
> + iassert(ctx->user_flags == 0);
> +
> + ctl->layer_destroy(ivilayer);
> +}
> +
> +static void
> +test_layer_create_notification_callback(struct ivi_layout_layer *ivilayer,
> + void *userdata)
> +{
> + struct test_context *ctx = userdata;
> + const struct ivi_controller_interface *ctl = ctx->controller_interface;
> + const struct ivi_layout_layer_properties *prop = ctl->get_properties_of_layer(ivilayer);
> +
> + iassert(ctl->get_id_of_layer(ivilayer) == IVI_TEST_LAYER_ID(0));
> + iassert(prop->source_width == 200);
> + iassert(prop->source_height == 300);
> +
> + if (ctl->get_id_of_layer(ivilayer) == IVI_TEST_LAYER_ID(0) &&
> + prop->source_width == 200 && prop->source_height == 300)
> + ctx->user_flags = 1;
> +}
> +
> +static void
> +test_layer_create_notification(struct test_context *ctx)
> +{
> +#define LAYER_NUM (2)
> + const struct ivi_controller_interface *ctl = ctx->controller_interface;
> + static const uint32_t layers[LAYER_NUM] = {IVI_TEST_LAYER_ID(0), IVI_TEST_LAYER_ID(1)};
> + struct ivi_layout_layer *ivilayers[LAYER_NUM] = {};
> +
> + ctx->user_flags = 0;
> +
> + iassert(ctl->add_notification_create_layer(
> + test_layer_create_notification_callback, ctx) == IVI_SUCCEEDED);
> + ivilayers[0] = ctl->layer_create_with_dimension(layers[0], 200, 300);
> +
> + iassert(ctx->user_flags == 1);
> +
> + ctx->user_flags = 0;
> + ctl->remove_notification_create_layer(test_layer_create_notification_callback, ctx);
> +
> + ivilayers[1] = ctl->layer_create_with_dimension(layers[1], 400, 500);
> +
> + iassert(ctx->user_flags == 0);
> +
> + ctl->layer_destroy(ivilayers[0]);
> + ctl->layer_destroy(ivilayers[1]);
> +#undef LAYER_NUM
> +}
> +
> +static void
> +test_layer_remove_notification_callback(struct ivi_layout_layer *ivilayer,
> + void *userdata)
> +{
> + struct test_context *ctx = userdata;
> + const struct ivi_controller_interface *ctl = ctx->controller_interface;
> + const struct ivi_layout_layer_properties *prop =
> + ctl->get_properties_of_layer(ivilayer);
> +
> + iassert(ctl->get_id_of_layer(ivilayer) == IVI_TEST_LAYER_ID(0));
> + iassert(prop->source_width == 200);
> + iassert(prop->source_height == 300);
> +
> + if (ctl->get_id_of_layer(ivilayer) == IVI_TEST_LAYER_ID(0) &&
> + prop->source_width == 200 && prop->source_height == 300)
> + ctx->user_flags = 1;
> +}
> +
> +static void
> +test_layer_remove_notification(struct test_context *ctx)
> +{
> +#define LAYER_NUM (2)
> + const struct ivi_controller_interface *ctl = ctx->controller_interface;
> + static const uint32_t layers[LAYER_NUM] = {IVI_TEST_LAYER_ID(0), IVI_TEST_LAYER_ID(1)};
> + struct ivi_layout_layer *ivilayers[LAYER_NUM] = {};
> +
> + ctx->user_flags = 0;
> +
> + ivilayers[0] = ctl->layer_create_with_dimension(layers[0], 200, 300);
> + iassert(ctl->add_notification_remove_layer(
> + test_layer_remove_notification_callback, ctx) == IVI_SUCCEEDED);
> + ctl->layer_destroy(ivilayers[0]);
> +
> + iassert(ctx->user_flags == 1);
> +
> + ctx->user_flags = 0;
> + ivilayers[1] = ctl->layer_create_with_dimension(layers[1], 250, 350);
> + ctl->remove_notification_remove_layer(test_layer_remove_notification_callback, ctx);
> + ctl->layer_destroy(ivilayers[1]);
> +
> + iassert(ctx->user_flags == 0);
> +#undef LAYER_NUM
> +}
> +
> /************************ tests end ********************************/
>
> static void
> @@ -947,6 +1096,9 @@ run_internal_tests(void *data)
> test_screen_bad_render_order(ctx);
> test_commit_changes_after_render_order_set_layer_destroy(ctx);
>
> + test_layer_properties_changed_notification(ctx);
> + test_layer_create_notification(ctx);
> + test_layer_remove_notification(ctx);
>
> weston_compositor_exit_with_code(ctx->compositor, EXIT_SUCCESS);
> free(ctx);
>
--
Jon A. Cruz - Senior Open Source Developer
Samsung Open Source Group
jonc at osg.samsung.com
More information about the wayland-devel
mailing list