summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMykola Solyanko <m.solyanko@samsung.com>2017-12-19 14:41:32 +0900
committerJean-Philippe Andre <jp.andre@samsung.com>2017-12-19 14:42:56 +0900
commitea63f487d33c2371b502dd5e3f31d045acde627e (patch)
treedd16ee84b87a9c5cd1bf85a6db076150ca02feda
parent346e9a190426071a1b15c80554b5e249dfd8d8a2 (diff)
downloadefl-ea63f487d33c2371b502dd5e3f31d045acde627e.tar.gz
Eldbus: add test suite for eldbus (eldbus_pending_data*)
Summary: add tests for next API: eldbus_pending_data_set() eldbus_pending_data_get() eldbus_pending_data_del() Reviewers: cedric, NikaWhite, myoungwoon, raster, artem.popov Subscribers: jpeg Differential Revision: https://phab.enlightenment.org/D5650
-rw-r--r--src/tests/eldbus/eldbus_test_eldbus_pending_data.c161
1 files changed, 161 insertions, 0 deletions
diff --git a/src/tests/eldbus/eldbus_test_eldbus_pending_data.c b/src/tests/eldbus/eldbus_test_eldbus_pending_data.c
new file mode 100644
index 0000000000..0428535ac4
--- /dev/null
+++ b/src/tests/eldbus/eldbus_test_eldbus_pending_data.c
@@ -0,0 +1,161 @@
+#include <check.h>
+#include <Eldbus.h>
+#include <Ecore.h>
+#include <string.h>
+#include <stdio.h>
+#include <Eina.h>
+
+#include "eldbus_suite.h"
+
+static Eina_Bool is_response_cb = EINA_FALSE;
+
+static Ecore_Timer *timeout = NULL;
+
+static int pending_data_stored = 5;
+const char *pending_key_store = "pending_data";
+
+static Eldbus_Connection *conn = NULL;
+static Eldbus_Object *obj = NULL;
+static Eldbus_Message *message = NULL;
+
+/**
+* @addtogroup eldbus
+* @{
+* @defgroup eldbus_pending_data
+* @li eldbus_pending_data_set()
+* @li eldbus_pending_data_get()
+* @li eldbus_pending_data_del()
+*
+* @precondition
+* @step 1 Initialize ecore with ecore_init()
+* @step 2 Initialize eldbus with eldbus_init()
+*/
+
+static void
+_setup(void)
+{
+ ecore_init();
+ int ret = eldbus_init();
+ ck_assert_int_ge(ret, 1);
+}
+
+static void
+_teardown(void)
+{
+ eldbus_shutdown();
+ ecore_shutdown();
+}
+
+static Eina_Bool
+_ecore_loop_close(void *data EINA_UNUSED)
+{
+ ecore_main_loop_quit();
+
+ return ECORE_CALLBACK_CANCEL;
+}
+
+static void
+_response_message_cb(void *data EINA_UNUSED, const Eldbus_Message *msg EINA_UNUSED, Eldbus_Pending *pending)
+{
+ ck_assert_ptr_ne(NULL, pending);
+
+ int *pending_data_get = eldbus_pending_data_get(pending, pending_key_store);
+
+ ck_assert_ptr_ne(NULL, pending_data_get);
+ ck_assert_int_eq((*pending_data_get), pending_data_stored);
+
+ int *pending_data_del = eldbus_pending_data_del(pending, pending_key_store);
+
+ ck_assert_ptr_ne(NULL, pending_data_del);
+ ck_assert_int_eq((*pending_data_del), pending_data_stored);
+
+ is_response_cb = EINA_TRUE;
+
+ if (timeout != NULL)
+ {
+ ecore_timer_del(timeout);
+ timeout = NULL;
+ }
+
+ ecore_main_loop_quit();
+}
+
+/**
+ * @addtogroup eldbus_pending_data
+ * @{
+ * @objective Positive test case checks if function correctly set, get and delete the data stored
+ * in pending connection object and without segmentation fault.
+ *
+ * @n Input Data:
+ * @li the conn object connection with bus
+ * @li the obj object of the given bus and path
+ * @li the message of the pointer to message strunct a dbus method
+ * @li the pending connection object to store data
+ * @li data that will be stored
+ * @li key that identifies data
+ *
+ * @procedure
+ * @step 1 Call eldbus_connection_get function to get connection object
+ * @step 2 Check returned connection object on NULL.
+ * @step 3 Call eldbus_object_get function to get an object
+ * of the given bus and path.
+ * @step 4 Check returned object on NULL.
+ * @step 5 Call eldbus_object_method_call_new function to call
+ * a dbus method on the object.
+ * @step 6 Check returned message on NULL.
+ * @step 7 Call eldbus_connection_send function to send a message a dbus object with timeout.
+ * @step 8 Check returned pending on NULL.
+ * @step 9 Call eldbus_pending_data_set function to set data in pending connection object.
+ * @step 10 Set timer for preschedule termination of main loop if tested callback wasn't executed.
+ * @step 11 Start of main loop and wait for tested response in callback executing.
+ * @step 12 Check variable if callback executing.
+ * @step 13 Call eldbus_message_unref function to delete message object
+ * @step 14 Call eldbus_object_unref function to delete connection dbus object
+ * @step 15 Call eldbus_connection_unref function to delete connection object
+ *
+ * @passcondition Function should set data without segmentation fault,
+ get and delete valid stored data.
+ * @}
+ */
+
+START_TEST(utc_eldbus_pending_data_p)
+{
+ const char *bus = "org.freedesktop.DBus";
+ const char *path = "/org/freedesktop/DBus";
+ const char *interface = "org.freedesktop.DBus";
+ const char *member = "GetId";
+ const int send_timeout_ms = 500;
+
+ conn = eldbus_connection_get(ELDBUS_CONNECTION_TYPE_SYSTEM);
+ ck_assert_ptr_ne(NULL, conn);
+
+ obj = eldbus_object_get(conn, bus, path);
+ ck_assert_ptr_ne(NULL, obj);
+
+ message = eldbus_object_method_call_new(obj, interface, member);
+ ck_assert_ptr_ne(NULL, message);
+
+ Eldbus_Pending *pending = eldbus_connection_send(conn, message, _response_message_cb, NULL, send_timeout_ms);
+ ck_assert_ptr_ne(NULL, pending);
+
+ eldbus_pending_data_set(pending, pending_key_store, &pending_data_stored);
+
+ timeout = ecore_timer_add(1.5, _ecore_loop_close, NULL);
+ ck_assert_ptr_ne(NULL, timeout);
+
+ ecore_main_loop_begin();
+
+ ck_assert(is_response_cb == EINA_TRUE);
+
+ eldbus_message_unref(message);
+ eldbus_object_unref(obj);
+ eldbus_connection_unref(conn);
+}
+END_TEST
+
+void
+eldbus_test_eldbus_pending_data(TCase *tc)
+{
+ tcase_add_checked_fixture(tc, _setup, _teardown);
+ tcase_add_test(tc, utc_eldbus_pending_data_p);
+}