Commit 00a53325 authored by Rich Prohaska's avatar Rich Prohaska Committed by Yoni Fogel

merge 1964 to main [t:1964]

git-svn-id: file:///svn/toku/tokudb@14284 c7de825b-a66e-492c-adef-691d508d4ae1
parent 16f4e878
...@@ -29,7 +29,7 @@ static void backward_scan_state_init(struct backward_scan_state *bs) { ...@@ -29,7 +29,7 @@ static void backward_scan_state_init(struct backward_scan_state *bs) {
// Map filenum to brt // Map filenum to brt
// TODO why can't we use the cachetable to find by filenum? // TODO why can't we use the cachetable to find by filenum?
struct filenum_map { struct file_map {
struct cf_pair { struct cf_pair {
FILENUM filenum; FILENUM filenum;
CACHEFILE cf; CACHEFILE cf;
...@@ -38,40 +38,44 @@ struct filenum_map { ...@@ -38,40 +38,44 @@ struct filenum_map {
int n_cf_pairs, max_cf_pairs; int n_cf_pairs, max_cf_pairs;
}; };
static void filenum_map_init(struct filenum_map *fmap) { static void file_map_init(struct file_map *fmap) {
fmap->cf_pairs = NULL; fmap->cf_pairs = NULL;
fmap->n_cf_pairs = fmap->max_cf_pairs = 0; fmap->n_cf_pairs = fmap->max_cf_pairs = 0;
} }
static void filenum_map_close_dictionaries(struct filenum_map *fmap) { static void file_map_close_dictionaries(struct file_map *fmap) {
int r; int r;
int i; for (int i=0; i<fmap->n_cf_pairs; i++) {
for (i=0; i<fmap->n_cf_pairs; i++) {
if (fmap->cf_pairs[i].brt) { if (fmap->cf_pairs[i].brt) {
r = toku_close_brt(fmap->cf_pairs[i].brt, 0, 0); r = toku_close_brt(fmap->cf_pairs[i].brt, 0, 0);
//r = toku_cachefile_close(&cf_pairs[i].cf); //r = toku_cachefile_close(&cf_pairs[i].cf);
assert(r == 0); assert(r == 0);
} }
} }
fmap->n_cf_pairs = 0; fmap->n_cf_pairs = fmap->max_cf_pairs = 0;
if (fmap->cf_pairs) { if (fmap->cf_pairs) {
toku_free(fmap->cf_pairs); toku_free(fmap->cf_pairs);
fmap->cf_pairs = NULL; fmap->cf_pairs = NULL;
} }
} }
static int filenum_map_add (struct filenum_map *fmap, FILENUM fnum, CACHEFILE cf, BRT brt) { static int file_map_add (struct file_map *fmap, FILENUM fnum, CACHEFILE cf, BRT brt) {
if (fmap->max_cf_pairs==0) { if (fmap->cf_pairs == NULL) {
fmap->n_cf_pairs=1; fmap->max_cf_pairs = 1;
fmap->max_cf_pairs=2;
MALLOC_N(fmap->max_cf_pairs, fmap->cf_pairs); MALLOC_N(fmap->max_cf_pairs, fmap->cf_pairs);
if (fmap->cf_pairs==0) return errno; if (fmap->cf_pairs == NULL) {
fmap->max_cf_pairs = 0;
return errno;
}
fmap->n_cf_pairs=1;
} else { } else {
if (fmap->n_cf_pairs >= fmap->max_cf_pairs) { if (fmap->n_cf_pairs >= fmap->max_cf_pairs) {
fmap->cf_pairs = toku_realloc(fmap->cf_pairs, 2*fmap->max_cf_pairs*sizeof(struct cf_pair)); struct cf_pair *new_cf_pairs = toku_realloc(fmap->cf_pairs, 2*fmap->max_cf_pairs*sizeof(struct cf_pair));
assert(fmap->cf_pairs); if (new_cf_pairs == NULL)
fmap->max_cf_pairs*=2; return errno;
fmap->cf_pairs = new_cf_pairs;
fmap->max_cf_pairs *= 2;
} }
fmap->n_cf_pairs++; fmap->n_cf_pairs++;
} }
...@@ -81,9 +85,8 @@ static int filenum_map_add (struct filenum_map *fmap, FILENUM fnum, CACHEFILE cf ...@@ -81,9 +85,8 @@ static int filenum_map_add (struct filenum_map *fmap, FILENUM fnum, CACHEFILE cf
return 0; return 0;
} }
static int find_cachefile (struct filenum_map *fmap, FILENUM fnum, struct cf_pair **cf_pair) { static int find_cachefile (struct file_map *fmap, FILENUM fnum, struct cf_pair **cf_pair) {
int i; for (int i=0; i<fmap->n_cf_pairs; i++) {
for (i=0; i<fmap->n_cf_pairs; i++) {
if (fnum.fileid==fmap->cf_pairs[i].filenum.fileid) { if (fnum.fileid==fmap->cf_pairs[i].filenum.fileid) {
*cf_pair = fmap->cf_pairs+i; *cf_pair = fmap->cf_pairs+i;
return 0; return 0;
...@@ -98,7 +101,7 @@ struct recover_env { ...@@ -98,7 +101,7 @@ struct recover_env {
brt_compare_func bt_compare; brt_compare_func bt_compare;
brt_compare_func dup_compare; brt_compare_func dup_compare;
struct backward_scan_state bs; struct backward_scan_state bs;
struct filenum_map fmap; struct file_map fmap;
}; };
typedef struct recover_env *RECOVER_ENV; typedef struct recover_env *RECOVER_ENV;
...@@ -113,7 +116,7 @@ int recover_env_init (RECOVER_ENV env, brt_compare_func bt_compare, brt_compare_ ...@@ -113,7 +116,7 @@ int recover_env_init (RECOVER_ENV env, brt_compare_func bt_compare, brt_compare_
toku_logger_set_cachetable(env->logger, env->ct); toku_logger_set_cachetable(env->logger, env->ct);
env->bt_compare = bt_compare; env->bt_compare = bt_compare;
env->dup_compare = dup_compare; env->dup_compare = dup_compare;
filenum_map_init(&env->fmap); file_map_init(&env->fmap);
if (toku_recover_trace) if (toku_recover_trace)
printf("%s:%d\n", __FUNCTION__, __LINE__); printf("%s:%d\n", __FUNCTION__, __LINE__);
...@@ -123,7 +126,7 @@ int recover_env_init (RECOVER_ENV env, brt_compare_func bt_compare, brt_compare_ ...@@ -123,7 +126,7 @@ int recover_env_init (RECOVER_ENV env, brt_compare_func bt_compare, brt_compare_
void recover_env_cleanup (RECOVER_ENV env) { void recover_env_cleanup (RECOVER_ENV env) {
int r; int r;
filenum_map_close_dictionaries(&env->fmap); file_map_close_dictionaries(&env->fmap);
r = toku_logger_close(&env->logger); r = toku_logger_close(&env->logger);
assert(r == 0); assert(r == 0);
...@@ -183,10 +186,9 @@ static int toku_recover_backward_xabort (struct logtype_xabort *UU(l), RECOVER_E ...@@ -183,10 +186,9 @@ static int toku_recover_backward_xabort (struct logtype_xabort *UU(l), RECOVER_E
} }
static void create_dir_from_file (const char *fname) { static void create_dir_from_file (const char *fname) {
int i;
char *tmp=toku_strdup(fname); char *tmp=toku_strdup(fname);
char ch; char ch;
for (i=0; (ch=fname[i]); i++) { for (int i=0; (ch=fname[i]); i++) {
// //
// TODO: this may fail in windows, double check the absolute path names // TODO: this may fail in windows, double check the absolute path names
// and '/' as the directory delimiter or something // and '/' as the directory delimiter or something
...@@ -210,27 +212,25 @@ static void create_dir_from_file (const char *fname) { ...@@ -210,27 +212,25 @@ static void create_dir_from_file (const char *fname) {
// Open the file if it is not already open. If it is already open, then do nothing. // Open the file if it is not already open. If it is already open, then do nothing.
static void internal_toku_recover_fopen_or_fcreate (RECOVER_ENV env, int flags, int mode, char *fixedfname, FILENUM filenum, u_int32_t treeflags) { static void internal_toku_recover_fopen_or_fcreate (RECOVER_ENV env, int flags, int mode, char *fixedfname, FILENUM filenum, u_int32_t treeflags) {
{ int r;
struct cf_pair *pair = NULL;
int r = find_cachefile(&env->fmap, filenum, &pair); // already open
if (0==r) { struct cf_pair *pair = NULL;
toku_free(fixedfname); r = find_cachefile(&env->fmap, filenum, &pair);
return; if (r == 0) {
} toku_free(fixedfname);
return;
} }
CACHEFILE cf; if (flags & O_TRUNC) {
int fd = open(fixedfname, O_RDWR|O_BINARY|flags, mode); // maybe unlink
if (fd<0) { r = unlink(fixedfname);
char org_wd[1000]; if (r != 0)
char *wd=getcwd(org_wd, sizeof(org_wd)); printf("%s:%d unlink %d\n", __FUNCTION__, __LINE__, errno);
fprintf(stderr, "%s:%d Could not open file %s, cwd=%s, errno=%d (%s)\n",
__FILE__, __LINE__, fixedfname, wd, errno, strerror(errno));
} }
assert(fd>=0);
BRT brt=0; BRT brt=0;
int r = toku_brt_create(&brt); r = toku_brt_create(&brt);
assert(r == 0); assert(r == 0);
// create tree with treeflags, otherwise use the treeflags from the tree // create tree with treeflags, otherwise use the treeflags from the tree
...@@ -243,17 +243,15 @@ static void internal_toku_recover_fopen_or_fcreate (RECOVER_ENV env, int flags, ...@@ -243,17 +243,15 @@ static void internal_toku_recover_fopen_or_fcreate (RECOVER_ENV env, int flags,
if (env->dup_compare) if (env->dup_compare)
toku_brt_set_dup_compare(brt, env->dup_compare); toku_brt_set_dup_compare(brt, env->dup_compare);
brt->fname = fixedfname; // TODO mode
brt->h=0; mode = mode;
brt->db = 0;
r = toku_cachetable_openfd(&cf, env->ct, fd, fixedfname); r = toku_brt_open(brt, fixedfname, fixedfname, (flags & O_CREAT) != 0, FALSE, env->ct, NULL, NULL);
assert(r == 0); assert(r == 0);
brt->cf=cf;
r = toku_read_brt_header_and_store_in_cachefile(brt->cf, &brt->h); toku_free(fixedfname);
if (r==TOKUDB_DICTIONARY_NO_HEADER) {
r = toku_brt_alloc_init_header(brt); file_map_add(&env->fmap, filenum, NULL, brt);
}
filenum_map_add(&env->fmap, filenum, cf, brt);
} }
static void toku_recover_fopen (LSN UU(lsn), TXNID UU(xid), BYTESTRING fname, FILENUM filenum, RECOVER_ENV env) { static void toku_recover_fopen (LSN UU(lsn), TXNID UU(xid), BYTESTRING fname, FILENUM filenum, RECOVER_ENV env) {
...@@ -261,7 +259,17 @@ static void toku_recover_fopen (LSN UU(lsn), TXNID UU(xid), BYTESTRING fname, FI ...@@ -261,7 +259,17 @@ static void toku_recover_fopen (LSN UU(lsn), TXNID UU(xid), BYTESTRING fname, FI
internal_toku_recover_fopen_or_fcreate(env, 0, 0, fixedfname, filenum, 0); internal_toku_recover_fopen_or_fcreate(env, 0, 0, fixedfname, filenum, 0);
} }
static int toku_recover_backward_fopen (struct logtype_fopen *UU(l), RECOVER_ENV UU(env)) { static int toku_recover_backward_fopen (struct logtype_fopen *l, RECOVER_ENV env) {
if (env->bs.bs == BS_SAW_CKPT_END) {
// close the tree
struct cf_pair *pair = NULL;
int r = find_cachefile(&env->fmap, l->filenum, &pair);
if (r == 0) {
r = toku_close_brt(pair->brt, 0, 0);
assert(r == 0);
pair->brt=0;
}
}
return 0; return 0;
} }
...@@ -348,13 +356,19 @@ static int toku_recover_backward_enq_delete_any (struct logtype_enq_delete_any * ...@@ -348,13 +356,19 @@ static int toku_recover_backward_enq_delete_any (struct logtype_enq_delete_any *
static void toku_recover_fclose (LSN UU(lsn), BYTESTRING UU(fname), FILENUM filenum, RECOVER_ENV UU(env)) { static void toku_recover_fclose (LSN UU(lsn), BYTESTRING UU(fname), FILENUM filenum, RECOVER_ENV UU(env)) {
struct cf_pair *pair = NULL; struct cf_pair *pair = NULL;
int r = find_cachefile(&env->fmap, filenum, &pair); int r = find_cachefile(&env->fmap, filenum, &pair);
assert(r == 0); if (r == 0) {
r = toku_close_brt(pair->brt, 0, 0); r = toku_close_brt(pair->brt, 0, 0);
assert(r == 0); assert(r == 0);
pair->brt=0; pair->brt=0;
}
} }
static int toku_recover_backward_fclose (struct logtype_fclose *UU(l), RECOVER_ENV UU(env)) { static int toku_recover_backward_fclose (struct logtype_fclose *l, RECOVER_ENV env) {
if (env->bs.bs == BS_SAW_CKPT) {
// tree open
char *fixedfname = fixup_fname(&l->fname);
internal_toku_recover_fopen_or_fcreate(env, 0, 0, fixedfname, l->filenum, 0);
}
return 0; return 0;
} }
...@@ -374,8 +388,8 @@ static int toku_recover_backward_begin_checkpoint (struct logtype_begin_checkpoi ...@@ -374,8 +388,8 @@ static int toku_recover_backward_begin_checkpoint (struct logtype_begin_checkpoi
if (bs->n_live_txns==0) { if (bs->n_live_txns==0) {
fprintf(stderr, "Turning around at begin_checkpoint %" PRIu64 "\n", l->lsn.lsn); fprintf(stderr, "Turning around at begin_checkpoint %" PRIu64 "\n", l->lsn.lsn);
return 1; return 1;
} } else
else return 0; return 0;
case BS_SAW_CKPT: case BS_SAW_CKPT:
return 0; // ignore it return 0; // ignore it
} }
...@@ -427,11 +441,11 @@ static int toku_recover_backward_xstillopen (struct logtype_xstillopen *l, RECOV ...@@ -427,11 +441,11 @@ static int toku_recover_backward_xstillopen (struct logtype_xstillopen *l, RECOV
case BS_INIT: case BS_INIT:
return 0; // ignore live txns from incomplete checkpoint return 0; // ignore live txns from incomplete checkpoint
case BS_SAW_CKPT_END: case BS_SAW_CKPT_END:
if (bs->n_live_txns==0) { if (bs->n_live_txns == 0)
bs->min_live_txn = l->txnid; bs->min_live_txn = l->txnid;
} else { // TODO need a new txnid comparison
if (bs->min_live_txn > l->txnid) bs->min_live_txn = l->txnid; else if (bs->min_live_txn > l->txnid)
} bs->min_live_txn = l->txnid;
bs->n_live_txns++; bs->n_live_txns++;
return 0; return 0;
case BS_SAW_CKPT: case BS_SAW_CKPT:
...@@ -470,7 +484,7 @@ static int toku_recover_backward_xbegin (struct logtype_xbegin *l, RECOVER_ENV e ...@@ -470,7 +484,7 @@ static int toku_recover_backward_xbegin (struct logtype_xbegin *l, RECOVER_ENV e
fprintf(stderr, "Turning around at xbegin %" PRIu64 "\n", l->lsn.lsn); fprintf(stderr, "Turning around at xbegin %" PRIu64 "\n", l->lsn.lsn);
return 1; return 1;
} else { } else {
fprintf(stderr, "scanning back at xbegin %" PRIu64 " (looking for %" PRIu64 ")\n", l->lsn.lsn, bs->min_live_txn); fprintf(stderr, "Scanning back at xbegin %" PRIu64 " (looking for %" PRIu64 ")\n", l->lsn.lsn, bs->min_live_txn);
return 0; return 0;
} }
} }
...@@ -580,6 +594,7 @@ int tokudb_needs_recovery(const char *log_dir) { ...@@ -580,6 +594,7 @@ int tokudb_needs_recovery(const char *log_dir) {
static int compare_txn(const void *a, const void *b) { static int compare_txn(const void *a, const void *b) {
TOKUTXN atxn = (TOKUTXN) * (void **) a; TOKUTXN atxn = (TOKUTXN) * (void **) a;
TOKUTXN btxn = (TOKUTXN) * (void **) b; TOKUTXN btxn = (TOKUTXN) * (void **) b;
// TODO this is wrong. we want if (older(atxn, btxn)) return -1
if (atxn->txnid64 > btxn->txnid64) if (atxn->txnid64 > btxn->txnid64)
return -1; return -1;
if (atxn->txnid64 < btxn->txnid64) if (atxn->txnid64 < btxn->txnid64)
...@@ -676,7 +691,7 @@ static int do_recovery(RECOVER_ENV env, const char *data_dir, const char *log_di ...@@ -676,7 +691,7 @@ static int do_recovery(RECOVER_ENV env, const char *data_dir, const char *log_di
varray_destroy(&live_txns); varray_destroy(&live_txns);
// close the open dictionaries // close the open dictionaries
filenum_map_close_dictionaries(&env->fmap); file_map_close_dictionaries(&env->fmap);
// write a recovery log entry // write a recovery log entry
BYTESTRING recover_comment = { strlen("recover"), "recover" }; BYTESTRING recover_comment = { strlen("recover"), "recover" };
......
// fcreate, fdelete, fcreate after a checkpoint
#include <sys/stat.h>
#include <sys/wait.h>
#include "test.h"
const int envflags = DB_INIT_MPOOL|DB_CREATE|DB_THREAD |DB_INIT_LOCK|DB_INIT_LOG|DB_INIT_TXN;
char *namea="a.db";
char *nameb="b.db";
static void run_test (void) {
int r;
system("rm -rf " ENVDIR);
toku_os_mkdir(ENVDIR, S_IRWXU+S_IRWXG+S_IRWXO);
DB_ENV *env;
DB *db;
r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
// checkpoint
r = env->txn_checkpoint(env, 0, 0, 0); CKERR(r);
// create
r = db_create(&db, env, 0); CKERR(r);
r = db->open(db, NULL, namea, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r);
r = db->close(db, 0); CKERR(r);
// delete
r = db_create(&db, env, 0); CKERR(r);
r = db->remove(db, namea, NULL, 0); CKERR(r);
// create
r = db_create(&db, env, 0); CKERR(r);
r = db->set_flags(db, DB_DUPSORT); CKERR(r);
r = db->open(db, NULL, namea, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r);
r = db->close(db, 0); CKERR(r);
abort();
}
static void run_recover (void) {
DB_ENV *env;
int r;
r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags + DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
u_int32_t dbflags;
DB *db;
r = db_create(&db, env, 0); CKERR(r);
r = db->open(db, NULL, namea, NULL, DB_UNKNOWN, DB_AUTO_COMMIT, 0666); CKERR(r);
r = db->get_flags(db, &dbflags); CKERR(r);
assert(dbflags == DB_DUPSORT);
r = db->close(db, 0); CKERR(r);
r = env->close(env, 0); CKERR(r);
exit(0);
}
static void run_recover_only (void) {
DB_ENV *env;
int r;
r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags + DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
r = env->close(env, 0); CKERR(r);
exit(0);
}
static void run_no_recover (void) {
DB_ENV *env;
int r;
r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags & ~DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
r = env->close(env, 0); CKERR(r);
exit(0);
}
const char *cmd;
BOOL do_test=FALSE, do_recover=FALSE, do_recover_only=FALSE, do_no_recover = FALSE;
static void test_parse_args (int argc, char *argv[]) {
int resultcode;
cmd = argv[0];
argc--; argv++;
while (argc>0) {
if (strcmp(argv[0], "-v") == 0) {
verbose++;
} else if (strcmp(argv[0],"-q")==0) {
verbose--;
if (verbose<0) verbose=0;
} else if (strcmp(argv[0], "--test")==0) {
do_test=TRUE;
} else if (strcmp(argv[0], "--recover") == 0) {
do_recover=TRUE;
} else if (strcmp(argv[0], "--recover-only") == 0) {
do_recover_only=TRUE;
} else if (strcmp(argv[0], "--no-recover") == 0) {
do_no_recover=TRUE;
} else if (strcmp(argv[0], "-h")==0) {
resultcode=0;
do_usage:
fprintf(stderr, "Usage:\n%s [-v|-q]* [-h] {--test | --recover } \n", cmd);
exit(resultcode);
} else {
fprintf(stderr, "Unknown arg: %s\n", argv[0]);
resultcode=1;
goto do_usage;
}
argc--;
argv++;
}
}
int test_main (int argc, char *argv[]) {
test_parse_args(argc, argv);
if (do_test) {
run_test();
} else if (do_recover) {
run_recover();
} else if (do_recover_only) {
run_recover_only();
} else if (do_no_recover) {
run_no_recover();
}
return 0;
}
// this test verifies that db creation after a checkpoint works for nodup and dupsort dictionaries
#include <sys/stat.h> #include <sys/stat.h>
#include <sys/wait.h>
#include "test.h" #include "test.h"
const int envflags = DB_INIT_MPOOL|DB_CREATE|DB_THREAD |DB_INIT_LOCK|DB_INIT_LOG|DB_INIT_TXN |DB_RECOVER; const int envflags = DB_INIT_MPOOL|DB_CREATE|DB_THREAD |DB_INIT_LOCK|DB_INIT_LOG|DB_INIT_TXN |DB_RECOVER;
char *namea="a.db"; char *namea="a.db";
char *nameb="b.db"; char *nameb="b.db";
static void run_test (BOOL do_commit, BOOL do_abort) { static void run_test (BOOL do_commit, BOOL do_abort) {
int r; int r;
system("rm -rf " ENVDIR); system("rm -rf " ENVDIR);
...@@ -29,8 +29,8 @@ static void run_test (BOOL do_commit, BOOL do_abort) { ...@@ -29,8 +29,8 @@ static void run_test (BOOL do_commit, BOOL do_abort) {
{ {
DBT a={.data="a", .size=2}; DBT a={.data="a", .size=2};
DBT b={.data="b", .size=2}; DBT b={.data="b", .size=2};
r = dba->put(dba, txn, &a, &b, 0); CKERR(r); r = dba->put(dba, txn, &a, &b, DB_YESOVERWRITE); CKERR(r);
r = dbb->put(dbb, txn, &b, &a, 0); CKERR(r); r = dbb->put(dbb, txn, &b, &a, DB_YESOVERWRITE); CKERR(r);
} }
//printf("opened\n"); //printf("opened\n");
if (do_commit) { if (do_commit) {
...@@ -46,8 +46,6 @@ static void run_test (BOOL do_commit, BOOL do_abort) { ...@@ -46,8 +46,6 @@ static void run_test (BOOL do_commit, BOOL do_abort) {
abort(); abort();
} }
#if 0
static void run_recover (BOOL did_commit) { static void run_recover (BOOL did_commit) {
DB_ENV *env; DB_ENV *env;
DB *dba, *dbb; DB *dba, *dbb;
...@@ -56,8 +54,19 @@ static void run_recover (BOOL did_commit) { ...@@ -56,8 +54,19 @@ static void run_recover (BOOL did_commit) {
r = env->open(env, ENVDIR, envflags, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r); r = env->open(env, ENVDIR, envflags, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
r = db_create(&dba, env, 0); CKERR(r); r = db_create(&dba, env, 0); CKERR(r);
r = dba->open(dba, NULL, namea, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r); r = dba->open(dba, NULL, namea, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r);
u_int32_t dbflags;
dbflags = 0;
r = dba->get_flags(dba, &dbflags); CKERR(r);
assert(dbflags == 0);
r = db_create(&dbb, env, 0); CKERR(r); r = db_create(&dbb, env, 0); CKERR(r);
r = dba->open(dbb, NULL, nameb, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r); r = dbb->open(dbb, NULL, nameb, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r);
dbflags = 0;
r = dbb->get_flags(dbb, &dbflags); CKERR(r);
assert(dbflags == 0);
DBT aa={.size=0}, ab={.size=0}; DBT aa={.size=0}, ab={.size=0};
DBT ba={.size=0}, bb={.size=0}; DBT ba={.size=0}, bb={.size=0};
DB_TXN *txn; DB_TXN *txn;
...@@ -99,8 +108,6 @@ static void run_recover (BOOL did_commit) { ...@@ -99,8 +108,6 @@ static void run_recover (BOOL did_commit) {
r = env->close(env, 0); CKERR(r); r = env->close(env, 0); CKERR(r);
} }
#endif
static void run_recover_only (void) { static void run_recover_only (void) {
DB_ENV *env; DB_ENV *env;
int r; int r;
...@@ -184,6 +191,10 @@ int test_main (int argc, char *argv[]) { ...@@ -184,6 +191,10 @@ int test_main (int argc, char *argv[]) {
run_test(TRUE, FALSE); run_test(TRUE, FALSE);
} else if (do_abort) { } else if (do_abort) {
run_test(FALSE, TRUE); run_test(FALSE, TRUE);
} else if (do_recover_committed) {
run_recover(TRUE);
} else if (do_recover_aborted) {
run_recover(FALSE);
} else if (do_recover_only) { } else if (do_recover_only) {
run_recover_only(); run_recover_only();
} else if (do_no_recover) { } else if (do_no_recover) {
......
// this test verifies that db creation after a checkpoint works for nodup and dupsort dictionaries
#include <sys/stat.h> #include <sys/stat.h>
#include "test.h" #include "test.h"
...@@ -46,8 +48,6 @@ static void run_test (BOOL do_commit, BOOL do_abort) { ...@@ -46,8 +48,6 @@ static void run_test (BOOL do_commit, BOOL do_abort) {
abort(); abort();
} }
#if 0
static void run_recover (BOOL did_commit) { static void run_recover (BOOL did_commit) {
DB_ENV *env; DB_ENV *env;
DB *dba, *dbb; DB *dba, *dbb;
...@@ -56,8 +56,19 @@ static void run_recover (BOOL did_commit) { ...@@ -56,8 +56,19 @@ static void run_recover (BOOL did_commit) {
r = env->open(env, ENVDIR, envflags, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r); r = env->open(env, ENVDIR, envflags, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
r = db_create(&dba, env, 0); CKERR(r); r = db_create(&dba, env, 0); CKERR(r);
r = dba->open(dba, NULL, namea, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r); r = dba->open(dba, NULL, namea, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r);
u_int32_t dbflags;
dbflags = 0;
r = dba->get_flags(dba, &dbflags); CKERR(r);
assert(dbflags == 0);
r = db_create(&dbb, env, 0); CKERR(r); r = db_create(&dbb, env, 0); CKERR(r);
r = dba->open(dbb, NULL, nameb, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r); r = dba->open(dbb, NULL, nameb, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r);
dbflags = 0;
r = dbb->get_flags(dbb, &dbflags); CKERR(r);
assert(dbflags == DB_DUPSORT);
DBT aa={.size=0}, ab={.size=0}; DBT aa={.size=0}, ab={.size=0};
DBT ba={.size=0}, bb={.size=0}; DBT ba={.size=0}, bb={.size=0};
DB_TXN *txn; DB_TXN *txn;
...@@ -99,8 +110,6 @@ static void run_recover (BOOL did_commit) { ...@@ -99,8 +110,6 @@ static void run_recover (BOOL did_commit) {
r = env->close(env, 0); CKERR(r); r = env->close(env, 0); CKERR(r);
} }
#endif
static void run_recover_only (void) { static void run_recover_only (void) {
DB_ENV *env; DB_ENV *env;
int r; int r;
...@@ -184,6 +193,10 @@ int test_main (int argc, char *argv[]) { ...@@ -184,6 +193,10 @@ int test_main (int argc, char *argv[]) {
run_test(TRUE, FALSE); run_test(TRUE, FALSE);
} else if (do_abort) { } else if (do_abort) {
run_test(FALSE, TRUE); run_test(FALSE, TRUE);
} else if (do_recover_committed) {
run_recover(TRUE);
} else if (do_recover_aborted) {
run_recover(FALSE);
} else if (do_recover_only) { } else if (do_recover_only) {
run_recover_only(); run_recover_only();
} else if (do_no_recover) { } else if (do_no_recover) {
......
// this test makes sure that fassociate can open nodup and dupsort dictionaries
#include <sys/stat.h> #include <sys/stat.h>
#include <sys/wait.h> #include <sys/wait.h>
#include "test.h" #include "test.h"
...@@ -7,8 +9,7 @@ const int envflags = DB_INIT_MPOOL|DB_CREATE|DB_THREAD |DB_INIT_LOCK|DB_INIT_LOG ...@@ -7,8 +9,7 @@ const int envflags = DB_INIT_MPOOL|DB_CREATE|DB_THREAD |DB_INIT_LOCK|DB_INIT_LOG
char *namea="a.db"; char *namea="a.db";
char *nameb="b.db"; char *nameb="b.db";
static void static void run_test (void) {
run_test (void) {
int r; int r;
system("rm -rf " ENVDIR); system("rm -rf " ENVDIR);
toku_os_mkdir(ENVDIR, S_IRWXU+S_IRWXG+S_IRWXO); toku_os_mkdir(ENVDIR, S_IRWXU+S_IRWXG+S_IRWXO);
...@@ -40,19 +41,32 @@ run_test (void) { ...@@ -40,19 +41,32 @@ run_test (void) {
abort(); abort();
} }
static void static void run_recover (void) {
run_recover (void) {
DB_ENV *env; DB_ENV *env;
int r; int r;
r = db_env_create(&env, 0); CKERR(r); r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags + DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r); r = env->open(env, ENVDIR, envflags + DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
u_int32_t dbflags;
DB *dba;
r = db_create(&dba, env, 0); CKERR(r);
r = dba->open(dba, NULL, namea, NULL, DB_UNKNOWN, DB_AUTO_COMMIT, 0666); CKERR(r);
r = dba->get_flags(dba, &dbflags); CKERR(r);
assert(dbflags == DB_DUPSORT);
r = dba->close(dba, 0); CKERR(r);
DB *dbb;
r = db_create(&dbb, env, 0); CKERR(r);
r = dbb->open(dbb, NULL, nameb, NULL, DB_UNKNOWN, DB_AUTO_COMMIT, 0666); CKERR(r);
r = dbb->get_flags(dbb, &dbflags); CKERR(r);
assert(dbflags == DB_DUPSORT);
r = dbb->close(dbb, 0); CKERR(r);
r = env->close(env, 0); CKERR(r); r = env->close(env, 0); CKERR(r);
exit(0); exit(0);
} }
static void static void run_no_recover (void) {
run_no_recover (void) {
DB_ENV *env; DB_ENV *env;
int r; int r;
...@@ -64,7 +78,7 @@ run_no_recover (void) { ...@@ -64,7 +78,7 @@ run_no_recover (void) {
const char *cmd; const char *cmd;
BOOL do_commit=FALSE, do_abort=FALSE, do_explicit_abort=FALSE, do_recover_committed=FALSE, do_recover_aborted=FALSE, do_recover_only=FALSE, do_no_recover = FALSE; BOOL do_test=FALSE, do_recover=FALSE, do_recover_only=FALSE, do_no_recover = FALSE;
static void test_parse_args (int argc, char *argv[]) { static void test_parse_args (int argc, char *argv[]) {
int resultcode; int resultcode;
...@@ -76,16 +90,10 @@ static void test_parse_args (int argc, char *argv[]) { ...@@ -76,16 +90,10 @@ static void test_parse_args (int argc, char *argv[]) {
} else if (strcmp(argv[0],"-q")==0) { } else if (strcmp(argv[0],"-q")==0) {
verbose--; verbose--;
if (verbose<0) verbose=0; if (verbose<0) verbose=0;
} else if (strcmp(argv[0], "--commit")==0) { } else if (strcmp(argv[0], "--test")==0) {
do_commit=TRUE; do_test=TRUE;
} else if (strcmp(argv[0], "--abort")==0) { } else if (strcmp(argv[0], "--recover") == 0) {
do_abort=TRUE; do_recover=TRUE;
} else if (strcmp(argv[0], "--explicit-abort")==0) {
do_explicit_abort=TRUE;
} else if (strcmp(argv[0], "--recover-committed")==0) {
do_recover_committed=TRUE;
} else if (strcmp(argv[0], "--recover-aborted")==0) {
do_recover_aborted=TRUE;
} else if (strcmp(argv[0], "--recover-only") == 0) { } else if (strcmp(argv[0], "--recover-only") == 0) {
do_recover_only=TRUE; do_recover_only=TRUE;
} else if (strcmp(argv[0], "--no-recover") == 0) { } else if (strcmp(argv[0], "--no-recover") == 0) {
...@@ -93,7 +101,7 @@ static void test_parse_args (int argc, char *argv[]) { ...@@ -93,7 +101,7 @@ static void test_parse_args (int argc, char *argv[]) {
} else if (strcmp(argv[0], "-h")==0) { } else if (strcmp(argv[0], "-h")==0) {
resultcode=0; resultcode=0;
do_usage: do_usage:
fprintf(stderr, "Usage:\n%s [-v|-q]* [-h] {--commit | --abort | --explicit-abort | --recover-committed | --recover-aborted } \n", cmd); fprintf(stderr, "Usage:\n%s [-v|-q]* [-h] {--test | --recover } \n", cmd);
exit(resultcode); exit(resultcode);
} else { } else {
fprintf(stderr, "Unknown arg: %s\n", argv[0]); fprintf(stderr, "Unknown arg: %s\n", argv[0]);
...@@ -103,28 +111,14 @@ static void test_parse_args (int argc, char *argv[]) { ...@@ -103,28 +111,14 @@ static void test_parse_args (int argc, char *argv[]) {
argc--; argc--;
argv++; argv++;
} }
{
int n_specified=0;
if (do_commit) n_specified++;
if (do_abort) n_specified++;
if (do_explicit_abort) n_specified++;
if (do_recover_committed) n_specified++;
if (do_recover_aborted) n_specified++;
if (do_recover_only) n_specified++;
if (do_no_recover) n_specified++;
if (n_specified>1) {
printf("Specify only one of --commit or --abort or --recover-committed or --recover-aborted\n");
resultcode=1;
goto do_usage;
}
}
} }
int int test_main (int argc, char *argv[]) {
test_main (int argc, char *argv[]) {
test_parse_args(argc, argv); test_parse_args(argc, argv);
if (do_commit) { if (do_test) {
run_test(); run_test();
} else if (do_recover) {
run_recover();
} else if (do_recover_only) { } else if (do_recover_only) {
run_recover(); run_recover();
} else if (do_no_recover) { } else if (do_no_recover) {
......
// this test makes sure that fassociate can open nodup and dupsort dictionaries
#include <sys/stat.h> #include <sys/stat.h>
#include <sys/wait.h> #include <sys/wait.h>
#include "test.h" #include "test.h"
...@@ -7,8 +9,7 @@ const int envflags = DB_INIT_MPOOL|DB_CREATE|DB_THREAD |DB_INIT_LOCK|DB_INIT_LOG ...@@ -7,8 +9,7 @@ const int envflags = DB_INIT_MPOOL|DB_CREATE|DB_THREAD |DB_INIT_LOCK|DB_INIT_LOG
char *namea="a.db"; char *namea="a.db";
char *nameb="b.db"; char *nameb="b.db";
static void static void run_test (void) {
run_test (void) {
int r; int r;
system("rm -rf " ENVDIR); system("rm -rf " ENVDIR);
toku_os_mkdir(ENVDIR, S_IRWXU+S_IRWXG+S_IRWXO); toku_os_mkdir(ENVDIR, S_IRWXU+S_IRWXG+S_IRWXO);
...@@ -38,19 +39,32 @@ run_test (void) { ...@@ -38,19 +39,32 @@ run_test (void) {
abort(); abort();
} }
static void static void run_recover (void) {
run_recover (void) {
DB_ENV *env; DB_ENV *env;
int r; int r;
r = db_env_create(&env, 0); CKERR(r); r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags + DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r); r = env->open(env, ENVDIR, envflags + DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
u_int32_t dbflags;
DB *dba;
r = db_create(&dba, env, 0); CKERR(r);
r = dba->open(dba, NULL, namea, NULL, DB_UNKNOWN, DB_AUTO_COMMIT, 0666); CKERR(r);
r = dba->get_flags(dba, &dbflags); CKERR(r);
assert(dbflags == 0);
r = dba->close(dba, 0); CKERR(r);
DB *dbb;
r = db_create(&dbb, env, 0); CKERR(r);
r = dbb->open(dbb, NULL, nameb, NULL, DB_UNKNOWN, DB_AUTO_COMMIT, 0666); CKERR(r);
r = dbb->get_flags(dbb, &dbflags); CKERR(r);
assert(dbflags == 0);
r = dbb->close(dbb, 0); CKERR(r);
r = env->close(env, 0); CKERR(r); r = env->close(env, 0); CKERR(r);
exit(0); exit(0);
} }
static void static void run_no_recover (void) {
run_no_recover (void) {
DB_ENV *env; DB_ENV *env;
int r; int r;
...@@ -62,7 +76,7 @@ run_no_recover (void) { ...@@ -62,7 +76,7 @@ run_no_recover (void) {
const char *cmd; const char *cmd;
BOOL do_commit=FALSE, do_abort=FALSE, do_explicit_abort=FALSE, do_recover_committed=FALSE, do_recover_aborted=FALSE, do_recover_only=FALSE, do_no_recover = FALSE; BOOL do_test=FALSE, do_recover=FALSE, do_recover_only=FALSE, do_no_recover = FALSE;
static void test_parse_args (int argc, char *argv[]) { static void test_parse_args (int argc, char *argv[]) {
int resultcode; int resultcode;
...@@ -74,16 +88,10 @@ static void test_parse_args (int argc, char *argv[]) { ...@@ -74,16 +88,10 @@ static void test_parse_args (int argc, char *argv[]) {
} else if (strcmp(argv[0],"-q")==0) { } else if (strcmp(argv[0],"-q")==0) {
verbose--; verbose--;
if (verbose<0) verbose=0; if (verbose<0) verbose=0;
} else if (strcmp(argv[0], "--commit")==0) { } else if (strcmp(argv[0], "--test")==0) {
do_commit=TRUE; do_test=TRUE;
} else if (strcmp(argv[0], "--abort")==0) { } else if (strcmp(argv[0], "--recover") == 0) {
do_abort=TRUE; do_recover=TRUE;
} else if (strcmp(argv[0], "--explicit-abort")==0) {
do_explicit_abort=TRUE;
} else if (strcmp(argv[0], "--recover-committed")==0) {
do_recover_committed=TRUE;
} else if (strcmp(argv[0], "--recover-aborted")==0) {
do_recover_aborted=TRUE;
} else if (strcmp(argv[0], "--recover-only") == 0) { } else if (strcmp(argv[0], "--recover-only") == 0) {
do_recover_only=TRUE; do_recover_only=TRUE;
} else if (strcmp(argv[0], "--no-recover") == 0) { } else if (strcmp(argv[0], "--no-recover") == 0) {
...@@ -91,7 +99,7 @@ static void test_parse_args (int argc, char *argv[]) { ...@@ -91,7 +99,7 @@ static void test_parse_args (int argc, char *argv[]) {
} else if (strcmp(argv[0], "-h")==0) { } else if (strcmp(argv[0], "-h")==0) {
resultcode=0; resultcode=0;
do_usage: do_usage:
fprintf(stderr, "Usage:\n%s [-v|-q]* [-h] {--commit | --abort | --explicit-abort | --recover-committed | --recover-aborted } \n", cmd); fprintf(stderr, "Usage:\n%s [-v|-q]* [-h] {--test | --recover } \n", cmd);
exit(resultcode); exit(resultcode);
} else { } else {
fprintf(stderr, "Unknown arg: %s\n", argv[0]); fprintf(stderr, "Unknown arg: %s\n", argv[0]);
...@@ -101,28 +109,14 @@ static void test_parse_args (int argc, char *argv[]) { ...@@ -101,28 +109,14 @@ static void test_parse_args (int argc, char *argv[]) {
argc--; argc--;
argv++; argv++;
} }
{
int n_specified=0;
if (do_commit) n_specified++;
if (do_abort) n_specified++;
if (do_explicit_abort) n_specified++;
if (do_recover_committed) n_specified++;
if (do_recover_aborted) n_specified++;
if (do_recover_only) n_specified++;
if (do_no_recover) n_specified++;
if (n_specified>1) {
printf("Specify only one of --commit or --abort or --recover-committed or --recover-aborted\n");
resultcode=1;
goto do_usage;
}
}
} }
int int test_main (int argc, char *argv[]) {
test_main (int argc, char *argv[]) {
test_parse_args(argc, argv); test_parse_args(argc, argv);
if (do_commit) { if (do_test) {
run_test(); run_test();
} else if (do_recover) {
run_recover();
} else if (do_recover_only) { } else if (do_recover_only) {
run_recover(); run_recover();
} else if (do_no_recover) { } else if (do_no_recover) {
......
// verify thtat we can create the correct tree type after the db is removed
#include <sys/stat.h>
#include <sys/wait.h>
#include "test.h"
const int envflags = DB_INIT_MPOOL|DB_CREATE|DB_THREAD |DB_INIT_LOCK|DB_INIT_LOG|DB_INIT_TXN;
char *namea="a.db";
char *nameb="b.db";
static void run_test (void) {
int r;
system("rm -rf " ENVDIR);
toku_os_mkdir(ENVDIR, S_IRWXU+S_IRWXG+S_IRWXO);
DB_ENV *env;
DB *db;
r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
DB_TXN *txn;
r = env->txn_begin(env, NULL, &txn, 0); CKERR(r);
r = db_create(&db, env, 0); CKERR(r);
r = db->open(db, NULL, namea, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r);
r = db->close(db, 0); CKERR(r);
r = db_create(&db, env, 0); CKERR(r);
r = db->remove(db, namea, NULL, 0); CKERR(r);
r = env->txn_checkpoint(env, 0, 0, 0); CKERR(r);
r = db_create(&db, env, 0); CKERR(r);
r = db->set_flags(db, DB_DUPSORT); CKERR(r);
r = db->open(db, NULL, namea, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r);
r = db->close(db, 0); CKERR(r);
r = txn->commit(txn, 0); CKERR(r);
abort();
}
static void run_recover (void) {
DB_ENV *env;
int r;
r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags + DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
u_int32_t dbflags;
DB *db;
r = db_create(&db, env, 0); CKERR(r);
r = db->open(db, NULL, namea, NULL, DB_UNKNOWN, DB_AUTO_COMMIT, 0666); CKERR(r);
r = db->get_flags(db, &dbflags); CKERR(r);
assert(dbflags == DB_DUPSORT);
r = db->close(db, 0); CKERR(r);
r = env->close(env, 0); CKERR(r);
exit(0);
}
static void run_no_recover (void) {
DB_ENV *env;
int r;
r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags & ~DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
r = env->close(env, 0); CKERR(r);
exit(0);
}
const char *cmd;
BOOL do_test=FALSE, do_recover=FALSE, do_recover_only=FALSE, do_no_recover = FALSE;
static void test_parse_args (int argc, char *argv[]) {
int resultcode;
cmd = argv[0];
argc--; argv++;
while (argc>0) {
if (strcmp(argv[0], "-v") == 0) {
verbose++;
} else if (strcmp(argv[0],"-q")==0) {
verbose--;
if (verbose<0) verbose=0;
} else if (strcmp(argv[0], "--test")==0) {
do_test=TRUE;
} else if (strcmp(argv[0], "--recover") == 0) {
do_recover=TRUE;
} else if (strcmp(argv[0], "--recover-only") == 0) {
do_recover_only=TRUE;
} else if (strcmp(argv[0], "--no-recover") == 0) {
do_no_recover=TRUE;
} else if (strcmp(argv[0], "-h")==0) {
resultcode=0;
do_usage:
fprintf(stderr, "Usage:\n%s [-v|-q]* [-h] {--test | --recover } \n", cmd);
exit(resultcode);
} else {
fprintf(stderr, "Unknown arg: %s\n", argv[0]);
resultcode=1;
goto do_usage;
}
argc--;
argv++;
}
}
int test_main (int argc, char *argv[]) {
test_parse_args(argc, argv);
if (do_test) {
run_test();
} else if (do_recover) {
run_recover();
} else if (do_recover_only) {
run_recover();
} else if (do_no_recover) {
run_no_recover();
}
return 0;
}
// verify that we can fcreate after fdelete with different treeflags
#include <sys/stat.h>
#include <sys/wait.h>
#include "test.h"
const int envflags = DB_INIT_MPOOL|DB_CREATE|DB_THREAD |DB_INIT_LOCK|DB_INIT_LOG|DB_INIT_TXN;
char *namea="a.db";
char *nameb="b.db";
static void put_something(DB_ENV *env, DB *db, char *k, char *v) {
int r;
DBT key={.data=k, .size=strlen(k)};
DBT val={.data=v, .size=strlen(v)};
DB_TXN *txn;
r = env->txn_begin(env, 0, &txn, 0); CKERR(r);
r = db->put(db, txn, &key, &val, DB_YESOVERWRITE); CKERR(r);
r = txn->commit(txn, 0); CKERR(r);
}
static void run_test (void) {
int r;
system("rm -rf " ENVDIR);
toku_os_mkdir(ENVDIR, S_IRWXU+S_IRWXG+S_IRWXO);
DB_ENV *env;
DB *db;
DB_TXN *txn;
r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
// fcreate
r = db_create(&db, env, 0); CKERR(r);
r = db->open(db, NULL, namea, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r);
r = db->close(db, 0); CKERR(r);
// dummy transaction
r = env->txn_begin(env, NULL, &txn, 0); CKERR(r);
// fopen
r = db_create(&db, env, 0); CKERR(r);
r = db->open(db, NULL, namea, NULL, DB_UNKNOWN, DB_AUTO_COMMIT, 0666); CKERR(r);
// insert something
put_something(env, db, "a", "b");
r = db->close(db, 0); CKERR(r);
// fdelete
r = db_create(&db, env, 0); CKERR(r);
r = db->remove(db, namea, NULL, 0); CKERR(r);
// checkpoint
r = env->txn_checkpoint(env, 0, 0, 0); CKERR(r);
r = txn->commit(txn, 0); CKERR(r);
// fcreate with different treeflags
r = db_create(&db, env, 0); CKERR(r);
r = db->set_flags(db, DB_DUPSORT); CKERR(r);
r = db->open(db, NULL, namea, NULL, DB_BTREE, DB_AUTO_COMMIT|DB_CREATE, 0666); CKERR(r);
// insert something
put_something(env, db, "c", "d");
r = db->close(db, 0); CKERR(r);
abort();
}
static void run_recover (void) {
DB_ENV *env;
int r;
r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags + DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
u_int32_t dbflags;
DB *db;
r = db_create(&db, env, 0); CKERR(r);
r = db->open(db, NULL, namea, NULL, DB_UNKNOWN, DB_AUTO_COMMIT, 0666); CKERR(r);
r = db->get_flags(db, &dbflags); CKERR(r);
assert(dbflags == DB_DUPSORT);
r = db->close(db, 0); CKERR(r);
r = env->close(env, 0); CKERR(r);
exit(0);
}
static void run_no_recover (void) {
DB_ENV *env;
int r;
r = db_env_create(&env, 0); CKERR(r);
r = env->open(env, ENVDIR, envflags & ~DB_RECOVER, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
r = env->close(env, 0); CKERR(r);
exit(0);
}
const char *cmd;
BOOL do_test=FALSE, do_recover=FALSE, do_recover_only=FALSE, do_no_recover = FALSE;
static void test_parse_args (int argc, char *argv[]) {
int resultcode;
cmd = argv[0];
argc--; argv++;
while (argc>0) {
if (strcmp(argv[0], "-v") == 0) {
verbose++;
} else if (strcmp(argv[0],"-q")==0) {
verbose--;
if (verbose<0) verbose=0;
} else if (strcmp(argv[0], "--test")==0) {
do_test=TRUE;
} else if (strcmp(argv[0], "--recover") == 0) {
do_recover=TRUE;
} else if (strcmp(argv[0], "--recover-only") == 0) {
do_recover_only=TRUE;
} else if (strcmp(argv[0], "--no-recover") == 0) {
do_no_recover=TRUE;
} else if (strcmp(argv[0], "-h")==0) {
resultcode=0;
do_usage:
fprintf(stderr, "Usage:\n%s [-v|-q]* [-h] {--test | --recover } \n", cmd);
exit(resultcode);
} else {
fprintf(stderr, "Unknown arg: %s\n", argv[0]);
resultcode=1;
goto do_usage;
}
argc--;
argv++;
}
}
int test_main (int argc, char *argv[]) {
test_parse_args(argc, argv);
if (do_test) {
run_test();
} else if (do_recover) {
run_recover();
} else if (do_recover_only) {
run_recover();
} else if (do_no_recover) {
run_no_recover();
}
return 0;
}
...@@ -45,11 +45,10 @@ do_x1_shutdown (BOOL do_commit, BOOL do_abort) { ...@@ -45,11 +45,10 @@ do_x1_shutdown (BOOL do_commit, BOOL do_abort) {
r = dbb->put(dbb, txn, &b, &a, 0); CKERR(r); r = dbb->put(dbb, txn, &b, &a, 0); CKERR(r);
} }
//printf("opened\n"); //printf("opened\n");
r = txn->commit(txn, 0); CKERR(r);
if (do_commit) { if (do_commit) {
r = txn->commit(txn, 0); CKERR(r);
r = txn->commit(txn0, 0); CKERR(r); r = txn->commit(txn0, 0); CKERR(r);
} else if (do_abort) { } else if (do_abort) {
r = txn->abort(txn); CKERR(r);
r = txn->abort(txn0); CKERR(r); r = txn->abort(txn0); CKERR(r);
// force an fsync of the log // force an fsync of the log
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment