Commit 10bdafb7 authored by Bradley C. Kuszmaul's avatar Bradley C. Kuszmaul

The problem was in the test code. It was creating a MALLOC DBT and then never...

The problem was in the test code.  It was creating a MALLOC DBT and then never freeing stuff. Fixes #1026.

git-svn-id: file:///svn/tokudb@5189 c7de825b-a66e-492c-adef-691d508d4ae1
parent 05d057c0
......@@ -54,12 +54,14 @@ void run (int choice) {
DBC *c;
r=db->cursor(db, txn, &c, 0); CKERR(r);
DBT kdbt,vdbt;
dbt_init_malloc(&kdbt);
dbt_init_malloc(&vdbt);
memset(&kdbt, 0, sizeof(kdbt));
memset(&vdbt, 0, sizeof(vdbt));
i=0;
while (0==(r=c->c_get(c, &kdbt, &vdbt, DB_NEXT))) {
//printf("Got %d %d\n", *(unsigned char*)kdbt.data, *(unsigned char*)vdbt.data);
i++;
kdbt.data=0;
vdbt.data=0;
}
CKERR2(r, DB_NOTFOUND);
//printf("i=%d N=%d\n", i, N);
......@@ -72,8 +74,8 @@ void run (int choice) {
DBC *c;
r=db->cursor(db, txn, &c, 0); CKERR(r);
DBT kdbt,vdbt;
dbt_init_malloc(&kdbt);
dbt_init_malloc(&vdbt);
memset(&kdbt, 0, sizeof(kdbt));
memset(&vdbt, 0, sizeof(vdbt));
i=0;
while (0==(r=(c->c_get(c, &kdbt, &vdbt, DB_FIRST)))) {
i++;
......
......@@ -50,11 +50,11 @@ void run (void) {
assert(*(char*)k.data==vN); assert(ntohl(*(int*)v.data)==i);
}
r=c->c_get(c, dbt_init_malloc(&k), dbt_init_malloc(&v), DB_NEXT); CKERR(r);
r=c->c_get(c, dbt_init(&k, 0, 0), dbt_init(&v, 0, 0), DB_NEXT); CKERR(r);
assert(*(char*)k.data==v1); assert(*(char*)v.data==v101);
r=c->c_get(c, dbt_init_malloc(&k), dbt_init_malloc(&v), DB_NEXT); CKERR(r);
r=c->c_get(c, dbt_init(&k, 0, 0), dbt_init(&v, 0, 0), DB_NEXT); CKERR(r);
assert(*(char*)k.data==v2); assert(*(char*)v.data==v102);
r=c->c_get(c, dbt_init_malloc(&k), dbt_init_malloc(&v), DB_NEXT); assert(r!=0);
r=c->c_get(c, dbt_init(&k, 0, 0), dbt_init(&v, 0, 0), DB_NEXT); assert(r!=0);
r=c->c_close(c); CKERR(r);
r=txn->commit(txn, 0); CKERR(r);
}
......
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