aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-06-30 19:18:28 +0000
committerNick Mathewson <nickm@torproject.org>2007-06-30 19:18:28 +0000
commit8bebff3deb8a71a2b31f3cbfa2b686d4b25c9e76 (patch)
treec4ac45306a3cfb37232ab0365e619c235f4889fd /src
parent25a11bf8aaeb216e0a62e10c58180acba80a948d (diff)
downloadtor-8bebff3deb8a71a2b31f3cbfa2b686d4b25c9e76.tar
tor-8bebff3deb8a71a2b31f3cbfa2b686d4b25c9e76.tar.gz
r13568@catbus: nickm | 2007-06-30 15:18:18 -0400
allow test_threads() to time out svn:r10711
Diffstat (limited to 'src')
-rw-r--r--src/or/test.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/or/test.c b/src/or/test.c
index 7a415d81e..80a9c5710 100644
--- a/src/or/test.c
+++ b/src/or/test.c
@@ -1403,7 +1403,8 @@ static void
test_threads(void)
{
char *s1, *s2;
- int done = 0;
+ int done = 0, timedout = 0;
+ time_t started;
#ifndef TOR_IS_MULTITHREADED
/* Skip this test if we aren't threading. We should be threading most
* everywhere by now. */
@@ -1422,16 +1423,26 @@ test_threads(void)
spawn_func(_thread_test_func, s2);
tor_mutex_release(_thread_test_start2);
tor_mutex_release(_thread_test_start1);
+ started = time(NULL);
while (!done) {
tor_mutex_acquire(_thread_test_mutex);
strmap_assert_ok(_thread_test_strmap);
if (strmap_get(_thread_test_strmap, "thread 1") &&
- strmap_get(_thread_test_strmap, "thread 2"))
+ strmap_get(_thread_test_strmap, "thread 2")) {
done = 1;
+ } else if (time(NULL) > started + 10) {
+ timedout = done = 1;
+ }
tor_mutex_release(_thread_test_mutex);
}
tor_mutex_free(_thread_test_mutex);
+ if (timedout) {
+ test_assert(strmap_get(_thread_test_strmap, "thread 1"));
+ test_assert(strmap_get(_thread_test_strmap, "thread 2"));
+ test_assert(!timedout);
+ }
+
/* different thread IDs. */
test_assert(strcmp(strmap_get(_thread_test_strmap, "thread 1"),
strmap_get(_thread_test_strmap, "thread 2")));