recovery-empty.c 1.28 KB
Newer Older
1 2
/* -*- mode: C; c-basic-offset: 4; indent-tabs-mode: nil -*- */
// vim: expandtab:ts=8:sw=4:softtabstop=4:
3
#ident "$Id$"
4 5 6 7 8
// test recovery from a log that exist but has no log entries

#include "test.h"
#include "includes.h"

9
#define TESTDIR __SRCFILE__ ".dir"
10 11 12 13 14 15

static int 
run_test(void) {
    int r;

    // setup the test dir
16 17
    r = system("rm -rf " TESTDIR);
    CKERR(r);
18 19 20 21 22 23 24 25
    r = toku_os_mkdir(TESTDIR, S_IRWXU); assert(r == 0);

    // create the log
    TOKULOGGER logger;
    r = toku_logger_create(&logger); assert(r == 0);
    r = toku_logger_open(TESTDIR, logger); assert(r == 0);
    r = toku_logger_close(&logger); assert(r == 0);

26 27 28 29 30 31 32 33
    if (!verbose) {
        // redirect stderr
        int devnul = open(DEV_NULL_FILE, O_WRONLY);
        assert(devnul >= 0);
        r = toku_dup2(devnul, fileno(stderr)); assert(r == fileno(stderr));
        r = close(devnul); assert(r == 0);
    }

34
    // run recovery
35 36 37 38
    r = tokudb_recover(NULL,
		       NULL_prepared_txn_callback,
		       NULL_keep_cachetable_callback,
		       NULL_logger, TESTDIR, TESTDIR, 0, 0, 0, NULL, 0); 
39 40
    assert(r == DB_RUNRECOVERY);

41 42 43
    r = system("rm -rf " TESTDIR);
    CKERR(r);

44 45 46 47
    return 0;
}

int
48 49
test_main(int argc, const char *argv[]) {
    default_parse_args(argc, argv);
50 51 52 53
    int r;
    r = run_test();
    return r;
}