Commit 9d5dadde authored by Rich Prohaska's avatar Rich Prohaska Committed by Yoni Fogel

#2875 refs[t:2875] check keys against expected keys

git-svn-id: file:///svn/toku/tokudb@22990 c7de825b-a66e-492c-adef-691d508d4ae1
parent 1edc17db
...@@ -242,13 +242,12 @@ static void check_results(DB **dbs) ...@@ -242,13 +242,12 @@ static void check_results(DB **dbs)
r = dbs[j]->cursor(dbs[j], txn, &cursor, 0); r = dbs[j]->cursor(dbs[j], txn, &cursor, 0);
CKERR(r); CKERR(r);
// generate skeys // generate the expected keys
unsigned int *expected_key = (unsigned int *) toku_malloc(NUM_ROWS * sizeof (unsigned int));
unsigned int *skey = (unsigned int *) toku_malloc(NUM_ROWS * sizeof (unsigned int));
for (int i = 0; i < NUM_ROWS; i++) for (int i = 0; i < NUM_ROWS; i++)
skey[i] = twiddle32(i+1, j); expected_key[i] = j == 0 ? (unsigned int)(i+1) : twiddle32(i+1, j);
// sort skeys // sort the keys
qsort(skey, NUM_ROWS, sizeof (unsigned int), uint_cmp); qsort(expected_key, NUM_ROWS, sizeof (unsigned int), uint_cmp);
for (int i = 0; i < NUM_ROWS+1; i++) { for (int i = 0; i < NUM_ROWS+1; i++) {
r = cursor->c_get(cursor, &key, &val, DB_NEXT); r = cursor->c_get(cursor, &key, &val, DB_NEXT);
...@@ -266,13 +265,8 @@ static void check_results(DB **dbs) ...@@ -266,13 +265,8 @@ static void check_results(DB **dbs)
assert((unsigned int)pkey_for_db_key == (unsigned int)pkey_for_val(v, j)); assert((unsigned int)pkey_for_db_key == (unsigned int)pkey_for_val(v, j));
// printf(" DB[%d] key = %10u, val = %10u, pkey_for_db_key = %10u, pkey_for_val=%10d\n", j, v, k, pkey_for_db_key, pkey_for_val(v, j)); // printf(" DB[%d] key = %10u, val = %10u, pkey_for_db_key = %10u, pkey_for_val=%10d\n", j, v, k, pkey_for_db_key, pkey_for_val(v, j));
// check the primary key == i+1 // check the expected keys
if (j == 0) { assert(k == expected_key[i]);
assert(k == (unsigned int)(i+1));
} else {
// check the secondary key
assert(k == skey[i]);
}
// check prev_key < key // check prev_key < key
if (i > 0) if (i > 0)
...@@ -281,7 +275,8 @@ static void check_results(DB **dbs) ...@@ -281,7 +275,8 @@ static void check_results(DB **dbs)
// update prev = current // update prev = current
prev_k = k; prev_v = v; prev_k = k; prev_v = v;
} }
toku_free(skey);
toku_free(expected_key);
if ( verbose ) {printf("."); fflush(stdout);} if ( verbose ) {printf("."); fflush(stdout);}
r = cursor->c_close(cursor); r = cursor->c_close(cursor);
......
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