efl/src/tests/eldbus/eldbus_test_fake_server_eld...

260 lines
7.8 KiB
C
Raw Normal View History

#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
2016-02-04 05:52:49 -08:00
#include <stdbool.h>
#include <Eina.h>
2016-02-04 05:52:49 -08:00
#include <Ecore.h>
#include <Eldbus_Model.h>
2016-02-04 05:52:49 -08:00
#include "eldbus_fake_server.h"
#include "eldbus_test_eldbus_model.h"
#include "eldbus_suite.h"
static Eo *fake_server_object = NULL;
static Eo *fake_server_proxy = NULL;
static Eldbus_Service_Interface *fake_server = NULL;
static Fake_Server_Data fake_server_data = {0};
#define FAKE_SERVER_READONLY_PROPERTY_VALUE 1111
#define FAKE_SERVER_WRITEONLY_PROPERTY_VALUE 2222
#define FAKE_SERVER_READWRITE_PROPERTY_VALUE 3333
static void
_setup(void)
{
check_init();
fake_server_data = (Fake_Server_Data){
.readonly_property = FAKE_SERVER_READONLY_PROPERTY_VALUE,
.writeonly_property = FAKE_SERVER_WRITEONLY_PROPERTY_VALUE,
.readwrite_property = FAKE_SERVER_READWRITE_PROPERTY_VALUE
};
fake_server = fake_server_start(&fake_server_data);
fake_server_object = eo_add(ELDBUS_MODEL_OBJECT_CLASS, NULL, eldbus_model_object_constructor(eo_self, ELDBUS_CONNECTION_TYPE_SESSION, NULL, EINA_FALSE, FAKE_SERVER_BUS, FAKE_SERVER_PATH));
ck_assert_ptr_ne(NULL, fake_server_object);
efl_model_load_and_wait_for_load_status(fake_server_object, EFL_MODEL_LOAD_STATUS_LOADED);
fake_server_proxy = eldbus_model_proxy_from_object_get(fake_server_object, FAKE_SERVER_INTERFACE);
efl_model_load_and_wait_for_load_status(fake_server_proxy, EFL_MODEL_LOAD_STATUS_LOADED);
}
static void
_teardown(void)
{
eo_unref(fake_server_object);
fake_server_stop(fake_server);
check_shutdown();
}
START_TEST(load_status_get)
{
check_efl_model_load_status_get(fake_server_proxy, EFL_MODEL_LOAD_STATUS_LOADED);
_teardown();
}
END_TEST
START_TEST(properties_get)
{
Eina_Array *properties = NULL;
Efl_Model_Load_Status status;
status = efl_model_properties_get(fake_server_proxy, &properties);
ck_assert_int_eq(EFL_MODEL_LOAD_STATUS_LOADED, status);
ck_assert_ptr_ne(NULL, properties);
const unsigned int expected_properties_count = 3; // FAKE_SERVER_READONLY_PROPERTY, FAKE_SERVER_WRITEONLY_PROPERTY and FAKE_SERVER_READWRITE_PROPERTY properties
const unsigned int actual_properties_count = eina_array_count(properties);
ck_assert_int_eq(expected_properties_count, actual_properties_count);
_teardown();
}
END_TEST
START_TEST(property_get)
{
check_efl_model_property_int_eq(fake_server_proxy, FAKE_SERVER_READONLY_PROPERTY, FAKE_SERVER_READONLY_PROPERTY_VALUE);
check_efl_model_property_int_eq(fake_server_proxy, FAKE_SERVER_READWRITE_PROPERTY, FAKE_SERVER_READWRITE_PROPERTY_VALUE);
// Write-only property returns error
const Eina_Value *dummy;
Efl_Model_Load_Status status;
status = efl_model_property_get(fake_server_proxy, FAKE_SERVER_WRITEONLY_PROPERTY, &dummy);
ck_assert_int_eq(EFL_MODEL_LOAD_STATUS_ERROR, status);
2016-02-04 05:52:49 -08:00
_teardown();
}
END_TEST
static void
_check_property_set(const char *property_name, int expected_property_value, int *actual_property_value)
{
Eina_Value value;
eina_value_setup(&value, EINA_VALUE_TYPE_INT);
eina_value_set(&value, expected_property_value);
Efl_Model_Load_Status status;
status = efl_model_property_set(fake_server_proxy, property_name, &value);
eina_value_flush(&value);
ck_assert_int_eq(EFL_MODEL_LOAD_STATUS_LOADED, status);
efl_model_wait_for_event(fake_server_proxy, EFL_MODEL_BASE_EVENT_PROPERTIES_CHANGED);
ck_assert_int_eq(expected_property_value, *actual_property_value);
}
START_TEST(property_set)
{
_check_property_set(FAKE_SERVER_WRITEONLY_PROPERTY, 0x12345678, &fake_server_data.writeonly_property);
_check_property_set(FAKE_SERVER_READWRITE_PROPERTY, 0x76543210, &fake_server_data.readwrite_property);
// Read-only property returns error
Eina_Value dummy = {0};
Efl_Model_Load_Status status;
status = efl_model_property_set(fake_server_proxy, FAKE_SERVER_READONLY_PROPERTY, &dummy);
ck_assert_int_eq(EFL_MODEL_LOAD_STATUS_ERROR, status);
_teardown();
}
END_TEST
static void
_test_fake_server_proxy_children_count(Eo *efl_model)
{
// 'Sum' and 'Ping' methods and 'Pong' signal
check_efl_model_children_count_eq(efl_model, 3);
}
START_TEST(children_count)
{
_test_fake_server_proxy_children_count(fake_server_proxy);
_teardown();
}
END_TEST
START_TEST(children_slice_get)
{
Eldbus_Model_Arguments *method1 = efl_model_nth_child_get(fake_server_proxy, 1);
Eldbus_Model_Arguments *method2 = efl_model_nth_child_get(fake_server_proxy, 2);
Eldbus_Model_Arguments *signal1 = efl_model_nth_child_get(fake_server_proxy, 3);
const char *actual_method1_name = eldbus_model_arguments_name_get(method1);
const char *actual_method2_name = eldbus_model_arguments_name_get(method2);
const char *actual_signal1_name = eldbus_model_arguments_name_get(signal1);
ck_assert_ptr_ne(NULL, actual_method1_name);
ck_assert_ptr_ne(NULL, actual_method2_name);
ck_assert_ptr_ne(NULL, actual_signal1_name);
// Eldbus doesn't have order for method names. Methods order are determined by Eina_Hash
if (strcmp(FAKE_SERVER_SUM_METHOD_NAME, actual_method1_name) == 0)
ck_assert(strcmp(FAKE_SERVER_PING_METHOD_NAME, actual_method2_name) == 0);
else
ck_assert(strcmp(FAKE_SERVER_SUM_METHOD_NAME, actual_method2_name) == 0);
ck_assert(strcmp(FAKE_SERVER_PONG_SIGNAL_NAME, actual_signal1_name) == 0);
_teardown();
}
END_TEST
static void
_check_unload(void)
{
check_efl_model_load_status_get(fake_server_proxy, EFL_MODEL_LOAD_STATUS_LOADED);
efl_model_unload(fake_server_proxy);
check_efl_model_load_status_get(fake_server_proxy, EFL_MODEL_LOAD_STATUS_UNLOADED);
check_efl_model_children_count_eq(fake_server_proxy, 0);
}
START_TEST(unload)
{
_check_unload();
_teardown();
}
END_TEST
START_TEST(properties_load)
{
_check_unload();
efl_model_properties_load(fake_server_proxy);
efl_model_wait_for_load_status(fake_server_proxy, EFL_MODEL_LOAD_STATUS_LOADED_PROPERTIES);
check_efl_model_load_status_get(fake_server_proxy, EFL_MODEL_LOAD_STATUS_LOADED_PROPERTIES);
_teardown();
}
END_TEST
START_TEST(children_load)
{
_check_unload();
efl_model_children_load(fake_server_proxy);
efl_model_wait_for_load_status(fake_server_proxy, EFL_MODEL_LOAD_STATUS_LOADED_CHILDREN);
check_efl_model_load_status_get(fake_server_proxy, EFL_MODEL_LOAD_STATUS_LOADED_CHILDREN);
_test_fake_server_proxy_children_count(fake_server_proxy);
_teardown();
}
END_TEST
START_TEST(child_add)
{
Eo *child = efl_model_child_add(fake_server_proxy);
ck_assert_ptr_eq(NULL, child);
_teardown();
}
END_TEST
START_TEST(child_del)
{
// Tests that it is not possible to delete children
unsigned int expected_children_count = 0;
Efl_Model_Load_Status status;
status = efl_model_children_count_get(fake_server_proxy, &expected_children_count);
ck_assert_int_eq(EFL_MODEL_LOAD_STATUS_LOADED, status);
// efl_model_child_del always returns ERROR
Eo *child = efl_model_first_child_get(fake_server_proxy);
status = efl_model_child_del(fake_server_proxy, child);
ck_assert_int_eq(EFL_MODEL_LOAD_STATUS_ERROR, status);
unsigned int actual_children_count = 0;
status = efl_model_children_count_get(fake_server_proxy, &actual_children_count);
ck_assert_int_eq(EFL_MODEL_LOAD_STATUS_LOADED, status);
ck_assert_int_le(expected_children_count, actual_children_count);
_teardown();
}
END_TEST
void eldbus_test_fake_server_eldbus_model_proxy(TCase *tc)
{
tcase_add_checked_fixture(tc, _setup, NULL);
tcase_add_test(tc, load_status_get);
tcase_add_test(tc, properties_get);
tcase_add_test(tc, property_get);
tcase_add_test(tc, property_set);
tcase_add_test(tc, children_count);
tcase_add_test(tc, children_slice_get);
tcase_add_test(tc, unload);
tcase_add_test(tc, properties_load);
tcase_add_test(tc, children_load);
tcase_add_test(tc, child_add);
tcase_add_test(tc, child_del);
}