xref: /aosp_15_r20/external/llvm-libc/test/src/stdio/fopencookie_test.cpp (revision 71db0c75aadcf003ffe3238005f61d7618a3fead)
1*71db0c75SAndroid Build Coastguard Worker //===-- Unittests for the fopencookie function ----------------------------===//
2*71db0c75SAndroid Build Coastguard Worker //
3*71db0c75SAndroid Build Coastguard Worker // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*71db0c75SAndroid Build Coastguard Worker // See https://llvm.org/LICENSE.txt for license information.
5*71db0c75SAndroid Build Coastguard Worker // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*71db0c75SAndroid Build Coastguard Worker //
7*71db0c75SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
8*71db0c75SAndroid Build Coastguard Worker 
9*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/clearerr.h"
10*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/fclose.h"
11*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/feof.h"
12*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/ferror.h"
13*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/fflush.h"
14*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/fopencookie.h"
15*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/fread.h"
16*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/fseek.h"
17*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/fwrite.h"
18*71db0c75SAndroid Build Coastguard Worker #include "test/UnitTest/MemoryMatcher.h"
19*71db0c75SAndroid Build Coastguard Worker #include "test/UnitTest/Test.h"
20*71db0c75SAndroid Build Coastguard Worker 
21*71db0c75SAndroid Build Coastguard Worker #include "hdr/stdio_macros.h"
22*71db0c75SAndroid Build Coastguard Worker #include "hdr/types/size_t.h"
23*71db0c75SAndroid Build Coastguard Worker #include "src/errno/libc_errno.h"
24*71db0c75SAndroid Build Coastguard Worker 
25*71db0c75SAndroid Build Coastguard Worker using MemoryView = LIBC_NAMESPACE::testing::MemoryView;
26*71db0c75SAndroid Build Coastguard Worker 
27*71db0c75SAndroid Build Coastguard Worker struct StringStream {
28*71db0c75SAndroid Build Coastguard Worker   char *buf;
29*71db0c75SAndroid Build Coastguard Worker   size_t bufsize; // Size of buf
30*71db0c75SAndroid Build Coastguard Worker   size_t endpos;  // 1 more than current fill size
31*71db0c75SAndroid Build Coastguard Worker   size_t offset;  // Current read/write location
32*71db0c75SAndroid Build Coastguard Worker };
33*71db0c75SAndroid Build Coastguard Worker 
write_ss(void * cookie,const char * buf,size_t size)34*71db0c75SAndroid Build Coastguard Worker ssize_t write_ss(void *cookie, const char *buf, size_t size) {
35*71db0c75SAndroid Build Coastguard Worker   auto *ss = reinterpret_cast<StringStream *>(cookie);
36*71db0c75SAndroid Build Coastguard Worker   if (ss->offset + size > ss->bufsize)
37*71db0c75SAndroid Build Coastguard Worker     ss->buf =
38*71db0c75SAndroid Build Coastguard Worker         reinterpret_cast<char *>(realloc(ss->buf, (ss->offset + size) * 2));
39*71db0c75SAndroid Build Coastguard Worker   for (size_t i = 0; i < size; ++i, ss->offset += 1)
40*71db0c75SAndroid Build Coastguard Worker     ss->buf[ss->offset] = buf[i];
41*71db0c75SAndroid Build Coastguard Worker   if (ss->offset > ss->endpos)
42*71db0c75SAndroid Build Coastguard Worker     ss->endpos = ss->offset;
43*71db0c75SAndroid Build Coastguard Worker   return size;
44*71db0c75SAndroid Build Coastguard Worker }
45*71db0c75SAndroid Build Coastguard Worker 
read_ss(void * cookie,char * buf,size_t size)46*71db0c75SAndroid Build Coastguard Worker ssize_t read_ss(void *cookie, char *buf, size_t size) {
47*71db0c75SAndroid Build Coastguard Worker   auto *ss = reinterpret_cast<StringStream *>(cookie);
48*71db0c75SAndroid Build Coastguard Worker   ssize_t copysize = size;
49*71db0c75SAndroid Build Coastguard Worker   if (ss->offset + size > ss->endpos) {
50*71db0c75SAndroid Build Coastguard Worker     // You cannot copy more than what you have available.
51*71db0c75SAndroid Build Coastguard Worker     copysize = ss->endpos - ss->offset;
52*71db0c75SAndroid Build Coastguard Worker     if (copysize < 0)
53*71db0c75SAndroid Build Coastguard Worker       copysize = 0; // A seek could have moved offset past the endpos
54*71db0c75SAndroid Build Coastguard Worker   }
55*71db0c75SAndroid Build Coastguard Worker   for (size_t i = 0; i < size_t(copysize); ++i, ++ss->offset)
56*71db0c75SAndroid Build Coastguard Worker     buf[i] = ss->buf[ss->offset];
57*71db0c75SAndroid Build Coastguard Worker   return copysize;
58*71db0c75SAndroid Build Coastguard Worker }
59*71db0c75SAndroid Build Coastguard Worker 
seek_ss(void * cookie,off64_t * offset,int whence)60*71db0c75SAndroid Build Coastguard Worker int seek_ss(void *cookie, off64_t *offset, int whence) {
61*71db0c75SAndroid Build Coastguard Worker   auto *ss = reinterpret_cast<StringStream *>(cookie);
62*71db0c75SAndroid Build Coastguard Worker   off64_t new_offset;
63*71db0c75SAndroid Build Coastguard Worker   if (whence == SEEK_SET) {
64*71db0c75SAndroid Build Coastguard Worker     new_offset = *offset;
65*71db0c75SAndroid Build Coastguard Worker   } else if (whence == SEEK_CUR) {
66*71db0c75SAndroid Build Coastguard Worker     new_offset = *offset + ss->offset;
67*71db0c75SAndroid Build Coastguard Worker   } else if (whence == SEEK_END) {
68*71db0c75SAndroid Build Coastguard Worker     new_offset = *offset + ss->endpos;
69*71db0c75SAndroid Build Coastguard Worker   } else {
70*71db0c75SAndroid Build Coastguard Worker     LIBC_NAMESPACE::libc_errno = EINVAL;
71*71db0c75SAndroid Build Coastguard Worker     return -1;
72*71db0c75SAndroid Build Coastguard Worker   }
73*71db0c75SAndroid Build Coastguard Worker   if (new_offset < 0 || size_t(new_offset) > ss->bufsize)
74*71db0c75SAndroid Build Coastguard Worker     return -1;
75*71db0c75SAndroid Build Coastguard Worker   ss->offset = new_offset;
76*71db0c75SAndroid Build Coastguard Worker   *offset = new_offset;
77*71db0c75SAndroid Build Coastguard Worker   return 0;
78*71db0c75SAndroid Build Coastguard Worker }
79*71db0c75SAndroid Build Coastguard Worker 
close_ss(void * cookie)80*71db0c75SAndroid Build Coastguard Worker int close_ss(void *cookie) {
81*71db0c75SAndroid Build Coastguard Worker   auto *ss = reinterpret_cast<StringStream *>(cookie);
82*71db0c75SAndroid Build Coastguard Worker   free(ss->buf);
83*71db0c75SAndroid Build Coastguard Worker   ss->buf = nullptr;
84*71db0c75SAndroid Build Coastguard Worker   ss->bufsize = ss->endpos = ss->offset = 0;
85*71db0c75SAndroid Build Coastguard Worker   return 0;
86*71db0c75SAndroid Build Coastguard Worker }
87*71db0c75SAndroid Build Coastguard Worker 
88*71db0c75SAndroid Build Coastguard Worker constexpr cookie_io_functions_t STRING_STREAM_FUNCS = {&read_ss, &write_ss,
89*71db0c75SAndroid Build Coastguard Worker                                                        &seek_ss, &close_ss};
90*71db0c75SAndroid Build Coastguard Worker 
TEST(LlvmLibcFOpenCookie,ReadOnlyCookieTest)91*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcFOpenCookie, ReadOnlyCookieTest) {
92*71db0c75SAndroid Build Coastguard Worker   constexpr char CONTENT[] = "Hello,readonly!";
93*71db0c75SAndroid Build Coastguard Worker   auto *ss = reinterpret_cast<StringStream *>(malloc(sizeof(StringStream)));
94*71db0c75SAndroid Build Coastguard Worker   ss->buf = reinterpret_cast<char *>(malloc(sizeof(CONTENT)));
95*71db0c75SAndroid Build Coastguard Worker   ss->bufsize = sizeof(CONTENT);
96*71db0c75SAndroid Build Coastguard Worker   ss->offset = 0;
97*71db0c75SAndroid Build Coastguard Worker   ss->endpos = ss->bufsize;
98*71db0c75SAndroid Build Coastguard Worker   for (size_t i = 0; i < sizeof(CONTENT); ++i)
99*71db0c75SAndroid Build Coastguard Worker     ss->buf[i] = CONTENT[i];
100*71db0c75SAndroid Build Coastguard Worker 
101*71db0c75SAndroid Build Coastguard Worker   ::FILE *f = LIBC_NAMESPACE::fopencookie(ss, "r", STRING_STREAM_FUNCS);
102*71db0c75SAndroid Build Coastguard Worker   ASSERT_TRUE(f != nullptr);
103*71db0c75SAndroid Build Coastguard Worker   char read_data[sizeof(CONTENT)];
104*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(sizeof(CONTENT),
105*71db0c75SAndroid Build Coastguard Worker             LIBC_NAMESPACE::fread(read_data, 1, sizeof(CONTENT), f));
106*71db0c75SAndroid Build Coastguard Worker   ASSERT_STREQ(read_data, CONTENT);
107*71db0c75SAndroid Build Coastguard Worker 
108*71db0c75SAndroid Build Coastguard Worker   // Reading another time should trigger eof.
109*71db0c75SAndroid Build Coastguard Worker   ASSERT_NE(sizeof(CONTENT),
110*71db0c75SAndroid Build Coastguard Worker             LIBC_NAMESPACE::fread(read_data, 1, sizeof(CONTENT), f));
111*71db0c75SAndroid Build Coastguard Worker   ASSERT_NE(LIBC_NAMESPACE::feof(f), 0);
112*71db0c75SAndroid Build Coastguard Worker 
113*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(0, LIBC_NAMESPACE::fseek(f, 0, SEEK_SET));
114*71db0c75SAndroid Build Coastguard Worker   // Should be an error to write.
115*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(size_t(0), LIBC_NAMESPACE::fwrite(CONTENT, 1, sizeof(CONTENT), f));
116*71db0c75SAndroid Build Coastguard Worker   ASSERT_NE(LIBC_NAMESPACE::ferror(f), 0);
117*71db0c75SAndroid Build Coastguard Worker   ASSERT_ERRNO_FAILURE();
118*71db0c75SAndroid Build Coastguard Worker   LIBC_NAMESPACE::libc_errno = 0;
119*71db0c75SAndroid Build Coastguard Worker 
120*71db0c75SAndroid Build Coastguard Worker   LIBC_NAMESPACE::clearerr(f);
121*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::ferror(f), 0);
122*71db0c75SAndroid Build Coastguard Worker 
123*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(0, LIBC_NAMESPACE::fclose(f));
124*71db0c75SAndroid Build Coastguard Worker   free(ss);
125*71db0c75SAndroid Build Coastguard Worker }
126*71db0c75SAndroid Build Coastguard Worker 
TEST(LlvmLibcFOpenCookie,WriteOnlyCookieTest)127*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcFOpenCookie, WriteOnlyCookieTest) {
128*71db0c75SAndroid Build Coastguard Worker   size_t INIT_BUFSIZE = 32;
129*71db0c75SAndroid Build Coastguard Worker   auto *ss = reinterpret_cast<StringStream *>(malloc(sizeof(StringStream)));
130*71db0c75SAndroid Build Coastguard Worker   ss->buf = reinterpret_cast<char *>(malloc(INIT_BUFSIZE));
131*71db0c75SAndroid Build Coastguard Worker   ss->bufsize = INIT_BUFSIZE;
132*71db0c75SAndroid Build Coastguard Worker   ss->offset = 0;
133*71db0c75SAndroid Build Coastguard Worker   ss->endpos = 0;
134*71db0c75SAndroid Build Coastguard Worker 
135*71db0c75SAndroid Build Coastguard Worker   ::FILE *f = LIBC_NAMESPACE::fopencookie(ss, "w", STRING_STREAM_FUNCS);
136*71db0c75SAndroid Build Coastguard Worker   ASSERT_TRUE(f != nullptr);
137*71db0c75SAndroid Build Coastguard Worker 
138*71db0c75SAndroid Build Coastguard Worker   constexpr char WRITE_DATA[] = "Hello,writeonly!";
139*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(sizeof(WRITE_DATA),
140*71db0c75SAndroid Build Coastguard Worker             LIBC_NAMESPACE::fwrite(WRITE_DATA, 1, sizeof(WRITE_DATA), f));
141*71db0c75SAndroid Build Coastguard Worker   // Flushing will ensure the data to be written to the string stream.
142*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(0, LIBC_NAMESPACE::fflush(f));
143*71db0c75SAndroid Build Coastguard Worker   ASSERT_STREQ(WRITE_DATA, ss->buf);
144*71db0c75SAndroid Build Coastguard Worker 
145*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(0, LIBC_NAMESPACE::fseek(f, 0, SEEK_SET));
146*71db0c75SAndroid Build Coastguard Worker   char read_data[sizeof(WRITE_DATA)];
147*71db0c75SAndroid Build Coastguard Worker   // Should be an error to read.
148*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(size_t(0),
149*71db0c75SAndroid Build Coastguard Worker             LIBC_NAMESPACE::fread(read_data, 1, sizeof(WRITE_DATA), f));
150*71db0c75SAndroid Build Coastguard Worker   ASSERT_NE(LIBC_NAMESPACE::ferror(f), 0);
151*71db0c75SAndroid Build Coastguard Worker   ASSERT_ERRNO_EQ(EBADF);
152*71db0c75SAndroid Build Coastguard Worker   LIBC_NAMESPACE::libc_errno = 0;
153*71db0c75SAndroid Build Coastguard Worker 
154*71db0c75SAndroid Build Coastguard Worker   LIBC_NAMESPACE::clearerr(f);
155*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::ferror(f), 0);
156*71db0c75SAndroid Build Coastguard Worker 
157*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(0, LIBC_NAMESPACE::fclose(f));
158*71db0c75SAndroid Build Coastguard Worker   free(ss);
159*71db0c75SAndroid Build Coastguard Worker }
160*71db0c75SAndroid Build Coastguard Worker 
TEST(LlvmLibcFOpenCookie,AppendOnlyCookieTest)161*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcFOpenCookie, AppendOnlyCookieTest) {
162*71db0c75SAndroid Build Coastguard Worker   constexpr char INITIAL_CONTENT[] = "1234567890987654321";
163*71db0c75SAndroid Build Coastguard Worker   constexpr char WRITE_DATA[] = "append";
164*71db0c75SAndroid Build Coastguard Worker   auto *ss = reinterpret_cast<StringStream *>(malloc(sizeof(StringStream)));
165*71db0c75SAndroid Build Coastguard Worker   ss->buf = reinterpret_cast<char *>(malloc(sizeof(INITIAL_CONTENT)));
166*71db0c75SAndroid Build Coastguard Worker   ss->bufsize = sizeof(INITIAL_CONTENT);
167*71db0c75SAndroid Build Coastguard Worker   ss->offset = ss->bufsize; // We want to open the file in append mode.
168*71db0c75SAndroid Build Coastguard Worker   ss->endpos = ss->bufsize;
169*71db0c75SAndroid Build Coastguard Worker   for (size_t i = 0; i < sizeof(INITIAL_CONTENT); ++i)
170*71db0c75SAndroid Build Coastguard Worker     ss->buf[i] = INITIAL_CONTENT[i];
171*71db0c75SAndroid Build Coastguard Worker 
172*71db0c75SAndroid Build Coastguard Worker   ::FILE *f = LIBC_NAMESPACE::fopencookie(ss, "a", STRING_STREAM_FUNCS);
173*71db0c75SAndroid Build Coastguard Worker   ASSERT_TRUE(f != nullptr);
174*71db0c75SAndroid Build Coastguard Worker 
175*71db0c75SAndroid Build Coastguard Worker   constexpr size_t READ_SIZE = 5;
176*71db0c75SAndroid Build Coastguard Worker   char read_data[READ_SIZE];
177*71db0c75SAndroid Build Coastguard Worker   // This is not a readable file.
178*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fread(read_data, 1, READ_SIZE, f), size_t(0));
179*71db0c75SAndroid Build Coastguard Worker   ASSERT_NE(LIBC_NAMESPACE::ferror(f), 0);
180*71db0c75SAndroid Build Coastguard Worker   ASSERT_ERRNO_FAILURE();
181*71db0c75SAndroid Build Coastguard Worker   LIBC_NAMESPACE::libc_errno = 0;
182*71db0c75SAndroid Build Coastguard Worker 
183*71db0c75SAndroid Build Coastguard Worker   LIBC_NAMESPACE::clearerr(f);
184*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::ferror(f), 0);
185*71db0c75SAndroid Build Coastguard Worker 
186*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fwrite(WRITE_DATA, 1, sizeof(WRITE_DATA), f),
187*71db0c75SAndroid Build Coastguard Worker             sizeof(WRITE_DATA));
188*71db0c75SAndroid Build Coastguard Worker   EXPECT_EQ(LIBC_NAMESPACE::fflush(f), 0);
189*71db0c75SAndroid Build Coastguard Worker   EXPECT_EQ(ss->endpos, sizeof(WRITE_DATA) + sizeof(INITIAL_CONTENT));
190*71db0c75SAndroid Build Coastguard Worker 
191*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fclose(f), 0);
192*71db0c75SAndroid Build Coastguard Worker   free(ss);
193*71db0c75SAndroid Build Coastguard Worker }
194*71db0c75SAndroid Build Coastguard Worker 
TEST(LlvmLibcFOpenCookie,ReadUpdateCookieTest)195*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcFOpenCookie, ReadUpdateCookieTest) {
196*71db0c75SAndroid Build Coastguard Worker   const char INITIAL_CONTENT[] = "1234567890987654321";
197*71db0c75SAndroid Build Coastguard Worker   auto *ss = reinterpret_cast<StringStream *>(malloc(sizeof(StringStream)));
198*71db0c75SAndroid Build Coastguard Worker   ss->buf = reinterpret_cast<char *>(malloc(sizeof(INITIAL_CONTENT)));
199*71db0c75SAndroid Build Coastguard Worker   ss->bufsize = sizeof(INITIAL_CONTENT);
200*71db0c75SAndroid Build Coastguard Worker   ss->offset = 0;
201*71db0c75SAndroid Build Coastguard Worker   ss->endpos = ss->bufsize;
202*71db0c75SAndroid Build Coastguard Worker   for (size_t i = 0; i < sizeof(INITIAL_CONTENT); ++i)
203*71db0c75SAndroid Build Coastguard Worker     ss->buf[i] = INITIAL_CONTENT[i];
204*71db0c75SAndroid Build Coastguard Worker 
205*71db0c75SAndroid Build Coastguard Worker   ::FILE *f = LIBC_NAMESPACE::fopencookie(ss, "r+", STRING_STREAM_FUNCS);
206*71db0c75SAndroid Build Coastguard Worker   ASSERT_TRUE(f != nullptr);
207*71db0c75SAndroid Build Coastguard Worker 
208*71db0c75SAndroid Build Coastguard Worker   constexpr size_t READ_SIZE = sizeof(INITIAL_CONTENT) / 2;
209*71db0c75SAndroid Build Coastguard Worker   char read_data[READ_SIZE];
210*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(READ_SIZE, LIBC_NAMESPACE::fread(read_data, 1, READ_SIZE, f));
211*71db0c75SAndroid Build Coastguard Worker 
212*71db0c75SAndroid Build Coastguard Worker   MemoryView src1(INITIAL_CONTENT, READ_SIZE), dst1(read_data, READ_SIZE);
213*71db0c75SAndroid Build Coastguard Worker   EXPECT_MEM_EQ(src1, dst1);
214*71db0c75SAndroid Build Coastguard Worker 
215*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fseek(f, 0, SEEK_SET), 0);
216*71db0c75SAndroid Build Coastguard Worker   constexpr char WRITE_DATA[] = "hello, file";
217*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(sizeof(WRITE_DATA),
218*71db0c75SAndroid Build Coastguard Worker             LIBC_NAMESPACE::fwrite(WRITE_DATA, 1, sizeof(WRITE_DATA), f));
219*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fflush(f), 0);
220*71db0c75SAndroid Build Coastguard Worker   EXPECT_STREQ(ss->buf, WRITE_DATA);
221*71db0c75SAndroid Build Coastguard Worker 
222*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fclose(f), 0);
223*71db0c75SAndroid Build Coastguard Worker   free(ss);
224*71db0c75SAndroid Build Coastguard Worker }
225*71db0c75SAndroid Build Coastguard Worker 
TEST(LlvmLibcFOpenCookie,WriteUpdateCookieTest)226*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcFOpenCookie, WriteUpdateCookieTest) {
227*71db0c75SAndroid Build Coastguard Worker   constexpr char WRITE_DATA[] = "hello, file";
228*71db0c75SAndroid Build Coastguard Worker   auto *ss = reinterpret_cast<StringStream *>(malloc(sizeof(StringStream)));
229*71db0c75SAndroid Build Coastguard Worker   ss->buf = reinterpret_cast<char *>(malloc(sizeof(WRITE_DATA)));
230*71db0c75SAndroid Build Coastguard Worker   ss->bufsize = sizeof(WRITE_DATA);
231*71db0c75SAndroid Build Coastguard Worker   ss->offset = 0;
232*71db0c75SAndroid Build Coastguard Worker   ss->endpos = 0;
233*71db0c75SAndroid Build Coastguard Worker 
234*71db0c75SAndroid Build Coastguard Worker   ::FILE *f = LIBC_NAMESPACE::fopencookie(ss, "w+", STRING_STREAM_FUNCS);
235*71db0c75SAndroid Build Coastguard Worker   ASSERT_TRUE(f != nullptr);
236*71db0c75SAndroid Build Coastguard Worker 
237*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(sizeof(WRITE_DATA),
238*71db0c75SAndroid Build Coastguard Worker             LIBC_NAMESPACE::fwrite(WRITE_DATA, 1, sizeof(WRITE_DATA), f));
239*71db0c75SAndroid Build Coastguard Worker 
240*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fseek(f, 0, SEEK_SET), 0);
241*71db0c75SAndroid Build Coastguard Worker 
242*71db0c75SAndroid Build Coastguard Worker   char read_data[sizeof(WRITE_DATA)];
243*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fread(read_data, 1, sizeof(read_data), f),
244*71db0c75SAndroid Build Coastguard Worker             sizeof(read_data));
245*71db0c75SAndroid Build Coastguard Worker   EXPECT_STREQ(read_data, WRITE_DATA);
246*71db0c75SAndroid Build Coastguard Worker 
247*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fclose(f), 0);
248*71db0c75SAndroid Build Coastguard Worker   free(ss);
249*71db0c75SAndroid Build Coastguard Worker }
250