summaryrefslogtreecommitdiff
path: root/test/testpipe.c
diff options
context:
space:
mode:
authortrawick <trawick@13f79535-47bb-0310-9956-ffa450edef68>2003-06-05 02:14:08 +0000
committertrawick <trawick@13f79535-47bb-0310-9956-ffa450edef68>2003-06-05 02:14:08 +0000
commit6f30688f19fd33c6c9f80c4a0b0ce6edb9653cda (patch)
treeb52d3ffae88ac64253041bd45417c58ac81322b9 /test/testpipe.c
parentfcecd05dcf38a0e42b8c4b3eb813765a2eb097c3 (diff)
downloadlibapr-6f30688f19fd33c6c9f80c4a0b0ce6edb9653cda.tar.gz
add a testcase to catch the problem seen with PR 20295, where
apr_file_write_full() to pipe with timeout can return EAGAIN PR: 20295 (not fixed just yet) git-svn-id: http://svn.apache.org/repos/asf/apr/apr/trunk@64527 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'test/testpipe.c')
-rw-r--r--test/testpipe.c67
1 files changed, 67 insertions, 0 deletions
diff --git a/test/testpipe.c b/test/testpipe.c
index 14df56e01..98702c0f3 100644
--- a/test/testpipe.c
+++ b/test/testpipe.c
@@ -52,11 +52,15 @@
* <http://www.apache.org/>.
*/
+#include <stdlib.h>
+
#include "test_apr.h"
#include "apr_file_io.h"
#include "apr_errno.h"
#include "apr_general.h"
#include "apr_lib.h"
+#include "apr_thread_proc.h"
+#include "apr_strings.h"
static apr_file_t *readp = NULL;
static apr_file_t *writep = NULL;
@@ -157,6 +161,68 @@ static void read_write_notimeout(CuTest *tc)
CuAssertStrEquals(tc, "this is a test", input);
}
+/* XXX FIXME */
+#ifdef WIN32
+#define EXTENSION ".exe"
+#elif NETWARE
+#define EXTENSION ".nlm"
+#else
+#define EXTENSION
+#endif
+
+static void test_pipe_writefull(CuTest *tc)
+{
+ int iterations = 1000;
+ int i;
+ int bytes_per_iteration = 8000;
+ char *buf = (char *)malloc(bytes_per_iteration);
+ char responsebuf[128];
+ apr_size_t nbytes;
+ int bytes_processed;
+ apr_proc_t proc = {0};
+ apr_procattr_t *procattr;
+ const char *args[2];
+ apr_status_t rv;
+
+ rv = apr_procattr_create(&procattr, p);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ rv = apr_procattr_io_set(procattr, APR_CHILD_BLOCK, APR_CHILD_BLOCK,
+ APR_CHILD_BLOCK);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ rv = apr_procattr_error_check_set(procattr, 1);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ args[0] = "readchild" EXTENSION;
+ args[1] = NULL;
+ rv = apr_proc_create(&proc, "./readchild" EXTENSION, args, NULL, procattr, p);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ rv = apr_file_pipe_timeout_set(proc.in, apr_time_from_sec(10));
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ rv = apr_file_pipe_timeout_set(proc.out, apr_time_from_sec(10));
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ i = iterations;
+ do {
+ rv = apr_file_write_full(proc.in, buf, bytes_per_iteration, NULL);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+ } while (--i);
+
+ free(buf);
+
+ rv = apr_file_close(proc.in);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ nbytes = sizeof(responsebuf);
+ rv = apr_file_read(proc.out, responsebuf, &nbytes);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+ bytes_processed = (int)apr_strtoi64(responsebuf, NULL, 10);
+ CuAssertIntEquals(tc, iterations * bytes_per_iteration, bytes_processed);
+}
+
CuSuite *testpipe(void)
{
CuSuite *suite = CuSuiteNew("Pipes");
@@ -166,6 +232,7 @@ CuSuite *testpipe(void)
SUITE_ADD_TEST(suite, set_timeout);
SUITE_ADD_TEST(suite, read_write);
SUITE_ADD_TEST(suite, read_write_notimeout);
+ SUITE_ADD_TEST(suite, test_pipe_writefull);
return suite;
}