summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorvivek <vivek.ellur@samsung.com>2015-04-22 14:52:55 +0200
committerCedric BAIL <cedric@osg.samsung.com>2015-04-22 15:10:20 +0200
commitd86ed2a46c5f6a7a76fceff7d33ed934f87bb714 (patch)
tree605f702d6fdac6db4ab87a1c77cac71cf0a491a4
parentf4453bc00b9c27eb4d32b683dde9af000674dd9b (diff)
downloadefl-d86ed2a46c5f6a7a76fceff7d33ed934f87bb714.tar.gz
eio: add testcases for various eio_xattr types set and get functions.
Summary: Added test cases for eio_file_xattr_string_set, eio_file_xattr_string_get, eio_file_xattr_int_set, eio_file_xattr_int_get, eio_file_xattr_double_get, eio_file_xattr_double set functions Signed-off-by: vivek <vivek.ellur@samsung.com> Reviewers: cedric Reviewed By: cedric Differential Revision: https://phab.enlightenment.org/D2380 Signed-off-by: Cedric BAIL <cedric@osg.samsung.com>
-rw-r--r--src/tests/eio/eio_test_xattr.c103
1 files changed, 103 insertions, 0 deletions
diff --git a/src/tests/eio/eio_test_xattr.c b/src/tests/eio/eio_test_xattr.c
index a9a3582f06..f28d04f680 100644
--- a/src/tests/eio/eio_test_xattr.c
+++ b/src/tests/eio/eio_test_xattr.c
@@ -13,6 +13,13 @@
#include "eio_suite.h"
+static char *str_attr = "user.name";
+static char *str_data = "Vivek Ellur";
+static char *int_attr = "user.id";
+static int int_data = 1234;
+static char *double_attr = "user.size";
+static double double_data = 123.456;
+
const char *attribute[] =
{
"user.comment1",
@@ -85,6 +92,30 @@ _done_get_cb(void *data, Eio_File *handler EINA_UNUSED, const char *name, unsign
}
static void
+_done_string_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED, const char *xattr_string)
+{
+ fail_if(strcmp(xattr_string, str_data) != 0);
+
+ ecore_main_loop_quit();
+}
+
+static void
+_done_int_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED, int xattr_int)
+{
+ fail_if(xattr_int != int_data);
+
+ ecore_main_loop_quit();
+}
+
+static void
+_done_double_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED, double xattr_double)
+{
+ fail_if(xattr_double != double_data);
+
+ ecore_main_loop_quit();
+}
+
+static void
_error_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED, int error)
{
@@ -152,12 +183,84 @@ START_TEST(eio_test_xattr_set)
ecore_shutdown();
}
END_TEST
+
+START_TEST(eio_test_xattr_types_set)
+{
+ char *filename = "eio-tmpfile";
+
+ Eina_Tmpstr *test_file_path;
+ int fd, num_of_attr=0;
+ Eio_File *fp;
+
+ ecore_init();
+ eina_init();
+ eio_init();
+
+ test_file_path = get_file_path(XATTR_TEST_DIR, filename);
+ fd = open(test_file_path,
+ O_WRONLY | O_CREAT | O_TRUNC,
+ S_IRWXU | S_IRWXG | S_IRWXO);
+ fail_if(fd == 0);
+ fp = eio_file_xattr_string_set(test_file_path, str_attr,
+ str_data, EINA_XATTR_INSERT,
+ _done_once_cb, _error_cb, &num_of_attr);
+
+ fail_if(num_of_attr != 0); // test asynchronous
+ fail_if(!fp);
+
+ ecore_main_loop_begin();
+
+ fp = eio_file_xattr_string_get(test_file_path, str_attr,
+ _done_string_cb, _error_cb, NULL);
+ fail_if(!fp);
+
+ ecore_main_loop_begin();
+
+ fp = eio_file_xattr_int_set(test_file_path, int_attr,
+ int_data, EINA_XATTR_INSERT,
+ _done_once_cb, _error_cb, &num_of_attr);
+
+ fail_if(num_of_attr != 0); // test asynchronous
+ fail_if(!fp);
+
+ ecore_main_loop_begin();
+
+ fp = eio_file_xattr_int_get(test_file_path, int_attr,
+ _done_int_cb, _error_cb, NULL);
+ fail_if(!fp);
+
+ ecore_main_loop_begin();
+
+ fp = eio_file_xattr_double_set(test_file_path, double_attr,
+ double_data, EINA_XATTR_INSERT,
+ _done_once_cb, _error_cb, &num_of_attr);
+
+ fail_if(num_of_attr != 0); // test asynchronous
+ fail_if(!fp);
+
+ ecore_main_loop_begin();
+
+ fp = eio_file_xattr_double_get(test_file_path, double_attr,
+ _done_double_cb, _error_cb, NULL);
+ fail_if(!fp);
+
+ ecore_main_loop_begin();
+
+ close(fd);
+ unlink(test_file_path);
+ eina_tmpstr_del(test_file_path);
+ eio_shutdown();
+ eina_shutdown();
+ ecore_shutdown();
+}
+END_TEST
#endif
void eio_test_xattr(TCase *tc)
{
#ifdef XATTR_TEST_DIR
tcase_add_test(tc, eio_test_xattr_set);
+ tcase_add_test(tc, eio_test_xattr_types_set);
#else
(void)tc;
#endif