Commit e8294d32 authored by Barry Perlman's avatar Barry Perlman Committed by Yoni Fogel

[t:3036] Fix test to not have hard-coded default number of range locks, and...

[t:3036] Fix test to not have hard-coded default number of range locks, and disable test of default because it is no longer a useful test.

git-svn-id: file:///svn/toku/tokudb@25580 c7de825b-a66e-492c-adef-691d508d4ae1
parent 59fe47f0
...@@ -27,6 +27,7 @@ static void make_db (int n_locks) { ...@@ -27,6 +27,7 @@ static void make_db (int n_locks) {
DB_TXN *tid, *tid2; DB_TXN *tid, *tid2;
int r; int r;
int i; int i;
u_int32_t actual_n_locks;
r = system("rm -rf " ENVDIR); r = system("rm -rf " ENVDIR);
CKERR(r); CKERR(r);
...@@ -39,14 +40,17 @@ static void make_db (int n_locks) { ...@@ -39,14 +40,17 @@ static void make_db (int n_locks) {
if (n_locks>0) { if (n_locks>0) {
r=env->set_lk_max_locks(env, n_locks+EXTRA_LOCK_NEEDED); CKERR(r); r=env->set_lk_max_locks(env, n_locks+EXTRA_LOCK_NEEDED); CKERR(r);
/* test the get_lk_max_locks method */ /* test the get_lk_max_locks method */
u_int32_t set_locks;
#ifdef TOKUDB #ifdef TOKUDB
// BDB cannot handle a NULL passed to get_lk_max_locks // BDB cannot handle a NULL passed to get_lk_max_locks
r=env->get_lk_max_locks(env, 0); r=env->get_lk_max_locks(env, 0);
assert(r == EINVAL); assert(r == EINVAL);
#endif #endif
r=env->get_lk_max_locks(env, &set_locks); r=env->get_lk_max_locks(env, &actual_n_locks);
assert(r == 0 && set_locks == (u_int32_t)n_locks+EXTRA_LOCK_NEEDED); assert(r == 0 && actual_n_locks == (u_int32_t)n_locks+EXTRA_LOCK_NEEDED);
}
else {
r=env->get_lk_max_locks(env, &actual_n_locks);
CKERR(r);
} }
r=env->open(env, ENVDIR, DB_INIT_LOCK|DB_INIT_LOG|DB_INIT_MPOOL|DB_INIT_TXN|DB_CREATE|DB_PRIVATE, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r); r=env->open(env, ENVDIR, DB_INIT_LOCK|DB_INIT_LOG|DB_INIT_MPOOL|DB_INIT_TXN|DB_CREATE|DB_PRIVATE, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
r=db_create(&db, env, 0); CKERR(r); r=db_create(&db, env, 0); CKERR(r);
...@@ -61,7 +65,7 @@ static void make_db (int n_locks) { ...@@ -61,7 +65,7 @@ static void make_db (int n_locks) {
#else #else
u_int32_t datasize = 1; u_int32_t datasize = 1;
#endif #endif
int effective_n_locks = (n_locks<0) ? 1000-EXTRA_LOCK_NEEDED : n_locks; int effective_n_locks = (n_locks<0) ? (int)actual_n_locks-EXTRA_LOCK_NEEDED : n_locks;
// create even numbered keys 0 2 4 ... (effective_n_locks*32-2) // create even numbered keys 0 2 4 ... (effective_n_locks*32-2)
r=env->txn_begin(env, 0, &tid, 0); CKERR(r); r=env->txn_begin(env, 0, &tid, 0); CKERR(r);
...@@ -128,11 +132,10 @@ static void make_db (int n_locks) { ...@@ -128,11 +132,10 @@ static void make_db (int n_locks) {
int int
test_main (int argc __attribute__((__unused__)), char *const argv[] __attribute__((__unused__))) { test_main (int argc __attribute__((__unused__)), char *const argv[] __attribute__((__unused__))) {
make_db(-1);
make_db(100); make_db(100);
if (0) {
make_db(1000); make_db(1000);
make_db(2000); if (0) {
make_db(-1); // Could be used to test default, but default is now too large for this to be a useful test
} }
return 0; return 0;
} }
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