summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Blumenkrantz <zmike@samsung.com>2020-03-25 10:07:56 -0400
committerMike Blumenkrantz <zmike@samsung.com>2020-04-08 12:37:46 -0400
commit71ef7158167a18176b7413e9810818d99ac6c143 (patch)
tree029d66845edb0b9cc79c007e449a3942e9fbff97
parent351e9fa23f1389f33fc8cf12ab6ed18ee2f0b72b (diff)
downloadefl-71ef7158167a18176b7413e9810818d99ac6c143.tar.gz
tests/elm: add image tests to verify internal object size is clamped to object size
ensure that this doesn't break again ref 11587 Differential Revision: https://phab.enlightenment.org/D11599
-rw-r--r--src/tests/elementary/efl_ui_test_image.c27
-rw-r--r--src/tests/elementary/elm_test_image.c26
2 files changed, 53 insertions, 0 deletions
diff --git a/src/tests/elementary/efl_ui_test_image.c b/src/tests/elementary/efl_ui_test_image.c
index 244f1047e4..bd7d125323 100644
--- a/src/tests/elementary/efl_ui_test_image.c
+++ b/src/tests/elementary/efl_ui_test_image.c
@@ -30,7 +30,34 @@ EFL_START_TEST(efl_ui_image_test_icon)
}
EFL_END_TEST
+extern Eo *elm_image_object_get(Eo*);
+EFL_START_TEST(efl_ui_image_test_scale_method)
+{
+ Eo *win, *image;
+ Eina_Size2D sz;
+
+ win = win_add(NULL, "image", EFL_UI_WIN_TYPE_BASIC);
+ efl_gfx_entity_size_set(win, EINA_SIZE2D(100, 100));
+
+ image = efl_add(EFL_UI_IMAGE_CLASS, win,
+ efl_file_set(efl_added, ELM_IMAGE_DATA_DIR"/images/logo.png"),
+ efl_gfx_arrangement_content_align_set(efl_added, 0.5, 0.0),
+ efl_gfx_image_scale_method_set(efl_added, EFL_GFX_IMAGE_SCALE_METHOD_FIT_WIDTH)
+ );
+ efl_gfx_entity_size_set(image, EINA_SIZE2D(100, 100));
+ get_me_to_those_events(win);
+ sz = efl_gfx_entity_size_get(image);
+ ck_assert_int_eq(sz.w, 100);
+ ck_assert_int_eq(sz.h, 100);
+ /* legacy operation on eo object: very illegal */
+ sz = efl_gfx_entity_size_get(elm_image_object_get(image));
+ ck_assert_int_eq(sz.w, 100);
+ ck_assert_int_eq(sz.h, 100);
+}
+EFL_END_TEST
+
void efl_ui_test_image(TCase *tc)
{
tcase_add_test(tc, efl_ui_image_test_icon);
+ tcase_add_test(tc, efl_ui_image_test_scale_method);
}
diff --git a/src/tests/elementary/elm_test_image.c b/src/tests/elementary/elm_test_image.c
index 108ee9f373..888069f2b7 100644
--- a/src/tests/elementary/elm_test_image.c
+++ b/src/tests/elementary/elm_test_image.c
@@ -277,6 +277,31 @@ EFL_START_TEST(elm_image_test_memfile_set)
}
EFL_END_TEST
+EFL_START_TEST(elm_image_test_scale_method)
+{
+ Evas_Object *win, *image;
+ int w, h;
+
+ win = win_add(NULL, "image", ELM_WIN_BASIC);
+ evas_object_resize(win, 100, 100);
+
+ image = elm_image_add(win);
+ ck_assert(elm_image_file_set(image, ELM_IMAGE_DATA_DIR"/images/logo.png", NULL));
+ evas_object_size_hint_align_set(image, 0.5, 0.0);
+ efl_gfx_image_scale_method_set(image, EFL_GFX_IMAGE_SCALE_METHOD_FIT_WIDTH);
+ evas_object_resize(image, 100, 100);
+ evas_object_show(image);
+ evas_object_show(win);
+ get_me_to_those_events(win);
+ evas_object_geometry_get(image, NULL, NULL, &w, &h);
+ ck_assert_int_eq(w, 100);
+ ck_assert_int_eq(h, 100);
+ evas_object_geometry_get(elm_image_object_get(image), NULL, NULL, &w, &h);
+ ck_assert_int_eq(w, 100);
+ ck_assert_int_eq(h, 100);
+}
+EFL_END_TEST
+
#ifdef BUILD_LOADER_GIF
static void
_test_render(void *data, Evas *e EINA_UNUSED, void *event_info)
@@ -332,6 +357,7 @@ void elm_test_image(TCase *tc)
tcase_add_test(tc, elm_image_evas_object_color_set);
tcase_add_test(tc, elm_image_evas_image_get);
tcase_add_test(tc, elm_image_test_memfile_set);
+ tcase_add_test(tc, elm_image_test_scale_method);
#ifdef BUILD_LOADER_GIF
tcase_add_test(tc, elm_image_test_gif);
#endif