[t:2499] Added preliminary ENOSPC testing.

git-svn-id: file:///svn/toku/tokudb@19780 c7de825b-a66e-492c-adef-691d508d4ae1
This commit is contained in:
Barry Perlman 2013-04-16 23:59:08 -04:00 committed by Yoni Fogel
parent 69ca56d9ba
commit db00df2c42

View file

@ -5,14 +5,12 @@
/* TODO: /* TODO:
* *
* Decide how to cause enospc, implement. * Improve enospc testing
* - fail only after n calls to write()
* - capture stream write() calls
* *
* Decide how to test on recovery (using checkpoint_stress technique?), implement. * Decide how to test on recovery (using checkpoint_stress technique?), implement.
* *
* Consider USE_PUTS:
* - no new inames
* - no test for old names deleted
*
*/ */
@ -67,6 +65,7 @@ int NUM_DBS=5;
int NUM_ROWS=100000; int NUM_ROWS=100000;
int CHECK_RESULTS=0; int CHECK_RESULTS=0;
int USE_PUTS=0; int USE_PUTS=0;
int INDUCE_ENOSPC=0;
enum {MAGIC=311}; enum {MAGIC=311};
@ -78,6 +77,9 @@ int count_temp(char * dirname);
void get_inames(DBT* inames, DB** dbs); void get_inames(DBT* inames, DB** dbs);
int verify_file(char * dirname, char * filename); int verify_file(char * dirname, char * filename);
void assert_inames_missing(DBT* inames); void assert_inames_missing(DBT* inames);
ssize_t bad_write(int, const void *, size_t);
// return number of temp files // return number of temp files
int int
@ -146,6 +148,11 @@ assert_inames_missing(DBT* inames) {
} }
} }
ssize_t
bad_write(int UU(fd), const void * UU(src), size_t UU(n)) {
errno= ENOSPC;
return -1;
}
#if 0 #if 0
@ -422,6 +429,13 @@ static void test_loader(enum test_type t, DB **dbs)
r = loader->close(loader); r = loader->close(loader);
assert(r); // not defined what close() returns when poll function returns non-zero assert(r); // not defined what close() returns when poll function returns non-zero
} }
else if (t == enospc) {
r = db_env_set_func_write(bad_write);
CKERR(r);
printf("closing, but expecting failure from enospc\n");
r = loader->close(loader);
assert(r);
}
else { else {
printf("aborting loader"); fflush(stdout); printf("aborting loader"); fflush(stdout);
r = loader->abort(loader); r = loader->abort(loader);
@ -516,6 +530,10 @@ int test_main(int argc, char * const *argv) {
} }
if (verbose) printf("\n\nTesting loader with loader close and txn abort\n"); if (verbose) printf("\n\nTesting loader with loader close and txn abort\n");
run_test(abort_txn); run_test(abort_txn);
if (INDUCE_ENOSPC) {
if (verbose) printf("\n\nTesting loader with enospc induced during loader close\n");
run_test(enospc);
}
return 0; return 0;
} }
@ -555,6 +573,9 @@ static void do_args(int argc, char * const argv[]) {
} else if (strcmp(argv[0], "-p")==0) { } else if (strcmp(argv[0], "-p")==0) {
USE_PUTS = LOADER_USE_PUTS; USE_PUTS = LOADER_USE_PUTS;
printf("Using puts\n"); printf("Using puts\n");
} else if (strcmp(argv[0], "-e")==0) {
INDUCE_ENOSPC = 1;
printf("Using puts\n");
} else { } else {
fprintf(stderr, "Unknown arg: %s\n", argv[0]); fprintf(stderr, "Unknown arg: %s\n", argv[0]);
resultcode=1; resultcode=1;