diff options
author | Nick Mathewson <nickm@torproject.org> | 2004-08-11 19:20:24 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2004-08-11 19:20:24 +0000 |
commit | ba7cc463d4f186cc17779c5fbfdcae15e54e37cb (patch) | |
tree | 7d5f923e17b73930b1a1284f9df2b60a7ccec046 | |
parent | 72f85adcbed7a753e988bff7e7ee9b74269576ac (diff) | |
download | tor-ba7cc463d4f186cc17779c5fbfdcae15e54e37cb.tar.gz tor-ba7cc463d4f186cc17779c5fbfdcae15e54e37cb.zip |
Clean up tempdir after finishing unittests; use tor_temp_$PID instead of tor_temp; quit if tor_temp_$PID exists.
svn:r2226
-rw-r--r-- | src/or/test.c | 67 |
1 files changed, 55 insertions, 12 deletions
diff --git a/src/or/test.c b/src/or/test.c index 704d3901ba..68d8e8dc30 100644 --- a/src/or/test.c +++ b/src/or/test.c @@ -11,7 +11,7 @@ /* For mkdir() */ #include <direct.h> #endif - +#include <dirent.h> #include "or.h" #include "../common/test.h" @@ -38,18 +38,60 @@ dump_hex(char *s, int len) } } +static char temp_dir[256]; + void -setup_directory() { - char buf[256]; +setup_directory() +{ + static int is_setup = 0; int r; - sprintf(buf, "/tmp/tor_test"); + if (is_setup) return; + + sprintf(temp_dir, "/tmp/tor_test_%d", (int) getpid()); #ifdef _MSC_VER - r = mkdir(buf); + r = mkdir(temp_dir); #else - r = mkdir(buf, 0700); + r = mkdir(temp_dir, 0700); +#endif + if (r) { + fprintf(stderr, "Can't create directory %s:", temp_dir); + perror(""); + exit(1); + } + is_setup = 1; +} + +const char * +get_fname(const char *name) +{ + static char buf[1024]; + setup_directory(); + sprintf(buf,"%s/%s",temp_dir,name); + return buf; +} + +void +remove_directory() +{ + DIR *dirp; + struct dirent *de; + setup_directory(); + if (!(dirp = opendir(temp_dir))) { + perror("Can't open temporary directory to remove files"); + return; + } + while ((de = readdir(dirp)) != NULL) { + /* Only "." and ".." start with ., since we don't create any dotfiles. */ + if (de->d_name[0] == '.') continue; + if (unlink(get_fname(de->d_name))) { + perror("Error removing file"); + } +#if 0 + printf("==%s\n", de->d_name); #endif - if (r && errno != EEXIST) - fprintf(stderr, "Can't create directory %s", buf); + } + closedir(dirp); + rmdir(temp_dir); } void @@ -75,14 +117,14 @@ test_buffers() { /**** * read_to_buf ****/ - s = open("/tmp/tor_test/data", O_WRONLY|O_CREAT|O_TRUNC, 0600); + s = open(get_fname("data"), O_WRONLY|O_CREAT|O_TRUNC, 0600); for (j=0;j<256;++j) { str[j] = (char)j; } write(s, str, 256); close(s); - s = open("/tmp/tor_test/data", O_RDONLY, 0); + s = open(get_fname("data"), O_RDONLY, 0); eof = 0; i = read_to_buf(s, 10, buf, &eof); test_eq(buf_capacity(buf), 512*1024); @@ -349,10 +391,10 @@ test_crypto() /* File operations: save and load private key */ test_assert(! crypto_pk_write_private_key_to_filename(pk1, - "/tmp/tor_test/pke1y")); + get_fname("pkey1"))); test_assert(! crypto_pk_read_private_key_from_filename(pk2, - "/tmp/tor_test/pke1y")); + get_fname("pkey1"))); test_eq(15, crypto_pk_private_decrypt(pk2, data1, 128, data3, PK_PKCS1_OAEP_PADDING,1)); @@ -933,6 +975,7 @@ main(int c, char**v){ crypto_seed_rng(); setup_directory(); rep_hist_init(); + atexit(remove_directory); // puts("========================== Buffers ========================="); // test_buffers(); |