summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorNobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>2015-06-22 15:34:09 +0900
committerPekka Paalanen <pekka.paalanen@collabora.co.uk>2015-06-25 11:38:37 +0300
commitd364393fca8ca1d8af4113857805aba74a3c7d31 (patch)
tree8583875824c0bcc224df9f9f4567b037a1bfebb8 /tests
parent16ed543f87563b12d66cef76030f060931f2e510 (diff)
tests: test set for ivi-layer normal use case with helper client
These test are implemented on test suite framework, which provides helper client. Following features are tested, - render order of ivi-surfaces on ivi-layer Signed-off-by: Nobuhiko Tanibata <nobuhiko_tanibata@xddp.denso.co.jp> Reviewed-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk> Reviewed-by: Jon A. Cruz <jonc@osg.samsung.com>
Diffstat (limited to 'tests')
-rw-r--r--tests/ivi-test.h4
-rw-r--r--tests/ivi_layout-test-plugin.c42
-rw-r--r--tests/ivi_layout-test.c27
3 files changed, 73 insertions, 0 deletions
diff --git a/tests/ivi-test.h b/tests/ivi-test.h
index 14415fa4..5cb47398 100644
--- a/tests/ivi-test.h
+++ b/tests/ivi-test.h
@@ -33,5 +33,9 @@
*/
#define IVI_TEST_SURFACE_ID_BASE 0xffc01200
#define IVI_TEST_SURFACE_ID(i) (IVI_TEST_SURFACE_ID_BASE + i)
+#define IVI_TEST_LAYER_ID_BASE 0xeef01200
+#define IVI_TEST_LAYER_ID(i) (IVI_TEST_LAYER_ID_BASE + i)
+
+#define IVI_TEST_SURFACE_COUNT (3)
#endif /* IVI_TEST_H */
diff --git a/tests/ivi_layout-test-plugin.c b/tests/ivi_layout-test-plugin.c
index fd57d068..afd108bc 100644
--- a/tests/ivi_layout-test-plugin.c
+++ b/tests/ivi_layout-test-plugin.c
@@ -697,3 +697,45 @@ RUNNER_TEST(get_surface_after_destroy_surface)
runner_assert(ivisurf == NULL);
}
+RUNNER_TEST(layer_render_order)
+{
+ const struct ivi_controller_interface *ctl = ctx->controller_interface;
+ struct ivi_layout_layer *ivilayer;
+ struct ivi_layout_surface *ivisurfs[IVI_TEST_SURFACE_COUNT] = {};
+ struct ivi_layout_surface **array;
+ int32_t length = 0;
+ uint32_t i;
+
+ ivilayer = ctl->layer_create_with_dimension(IVI_TEST_LAYER_ID(0), 200, 300);
+
+ for (i = 0; i < IVI_TEST_SURFACE_COUNT; i++)
+ ivisurfs[i] = ctl->get_surface_from_id(IVI_TEST_SURFACE_ID(i));
+
+ runner_assert(ctl->layer_set_render_order(
+ ivilayer, ivisurfs, IVI_TEST_SURFACE_COUNT) == IVI_SUCCEEDED);
+
+ ctl->commit_changes();
+
+ runner_assert(ctl->get_surfaces_on_layer(
+ ivilayer, &length, &array) == IVI_SUCCEEDED);
+ runner_assert(IVI_TEST_SURFACE_COUNT == length);
+ for (i = 0; i < IVI_TEST_SURFACE_COUNT; i++)
+ runner_assert(array[i] == ivisurfs[i]);
+
+ if (length > 0)
+ free(array);
+
+ runner_assert(ctl->layer_set_render_order(
+ ivilayer, NULL, 0) == IVI_SUCCEEDED);
+
+ array = NULL;
+
+ ctl->commit_changes();
+
+ runner_assert(ctl->get_surfaces_on_layer(
+ ivilayer, &length, &array) == IVI_SUCCEEDED);
+ runner_assert(length == 0 && array == NULL);
+
+ ctl->layer_destroy(ivilayer);
+}
+
diff --git a/tests/ivi_layout-test.c b/tests/ivi_layout-test.c
index 1dc1457b..051ded44 100644
--- a/tests/ivi_layout-test.c
+++ b/tests/ivi_layout-test.c
@@ -208,6 +208,10 @@ const char * const surface_property_commit_changes_test_names[] = {
"commit_changes_after_destination_rectangle_set_surface_destroy",
};
+const char * const render_order_test_names[] = {
+ "layer_render_order",
+};
+
TEST_P(ivi_layout_runner, basic_test_names)
{
/* an element from basic_test_names */
@@ -310,3 +314,26 @@ TEST(get_surface_after_destroy_wl_surface)
free(wnd);
runner_destroy(runner);
}
+
+TEST_P(ivi_layout_layer_render_order_runner, render_order_test_names)
+{
+ /* an element from render_order_test_names */
+ const char * const *test_name = data;
+ struct client *client;
+ struct runner *runner;
+ struct ivi_window *winds[3];
+
+ client = create_client();
+ runner = client_create_runner(client);
+
+ winds[0] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0));
+ winds[1] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(1));
+ winds[2] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(2));
+
+ runner_run(runner, *test_name);
+
+ ivi_window_destroy(winds[0]);
+ ivi_window_destroy(winds[1]);
+ ivi_window_destroy(winds[2]);
+ runner_destroy(runner);
+}