#ifdef HAVE_CONFIG_H # include #endif #include #include #define EFL_GFX_FILTER_BETA #include #include #include "edje_suite.h" #include "edje_tests_helpers.h" #define EVAS_DATA_DIR TESTS_SRC_DIR "/../../lib/evas" START_TEST(edje_test_edje_init) { int ret; ret = edje_init(); fail_if(ret != 1); ret = edje_shutdown(); fail_if(ret != 0); } END_TEST START_TEST(edje_test_edje_load) { Evas *evas = EDJE_TEST_INIT_EVAS(); Edje_Load_Error error; Evas_Object *obj; obj = edje_object_add(evas); edje_object_file_set(obj, "blaoeuaeoueoaua.edj", "test"); error = edje_object_load_error_get(obj); fail_if(error != EDJE_LOAD_ERROR_DOES_NOT_EXIST); EDJE_TEST_FREE_EVAS(); } END_TEST static const char * test_layout_get(const char *name) { static char filename[PATH_MAX]; snprintf(filename, PATH_MAX, TESTS_BUILD_DIR"/data/%s", name); static int is_local = -1; if (is_local == -1) { struct stat st; is_local = (stat(filename, &st) == 0); } if (!is_local) snprintf(filename, PATH_MAX, PACKAGE_DATA_DIR"/data/%s", name); return filename; } START_TEST(edje_test_load_simple_layout) { Evas *evas = EDJE_TEST_INIT_EVAS(); Evas_Object *obj; obj = edje_object_add(evas); fail_unless(edje_object_file_set(obj, test_layout_get("test_layout.edj"), "test_group")); fail_if(edje_object_part_exists(obj, "unexistant_part")); fail_unless(edje_object_part_exists(obj, "background")); EDJE_TEST_FREE_EVAS(); } END_TEST START_TEST(edje_test_simple_layout_geometry) { int x, y, w, h; int r, g, b, a; Evas *evas = EDJE_TEST_INIT_EVAS(); Evas_Object *obj; const Evas_Object *bg; obj = edje_object_add(evas); fail_unless(edje_object_file_set(obj, test_layout_get("test_layout.edj"), "test_group")); /* rel1.relative: 0.0 0.0; * rel2.relative: 1.0 1.0; */ evas_object_resize(obj, 1000, 1000); edje_object_part_geometry_get(obj, "background", &x, &y, &w, &h); fail_if(x != 0 || y != 0); fail_if(w != 1000 || h != 1000); bg = edje_object_part_object_get(obj, "background"); fail_if(!bg); evas_object_color_get(bg, &r, &g, &b, &a); fail_if(r != 255 || g != 255 || b != 255 || a != 255); EDJE_TEST_FREE_EVAS(); } END_TEST START_TEST(edje_test_complex_layout) { int x, y, w, h; Evas *evas = EDJE_TEST_INIT_EVAS(); Evas_Object *obj; obj = edje_object_add(evas); fail_unless(edje_object_file_set(obj, test_layout_get("complex_layout.edj"), "test_group")); evas_object_resize(obj, 1000, 1000); /* Apparently rel2 offsets are retarded and you have to introduce off-by-one * madness (rel2.offset: -1 -1; acts like there is zero offset...) * Take that into account when checking w and h */ /* rel1.relative: 0.0 0.0; rel1.offset: 0 0; * rel2.relative: 1.0 1.0; rel2.offset -1 -1; */ edje_object_part_geometry_get(obj, "background", &x, &y, &w, &h); fail_if(x != 0 || y != 0); fail_if(w != 1000-1 + 1 || h != 1000-1 + 1); /* rel1.relative: 0.0 0.0; rel1.offset: 1 1; * rel2.relative: 1.0 1.0; rel2.offset 0 0; */ edje_object_part_geometry_get(obj, "background2", &x, &y, &w, &h); fail_if(x != 1 || y != 1); fail_if(w != 1000-1 + 1 || h != 1000-1 + 1); /* rel1.relative: 0.0 0.0; rel1.offset: 5 5; * rel2.relative: 0.5 0.5; rel2.offset -2 -2; */ edje_object_part_geometry_get(obj, "ul", &x, &y, &w, &h); fail_if(x != 5 || y != 5); fail_if(w != 500-5-2 + 1 || h != 500-5-2 + 1); /* rel1.relative: 0.5 0.0; rel1.offset: 2 5; * rel2.relative: 1.0 0.5; rel2.offset -5 -2; */ edje_object_part_geometry_get(obj, "ur", &x, &y, &w, &h); fail_if(x != 500+2 || y != 5); fail_if(w != 500-5-2 + 1 || h != 500-5-2 + 1); /* rel1.relative: 0.0 0.5; rel1.offset: 5 2; * rel2.relative: 1.0 1.0; rel2.offset -5 -5; */ edje_object_part_geometry_get(obj, "l", &x, &y, &w, &h); fail_if(x != 5 || y != 500+2); fail_if(w != 1000-5-5 + 1 || h != 500-5-2 + 1); EDJE_TEST_FREE_EVAS(); } END_TEST START_TEST(edje_test_calculate_parens) { int x, y, w, h; Evas *evas = EDJE_TEST_INIT_EVAS(); Evas_Object *obj; obj = edje_object_add(evas); fail_unless(edje_object_file_set(obj, test_layout_get("test_parens.edj"), "test_group")); evas_object_resize(obj, 100, 100); edje_object_part_geometry_get(obj, "background", &x, &y, &w, &h); fail_if(x != 0 || y != 0 || w != 100 || h != 100); EDJE_TEST_FREE_EVAS(); } END_TEST START_TEST(edje_test_masking) { int x, y, w, h; Evas *evas = EDJE_TEST_INIT_EVAS(); const Evas_Object *sub, *clip2, *clip; Evas_Object *obj; Eina_Bool b; obj = edje_object_add(evas); fail_unless(edje_object_file_set(obj, test_layout_get("test_masking.edj"), "test_group")); evas_object_resize(obj, 100, 100); edje_object_part_geometry_get(obj, "background", &x, &y, &w, &h); fail_if(x != 0 || y != 0 || w != 100 || h != 100); clip = edje_object_part_object_get(obj, "clip2"); fail_if(!clip); /* check value of no_render flag as seen from evas land */ sub = edje_object_part_object_get(obj, "mask"); fail_if(!eo_do_ret(sub, b, evas_obj_no_render_get())); /* check that text has a clip (based on description.clip_to) */ sub = edje_object_part_object_get(obj, "text"); fail_if(!eo_do_ret(sub, clip2, evas_obj_clip_get())); /* test description.clip_to override */ sub = edje_object_part_object_get(obj, "noclip"); clip2 = eo_do_ret(sub, clip2, evas_obj_clip_get()); fail_if(clip != clip2); EDJE_TEST_FREE_EVAS(); } END_TEST START_TEST(edje_test_filters) { Evas *evas = EDJE_TEST_INIT_EVAS(); const Evas_Object *text, *sub; Evas_Object *obj, *src = NULL; const char *prg, *name; Eina_Bool b; setenv("EVAS_DATA_DIR", EVAS_DATA_DIR, 1); obj = edje_object_add(evas); fail_unless(edje_object_file_set(obj, test_layout_get("test_filters.edj"), "test_group")); evas_object_resize(obj, 200, 200); /* check value of no_render flag as seen from evas land */ sub = edje_object_part_object_get(obj, "mask"); fail_if(!eo_do_ret(sub, b, evas_obj_no_render_get())); /* check no_render inheritance */ sub = edje_object_part_object_get(obj, "mask2"); fail_if(eo_do_ret(sub, b, evas_obj_no_render_get())); sub = edje_object_part_object_get(obj, "mask3"); fail_if(!eo_do_ret(sub, b, evas_obj_no_render_get())); /* text part: check filter status */ text = edje_object_part_object_get(obj, "text"); fail_if(!text); eo_do(text, efl_gfx_filter_program_get(&prg, &name)); fail_if(!prg); fail_if(!name || strcmp(name, "filterfile")); eo_do(text, efl_gfx_filter_source_get("mask", &src)); fail_if(!src); // TODO: Verify properly that the filter runs well EDJE_TEST_FREE_EVAS(); } END_TEST START_TEST(edje_test_snapshot) { Evas *evas = EDJE_TEST_INIT_EVAS(); const Evas_Object *sub; Evas_Object *obj; Eina_Bool b; setenv("EVAS_DATA_DIR", EVAS_DATA_DIR, 1); obj = edje_object_add(evas); fail_unless(edje_object_file_set(obj, test_layout_get("test_snapshot.edj"), "test_group")); evas_object_resize(obj, 200, 200); /* check value of no_render flag as seen from evas land */ sub = edje_object_part_object_get(obj, "snap"); fail_if(!eo_do_ret(sub, b, evas_obj_image_snapshot_get())); // TODO: Verify that evas snapshot actually works (and has a filter) EDJE_TEST_FREE_EVAS(); } END_TEST START_TEST(edje_test_size_class) { int minw, minh, minw2, minh2; Evas *evas = EDJE_TEST_INIT_EVAS(); Eina_List *l; Eina_Stringshare *name; Evas_Object *obj, *obj2; Eina_Bool b; obj = edje_object_add(evas); fail_unless(edje_object_file_set(obj, test_layout_get("test_size_class.edj"), "test_group")); obj2 = edje_object_add(evas); fail_unless(edje_object_file_set(obj2, test_layout_get("test_size_class.edj"), "test_group")); evas_object_resize(obj, 200, 200); evas_object_resize(obj2, 200, 200); /* check predefined min size of rect part by edc */ edje_object_part_geometry_get(obj, "rect", NULL, NULL, &minw, &minh); fail_if(minw != 50 || minh != 50); /* check that edje_size_class_set works */ b = edje_size_class_set("rect_size", 100, 100, -1, -1); edje_object_part_geometry_get(obj, "rect", NULL, NULL, &minw, &minh); edje_object_part_geometry_get(obj2, "rect", NULL, NULL, &minw2, &minh2); fail_if(!b || minw != 100 || minh != 100 || minw2 != 100 || minh2 != 100); /* check that edje_size_class_get works */ b = edje_size_class_get("rect_size", &minw, &minh, NULL, NULL); fail_if(!b || minw != 100 || minh != 100); /* check that edje_size_class_list works */ l = edje_size_class_list(); EINA_LIST_FREE(l, name) { fail_if(strcmp(name, "rect_size")); eina_stringshare_del(name); } /* check that edje_object_size_class_set works */ b = edje_object_size_class_set(obj, "rect_size", 150, 150, -1, -1); edje_object_part_geometry_get(obj, "rect", NULL, NULL, &minw, &minh); edje_object_part_geometry_get(obj2, "rect", NULL, NULL, &minw2, &minh2); fail_if(!b || minw != 150 || minh != 150 || minw2 != 100 || minh2 != 100); /* check that edje_object_size_class_get works */ b = edje_object_size_class_get(obj, "rect_size", &minw, &minh, NULL, NULL); fail_if(!b || minw != 150 || minh != 150); EDJE_TEST_FREE_EVAS(); } END_TEST START_TEST(edje_test_color_class) { Evas *evas = EDJE_TEST_INIT_EVAS(); Eina_File *f; Eina_Iterator *it; Edje_Color_Class *itcc, *cc = NULL; char *filename; filename = realpath(test_layout_get("test_color_class.edj"), NULL); fail_if(!filename); f = eina_file_open(filename, EINA_FALSE); fail_if(!f); it = edje_mmap_color_class_iterator_new(f); fail_if(!it); EINA_ITERATOR_FOREACH(it, itcc) { if (!strcmp(itcc->name, "test_color_class")) { cc = itcc; break; } } fail_if((!cc) || (cc->r != 100) || (cc->g != 100) || (cc->b != 100) || (cc->a != 100)); eina_iterator_free(it); eina_file_close(f); free(filename); EDJE_TEST_FREE_EVAS(); } END_TEST void edje_test_edje(TCase *tc) { tcase_add_test(tc, edje_test_edje_init); tcase_add_test(tc,edje_test_load_simple_layout); tcase_add_test(tc, edje_test_edje_load); tcase_add_test(tc, edje_test_simple_layout_geometry); tcase_add_test(tc, edje_test_complex_layout); tcase_add_test(tc, edje_test_calculate_parens); tcase_add_test(tc, edje_test_masking); tcase_add_test(tc, edje_test_filters); tcase_add_test(tc, edje_test_snapshot); tcase_add_test(tc, edje_test_size_class); tcase_add_test(tc, edje_test_color_class); }