xref: /netbsd-src/tests/lib/libc/stdio/t_fflush.c (revision 1c183744f50e4c9727c34d8410c5322745937ddd)
1*1c183744Sjruoho /*	$NetBSD: t_fflush.c,v 1.1 2011/09/11 05:15:55 jruoho Exp $ */
2*1c183744Sjruoho 
3*1c183744Sjruoho /*-
4*1c183744Sjruoho  * Copyright (c) 2011 The NetBSD Foundation, Inc.
5*1c183744Sjruoho  * All rights reserved.
6*1c183744Sjruoho  *
7*1c183744Sjruoho  * This code is derived from software contributed to The NetBSD Foundation
8*1c183744Sjruoho  * by Jukka Ruohonen.
9*1c183744Sjruoho  *
10*1c183744Sjruoho  * Redistribution and use in source and binary forms, with or without
11*1c183744Sjruoho  * modification, are permitted provided that the following conditions
12*1c183744Sjruoho  * are met:
13*1c183744Sjruoho  * 1. Redistributions of source code must retain the above copyright
14*1c183744Sjruoho  *    notice, this list of conditions and the following disclaimer.
15*1c183744Sjruoho  * 2. Redistributions in binary form must reproduce the above copyright
16*1c183744Sjruoho  *    notice, this list of conditions and the following disclaimer in the
17*1c183744Sjruoho  *    documentation and/or other materials provided with the distribution.
18*1c183744Sjruoho  *
19*1c183744Sjruoho  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20*1c183744Sjruoho  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21*1c183744Sjruoho  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22*1c183744Sjruoho  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23*1c183744Sjruoho  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24*1c183744Sjruoho  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25*1c183744Sjruoho  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26*1c183744Sjruoho  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27*1c183744Sjruoho  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28*1c183744Sjruoho  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29*1c183744Sjruoho  * POSSIBILITY OF SUCH DAMAGE.
30*1c183744Sjruoho  */
31*1c183744Sjruoho #include <sys/cdefs.h>
32*1c183744Sjruoho __RCSID("$NetBSD: t_fflush.c,v 1.1 2011/09/11 05:15:55 jruoho Exp $");
33*1c183744Sjruoho 
34*1c183744Sjruoho #include <atf-c.h>
35*1c183744Sjruoho #include <errno.h>
36*1c183744Sjruoho #include <stdio.h>
37*1c183744Sjruoho #include <unistd.h>
38*1c183744Sjruoho 
39*1c183744Sjruoho static const char *path = "fflush";
40*1c183744Sjruoho 
41*1c183744Sjruoho ATF_TC_WITH_CLEANUP(fflush_err);
ATF_TC_HEAD(fflush_err,tc)42*1c183744Sjruoho ATF_TC_HEAD(fflush_err, tc)
43*1c183744Sjruoho {
44*1c183744Sjruoho 	atf_tc_set_md_var(tc, "descr", "Test errors from fflush(3)");
45*1c183744Sjruoho }
46*1c183744Sjruoho 
ATF_TC_BODY(fflush_err,tc)47*1c183744Sjruoho ATF_TC_BODY(fflush_err, tc)
48*1c183744Sjruoho {
49*1c183744Sjruoho 	FILE *f;
50*1c183744Sjruoho 
51*1c183744Sjruoho 	f = fopen(path, "w");
52*1c183744Sjruoho 
53*1c183744Sjruoho 	ATF_REQUIRE(f != NULL);
54*1c183744Sjruoho 	ATF_REQUIRE(fflush(NULL) == 0);
55*1c183744Sjruoho 	ATF_REQUIRE(fclose(f) == 0);
56*1c183744Sjruoho 
57*1c183744Sjruoho 	f = fopen(path, "r");
58*1c183744Sjruoho 	ATF_REQUIRE(f != NULL);
59*1c183744Sjruoho 
60*1c183744Sjruoho 	/*
61*1c183744Sjruoho 	 * In NetBSD the call should fail if the supplied
62*1c183744Sjruoho 	 * parameteris not an open stream or the stream is
63*1c183744Sjruoho 	 * not open for writing.
64*1c183744Sjruoho 	 */
65*1c183744Sjruoho 	errno = 0;
66*1c183744Sjruoho 	ATF_REQUIRE_ERRNO(EBADF, fflush(f) == EOF);
67*1c183744Sjruoho 
68*1c183744Sjruoho 	ATF_REQUIRE(fclose(f) == 0);
69*1c183744Sjruoho 
70*1c183744Sjruoho 	errno = 0;
71*1c183744Sjruoho 	ATF_REQUIRE_ERRNO(EBADF, fflush(f) == EOF);
72*1c183744Sjruoho 
73*1c183744Sjruoho 	(void)unlink(path);
74*1c183744Sjruoho }
75*1c183744Sjruoho 
ATF_TC_CLEANUP(fflush_err,tc)76*1c183744Sjruoho ATF_TC_CLEANUP(fflush_err, tc)
77*1c183744Sjruoho {
78*1c183744Sjruoho 	(void)unlink(path);
79*1c183744Sjruoho }
80*1c183744Sjruoho 
81*1c183744Sjruoho ATF_TC_WITH_CLEANUP(fflush_seek);
ATF_TC_HEAD(fflush_seek,tc)82*1c183744Sjruoho ATF_TC_HEAD(fflush_seek, tc)
83*1c183744Sjruoho {
84*1c183744Sjruoho 	atf_tc_set_md_var(tc, "descr", "Test file offsets with fflush(3)");
85*1c183744Sjruoho }
86*1c183744Sjruoho 
ATF_TC_BODY(fflush_seek,tc)87*1c183744Sjruoho ATF_TC_BODY(fflush_seek, tc)
88*1c183744Sjruoho {
89*1c183744Sjruoho 	char buf[12];
90*1c183744Sjruoho 	int fd = -1;
91*1c183744Sjruoho 	FILE *f;
92*1c183744Sjruoho 
93*1c183744Sjruoho 	/*
94*1c183744Sjruoho 	 * IEEE Std 1003.1-2008:
95*1c183744Sjruoho 	 *
96*1c183744Sjruoho 	 * "For a stream open for reading, if the file
97*1c183744Sjruoho 	 *  is not already at EOF, and the file is one
98*1c183744Sjruoho 	 *  capable of seeking, the file offset of the
99*1c183744Sjruoho 	 *  underlying open file description shall be
100*1c183744Sjruoho 	 *  adjusted so that the next operation on the
101*1c183744Sjruoho 	 *  open file description deals with the byte
102*1c183744Sjruoho 	 *  after the last one read from or written to
103*1c183744Sjruoho 	 *  the stream being flushed."
104*1c183744Sjruoho 	 */
105*1c183744Sjruoho 	f = fopen(path, "w");
106*1c183744Sjruoho 	ATF_REQUIRE(f != NULL);
107*1c183744Sjruoho 
108*1c183744Sjruoho 	ATF_REQUIRE(fwrite("garbage", 1, 7, f) == 7);
109*1c183744Sjruoho 	ATF_REQUIRE(fclose(f) == 0);
110*1c183744Sjruoho 
111*1c183744Sjruoho 	f = fopen(path, "r+");
112*1c183744Sjruoho 	ATF_REQUIRE(f != NULL);
113*1c183744Sjruoho 
114*1c183744Sjruoho 	fd = fileno(f);
115*1c183744Sjruoho 	ATF_REQUIRE(fd != -1);
116*1c183744Sjruoho 
117*1c183744Sjruoho 	ATF_REQUIRE(fread(buf, 1, 3, f) == 3);
118*1c183744Sjruoho 	ATF_REQUIRE(fflush(f) == 0);
119*1c183744Sjruoho 	ATF_REQUIRE(fseek(f, 0, SEEK_CUR) == 0);
120*1c183744Sjruoho 
121*1c183744Sjruoho 	/*
122*1c183744Sjruoho 	 * Verify that the offsets are right and that
123*1c183744Sjruoho 	 * a read operation resumes at the correct location.
124*1c183744Sjruoho 	 */
125*1c183744Sjruoho 	ATF_REQUIRE(ftell(f) == 3);
126*1c183744Sjruoho 	ATF_REQUIRE(lseek(fd, 0, SEEK_CUR) == 3);
127*1c183744Sjruoho 	ATF_REQUIRE(fgetc(f) == 'b');
128*1c183744Sjruoho 
129*1c183744Sjruoho 	ATF_REQUIRE(fclose(f) == 0);
130*1c183744Sjruoho 	ATF_REQUIRE(unlink(path) == 0);
131*1c183744Sjruoho }
132*1c183744Sjruoho 
ATF_TC_CLEANUP(fflush_seek,tc)133*1c183744Sjruoho ATF_TC_CLEANUP(fflush_seek, tc)
134*1c183744Sjruoho {
135*1c183744Sjruoho 	(void)unlink(path);
136*1c183744Sjruoho }
137*1c183744Sjruoho 
138*1c183744Sjruoho ATF_TC_WITH_CLEANUP(fpurge_err);
ATF_TC_HEAD(fpurge_err,tc)139*1c183744Sjruoho ATF_TC_HEAD(fpurge_err, tc)
140*1c183744Sjruoho {
141*1c183744Sjruoho 	atf_tc_set_md_var(tc, "descr", "Test errors from fpurge(3)");
142*1c183744Sjruoho }
143*1c183744Sjruoho 
ATF_TC_BODY(fpurge_err,tc)144*1c183744Sjruoho ATF_TC_BODY(fpurge_err, tc)
145*1c183744Sjruoho {
146*1c183744Sjruoho 	FILE *f;
147*1c183744Sjruoho 
148*1c183744Sjruoho 	f = fopen(path, "w");
149*1c183744Sjruoho 	ATF_REQUIRE(f != NULL);
150*1c183744Sjruoho 	ATF_REQUIRE(fclose(f) == 0);
151*1c183744Sjruoho 
152*1c183744Sjruoho 	errno = 0;
153*1c183744Sjruoho 	ATF_REQUIRE_ERRNO(EBADF, fpurge(f) == EOF);
154*1c183744Sjruoho 
155*1c183744Sjruoho 	(void)unlink(path);
156*1c183744Sjruoho }
157*1c183744Sjruoho 
ATF_TC_CLEANUP(fpurge_err,tc)158*1c183744Sjruoho ATF_TC_CLEANUP(fpurge_err, tc)
159*1c183744Sjruoho {
160*1c183744Sjruoho 	(void)unlink(path);
161*1c183744Sjruoho }
162*1c183744Sjruoho 
ATF_TP_ADD_TCS(tp)163*1c183744Sjruoho ATF_TP_ADD_TCS(tp)
164*1c183744Sjruoho {
165*1c183744Sjruoho 
166*1c183744Sjruoho 	ATF_TP_ADD_TC(tp, fflush_err);
167*1c183744Sjruoho 	ATF_TP_ADD_TC(tp, fflush_seek);
168*1c183744Sjruoho 	ATF_TP_ADD_TC(tp, fpurge_err);
169*1c183744Sjruoho 
170*1c183744Sjruoho 	return atf_no_error();
171*1c183744Sjruoho }
172