forked from enlightenment/efl
374 lines
11 KiB
C
374 lines
11 KiB
C
#ifdef HAVE_CONFIG_H
|
|
# include <config.h>
|
|
#endif
|
|
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
#include <string.h>
|
|
#include <sys/stat.h>
|
|
#include <fcntl.h>
|
|
|
|
#include <Eio.h>
|
|
#include <Ecore.h>
|
|
#include <Ecore_File.h>
|
|
|
|
#include "eio_suite.h"
|
|
|
|
static unsigned int default_rights = 0755;
|
|
static int test_count = 0;
|
|
static const char *good_dirs[] =
|
|
{
|
|
"eio_file_ls_simple_dir",
|
|
"b."
|
|
};
|
|
static const char *files[] =
|
|
{
|
|
".hidden_file",
|
|
"~$b@:-*$a!{}",
|
|
"$b$a",
|
|
"normal_file"
|
|
};
|
|
|
|
static Eina_Bool
|
|
_filter_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED, const char *file)
|
|
{
|
|
char *last_slash = strrchr(file, '/');
|
|
|
|
//Check if it is a hidden file
|
|
if (last_slash != NULL && strlen(last_slash) > 1 && last_slash[1] == '.')
|
|
return EINA_FALSE;
|
|
|
|
return EINA_TRUE;
|
|
}
|
|
|
|
static Eina_Bool
|
|
_delete_filter_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED,
|
|
const Eina_File_Direct_Info *info EINA_UNUSED)
|
|
{
|
|
return EINA_TRUE;
|
|
}
|
|
|
|
static void
|
|
_main_cb(void *data, Eio_File *handler EINA_UNUSED, const char *file)
|
|
{
|
|
int *number_of_listed_files = (int *)data;
|
|
|
|
fprintf(stderr, "Processing file:%s\n", file);
|
|
(*number_of_listed_files)++;
|
|
}
|
|
|
|
static Eina_Bool
|
|
_direct_filter_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED,
|
|
const Eina_File_Direct_Info *info)
|
|
{
|
|
char *last_slash = strrchr(info->path, '/');
|
|
|
|
//Check if it is a hidden file
|
|
if (last_slash != NULL && strlen(last_slash) > 1 && last_slash[1] == '.')
|
|
return EINA_FALSE;
|
|
|
|
return EINA_TRUE;
|
|
}
|
|
|
|
static void
|
|
_direct_main_cb(void *data, Eio_File *handler EINA_UNUSED, const Eina_File_Direct_Info *info)
|
|
{
|
|
int *number_of_listed_files = (int *)data;
|
|
|
|
fprintf(stderr, "Processing file:%s\n", info->path);
|
|
(*number_of_listed_files)++;
|
|
}
|
|
|
|
static void
|
|
_progress_cb(void *data, Eio_File *handler EINA_UNUSED, const Eio_Progress *info EINA_UNUSED)
|
|
{
|
|
int *number_of_listed_files = (int *)data;
|
|
|
|
(*number_of_listed_files)++;
|
|
}
|
|
|
|
static void
|
|
_stat_done_cb(void *data, Eio_File *handler EINA_UNUSED, const Eina_Stat *stat)
|
|
{
|
|
unsigned int rights;
|
|
Eina_Bool *is_dir = (Eina_Bool *)data;
|
|
fail_if(eio_file_is_dir(stat) != *is_dir);
|
|
fail_if(eio_file_is_lnk(stat));
|
|
rights = stat->mode & (S_IRWXU | S_IRWXG | S_IRWXO);
|
|
fail_if(rights != default_rights);
|
|
ecore_main_loop_quit();
|
|
}
|
|
|
|
static void
|
|
_done_cb(void *data, Eio_File *handler EINA_UNUSED)
|
|
{
|
|
int *number_of_listed_files = (int *)data;
|
|
fail_if((*number_of_listed_files) != test_count);
|
|
ecore_main_loop_quit();
|
|
}
|
|
|
|
static void
|
|
_error_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED, int error)
|
|
{
|
|
fprintf(stderr, "Something has gone wrong:%s\n", strerror(error));
|
|
ecore_main_loop_quit();
|
|
}
|
|
|
|
Eina_Tmpstr*
|
|
get_full_path(const char* tmpdirname, const char* filename)
|
|
{
|
|
char full_path[PATH_MAX] = "";
|
|
eina_str_join(full_path, sizeof(full_path), '/', tmpdirname, filename);
|
|
return eina_tmpstr_add(full_path);
|
|
}
|
|
|
|
Eina_Tmpstr*
|
|
get_eio_test_file_tmp_dir()
|
|
{
|
|
Eina_Tmpstr *tmp_dir;
|
|
|
|
Eina_Bool created = eina_file_mkdtemp("EioFileTestXXXXXX", &tmp_dir);
|
|
|
|
if (!created)
|
|
{
|
|
return NULL;
|
|
}
|
|
|
|
return tmp_dir;
|
|
}
|
|
|
|
Eina_Tmpstr*
|
|
create_test_dirs(Eina_Tmpstr *test_dirname)
|
|
{
|
|
int i, fd;
|
|
int count = sizeof(good_dirs) / sizeof(const char *);
|
|
fail_if(test_dirname == NULL);
|
|
|
|
for (i = 0; i != count; ++i)
|
|
{
|
|
Eina_Tmpstr *dirname = get_full_path(test_dirname, good_dirs[i]);
|
|
fail_if(mkdir(dirname, default_rights) != 0);
|
|
eina_tmpstr_del(dirname);
|
|
}
|
|
count = sizeof(files) / sizeof(const char *);
|
|
for (i = 0; i != count; ++i)
|
|
{
|
|
Eina_Tmpstr *filename = get_full_path(test_dirname, files[i]);
|
|
fd = open(filename, O_RDWR|O_CREAT, default_rights);
|
|
fail_if(fd < 0);
|
|
fail_if(close(fd) != 0);
|
|
eina_tmpstr_del(filename);
|
|
}
|
|
Eina_Tmpstr *nested_dirname = get_full_path(test_dirname, good_dirs[0]);
|
|
for (i = 0; i != count; ++i)
|
|
{
|
|
Eina_Tmpstr *filename = get_full_path(nested_dirname, files[i]);
|
|
fd = open(filename, O_RDWR|O_CREAT, default_rights);
|
|
fail_if(fd < 0);
|
|
fail_if(close(fd) != 0);
|
|
eina_tmpstr_del(filename);
|
|
}
|
|
return nested_dirname;
|
|
}
|
|
|
|
START_TEST(eio_file_test_ls)
|
|
{
|
|
int number_of_listed_files = 0, ret;
|
|
const char *new_dir = "new_dir";
|
|
|
|
ret = ecore_init();
|
|
fail_if(ret < 1);
|
|
ret = eio_init();
|
|
fail_if(ret < 1);
|
|
ret = eina_init();
|
|
fail_if(ret < 1);
|
|
|
|
Eina_Tmpstr *test_dirname = get_eio_test_file_tmp_dir();
|
|
Eina_Tmpstr *nested_dirname = create_test_dirs(test_dirname);
|
|
Eina_Tmpstr *nested_filename = get_full_path(test_dirname, files[3]);
|
|
Eina_Tmpstr *new_dirname = get_full_path(test_dirname, new_dir);
|
|
|
|
eio_file_ls(test_dirname, _filter_cb, _main_cb, _done_cb, _error_cb,
|
|
&number_of_listed_files);
|
|
test_count = 5;
|
|
fail_if(number_of_listed_files != 0); //check asynchronous
|
|
ecore_main_loop_begin();
|
|
|
|
number_of_listed_files = 0;
|
|
#ifdef _WIN32
|
|
eio_file_direct_ls(test_dirname, _direct_filter_cb, _direct_main_cb, _done_cb,
|
|
_error_cb, &number_of_listed_files);
|
|
#else
|
|
eio_file_stat_ls(test_dirname, _direct_filter_cb, _direct_main_cb, _done_cb,
|
|
_error_cb, &number_of_listed_files);
|
|
#endif
|
|
test_count = 5;
|
|
fail_if(number_of_listed_files != 0); //check asynchronous
|
|
ecore_main_loop_begin();
|
|
|
|
number_of_listed_files = 0;
|
|
#ifdef _WIN32
|
|
eio_dir_direct_ls(test_dirname, _direct_filter_cb, _direct_main_cb, _done_cb,
|
|
_error_cb, &number_of_listed_files);
|
|
#else
|
|
eio_dir_stat_ls(test_dirname, _direct_filter_cb, _direct_main_cb, _done_cb,
|
|
_error_cb, &number_of_listed_files);
|
|
#endif
|
|
test_count = 8;
|
|
fail_if(number_of_listed_files != 0); //check asynchronous
|
|
ecore_main_loop_begin();
|
|
|
|
test_count = 1;
|
|
eio_file_unlink(nested_filename, _done_cb, _error_cb, &test_count);
|
|
ecore_main_loop_begin();
|
|
|
|
test_count = 1;
|
|
eio_file_mkdir(new_dirname, default_rights, _done_cb, _error_cb, &test_count);
|
|
ecore_main_loop_begin();
|
|
|
|
number_of_listed_files = 0;
|
|
eio_dir_unlink(nested_dirname, _delete_filter_cb, _progress_cb, _done_cb,
|
|
_error_cb, &number_of_listed_files);
|
|
test_count = 5; // 4 internal files + 1 nested_dir
|
|
fail_if(number_of_listed_files != 0); // check asynchronous
|
|
ecore_main_loop_begin();
|
|
|
|
number_of_listed_files = 0;
|
|
eio_dir_unlink(test_dirname, _delete_filter_cb, _progress_cb, _done_cb,
|
|
_error_cb, &number_of_listed_files);
|
|
test_count = 6; // 3 internal files + 2 dir + 1 test_dir
|
|
fail_if(number_of_listed_files != 0); // check asynchronous
|
|
ecore_main_loop_begin();
|
|
|
|
eina_tmpstr_del(nested_dirname);
|
|
eina_tmpstr_del(test_dirname);
|
|
eina_tmpstr_del(nested_filename);
|
|
eina_tmpstr_del(new_dirname);
|
|
eina_shutdown();
|
|
eio_shutdown();
|
|
ecore_shutdown();
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(eio_file_test_file)
|
|
{
|
|
int number_of_listed_files = 0, ret;
|
|
Eina_Bool is_dir;
|
|
const char * new_file = "new_file";
|
|
|
|
ret = ecore_init();
|
|
fail_if(ret < 1);
|
|
ret = eio_init();
|
|
fail_if(ret < 1);
|
|
ret = eina_init();
|
|
fail_if(ret < 1);
|
|
ret = ecore_file_init();
|
|
fail_if(ret < 1);
|
|
|
|
|
|
Eina_Tmpstr *test_dirname = get_eio_test_file_tmp_dir();
|
|
Eina_Tmpstr *nested_dirname = create_test_dirs(test_dirname);
|
|
Eina_Tmpstr *nested_filename = get_full_path(test_dirname, files[3]);
|
|
Eina_Tmpstr *new_filename = get_full_path(nested_dirname, new_file);
|
|
Eina_Tmpstr *new_dirname = get_full_path(test_dirname, new_file);
|
|
|
|
is_dir = EINA_TRUE;
|
|
eio_file_direct_stat(nested_dirname, _stat_done_cb, _error_cb, &is_dir);
|
|
ecore_main_loop_begin();
|
|
|
|
test_count = 1;
|
|
default_rights = 0766;
|
|
eio_file_chmod(nested_filename, default_rights, _done_cb, _error_cb, &test_count);
|
|
ecore_main_loop_begin();
|
|
|
|
is_dir = EINA_FALSE;
|
|
eio_file_direct_stat(nested_filename, _stat_done_cb, _error_cb, &is_dir);
|
|
ecore_main_loop_begin();
|
|
|
|
test_count = 1;
|
|
eio_file_move(nested_filename, new_filename, _progress_cb, _done_cb,
|
|
_error_cb, &test_count);
|
|
ecore_main_loop_begin();
|
|
|
|
fail_if(ecore_file_exists(nested_filename));
|
|
eio_file_ls(nested_dirname, _filter_cb, _main_cb, _done_cb, _error_cb,
|
|
&number_of_listed_files);
|
|
test_count = 4;
|
|
fail_if(number_of_listed_files != 0); //check asynchronous
|
|
ecore_main_loop_begin();
|
|
|
|
number_of_listed_files = 0;
|
|
eio_file_ls(test_dirname, _filter_cb, _main_cb, _done_cb, _error_cb,
|
|
&number_of_listed_files);
|
|
test_count = 4; //2 dirs + 2 normal files
|
|
fail_if(number_of_listed_files != 0); //check asynchronous
|
|
ecore_main_loop_begin();
|
|
|
|
test_count = 1;
|
|
eio_file_copy(new_filename, nested_filename, _progress_cb, _done_cb,
|
|
_error_cb, &test_count);
|
|
ecore_main_loop_begin();
|
|
|
|
number_of_listed_files = 0;
|
|
eio_file_ls(nested_dirname, _filter_cb, _main_cb, _done_cb, _error_cb,
|
|
&number_of_listed_files);
|
|
test_count = 4; // 3 normal files + 1 new file
|
|
fail_if(number_of_listed_files != 0); //check asynchronous
|
|
ecore_main_loop_begin();
|
|
|
|
number_of_listed_files = 0;
|
|
eio_file_ls(test_dirname, _filter_cb, _main_cb, _done_cb, _error_cb,
|
|
&number_of_listed_files);
|
|
test_count = 5;
|
|
fail_if(number_of_listed_files != 0); //check asynchronous
|
|
ecore_main_loop_begin();
|
|
|
|
number_of_listed_files = 0;
|
|
eio_dir_move(nested_dirname, new_dirname, _direct_filter_cb, _progress_cb,
|
|
_done_cb, _error_cb, &number_of_listed_files);
|
|
test_count = 1;
|
|
fail_if(number_of_listed_files != 0); //check asynchronous
|
|
ecore_main_loop_begin();
|
|
fail_if(ecore_file_is_dir(nested_dirname));
|
|
fail_if(!ecore_file_is_dir(new_dirname));
|
|
|
|
number_of_listed_files = 0;
|
|
eio_dir_copy(new_dirname, nested_dirname, _direct_filter_cb, _progress_cb,
|
|
_done_cb, _error_cb, &number_of_listed_files);
|
|
test_count = 6;
|
|
fail_if(number_of_listed_files != 0); //check asynchronous
|
|
ecore_main_loop_begin();
|
|
fail_if(!ecore_file_is_dir(nested_dirname));
|
|
fail_if(!ecore_file_is_dir(new_dirname));
|
|
|
|
number_of_listed_files = 0;
|
|
eio_dir_unlink(nested_dirname, _delete_filter_cb, _progress_cb, _done_cb,
|
|
_error_cb, &number_of_listed_files);
|
|
test_count = 5; // 4 internal files + 1 nested_dir
|
|
fail_if(number_of_listed_files != 0); // check asynchronous
|
|
ecore_main_loop_begin();
|
|
fail_if(ecore_file_is_dir(nested_dirname));
|
|
|
|
fail_if(!ecore_file_recursive_rm(test_dirname));
|
|
fail_if(ecore_file_is_dir(new_dirname));
|
|
|
|
eina_tmpstr_del(nested_dirname);
|
|
eina_tmpstr_del(test_dirname);
|
|
eina_tmpstr_del(nested_filename);
|
|
eina_tmpstr_del(new_filename);
|
|
eina_tmpstr_del(new_dirname);
|
|
ecore_file_shutdown();
|
|
eina_shutdown();
|
|
eio_shutdown();
|
|
ecore_shutdown();
|
|
}
|
|
END_TEST
|
|
|
|
void
|
|
eio_test_file(TCase *tc)
|
|
{
|
|
tcase_add_test(tc, eio_file_test_ls);
|
|
tcase_add_test(tc, eio_file_test_file);
|
|
}
|
|
|