nextcloud-desktop/tests/csync_tests/check_csync_journal.c
2008-05-08 17:28:12 +02:00

260 lines
7.9 KiB
C

#define _GNU_SOURCE /* asprintf */
#include <string.h>
#include "support.h"
#define CSYNC_TEST 1
#include "csync_journal.c"
CSYNC *csync;
const char *testdb = (char *) "/tmp/check_csync1/test.db";
const char *testtmpdb = (char *) "/tmp/check_csync1/test.db.ctmp";
static void setup(void) {
fail_if(system("rm -rf /tmp/check_csync1") < 0, "Setup failed");
fail_if(system("mkdir -p /tmp/check_csync1") < 0, "Setup failed");
fail_if(csync_create(&csync, "/tmp/check_csync1", "/tmp/check_csync2") < 0, "Setup failed");
SAFE_FREE(csync->options.config_dir);
csync->options.config_dir = c_strdup("/tmp/check_csync1/");
}
static void setup_init(void) {
fail_if(system("rm -rf /tmp/check_csync1") < 0, "Setup failed");
fail_if (system("mkdir -p /tmp/check_csync1") < 0, "Setup failed");
fail_if (csync_create(&csync, "/tmp/check_csync1", "/tmp/check_csync2") < 0, "Setup failed");
SAFE_FREE(csync->options.config_dir);
csync->options.config_dir = c_strdup("/tmp/check_csync1/");
csync_init(csync);
}
static void teardown(void) {
fail_if(csync_destroy(csync) < 0, "Teardown failed");
fail_if(system("rm -rf /tmp/check_csync1") < 0, "Teardown failed");
}
START_TEST (check_csync_journal_check)
{
fail_if(system("mkdir -p /tmp/check_csync1") < 0, NULL);
/* old db */
fail_if(system("echo \"SQLite format 2\" > /tmp/check_csync1/test.db") < 0, NULL);
fail_unless(csync_journal_check(testdb) == 0);
/* db already exists */
fail_unless(csync_journal_check(testdb) == 0);
/* no db exists */
fail_if(system("rm -f /tmp/check_csync1/test.db") < 0, NULL);
fail_unless(csync_journal_check(testdb) == 0);
fail_unless(csync_journal_check((char *) "/tmp/check_csync1/") < 0);
fail_if(system("rm -rf /tmp/check_csync1") < 0, NULL);
}
END_TEST
START_TEST (check_csync_journal_load)
{
struct stat sb;
fail_unless(csync_journal_load(csync, testdb) == 0, NULL);
fail_unless(lstat(testtmpdb, &sb) == 0, NULL);
sqlite3_close(csync->journal.db);
}
END_TEST
START_TEST (check_csync_journal_close)
{
struct stat sb;
/* journal not written */
csync_journal_load(csync, testdb);
fail_unless(csync_journal_close(csync, testdb, 0) == 0, NULL);
fail_unless(lstat(testtmpdb, &sb) == 0, NULL);
csync_journal_load(csync, testdb);
/* journal written */
fail_unless(csync_journal_close(csync, testdb, 1) == 0, NULL);
fail_unless(lstat(testtmpdb, &sb) < 0, NULL);
}
END_TEST
START_TEST (check_csync_journal_query_statement)
{
c_strlist_t *result = NULL;
result = csync_journal_query(csync, "");
fail_unless(result == NULL, NULL);
c_strlist_destroy(result);
result = csync_journal_query(csync, "SELECT;");
fail_unless(result == NULL, NULL);
c_strlist_destroy(result);
}
END_TEST
START_TEST (check_csync_journal_create_error)
{
c_strlist_t *result = NULL;
result = csync_journal_query(csync, "CREATE TABLE test(phash INTEGER, text VARCHAR(10));");
fail_if(result == NULL, NULL);
c_strlist_destroy(result);
result = csync_journal_query(csync, "CREATE TABLE test(phash INTEGER, text VARCHAR(10));");
fail_unless(result == NULL, NULL);
c_strlist_destroy(result);
}
END_TEST
START_TEST (check_csync_journal_insert_statement)
{
c_strlist_t *result = NULL;
result = csync_journal_query(csync, "CREATE TABLE test(phash INTEGER, text VARCHAR(10));");
fail_if(result == NULL, NULL);
c_strlist_destroy(result);
fail_unless(csync_journal_insert(csync, "INSERT;") == 0, NULL);
fail_unless(csync_journal_insert(csync, "INSERT") == 0, NULL);
fail_unless(csync_journal_insert(csync, "") == 0, NULL);
}
END_TEST
START_TEST (check_csync_journal_query_create_and_insert_table)
{
c_strlist_t *result = NULL;
result = csync_journal_query(csync, "CREATE TABLE test(phash INTEGER, text VARCHAR(10));");
c_strlist_destroy(result);
fail_unless(csync_journal_insert(csync, "INSERT INTO test (phash, text) VALUES (42, 'hello');"), NULL);
result = csync_journal_query(csync, "SELECT * FROM test;");
fail_unless(result->count == 2, NULL);
fail_unless(strcmp(result->vector[0], "42") == 0, NULL);
fail_unless(strcmp(result->vector[1], "hello") == 0, NULL);
c_strlist_destroy(result);
}
END_TEST
START_TEST (check_csync_journal_is_empty)
{
c_strlist_t *result = NULL;
/* we have an empty db */
fail_unless(csync_journal_is_empty(csync) == 1, NULL);
/* add a table and an entry */
result = csync_journal_query(csync, "CREATE TABLE metadata(phash INTEGER, text VARCHAR(10));");
c_strlist_destroy(result);
fail_unless(csync_journal_insert(csync, "INSERT INTO metadata (phash, text) VALUES (42, 'hello');"), NULL);
fail_unless(csync_journal_is_empty(csync) == 0, NULL);
}
END_TEST
START_TEST (check_csync_journal_create_tables)
{
char *stmt = NULL;
fail_unless(csync_journal_create_tables(csync) == 0, NULL);
stmt = sqlite3_mprintf("INSERT INTO metadata_temp"
"(phash, pathlen, path, inode, uid, gid, mode, modtime) VALUES"
"(%lu, %d, '%q', %d, %d, %d, %d, %lu);",
42,
42,
"It's a rainy day",
42,
42,
42,
42,
42);
fail_if(csync_journal_insert(csync, stmt) < 0, NULL);
sqlite3_free(stmt);
}
END_TEST
START_TEST (check_csync_journal_drop_tables)
{
fail_unless(csync_journal_drop_tables(csync) == 0, NULL);
fail_unless(csync_journal_create_tables(csync) == 0, NULL);
fail_unless(csync_journal_drop_tables(csync) == 0, NULL);
}
END_TEST
START_TEST (check_csync_journal_insert_metadata)
{
int i = 0;
csync_file_stat_t *st;
fail_unless(csync_journal_create_tables(csync) == 0, NULL);
for(i = 0; i < 100; i++) {
st = c_malloc(sizeof(csync_file_stat_t));
st->phash = i;
fail_unless(c_rbtree_insert(csync->local.tree, (void *) st) == 0, NULL);
}
fail_unless(csync_journal_insert_metadata(csync) == 0, NULL);
}
END_TEST
START_TEST (check_csync_journal_write)
{
int i = 0;
csync_file_stat_t *st;
for(i = 0; i < 100; i++) {
st = c_malloc(sizeof(csync_file_stat_t));
st->phash = i;
fail_unless(c_rbtree_insert(csync->local.tree, (void *) st) == 0, NULL);
}
fail_unless(csync_journal_write(csync) == 0, NULL);
}
END_TEST
static Suite *make_csync_suite(void) {
Suite *s = suite_create("csync_journal");
create_case(s, "check_csync_journal_check", check_csync_journal_check);
create_case_fixture(s, "check_csync_journal_load", check_csync_journal_load, setup, teardown);
create_case_fixture(s, "check_csync_journal_close", check_csync_journal_close, setup, teardown);
create_case_fixture(s, "check_csync_journal_query_statement", check_csync_journal_query_statement, setup_init, teardown);
create_case_fixture(s, "check_csync_journal_create_error", check_csync_journal_create_error, setup_init, teardown);
create_case_fixture(s, "check_csync_journal_insert_statement", check_csync_journal_insert_statement, setup_init, teardown);
create_case_fixture(s, "check_csync_journal_query_create_and_insert_table", check_csync_journal_query_create_and_insert_table, setup_init, teardown);
create_case_fixture(s, "check_csync_journal_is_empty", check_csync_journal_is_empty, setup_init, teardown);
create_case_fixture(s, "check_csync_journal_create_tables", check_csync_journal_create_tables, setup_init, teardown);
create_case_fixture(s, "check_csync_journal_drop_tables", check_csync_journal_drop_tables, setup_init, teardown);
create_case_fixture(s, "check_csync_journal_insert_metadata", check_csync_journal_insert_metadata, setup_init, teardown);
create_case_fixture(s, "check_csync_journal_write", check_csync_journal_write, setup_init, teardown);
return s;
}
int main(int argc, char **argv) {
Suite *s = NULL;
SRunner *sr = NULL;
struct argument_s arguments;
int nf;
ZERO_STRUCT(arguments);
cmdline_parse(argc, argv, &arguments);
s = make_csync_suite();
sr = srunner_create(s);
if (arguments.nofork) {
srunner_set_fork_status(sr, CK_NOFORK);
}
srunner_run_all(sr, CK_VERBOSE);
nf = srunner_ntests_failed(sr);
srunner_free(sr);
return (nf == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
}