efl/src/tests/edje/edje_test_edje.c

379 lines
10 KiB
C

#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
#include <unistd.h>
#include <stdio.h>
#define EFL_GFX_FILTER_BETA
#include <Eina.h>
#include <Edje.h>
#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);
}