forked from enlightenment/efl
328 lines
9.8 KiB
C
328 lines
9.8 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 <Ecore.h>
|
|
#include <Ecore_File.h>
|
|
#include <Eio.h>
|
|
|
|
#include "eio_suite.h"
|
|
#include "eio_test_common.h"
|
|
|
|
#ifndef O_BINARY
|
|
# define O_BINARY 0
|
|
#endif
|
|
|
|
static int test_count = 0;
|
|
|
|
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();
|
|
}
|
|
|
|
static void
|
|
_open_done_cb(void *data, Eio_File *handler EINA_UNUSED, Eina_File *file)
|
|
{
|
|
Eina_Bool *opened = (Eina_Bool *)data;
|
|
*opened = EINA_TRUE;
|
|
eina_file_close(file);
|
|
ecore_main_loop_quit();
|
|
}
|
|
|
|
EFL_START_TEST(eio_file_test_ls)
|
|
{
|
|
int number_of_listed_files = 0;
|
|
const char *new_dir = "new_dir";
|
|
|
|
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);
|
|
}
|
|
EFL_END_TEST
|
|
|
|
EFL_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_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();
|
|
default_rights = DEFAULT_RIGHTS;
|
|
|
|
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();
|
|
}
|
|
EFL_END_TEST
|
|
|
|
EFL_START_TEST(eio_file_test_open)
|
|
{
|
|
Eina_Bool opened_file;
|
|
int ret;
|
|
|
|
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]);
|
|
|
|
opened_file = EINA_FALSE;
|
|
eio_file_open(nested_filename, EINA_FALSE, _open_done_cb, _error_cb, &opened_file);
|
|
ecore_main_loop_begin();
|
|
fail_if(!opened_file);
|
|
|
|
// Cleanup
|
|
fail_if(!ecore_file_recursive_rm(test_dirname));
|
|
|
|
eina_tmpstr_del(nested_dirname);
|
|
eina_tmpstr_del(test_dirname);
|
|
eina_tmpstr_del(nested_filename);
|
|
ecore_file_shutdown();
|
|
}
|
|
EFL_END_TEST
|
|
|
|
void
|
|
eio_test_file(TCase *tc)
|
|
{
|
|
tcase_add_test(tc, eio_file_test_ls);
|
|
tcase_add_test(tc, eio_file_test_file);
|
|
tcase_add_test(tc, eio_file_test_open);
|
|
}
|