Commit 4aa51ab1 authored by Bradley C. Kuszmaul's avatar Bradley C. Kuszmaul Committed by Yoni Fogel

Merge in the 2623 branch to main. Closes #2623. close[t:2623]

{{{
svn merge -r 20428:20432 https://svn.tokutek.com/tokudb/toku/tokudb.2623
}}}
.


git-svn-id: file:///svn/toku/tokudb@20433 c7de825b-a66e-492c-adef-691d508d4ae1
parent c33084b0
...@@ -5851,6 +5851,9 @@ int toku_brt_strerror_r(int error, char *buf, size_t buflen) ...@@ -5851,6 +5851,9 @@ int toku_brt_strerror_r(int error, char *buf, size_t buflen)
case DB_KEYEXIST: case DB_KEYEXIST:
snprintf(buf, buflen, "Key exists"); snprintf(buf, buflen, "Key exists");
return 0; return 0;
case TOKUDB_CANCELED:
snprintf(buf, buflen, "User canceled operation");
return 0;
default: default:
snprintf(buf, buflen, "Unknown error %d", error); snprintf(buf, buflen, "Unknown error %d", error);
errno = EINVAL; errno = EINVAL;
......
...@@ -1583,7 +1583,12 @@ int toku_merge_some_files_using_dbufio (const BOOL to_q, FIDX dest_data, QUEUE q ...@@ -1583,7 +1583,12 @@ int toku_merge_some_files_using_dbufio (const BOOL to_q, FIDX dest_data, QUEUE q
int progress_just_done = fraction_of_remaining_we_just_did * progress_allocation; int progress_just_done = fraction_of_remaining_we_just_did * progress_allocation;
progress_allocation -= progress_just_done; progress_allocation -= progress_just_done;
r = update_progress(progress_just_done, bl, "in file merge"); r = update_progress(progress_just_done, bl, "in file merge");
if (r!=0) return r; //printf("%s:%d Progress=%d\n", __FILE__, __LINE__, r);
if (r!=0) {
invariant(result==0);
result=r;
break;
}
} }
} }
if (result==0 && to_q) { if (result==0 && to_q) {
...@@ -1607,6 +1612,7 @@ int toku_merge_some_files_using_dbufio (const BOOL to_q, FIDX dest_data, QUEUE q ...@@ -1607,6 +1612,7 @@ int toku_merge_some_files_using_dbufio (const BOOL to_q, FIDX dest_data, QUEUE q
toku_free(pq_nodes); toku_free(pq_nodes);
{ {
int r = update_progress(progress_allocation, bl, "end of merge_some_files"); int r = update_progress(progress_allocation, bl, "end of merge_some_files");
//printf("%s:%d Progress=%d\n", __FILE__, __LINE__, r);
if (r!=0 && result==0) result = r; if (r!=0 && result==0) result = r;
} }
return result; return result;
......
...@@ -27,7 +27,7 @@ static int loader_poll_callback(void *UU(extra), float UU(progress)) { ...@@ -27,7 +27,7 @@ static int loader_poll_callback(void *UU(extra), float UU(progress)) {
event_count++; event_count++;
if (event_count_trigger == event_count) { if (event_count_trigger == event_count) {
event_hit(); event_hit();
r = 1; r = TOKUDB_CANCELED;
} else { } else {
r = 0; r = 0;
} }
...@@ -167,7 +167,7 @@ static void *consumer_thread (void *ctv) { ...@@ -167,7 +167,7 @@ static void *consumer_thread (void *ctv) {
} }
static void test (const char *directory) { static void test (const char *directory, BOOL is_error) {
int *XMALLOC_N(N_SOURCES, fds); int *XMALLOC_N(N_SOURCES, fds);
...@@ -265,24 +265,31 @@ static void test (const char *directory) { ...@@ -265,24 +265,31 @@ static void test (const char *directory) {
int r = toku_pthread_create(&consumer, NULL, consumer_thread, (void*)&cthunk); int r = toku_pthread_create(&consumer, NULL, consumer_thread, (void*)&cthunk);
assert(r==0); assert(r==0);
} }
int result = 0;
{ {
int r = toku_merge_some_files_using_dbufio(TRUE, FIDX_NULL, q, N_SOURCES, bfs, src_fidxs, bl, 0, (DB*)NULL, compare_ints, 10000); int r = toku_merge_some_files_using_dbufio(TRUE, FIDX_NULL, q, N_SOURCES, bfs, src_fidxs, bl, 0, (DB*)NULL, compare_ints, 10000);
if (is_error && r!=0) {
result = r;
} else {
if (r!=0) printf("%s:%d r=%d (%s)\n", __FILE__, __LINE__, r, errorstr_static(r)); if (r!=0) printf("%s:%d r=%d (%s)\n", __FILE__, __LINE__, r, errorstr_static(r));
assert(r==0); assert(r==0);
} }
}
{ {
int r = queue_eof(q); int r = queue_eof(q);
assert(r==0); assert(r==0);
} }
{ {
void *result; void *vresult;
int r = toku_pthread_join(consumer, &result); int r = toku_pthread_join(consumer, &vresult);
assert(r==0); assert(r==0);
assert(result==NULL); assert(vresult==NULL);
//printf("n_read = %ld, N_SOURCES=%d N_RECORDS=%d\n", cthunk.n_read, N_SOURCES, N_RECORDS); //printf("n_read = %ld, N_SOURCES=%d N_RECORDS=%d\n", cthunk.n_read, N_SOURCES, N_RECORDS);
if (result==0) {
assert(cthunk.n_read == N_RECORDS); assert(cthunk.n_read == N_RECORDS);
} }
printf("%s:%d Destroying\n", __FILE__, __LINE__); }
//printf("%s:%d Destroying\n", __FILE__, __LINE__);
{ {
int r = queue_destroy(bl->primary_rowset_queue); int r = queue_destroy(bl->primary_rowset_queue);
assert(r==0); assert(r==0);
...@@ -368,11 +375,11 @@ int test_main (int argc, const char *argv[]) { ...@@ -368,11 +375,11 @@ int test_main (int argc, const char *argv[]) {
int r; int r;
r = system(unlink_all); CKERR(r); r = system(unlink_all); CKERR(r);
r = toku_os_mkdir(directory, 0755); CKERR(r); r = toku_os_mkdir(directory, 0755); CKERR(r);
test(directory); test(directory, FALSE);
if (verbose) printf("my_malloc_count=%d big_count=%d\n", my_malloc_count, my_big_malloc_count); if (verbose) printf("my_malloc_count=%d big_count=%d\n", my_malloc_count, my_big_malloc_count);
if (0) { {
int event_limit = event_count; int event_limit = event_count;
if (verbose) printf("event_limit=%d\n", event_limit); if (verbose) printf("event_limit=%d\n", event_limit);
...@@ -383,7 +390,7 @@ int test_main (int argc, const char *argv[]) { ...@@ -383,7 +390,7 @@ int test_main (int argc, const char *argv[]) {
r = system(unlink_all); CKERR(r); r = system(unlink_all); CKERR(r);
r = toku_os_mkdir(directory, 0755); CKERR(r); r = toku_os_mkdir(directory, 0755); CKERR(r);
test(directory); test(directory, TRUE);
} }
} }
......
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