2016-02-04 05:29:22 -08:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include "config.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include <Eina.h>
|
|
|
|
#include <Eet.h>
|
|
|
|
|
|
|
|
#include "eet_suite.h"
|
|
|
|
#include "eet_test_common.h"
|
|
|
|
|
|
|
|
static Eina_Bool open_worker_stop;
|
|
|
|
static Eina_Condition open_worker_cond;
|
|
|
|
static Eina_Lock open_worker_mutex;
|
|
|
|
|
|
|
|
static void *
|
|
|
|
_open_close_worker(void *path, Eina_Thread tid EINA_UNUSED)
|
|
|
|
{
|
|
|
|
static Eina_Bool first = EINA_TRUE;
|
|
|
|
|
|
|
|
while (!open_worker_stop)
|
|
|
|
{
|
|
|
|
Eet_File *ef = eet_open((char const *)path, EET_FILE_MODE_READ);
|
|
|
|
if (ef == NULL)
|
|
|
|
return "eet_open() failed";
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Eet_Error err_code = eet_close(ef);
|
|
|
|
if (err_code != EET_ERROR_NONE)
|
|
|
|
return "eet_close() failed";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (first)
|
|
|
|
{
|
|
|
|
eina_lock_take(&open_worker_mutex);
|
|
|
|
eina_condition_broadcast(&open_worker_cond);
|
|
|
|
eina_lock_release(&open_worker_mutex);
|
|
|
|
first = EINA_FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2018-03-26 11:19:28 -07:00
|
|
|
EFL_START_TEST(eet_test_cache_concurrency)
|
2016-02-04 05:29:22 -08:00
|
|
|
{
|
|
|
|
char *file;
|
|
|
|
const char *buffer = "test data";
|
|
|
|
Eet_File *ef;
|
|
|
|
void *thread_ret;
|
|
|
|
unsigned int n;
|
|
|
|
Eina_Thread thread;
|
|
|
|
Eina_Bool r;
|
|
|
|
int tmpfd;
|
|
|
|
|
|
|
|
file = strdup("/tmp/eet_suite_testXXXXXX");
|
|
|
|
|
|
|
|
eina_threads_init();
|
|
|
|
|
|
|
|
eina_lock_new(&open_worker_mutex);
|
|
|
|
eina_condition_new(&open_worker_cond, &open_worker_mutex);
|
|
|
|
|
|
|
|
/* create a file to test with */
|
|
|
|
fail_if(-1 == (tmpfd = mkstemp(file)));
|
|
|
|
fail_if(!!close(tmpfd));
|
|
|
|
ef = eet_open(file, EET_FILE_MODE_WRITE);
|
|
|
|
fail_if(!ef);
|
|
|
|
fail_if(!eet_write(ef, "keys/tests", buffer, strlen(buffer) + 1, 0));
|
|
|
|
|
|
|
|
eina_lock_take(&open_worker_mutex);
|
|
|
|
/* start a thread that repeatedly opens and closes a file */
|
|
|
|
open_worker_stop = 0;
|
|
|
|
r = eina_thread_create(&thread, EINA_THREAD_NORMAL, -1, _open_close_worker, file);
|
|
|
|
fail_unless(r);
|
|
|
|
|
|
|
|
eina_condition_wait(&open_worker_cond);
|
|
|
|
eina_lock_release(&open_worker_mutex);
|
|
|
|
|
|
|
|
/* clear the cache repeatedly in this thread */
|
|
|
|
for (n = 0; n < 20000; ++n)
|
|
|
|
{
|
|
|
|
eet_clearcache();
|
|
|
|
}
|
|
|
|
|
|
|
|
/* join the other thread, and fail if it returned an error message */
|
|
|
|
open_worker_stop = 1;
|
|
|
|
thread_ret = eina_thread_join(thread);
|
|
|
|
fail_unless(thread_ret == NULL, (char const *)thread_ret);
|
|
|
|
|
|
|
|
eet_close(ef);
|
|
|
|
|
|
|
|
fail_if(unlink(file) != 0);
|
|
|
|
|
|
|
|
eina_threads_shutdown();
|
|
|
|
}
|
2018-03-26 11:19:28 -07:00
|
|
|
EFL_END_TEST
|
2016-02-04 05:29:22 -08:00
|
|
|
|
|
|
|
void eet_test_cache(TCase *tc)
|
|
|
|
{
|
|
|
|
tcase_add_test(tc, eet_test_cache_concurrency);
|
|
|
|
}
|