X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=test%2Fsetup.cpp;h=8ee8bda09a6ec9a1f9167dd207d644f8b3f3c5bc;hb=92d18858b417309f6bdee6bce464a4f3d6a375fd;hp=22c7c2ada9cfc4060aa1c610f0dca73bb3df034d;hpb=9eeee02fddffb336454a6c08c700bfeb2758756e;p=awesomized%2Flibmemcached diff --git a/test/setup.cpp b/test/setup.cpp index 22c7c2ad..8ee8bda0 100644 --- a/test/setup.cpp +++ b/test/setup.cpp @@ -8,7 +8,9 @@ #include #include #include -#include +#if HAVE_UNISTD_H +# include +#endif static void sigchld(int, siginfo_t *si, void *) { switch (si->si_code) { @@ -59,6 +61,7 @@ static inline void setup_signals() { # define LSAN_OPTIONS \ "suppressions=" SOURCES_ROOT "/test/LeakSanitizer.suppressions," \ "" + static inline void setup_asan(char **argv) { const auto set = getenv("ASAN_OPTIONS"); @@ -82,6 +85,24 @@ static inline void setup_lsan(char **argv) { # define setup_lsan(a) (void) a #endif +#if HAVE_TSAN +# define TSAN_OPTIONS \ + "abort_on_error=0," \ + "halt_on_error=0" \ + "" +static inline void setup_tsan(char **argv) { + const auto set = getenv("TSAN_OPTIONS"); + + if (!set || !*set) { + SET_ENV_EX(tsan, "TSAN_OPTIONS", TSAN_OPTIONS, 0); + execvp(argv[0], argv); + perror("exec()"); + } +} +#else +# define setup_tsan(a) (void) a +#endif + #if LIBMEMCACHED_WITH_SASL_SUPPORT static inline void setup_sasl() { SET_ENV_EX(sasl_pwdb, "MEMCACHED_SASL_PWDB", LIBMEMCACHED_WITH_SASL_PWDB, 0); @@ -100,6 +121,7 @@ int setup(int &, char ***argv) { setup_random(); setup_asan(*argv); setup_lsan(*argv); + setup_tsan(*argv); setup_sasl(); return 0;