Commit 7fa028b7 authored by Rich Prohaska's avatar Rich Prohaska Committed by Yoni Fogel

#4052 merge test case from 506 to main refs[t:4052]

git-svn-id: file:///svn/toku/tokudb@36441 c7de825b-a66e-492c-adef-691d508d4ae1
parent fea0f82b
......@@ -1353,6 +1353,8 @@ toku_lt_create(toku_lock_tree** ptree,
tmp_tree->bw_buf = (toku_range*)
toku_malloc(tmp_tree->bw_buflen * sizeof(toku_range));
if (!tmp_tree->bw_buf) { r = ENOMEM; goto cleanup; }
tmp_tree->verify_buflen = 0;
tmp_tree->verify_buf = NULL;
r = toku_omt_create(&tmp_tree->dbs);
if (r != 0)
goto cleanup;
......@@ -1497,6 +1499,7 @@ toku_lt_close(toku_lock_tree* tree) {
toku_free(tree->buf);
toku_free(tree->bw_buf);
toku_free(tree->verify_buf);
toku_free(tree);
r = first_error;
cleanup:
......@@ -2280,29 +2283,6 @@ toku_lt_remove_db_ref(toku_lock_tree* tree, DB *db) {
assert_zero(r);
}
static void
lt_verify(toku_lock_tree *lt) {
// verify the borderwrite tree
toku_rt_verify(lt->borderwrite);
// verify all of the selfread and selfwrite trees
toku_rth_start_scan(lt->rth);
rt_forest *forest;
while ((forest = toku_rth_next(lt->rth)) != NULL) {
if (forest->self_read)
toku_rt_verify(forest->self_read);
if (forest->self_write)
toku_rt_verify(forest->self_write);
}
}
void
toku_lt_verify(toku_lock_tree *lt, DB *db) {
lt_set_comparison_functions(lt, db);
lt_verify(lt);
lt_clear_comparison_functions(lt);
}
static void
toku_lock_request_init_wait(toku_lock_request *lock_request) {
if (!lock_request->wait_initialized) {
......@@ -2725,3 +2705,71 @@ toku_ltm_get_lock_wait_time(toku_ltm *mgr, uint64_t *lock_wait_time_msec) {
else
*lock_wait_time_msec = mgr->lock_wait_time.tv_sec * 1000 + mgr->lock_wait_time.tv_usec / 1000;
}
static void
verify_range_in_borderwrite(toku_lock_tree *tree, toku_interval *query, TXNID txnid) {
int r;
uint32_t numfound;
r = toku_rt_find(tree->borderwrite, query, 0, &tree->verify_buf, &tree->verify_buflen, &numfound);
assert(r == 0);
assert(numfound == 1);
toku_range *range = &tree->verify_buf[0];
assert(range->data == txnid);
assert(interval_dominated(query, &range->ends));
}
struct verify_extra {
toku_lock_tree *lt;
TXNID id;
};
static int
verify_range_in_borderwrite_cb(toku_range *range, void *extra) {
struct verify_extra *vextra = (struct verify_extra *) extra;
verify_range_in_borderwrite(vextra->lt, &range->ends, vextra->id);
return 0;
}
static void
verify_all_ranges_in_borderwrite(toku_lock_tree *lt, toku_range_tree *rt, TXNID id) {
struct verify_extra vextra = { .lt = lt, .id = id };
toku_rt_iterate(rt, verify_range_in_borderwrite_cb, &vextra);
}
static void
verify_all_selfwrite_ranges_in_borderwrite(toku_lock_tree *lt) {
toku_rth_start_scan(lt->rth);
rt_forest *forest;
while ((forest = toku_rth_next(lt->rth))) {
if (forest->self_write)
verify_all_ranges_in_borderwrite(lt, forest->self_write, forest->hash_key);
}
}
static void
lt_verify(toku_lock_tree *lt) {
// verify all of the selfread and selfwrite trees
toku_rth_start_scan(lt->rth);
rt_forest *forest;
while ((forest = toku_rth_next(lt->rth)) != NULL) {
if (forest->self_read)
toku_rt_verify(forest->self_read);
if (forest->self_write)
toku_rt_verify(forest->self_write);
}
// verify the borderwrite tree
toku_rt_verify(lt->borderwrite);
// verify that the ranges in the selfwrite trees are in the borderwrite tree
verify_all_selfwrite_ranges_in_borderwrite(lt);
}
void
toku_lt_verify(toku_lock_tree *lt, DB *db) {
lt_set_comparison_functions(lt, db);
lt_verify(lt);
lt_clear_comparison_functions(lt);
}
......@@ -96,6 +96,8 @@ struct __toku_lock_tree {
uint32_t buflen; /**< The length of buf */
toku_range* bw_buf;
uint32_t bw_buflen;
toku_range* verify_buf;
uint32_t verify_buflen;
/** Whether lock escalation is allowed. */
bool lock_escalation_allowed;
/** Lock tree manager */
......
......@@ -134,6 +134,12 @@ static void runtest(void) {
lt_unlock('a');
close_tree();
setup_tree();
lt_insert_write_range(0, 'a', 5, 10);
lt_insert_write_range(0, 'a', 20, 30);
lt_insert_write_range(0, 'a', 1, 35);
lt_unlock('a');
close_tree();
}
static void init_test(void) {
......
......@@ -58,6 +58,8 @@ toku__rt_increase_capacity(toku_range_tree* tree, u_int32_t num) {
//TODO: SOME ATTRIBUTE TO REMOVE NEVER EXECUTABLE ERROR: assert(tree);
if (tree->i.ranges_len < num) {
u_int32_t temp_len = tree->i.ranges_len;
if (temp_len == 0)
temp_len = 1;
while (temp_len < num)
temp_len *= 2;
size_t start_size = toku_rt_memory_size(tree);
......
......@@ -74,14 +74,6 @@ int main(int argc, const char *argv[]) {
r = toku_rt_find(tree, &range.ends, 2, &buf, NULL, &found);
CKERR2(r, EINVAL);
unsigned oldbufsize = bufsize;
bufsize = 0;
#if 0
r = toku_rt_find(tree, &range.ends, 2, &buf, &bufsize, &found);
CKERR2(r, EINVAL);
#endif
bufsize = oldbufsize;
r = toku_rt_find(tree, &range.ends, 2, &buf, &bufsize, NULL);
CKERR2(r, EINVAL);
......
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