1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
#include <Ecore_Evas.h>
#include <Efl_Core.h>
#include "ecore_suite.h"
#define WINDOW_HEIGHT 200
#define WINDOW_WIDTH 200
EFL_START_TEST(ecore_test_ecore_evas_associate)
{
Ecore_Evas *ee;
Evas *canvas;
Evas_Object *bg;
int ret;
ret = ecore_evas_init();
fail_if(ret == 0);
ee = ecore_evas_buffer_new(WINDOW_WIDTH, WINDOW_HEIGHT);
fail_if(ee == NULL);
canvas = ecore_evas_get(ee);
fail_if(ecore_evas_ecore_evas_get(canvas) != ee);
bg = evas_object_rectangle_add(canvas);
ret = ecore_evas_object_associate(ee, bg, ECORE_EVAS_OBJECT_ASSOCIATE_BASE);
fail_if(ret == 0);
ecore_evas_free(ee);
ret = ecore_evas_shutdown();
fail_if(ret != 0);
}
EFL_END_TEST
EFL_START_TEST(ecore_test_ecore_evas_cocoa)
{
int ret;
Ecore_Evas *ee;
Ecore_Cocoa_Window *win;
ret = ecore_evas_init();
fail_if(ret != 1);
ret = ecore_evas_engine_type_supported_get(ECORE_EVAS_ENGINE_OPENGL_COCOA);
if (ret == EINA_TRUE)
{
/* Engine supported. Shall not fail... */
ee = ecore_evas_cocoa_new(NULL, 0, 0, WINDOW_WIDTH, WINDOW_HEIGHT);
fail_if(ee == NULL);
win = ecore_evas_cocoa_window_get(ee);
fail_if(win == NULL);
}
else
{
/* Engine not supported. Shall not succeed... */
ee = ecore_evas_cocoa_new(NULL, 0, 0, WINDOW_WIDTH, WINDOW_HEIGHT);
fail_if(ee != NULL);
win = ecore_evas_cocoa_window_get(ee);
fail_if(win != NULL);
}
ecore_evas_free(ee);
ret = ecore_evas_shutdown();
fail_if(ret != 0);
}
EFL_END_TEST
static Eina_Value
_verify_and_exit(void *data, const Eina_Value value, const Eina_Future *dead_future EINA_UNUSED)
{
ck_assert_ptr_eq(eina_value_type_get(&value), EINA_VALUE_TYPE_CONTENT);
Eina_Content *content = eina_value_to_content(&value);
Eina_Content *reference = data;
ck_assert_int_eq(eina_content_data_get(content).len, eina_content_data_get(reference).len);
ck_assert_str_eq(eina_content_data_get(content).mem, eina_content_data_get(reference).mem);
ck_assert_str_eq(eina_content_type_get(content), eina_content_type_get(reference));
efl_loop_quit(efl_main_loop_get(), eina_value_int_init(0));
return EINA_VALUE_EMPTY;
}
EFL_START_TEST(ecore_test_ecore_evas_fallback_selection)
{
Ecore_Evas *ee;
ecore_evas_init();
ee = ecore_evas_buffer_new(WINDOW_WIDTH, WINDOW_HEIGHT);
fail_if(ee == NULL);
for (int i = 0; i < ECORE_EVAS_SELECTION_BUFFER_LAST; ++i)
{
ck_assert_int_eq(ecore_evas_selection_exists(ee, 0, i), EINA_FALSE);
}
Eina_Content *content = eina_content_new((Eina_Slice)EINA_SLICE_STR_FULL("asdf"), "text/plain");
Eina_Content *ref = eina_content_new((Eina_Slice)EINA_SLICE_STR_FULL("asdf"), "text/plain");
ecore_evas_selection_set(ee, 0, ECORE_EVAS_SELECTION_BUFFER_SELECTION_BUFFER, content);
const char *types[] = {eina_stringshare_add("text/plain")};
Eina_Future *f = ecore_evas_selection_get(ee, 0, ECORE_EVAS_SELECTION_BUFFER_SELECTION_BUFFER, EINA_C_ARRAY_ITERATOR_NEW(types));
ck_assert_ptr_ne(f, NULL);
eina_future_then(f, _verify_and_exit, ref);
efl_task_run(efl_main_loop_get());
ecore_evas_shutdown();
}
EFL_END_TEST
void ecore_test_ecore_evas(TCase *tc)
{
tcase_add_test(tc, ecore_test_ecore_evas_associate);
tcase_add_test(tc, ecore_test_ecore_evas_cocoa);
tcase_add_test(tc, ecore_test_ecore_evas_fallback_selection);
}
|