Commit 95e8ac76 authored by Bradley C. Kuszmaul's avatar Bradley C. Kuszmaul

Fiddle with the error code for truncate under bdb. Addresses #968.

git-svn-id: file:///svn/tokudb@5269 c7de825b-a66e-492c-adef-691d508d4ae1
parent 4b78cca4
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
int test_errors = 0; int test_errors = 0;
void test_errcall(const DB_ENV *emv, const char *errpfx, const char *msg) { void test_errcall(const DB_ENV *emv, const char *errpfx, const char *msg) {
if (verbose) printf("%s %s\n", errpfx, msg); if (verbose) fprintf(stderr, "%s %s\n", errpfx, msg);
test_errors++; test_errors++;
} }
...@@ -71,7 +71,14 @@ int test_truncate_with_cursors(int n) { ...@@ -71,7 +71,14 @@ int test_truncate_with_cursors(int n) {
u_int32_t row_count = 0; u_int32_t row_count = 0;
r = db->truncate(db, 0, &row_count, 0); r = db->truncate(db, 0, &row_count, 0);
#if USE_BDB #if USE_BDB
assert(r == 0 && test_errors); // It looks like for 4.6 there's no error code, even though the documentation says "it is an error to truncate with open cursors".
// For 4.3 the error code is EINVAL
// I don't know where the boundary really is: Is it an error in 4.5 or 4.4?
if (DB_VERSION_MAJOR==4 && DB_VERSION_MINOR>=6) {
assert(r == 0 && test_errors);
} else {
assert(r == EINVAL && test_errors);
}
#else #else
assert(r == EINVAL); assert(r == EINVAL);
#endif #endif
......
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