[tor-commits] [tor/master] Use read_all() to read messages from spawn_background

nickm at torproject.org nickm at torproject.org
Thu May 5 03:43:30 UTC 2011


commit d8cb4f9f0ce075daf4469db18218901f3a720282
Author: Nick Mathewson <nickm at torproject.org>
Date:   Wed May 4 23:32:18 2011 -0400

    Use read_all() to read messages from spawn_background
    
    Using read() is an invitation to get some of the data you want, not all.
    
    Possible fix for bug 2462
---
 src/test/test_util.c |    4 ++--
 1 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/src/test/test_util.c b/src/test/test_util.c
index 25fd51c..efbc47b 100644
--- a/src/test/test_util.c
+++ b/src/test/test_util.c
@@ -1367,7 +1367,7 @@ run_util_spawn_background(const char *argv[], const char *expected_out,
   pid = retval;
 
   /* Check stdout */
-  pos = read(stdout_pipe, stdout_buf, sizeof(stdout_buf) - 1);
+  pos = read_all(stdout_pipe, stdout_buf, sizeof(stdout_buf) - 1, 0);
   stdout_buf[pos] = '\0';
   tt_int_op(pos, ==, strlen(expected_out));
   tt_str_op(stdout_buf, ==, expected_out);
@@ -1381,7 +1381,7 @@ run_util_spawn_background(const char *argv[], const char *expected_out,
   tt_assert(!WIFSTOPPED(stat_loc));
 
   /* Check stderr */
-  pos = read(stderr_pipe, stderr_buf, sizeof(stderr_buf) - 1);
+  pos = read_all(stderr_pipe, stderr_buf, sizeof(stderr_buf) - 1, 0);
   stderr_buf[pos] = '\0';
   tt_int_op(pos, ==, strlen(expected_err));
   tt_str_op(stderr_buf, ==, expected_err);



More information about the tor-commits mailing list