Commit aee8af1c authored by Leif Walsh's avatar Leif Walsh

optimized test_keylen_diff so it's faster under valgrind

also widened one valgrind suppression to also catch something we
initialize in the assert layer
parent 5d8b9214
...@@ -286,11 +286,9 @@ ...@@ -286,11 +286,9 @@
Memcheck:Leak Memcheck:Leak
match-leak-kinds: reachable match-leak-kinds: reachable
fun:calloc fun:calloc
obj:/usr/lib/libdl-2.19.so ...
fun:dlsym fun:dlsym
fun:_Z19toku_memory_startupv ...
fun:call_init.part.0
fun:_dl_init fun:_dl_init
obj:/usr/lib/ld-2.19.so
} }
...@@ -138,15 +138,12 @@ static int update_callback(DB *UU(db), const DBT *UU(key), const DBT *old_val, c ...@@ -138,15 +138,12 @@ static int update_callback(DB *UU(db), const DBT *UU(key), const DBT *old_val, c
void (*set_val)(const DBT *new_val, void *setval_extra), void *setval_extra) { void (*set_val)(const DBT *new_val, void *setval_extra), void *setval_extra) {
assert(extra != nullptr); assert(extra != nullptr);
assert(old_val != nullptr); assert(old_val != nullptr);
assert(extra->size == 0); assert(extra->size == 0 || extra->size == 100);
assert(old_val->size == 0); assert(old_val->size == 0 || old_val->size == 100);
if (extra->data == nullptr) { if (extra->data == nullptr) {
set_val(nullptr, setval_extra); set_val(nullptr, setval_extra);
} else { } else {
DBT new_val; set_val(extra, setval_extra);
char empty_v;
dbt_init(&new_val, &empty_v, 0);
set_val(&new_val, setval_extra);
} }
return 0; return 0;
} }
...@@ -176,12 +173,13 @@ static void test_keylen_diff(enum overwrite_method method, bool control_test) { ...@@ -176,12 +173,13 @@ static void test_keylen_diff(enum overwrite_method method, bool control_test) {
r = db->set_readpagesize(db, 1 * 1024); // smaller basements so we get more per leaf r = db->set_readpagesize(db, 1 * 1024); // smaller basements so we get more per leaf
r = db->open(db, nullptr, "db", nullptr, DB_BTREE, DB_CREATE, 0666); CKERR(r); r = db->open(db, nullptr, "db", nullptr, DB_BTREE, DB_CREATE, 0666); CKERR(r);
DBT null_dbt, empty_dbt; DBT null_dbt, val_dbt;
char empty_v; char val_buf[100];
dbt_init(&empty_dbt, &empty_v, 0); memset(val_buf, 0, sizeof val_buf);
dbt_init(&val_dbt, &val_buf, sizeof val_buf);
dbt_init(&null_dbt, nullptr, 0); dbt_init(&null_dbt, nullptr, 0);
const int num_keys = 256 * 1000; const int num_keys = 1<<11; //256 * 1000;
for (int i = 0; i < num_keys; i++) { for (int i = 0; i < num_keys; i++) {
// insert it using a 4 byte key .. // insert it using a 4 byte key ..
...@@ -189,7 +187,7 @@ static void test_keylen_diff(enum overwrite_method method, bool control_test) { ...@@ -189,7 +187,7 @@ static void test_keylen_diff(enum overwrite_method method, bool control_test) {
DBT dbt; DBT dbt;
dbt_init(&dbt, &key, key.size()); dbt_init(&dbt, &key, key.size());
r = db->put(db, nullptr, &dbt, &empty_dbt, 0); CKERR(r); r = db->put(db, nullptr, &dbt, &val_dbt, 0); CKERR(r);
} }
// overwrite keys randomly, so we induce flushes and get better / realistic coverage // overwrite keys randomly, so we induce flushes and get better / realistic coverage
...@@ -217,7 +215,7 @@ static void test_keylen_diff(enum overwrite_method method, bool control_test) { ...@@ -217,7 +215,7 @@ static void test_keylen_diff(enum overwrite_method method, bool control_test) {
env->txn_begin(env, nullptr, &txn, DB_TXN_NOSYNC); CKERR(r); env->txn_begin(env, nullptr, &txn, DB_TXN_NOSYNC); CKERR(r);
switch (method) { switch (method) {
case VIA_INSERT: { case VIA_INSERT: {
r = db->put(db, txn, &dbt, &empty_dbt, 0); CKERR(r); r = db->put(db, txn, &dbt, &val_dbt, 0); CKERR(r);
break; break;
} }
case VIA_DELETE: { case VIA_DELETE: {
...@@ -228,12 +226,12 @@ static void test_keylen_diff(enum overwrite_method method, bool control_test) { ...@@ -228,12 +226,12 @@ static void test_keylen_diff(enum overwrite_method method, bool control_test) {
} }
case VIA_UPDATE_OVERWRITE: case VIA_UPDATE_OVERWRITE:
case VIA_UPDATE_DELETE: { case VIA_UPDATE_DELETE: {
r = db->update(db, txn, &dbt, method == VIA_UPDATE_DELETE ? &null_dbt : &empty_dbt, 0); CKERR(r); r = db->update(db, txn, &dbt, method == VIA_UPDATE_DELETE ? &null_dbt : &val_dbt, 0); CKERR(r);
break; break;
} }
case VIA_UPDATE_OVERWRITE_BROADCAST: case VIA_UPDATE_OVERWRITE_BROADCAST:
case VIA_UPDATE_DELETE_BROADCAST: { case VIA_UPDATE_DELETE_BROADCAST: {
r = db->update_broadcast(db, txn, method == VIA_UPDATE_DELETE_BROADCAST ? &null_dbt : &empty_dbt, 0); CKERR(r); r = db->update_broadcast(db, txn, method == VIA_UPDATE_DELETE_BROADCAST ? &null_dbt : &val_dbt, 0); CKERR(r);
if (i > 1 ) { // only need to test broadcast twice - one with abort, one without if (i > 1 ) { // only need to test broadcast twice - one with abort, one without
txn->abort(txn); // we opened a txn so we should abort it before exiting txn->abort(txn); // we opened a txn so we should abort it before exiting
goto done; goto done;
......
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