xref: /openbsd-src/regress/lib/libc/popen/popen.c (revision db3296cf5c1dd9058ceecc3a29fe4aaa0bd26000)
1 /*	$NetBSD: popen.c,v 1.1 1999/09/30 09:23:23 tron Exp $	*/
2 
3 /*-
4  * Copyright (c) 1999 The NetBSD Foundation, Inc.
5  * All rights reserved.
6  *
7  * This code is derived from software contributed to The NetBSD Foundation
8  * by Matthias Scheler.
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions
12  * are met:
13  * 1. Redistributions of source code must retain the above copyright
14  *    notice, this list of conditions and the following disclaimer.
15  * 2. Redistributions in binary form must reproduce the above copyright
16  *    notice, this list of conditions and the following disclaimer in the
17  *    documentation and/or other materials provided with the distribution.
18  * 3. All advertising materials mentioning features or use of this software
19  *    must display the following acknowledgement:
20  *	This product includes software developed by the NetBSD
21  *	Foundation, Inc. and its contributors.
22  * 4. Neither the name of The NetBSD Foundation nor the names of its
23  *    contributors may be used to endorse or promote products derived
24  *    from this software without specific prior written permission.
25  *
26  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
27  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
28  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
30  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
32  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
33  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
34  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
35  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36  * POSSIBILITY OF SUCH DAMAGE.
37  */
38 
39 #include <sys/param.h>
40 
41 #include <errno.h>
42 #include <paths.h>
43 #include <stdio.h>
44 #include <stdlib.h>
45 #include <time.h>
46 #include <unistd.h>
47 
48 #define _PATH_CAT	"/bin/cat"
49 #define BUFSIZE		(640*1024)
50 			/* 640KB ought to be enough for everyone. */
51 #define DATAFILE	"popen.data"
52 
53 int
54 main(int argc, char **argv)
55 {
56 	char *buffer, command[MAXPATHLEN];
57 	int index, in;
58 	FILE *pipe;
59 
60 	if ((buffer = malloc(BUFSIZE*sizeof(char))) == NULL)
61 	    err(1, NULL);
62 
63 	for (index=0; index<BUFSIZE; index++)
64 	    buffer[index]=arc4random();
65 
66 	(void)snprintf(command, sizeof(command), "%s >%s",
67 	               _PATH_CAT, DATAFILE);
68 	if ((pipe = popen(command, "w")) == NULL)
69 	    err(1, "popen write");
70 
71 	if (fwrite(buffer, sizeof(char), BUFSIZE, pipe) != BUFSIZE)
72 	    err(1, "write");
73 
74 	if (pclose(pipe) == -1)
75 	    err(1, "pclose");
76 
77 	(void)snprintf(command, sizeof(command), "%s %s",
78 	               _PATH_CAT, DATAFILE);
79 	if ((pipe = popen(command, "r")) == NULL)
80 	    err(1, "popen read");
81 
82 	index = 0;
83 	while ((in = fgetc(pipe)) != EOF)
84 	    if (index == BUFSIZE) {
85 		errno = EFBIG;
86 		err(1, "read");
87 	    }
88 	    else
89 		if ((char)in != buffer[index++]) {
90 	    	    errno = EINVAL;
91 		    err(1, "read");
92 		}
93 
94 	if (index < BUFSIZE) {
95 	    errno = EIO;
96 	    err(1, "read");
97 	}
98 
99 	if (pclose(pipe) == -1)
100 	    err(1, "pclose");
101 
102 	(void)unlink(DATAFILE);
103 	return 0;
104 }
105