xref: /aosp_15_r20/external/llvm-libc/test/src/stdio/setbuf_test.cpp (revision 71db0c75aadcf003ffe3238005f61d7618a3fead)
1*71db0c75SAndroid Build Coastguard Worker //===-- Unittests for setbuf ----------------------------------------------===//
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 "hdr/stdio_macros.h"
10*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/fclose.h"
11*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/fopen.h"
12*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/fread.h"
13*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/fwrite.h"
14*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/setbuf.h"
15*71db0c75SAndroid Build Coastguard Worker #include "src/stdio/ungetc.h"
16*71db0c75SAndroid Build Coastguard Worker #include "test/UnitTest/Test.h"
17*71db0c75SAndroid Build Coastguard Worker 
TEST(LlvmLibcSetbufTest,DefaultBufsize)18*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcSetbufTest, DefaultBufsize) {
19*71db0c75SAndroid Build Coastguard Worker   // The idea in this test is to change the buffer after opening a file and
20*71db0c75SAndroid Build Coastguard Worker   // ensure that read and write work as expected.
21*71db0c75SAndroid Build Coastguard Worker   constexpr char FILENAME[] = "testdata/setbuf_test_default_bufsize.test";
22*71db0c75SAndroid Build Coastguard Worker   ::FILE *file = LIBC_NAMESPACE::fopen(FILENAME, "w");
23*71db0c75SAndroid Build Coastguard Worker   ASSERT_FALSE(file == nullptr);
24*71db0c75SAndroid Build Coastguard Worker   char buffer[BUFSIZ];
25*71db0c75SAndroid Build Coastguard Worker   LIBC_NAMESPACE::setbuf(file, buffer);
26*71db0c75SAndroid Build Coastguard Worker   constexpr char CONTENT[] = "abcdef";
27*71db0c75SAndroid Build Coastguard Worker   constexpr size_t CONTENT_SIZE = sizeof(CONTENT);
28*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(CONTENT_SIZE,
29*71db0c75SAndroid Build Coastguard Worker             LIBC_NAMESPACE::fwrite(CONTENT, 1, CONTENT_SIZE, file));
30*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(0, LIBC_NAMESPACE::fclose(file));
31*71db0c75SAndroid Build Coastguard Worker 
32*71db0c75SAndroid Build Coastguard Worker   file = LIBC_NAMESPACE::fopen(FILENAME, "r");
33*71db0c75SAndroid Build Coastguard Worker   LIBC_NAMESPACE::setbuf(file, buffer);
34*71db0c75SAndroid Build Coastguard Worker   ASSERT_FALSE(file == nullptr);
35*71db0c75SAndroid Build Coastguard Worker   char data[CONTENT_SIZE];
36*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fread(&data, 1, CONTENT_SIZE, file), CONTENT_SIZE);
37*71db0c75SAndroid Build Coastguard Worker   ASSERT_STREQ(CONTENT, data);
38*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(0, LIBC_NAMESPACE::fclose(file));
39*71db0c75SAndroid Build Coastguard Worker }
40*71db0c75SAndroid Build Coastguard Worker 
TEST(LlvmLibcSetbufTest,NullBuffer)41*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcSetbufTest, NullBuffer) {
42*71db0c75SAndroid Build Coastguard Worker   // The idea in this test is that we set a null buffer and ensure that
43*71db0c75SAndroid Build Coastguard Worker   // everything works correctly.
44*71db0c75SAndroid Build Coastguard Worker   constexpr char FILENAME[] = "testdata/setbuf_test_null_buffer.test";
45*71db0c75SAndroid Build Coastguard Worker   ::FILE *file = LIBC_NAMESPACE::fopen(FILENAME, "w");
46*71db0c75SAndroid Build Coastguard Worker   ASSERT_FALSE(file == nullptr);
47*71db0c75SAndroid Build Coastguard Worker   LIBC_NAMESPACE::setbuf(file, nullptr);
48*71db0c75SAndroid Build Coastguard Worker   constexpr char CONTENT[] = "abcdef";
49*71db0c75SAndroid Build Coastguard Worker   constexpr size_t CONTENT_SIZE = sizeof(CONTENT);
50*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(CONTENT_SIZE,
51*71db0c75SAndroid Build Coastguard Worker             LIBC_NAMESPACE::fwrite(CONTENT, 1, CONTENT_SIZE, file));
52*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(0, LIBC_NAMESPACE::fclose(file));
53*71db0c75SAndroid Build Coastguard Worker 
54*71db0c75SAndroid Build Coastguard Worker   file = LIBC_NAMESPACE::fopen(FILENAME, "r");
55*71db0c75SAndroid Build Coastguard Worker   LIBC_NAMESPACE::setbuf(file, nullptr);
56*71db0c75SAndroid Build Coastguard Worker   ASSERT_FALSE(file == nullptr);
57*71db0c75SAndroid Build Coastguard Worker   char data[CONTENT_SIZE];
58*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fread(&data, 1, CONTENT_SIZE, file), CONTENT_SIZE);
59*71db0c75SAndroid Build Coastguard Worker   ASSERT_STREQ(CONTENT, data);
60*71db0c75SAndroid Build Coastguard Worker 
61*71db0c75SAndroid Build Coastguard Worker   // Ensure that ungetc also works.
62*71db0c75SAndroid Build Coastguard Worker   char unget_char = 'z';
63*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(int(unget_char), LIBC_NAMESPACE::ungetc(unget_char, file));
64*71db0c75SAndroid Build Coastguard Worker   char c;
65*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(LIBC_NAMESPACE::fread(&c, 1, 1, file), size_t(1));
66*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(c, unget_char);
67*71db0c75SAndroid Build Coastguard Worker 
68*71db0c75SAndroid Build Coastguard Worker   ASSERT_EQ(0, LIBC_NAMESPACE::fclose(file));
69*71db0c75SAndroid Build Coastguard Worker }
70