forked from enlightenment/efl
tests: move efl_ui_layout tests into efl_ui_suite
also use legacy api for elm_layout swallow test ref T6815 Reviewed-by: Stefan Schmidt <stefan@datenfreihafen.org> Differential Revision: https://phab.enlightenment.org/D7824
This commit is contained in:
parent
77b7646d56
commit
633a2e506c
|
@ -1610,7 +1610,8 @@ tests_elementary_efl_ui_suite_SOURCES = \
|
||||||
tests/elementary/elm_test_init.c \
|
tests/elementary/elm_test_init.c \
|
||||||
tests/elementary/efl_ui_test_atspi.c \
|
tests/elementary/efl_ui_test_atspi.c \
|
||||||
tests/elementary/efl_ui_test_image_zoomable.c \
|
tests/elementary/efl_ui_test_image_zoomable.c \
|
||||||
tests/elementary/efl_ui_test_grid.c
|
tests/elementary/efl_ui_test_grid.c \
|
||||||
|
tests/elementary/efl_ui_test_layout.c
|
||||||
|
|
||||||
tests_elementary_efl_ui_suite_CPPFLAGS = \
|
tests_elementary_efl_ui_suite_CPPFLAGS = \
|
||||||
-DELM_INTERNAL_API_ARGESFSDFEFC=1 \
|
-DELM_INTERNAL_API_ARGESFSDFEFC=1 \
|
||||||
|
|
|
@ -15,6 +15,7 @@ static const Efl_Test_Case etc[] = {
|
||||||
{ "efl_ui_atspi", efl_ui_test_atspi},
|
{ "efl_ui_atspi", efl_ui_test_atspi},
|
||||||
{ "efl_ui_grid", efl_ui_test_grid},
|
{ "efl_ui_grid", efl_ui_test_grid},
|
||||||
{ "efl_ui_image_zoomable", efl_ui_test_image_zoomable},
|
{ "efl_ui_image_zoomable", efl_ui_test_image_zoomable},
|
||||||
|
{ "efl_ui_layout", efl_ui_test_layout},
|
||||||
{ NULL, NULL }
|
{ NULL, NULL }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
void efl_ui_test_grid(TCase *tc);
|
void efl_ui_test_grid(TCase *tc);
|
||||||
void efl_ui_test_atspi(TCase *tc);
|
void efl_ui_test_atspi(TCase *tc);
|
||||||
void efl_ui_test_image_zoomable(TCase *tc);
|
void efl_ui_test_image_zoomable(TCase *tc);
|
||||||
|
void efl_ui_test_layout(TCase *tc);
|
||||||
|
|
||||||
Eo *win_add();
|
Eo *win_add();
|
||||||
Eo *win_add_focused();
|
Eo *win_add_focused();
|
||||||
|
|
|
@ -0,0 +1,99 @@
|
||||||
|
#define EFL_NOLEGACY_API_SUPPORT
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "elementary_config.h"
|
||||||
|
#endif
|
||||||
|
#define EFL_LAYOUT_CALC_PROTECTED
|
||||||
|
#include <Efl_Ui.h>
|
||||||
|
#include "efl_ui_suite.h"
|
||||||
|
|
||||||
|
static Eina_Value
|
||||||
|
_propagated_cb(void *data EINA_UNUSED,
|
||||||
|
const Eina_Value v,
|
||||||
|
const Eina_Future *dead_future EINA_UNUSED)
|
||||||
|
{
|
||||||
|
ecore_main_loop_quit();
|
||||||
|
|
||||||
|
fprintf(stderr, "delivered '%s'\n", eina_value_to_string(&v));
|
||||||
|
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
EFL_START_TEST(efl_ui_layout_test_model_connect)
|
||||||
|
{
|
||||||
|
char buf[PATH_MAX];
|
||||||
|
Evas_Object *win, *ly;
|
||||||
|
Efl_Model_Item *model;
|
||||||
|
Eina_Value v;
|
||||||
|
Eina_Future *f;
|
||||||
|
const char *part_text;
|
||||||
|
const char text_value[] = "A random string for elm_layout_model_connect test";
|
||||||
|
|
||||||
|
win = win_add(NULL, "layout", EFL_UI_WIN_BASIC);
|
||||||
|
|
||||||
|
ly = efl_add(EFL_UI_LAYOUT_CLASS, win);
|
||||||
|
snprintf(buf, sizeof(buf), "%s/objects/test.edj", ELM_TEST_DATA_DIR);
|
||||||
|
efl_file_set(ly, buf, "layout");
|
||||||
|
efl_gfx_entity_visible_set(ly, EINA_TRUE);
|
||||||
|
|
||||||
|
model = efl_add(EFL_MODEL_ITEM_CLASS, win);
|
||||||
|
ck_assert(!!eina_value_setup(&v, EINA_VALUE_TYPE_STRING));
|
||||||
|
ck_assert(!!eina_value_set(&v, text_value));
|
||||||
|
f = efl_model_property_set(model, "text_property", &v);
|
||||||
|
eina_future_then(f, _propagated_cb, NULL, NULL);
|
||||||
|
|
||||||
|
efl_ui_model_connect(ly, "text", "text_property");
|
||||||
|
efl_ui_view_model_set(ly, model);
|
||||||
|
|
||||||
|
ecore_main_loop_begin();
|
||||||
|
|
||||||
|
part_text = efl_text_get(efl_part(ly, "text"));
|
||||||
|
|
||||||
|
ck_assert_str_eq(part_text, text_value);
|
||||||
|
|
||||||
|
}
|
||||||
|
EFL_END_TEST
|
||||||
|
|
||||||
|
EFL_START_TEST(efl_ui_layout_test_layout_api_size_min)
|
||||||
|
{
|
||||||
|
Evas_Object *win;
|
||||||
|
Eina_Size2D res;
|
||||||
|
|
||||||
|
win = win_add(NULL, "layout", EFL_UI_WIN_BASIC);
|
||||||
|
/* this is just a test to not get segfaults in those calls */
|
||||||
|
Eo *layout = efl_add(EFL_UI_LAYOUT_CLASS, win);
|
||||||
|
res = efl_layout_calc_size_min(layout, EINA_SIZE2D(2, 2));
|
||||||
|
ck_assert_int_eq(res.w, 2);
|
||||||
|
ck_assert_int_eq(res.h, 2);
|
||||||
|
}
|
||||||
|
EFL_END_TEST
|
||||||
|
|
||||||
|
EFL_START_TEST(efl_ui_layout_test_layout_api_update_hints)
|
||||||
|
{
|
||||||
|
Evas_Object *win;
|
||||||
|
|
||||||
|
win = win_add(NULL, "layout", EFL_UI_WIN_BASIC);
|
||||||
|
/* this is just a test to not get segfaults in those calls */
|
||||||
|
Eo *layout = efl_add(EFL_UI_LAYOUT_CLASS, win);
|
||||||
|
efl_layout_calc_auto_update_hints_set(layout, EINA_TRUE);
|
||||||
|
ck_assert_int_eq(efl_layout_calc_auto_update_hints_get(layout), EINA_TRUE);
|
||||||
|
}
|
||||||
|
EFL_END_TEST
|
||||||
|
|
||||||
|
EFL_START_TEST(efl_ui_layout_test_layout_force)
|
||||||
|
{
|
||||||
|
Evas_Object *win;
|
||||||
|
|
||||||
|
win = win_add(NULL, "layout", EFL_UI_WIN_BASIC);
|
||||||
|
/* this is just a test to not get segfaults in those calls */
|
||||||
|
Eo *layout = efl_add(EFL_UI_LAYOUT_CLASS, win);
|
||||||
|
efl_layout_calc_force(layout);
|
||||||
|
}
|
||||||
|
EFL_END_TEST
|
||||||
|
|
||||||
|
void efl_ui_test_layout(TCase *tc)
|
||||||
|
{
|
||||||
|
tcase_add_test(tc, efl_ui_layout_test_model_connect);
|
||||||
|
tcase_add_test(tc, efl_ui_layout_test_layout_api_size_min);
|
||||||
|
tcase_add_test(tc, efl_ui_layout_test_layout_api_update_hints);
|
||||||
|
tcase_add_test(tc, efl_ui_layout_test_layout_force);
|
||||||
|
}
|
|
@ -2,7 +2,6 @@
|
||||||
# include "elementary_config.h"
|
# include "elementary_config.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define EFL_LAYOUT_CALC_PROTECTED
|
|
||||||
#define EFL_ACCESS_OBJECT_BETA
|
#define EFL_ACCESS_OBJECT_BETA
|
||||||
#include <Elementary.h>
|
#include <Elementary.h>
|
||||||
#include "elm_suite.h"
|
#include "elm_suite.h"
|
||||||
|
@ -49,118 +48,31 @@ EFL_START_TEST(elm_layout_test_swallows)
|
||||||
|
|
||||||
win = win_add(NULL, "layout", ELM_WIN_BASIC);
|
win = win_add(NULL, "layout", ELM_WIN_BASIC);
|
||||||
|
|
||||||
ly = efl_add(EFL_UI_LAYOUT_CLASS, win);
|
ly = elm_layout_add(win);
|
||||||
snprintf(buf, sizeof(buf), "%s/objects/test.edj", ELM_TEST_DATA_DIR);
|
snprintf(buf, sizeof(buf), "%s/objects/test.edj", ELM_TEST_DATA_DIR);
|
||||||
elm_layout_file_set(ly, buf, "layout");
|
elm_layout_file_set(ly, buf, "layout");
|
||||||
evas_object_show(ly);
|
evas_object_show(ly);
|
||||||
|
|
||||||
bt = efl_add(EFL_UI_BUTTON_CLASS, ly);
|
bt = elm_button_add(ly);
|
||||||
fail_if(!efl_content_set(efl_part(ly, "element1"), bt));
|
fail_if(!elm_layout_content_set(ly, "element1", bt));
|
||||||
ck_assert_ptr_eq(efl_parent_get(bt), ly);
|
ck_assert_ptr_eq(efl_parent_get(bt), ly);
|
||||||
|
|
||||||
bt = efl_content_unset(efl_part(ly, "element1"));
|
bt = elm_object_part_content_unset(ly, "element1");
|
||||||
ck_assert_ptr_eq(efl_parent_get(bt), evas_object_evas_get(bt));
|
ck_assert_ptr_eq(efl_parent_get(bt), evas_object_evas_get(bt));
|
||||||
|
|
||||||
fail_if(!efl_content_set(efl_part(ly, "element1"), bt));
|
fail_if(!elm_layout_content_set(ly, "element1", bt));
|
||||||
ck_assert_ptr_eq(efl_parent_get(bt), ly);
|
ck_assert_ptr_eq(efl_parent_get(bt), ly);
|
||||||
|
|
||||||
bt2 = efl_add(EFL_UI_BUTTON_CLASS, ly);
|
bt2 = elm_button_add(ly);
|
||||||
fail_if(!efl_content_set(efl_part(ly, "element1"), bt2));
|
fail_if(!elm_layout_content_set(ly, "element1", bt2));
|
||||||
ck_assert_ptr_eq(efl_parent_get(bt2), ly);
|
ck_assert_ptr_eq(efl_parent_get(bt2), ly);
|
||||||
|
|
||||||
}
|
}
|
||||||
EFL_END_TEST
|
EFL_END_TEST
|
||||||
|
|
||||||
static Eina_Value
|
|
||||||
_propagated_cb(void *data EINA_UNUSED,
|
|
||||||
const Eina_Value v,
|
|
||||||
const Eina_Future *dead_future EINA_UNUSED)
|
|
||||||
{
|
|
||||||
ecore_main_loop_quit();
|
|
||||||
|
|
||||||
fprintf(stderr, "delivered '%s'\n", eina_value_to_string(&v));
|
|
||||||
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
EFL_START_TEST(elm_layout_test_model_connect)
|
|
||||||
{
|
|
||||||
char buf[PATH_MAX];
|
|
||||||
Evas_Object *win, *ly;
|
|
||||||
Efl_Model_Item *model;
|
|
||||||
Eina_Value v;
|
|
||||||
Eina_Future *f;
|
|
||||||
const char *part_text;
|
|
||||||
const char text_value[] = "A random string for elm_layout_model_connect test";
|
|
||||||
|
|
||||||
win = win_add(NULL, "layout", ELM_WIN_BASIC);
|
|
||||||
|
|
||||||
ly = efl_add(EFL_UI_LAYOUT_CLASS, win);
|
|
||||||
snprintf(buf, sizeof(buf), "%s/objects/test.edj", ELM_TEST_DATA_DIR);
|
|
||||||
elm_layout_file_set(ly, buf, "layout");
|
|
||||||
evas_object_show(ly);
|
|
||||||
|
|
||||||
model = efl_add(EFL_MODEL_ITEM_CLASS, win);
|
|
||||||
ck_assert(!!eina_value_setup(&v, EINA_VALUE_TYPE_STRING));
|
|
||||||
ck_assert(!!eina_value_set(&v, text_value));
|
|
||||||
f = efl_model_property_set(model, "text_property", &v);
|
|
||||||
eina_future_then(f, _propagated_cb, NULL, NULL);
|
|
||||||
|
|
||||||
efl_ui_model_connect(ly, "text", "text_property");
|
|
||||||
efl_ui_view_model_set(ly, model);
|
|
||||||
|
|
||||||
ecore_main_loop_begin();
|
|
||||||
|
|
||||||
part_text = elm_layout_text_get(ly, "text");
|
|
||||||
|
|
||||||
ck_assert_str_eq(part_text, text_value);
|
|
||||||
|
|
||||||
}
|
|
||||||
EFL_END_TEST
|
|
||||||
|
|
||||||
EFL_START_TEST(efl_ui_layout_layout_api_size_min)
|
|
||||||
{
|
|
||||||
Evas_Object *win;
|
|
||||||
Eina_Size2D res;
|
|
||||||
|
|
||||||
win = win_add(NULL, "layout", ELM_WIN_BASIC);
|
|
||||||
/* this is just a test to not get segfaults in those calls */
|
|
||||||
Eo *layout = efl_add(EFL_UI_LAYOUT_CLASS, win);
|
|
||||||
res = efl_layout_calc_size_min(layout, EINA_SIZE2D(2, 2));
|
|
||||||
ck_assert_int_eq(res.w, 2);
|
|
||||||
ck_assert_int_eq(res.h, 2);
|
|
||||||
}
|
|
||||||
EFL_END_TEST
|
|
||||||
|
|
||||||
EFL_START_TEST(efl_ui_layout_layout_api_update_hints)
|
|
||||||
{
|
|
||||||
Evas_Object *win;
|
|
||||||
|
|
||||||
win = win_add(NULL, "layout", ELM_WIN_BASIC);
|
|
||||||
/* this is just a test to not get segfaults in those calls */
|
|
||||||
Eo *layout = efl_add(EFL_UI_LAYOUT_CLASS, win);
|
|
||||||
efl_layout_calc_auto_update_hints_set(layout, EINA_TRUE);
|
|
||||||
ck_assert_int_eq(efl_layout_calc_auto_update_hints_get(layout), EINA_TRUE);
|
|
||||||
}
|
|
||||||
EFL_END_TEST
|
|
||||||
|
|
||||||
EFL_START_TEST(efl_ui_layout_layout_force)
|
|
||||||
{
|
|
||||||
Evas_Object *win;
|
|
||||||
|
|
||||||
win = win_add(NULL, "layout", ELM_WIN_BASIC);
|
|
||||||
/* this is just a test to not get segfaults in those calls */
|
|
||||||
Eo *layout = efl_add(EFL_UI_LAYOUT_CLASS, win);
|
|
||||||
efl_layout_calc_force(layout);
|
|
||||||
}
|
|
||||||
EFL_END_TEST
|
|
||||||
void elm_test_layout(TCase *tc)
|
void elm_test_layout(TCase *tc)
|
||||||
{
|
{
|
||||||
tcase_add_test(tc, elm_layout_test_legacy_type_check);
|
tcase_add_test(tc, elm_layout_test_legacy_type_check);
|
||||||
tcase_add_test(tc, elm_atspi_role_get);
|
tcase_add_test(tc, elm_atspi_role_get);
|
||||||
tcase_add_test(tc, elm_layout_test_swallows);
|
tcase_add_test(tc, elm_layout_test_swallows);
|
||||||
tcase_add_test(tc, elm_layout_test_model_connect);
|
|
||||||
tcase_add_test(tc, efl_ui_layout_layout_api_size_min);
|
|
||||||
tcase_add_test(tc, efl_ui_layout_layout_api_update_hints);
|
|
||||||
tcase_add_test(tc, efl_ui_layout_layout_force);
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -123,6 +123,7 @@ efl_ui_suite_src = [
|
||||||
'efl_ui_test_atspi.c',
|
'efl_ui_test_atspi.c',
|
||||||
'efl_ui_test_grid.c',
|
'efl_ui_test_grid.c',
|
||||||
'efl_ui_test_image_zoomable.c',
|
'efl_ui_test_image_zoomable.c',
|
||||||
|
'efl_ui_test_layout.c',
|
||||||
]
|
]
|
||||||
|
|
||||||
efl_ui_suite = executable('efl_ui_suite',
|
efl_ui_suite = executable('efl_ui_suite',
|
||||||
|
|
Loading…
Reference in New Issue