diff options
author | Nick Mathewson <nickm@torproject.org> | 2018-09-13 11:45:58 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2018-09-13 11:45:58 -0400 |
commit | c02f2d9eb45786c552dcc33c102e9964d95f66c1 (patch) | |
tree | 8b093a8bba5ebf4eab4dcf3188a88125932b12d6 | |
parent | 198b6354e6c58ab4276461b5215487b8e9c15683 (diff) | |
parent | 73a37d1e547d996515e2a0ffea8331bb535d2841 (diff) | |
download | tor-c02f2d9eb45786c552dcc33c102e9964d95f66c1.tar.gz tor-c02f2d9eb45786c552dcc33c102e9964d95f66c1.zip |
Merge branch 'bug27658_029' into maint-0.2.9
-rw-r--r-- | changes/bug27658 | 6 | ||||
-rw-r--r-- | src/ext/tinytest.c | 12 |
2 files changed, 16 insertions, 2 deletions
diff --git a/changes/bug27658 b/changes/bug27658 new file mode 100644 index 0000000000..8cc0aa4714 --- /dev/null +++ b/changes/bug27658 @@ -0,0 +1,6 @@ + o Minor bugfixes (testing): + - If a unit test running in a subprocess exits abnormally or with a + nonzero status code, treat the test as having failed, even if + the test reported success. Without this fix, memory leaks don't cause + cause the tests to fail, even with LeakSanitizer. Fixes bug 27658; + bugfix on 0.2.2.4-alpha. diff --git a/src/ext/tinytest.c b/src/ext/tinytest.c index 3fb1b39c71..a51cd6011a 100644 --- a/src/ext/tinytest.c +++ b/src/ext/tinytest.c @@ -207,12 +207,20 @@ testcase_run_forked_(const struct testgroup_t *group, r = (int)read(outcome_pipe[0], b, 1); if (r == 0) { printf("[Lost connection!] "); - return 0; + return FAIL; } else if (r != 1) { perror("read outcome from pipe"); } - waitpid(pid, &status, 0); + r = waitpid(pid, &status, 0); close(outcome_pipe[0]); + if (r == -1) { + perror("waitpid"); + return FAIL; + } + if (! WIFEXITED(status) || WEXITSTATUS(status) != 0) { + printf("[did not exit cleanly.]"); + return FAIL; + } return b[0]=='Y' ? OK : (b[0]=='S' ? SKIP : FAIL); } #endif |