[tor-commits] [tor/master] Add get_fname_rnd for unit tests that want a unique path every time
nickm at torproject.org
nickm at torproject.org
Mon Nov 7 21:31:50 UTC 2016
commit 77e1d660ee5b8e2beae12f3de543d19009aaa8ac
Author: teor <teor2345 at gmail.com>
Date: Wed Nov 2 14:14:19 2016 +1100
Add get_fname_rnd for unit tests that want a unique path every time
---
src/test/test.h | 1 +
src/test/testing_common.c | 12 ++++++++++++
2 files changed, 13 insertions(+)
diff --git a/src/test/test.h b/src/test/test.h
index 770f403..25336ac 100644
--- a/src/test/test.h
+++ b/src/test/test.h
@@ -73,6 +73,7 @@
{print_ = (I64_PRINTF_TYPE) value_;}, {}, TT_EXIT_TEST_FUNCTION)
const char *get_fname(const char *name);
+const char *get_fname_rnd(const char *name);
struct crypto_pk_t *pk_generate(int idx);
#define US2_CONCAT_2__(a, b) a ## __ ## b
diff --git a/src/test/testing_common.c b/src/test/testing_common.c
index e28e3dd..1eae07e 100644
--- a/src/test/testing_common.c
+++ b/src/test/testing_common.c
@@ -125,6 +125,18 @@ get_fname(const char *name)
return get_fname_suffix(name, NULL);
}
+/** Return a filename with a random suffix, relative to our testing temporary
+ * directory. If name is NULL, return the name of the testing temporary
+ * directory, without any suffix. */
+const char *
+get_fname_rnd(const char *name)
+{
+ char rnd[256], rnd32[256];
+ crypto_rand(rnd, RAND_PATH_BYTES);
+ base32_encode(rnd32, sizeof(rnd32), rnd, RAND_PATH_BYTES);
+ return get_fname_suffix(name, rnd32);
+}
+
/* Remove a directory and all of its subdirectories */
static void
rm_rf(const char *dir)
More information about the tor-commits
mailing list