Commit e9cb025a authored by Rich Prohaska's avatar Rich Prohaska

brt assert dupsort in handle_split_of_child. address #442

git-svn-id: file:///svn/tokudb@2450 c7de825b-a66e-492c-adef-691d508d4ae1
parent 449ce6a9
...@@ -12,6 +12,10 @@ ...@@ -12,6 +12,10 @@
#include <unistd.h> #include <unistd.h>
#include <db.h> #include <db.h>
#if !defined(DB_YESOVERWRITE)
#define DB_YESOVERWRITE 0
#endif
enum { SERIAL_SPACING = 1<<6 }; enum { SERIAL_SPACING = 1<<6 };
enum { ITEMS_TO_INSERT_PER_ITERATION = 1<<20 }; enum { ITEMS_TO_INSERT_PER_ITERATION = 1<<20 };
enum { ITEMS_PER_TRANSACTION = 1<<14 }; enum { ITEMS_PER_TRANSACTION = 1<<14 };
...@@ -25,6 +29,7 @@ int keysize = sizeof (long long); ...@@ -25,6 +29,7 @@ int keysize = sizeof (long long);
int valsize = sizeof (long long); int valsize = sizeof (long long);
int pagesize = 0; int pagesize = 0;
long long cachesize = 128*1024*1024; long long cachesize = 128*1024*1024;
int dupflags = 0;
#define STRINGIFY2(s) #s #define STRINGIFY2(s) #s
#define STRINGIFY(s) STRINGIFY2(s) #define STRINGIFY(s) STRINGIFY2(s)
...@@ -87,6 +92,10 @@ void setup (void) { ...@@ -87,6 +92,10 @@ void setup (void) {
r = db->set_pagesize(db, pagesize); r = db->set_pagesize(db, pagesize);
assert(r == 0); assert(r == 0);
} }
if (dupflags) {
r = db->set_flags(db, dupflags);
assert(r == 0);
}
r = db->open(db, tid, dbfilename, NULL, DB_BTREE, DB_CREATE, 0644); r = db->open(db, tid, dbfilename, NULL, DB_BTREE, DB_CREATE, 0644);
assert(r == 0); assert(r == 0);
if (do_transactions) { if (do_transactions) {
...@@ -124,7 +133,7 @@ void insert (long long v) { ...@@ -124,7 +133,7 @@ void insert (long long v) {
long_long_to_array(kc, v); long_long_to_array(kc, v);
memset(vc, 0, sizeof vc); memset(vc, 0, sizeof vc);
long_long_to_array(vc, v); long_long_to_array(vc, v);
int r = db->put(db, tid, toku_fill_dbt(&kt, kc, keysize), toku_fill_dbt(&vt, vc, valsize), 0); int r = db->put(db, tid, toku_fill_dbt(&kt, kc, keysize), toku_fill_dbt(&vt, vc, valsize), DB_YESOVERWRITE);
CKERR(r); CKERR(r);
if (do_transactions) { if (do_transactions) {
if (n_insertions_since_txn_began>=ITEMS_PER_TRANSACTION) { if (n_insertions_since_txn_began>=ITEMS_PER_TRANSACTION) {
...@@ -143,7 +152,7 @@ void serial_insert_from (long long from) { ...@@ -143,7 +152,7 @@ void serial_insert_from (long long from) {
int r = dbenv->txn_begin(dbenv, 0, &tid, 0); assert(r==0); int r = dbenv->txn_begin(dbenv, 0, &tid, 0); assert(r==0);
{ {
DBT k,v; DBT k,v;
r=db->put(db, tid, toku_fill_dbt(&k, "a", 1), toku_fill_dbt(&v, "b", 1), 0); r=db->put(db, tid, toku_fill_dbt(&k, "a", 1), toku_fill_dbt(&v, "b", 1), DB_YESOVERWRITE);
CKERR(r); CKERR(r);
} }
...@@ -201,7 +210,7 @@ void biginsert (long long n_elements, struct timeval *starttime) { ...@@ -201,7 +210,7 @@ void biginsert (long long n_elements, struct timeval *starttime) {
const long long default_n_items = 1LL<<22; const long long default_n_items = 1LL<<22;
void print_usage (const char *argv0) { int print_usage (const char *argv0) {
fprintf(stderr, "Usage:\n"); fprintf(stderr, "Usage:\n");
fprintf(stderr, " %s [-x] [--keysize KEYSIZE] [--valsize VALSIZE] [ n_iterations ]\n", argv0); fprintf(stderr, " %s [-x] [--keysize KEYSIZE] [--valsize VALSIZE] [ n_iterations ]\n", argv0);
fprintf(stderr, " where\n"); fprintf(stderr, " where\n");
...@@ -211,8 +220,9 @@ void print_usage (const char *argv0) { ...@@ -211,8 +220,9 @@ void print_usage (const char *argv0) {
fprintf(stderr, " --cachesize CACHESIZE set the database cache size\n"); fprintf(stderr, " --cachesize CACHESIZE set the database cache size\n");
fprintf(stderr, " --pagesize PAGESIZE sets the database page size\n"); fprintf(stderr, " --pagesize PAGESIZE sets the database page size\n");
fprintf(stderr, " n_iterations how many iterations (default %lld iterations of %d items per iteration)\n", default_n_items/ITEMS_TO_INSERT_PER_ITERATION, ITEMS_TO_INSERT_PER_ITERATION); fprintf(stderr, " n_iterations how many iterations (default %lld iterations of %d items per iteration)\n", default_n_items/ITEMS_TO_INSERT_PER_ITERATION, ITEMS_TO_INSERT_PER_ITERATION);
}
return 1;
}
int main (int argc, const char *argv[]) { int main (int argc, const char *argv[]) {
struct timeval t1,t2,t3; struct timeval t1,t2,t3;
...@@ -227,35 +237,30 @@ int main (int argc, const char *argv[]) { ...@@ -227,35 +237,30 @@ int main (int argc, const char *argv[]) {
continue; continue;
} }
if (strcmp(arg, "--cachesize") == 0) { if (strcmp(arg, "--cachesize") == 0) {
if (i+1 < argc) { if (i+1 >= argc) return print_usage(argv[0]);
i++; cachesize = strtoll(argv[++i], 0, 10);
cachesize = strtoll(argv[i], 0, 10);
}
continue; continue;
} }
if (strcmp(arg, "--keysize") == 0) { if (strcmp(arg, "--keysize") == 0) {
if (i+1 < argc) { if (i+1 >= argc) return print_usage(argv[0]);
i++; keysize = atoi(argv[++i]);
keysize = atoi(argv[i]);
}
continue; continue;
} }
if (strcmp(arg, "--valsize") == 0) { if (strcmp(arg, "--valsize") == 0) {
if (i+1 < argc) { if (i+1 >= argc) return print_usage(argv[0]);
i++; valsize = atoi(argv[++i]);
valsize = atoi(argv[i]);
}
continue; continue;
} }
if (strcmp(arg, "--pagesize") == 0) { if (strcmp(arg, "--pagesize") == 0) {
if (i+1 < argc) { if (i+1 >= argc) return print_usage(argv[0]);
i++; pagesize = atoi(argv[++i]);
pagesize = atoi(argv[i]); continue;
} }
if (strcmp(arg, "--dupsort") == 0) {
dupflags = DB_DUP + DB_DUPSORT;
continue; continue;
} }
print_usage(argv[0]); return print_usage(argv[0]);
return 1;
} }
if (i<argc) { if (i<argc) {
/* if it looks like a number */ /* if it looks like a number */
......
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