xref: /aosp_15_r20/system/media/audio_utils/tests/fdtostring_tests.cpp (revision b9df5ad1c9ac98a7fefaac271a55f7ae3db05414)
1*b9df5ad1SAndroid Build Coastguard Worker /*
2*b9df5ad1SAndroid Build Coastguard Worker  * Copyright 2018 The Android Open Source Project
3*b9df5ad1SAndroid Build Coastguard Worker  *
4*b9df5ad1SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*b9df5ad1SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*b9df5ad1SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*b9df5ad1SAndroid Build Coastguard Worker  *
8*b9df5ad1SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*b9df5ad1SAndroid Build Coastguard Worker  *
10*b9df5ad1SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*b9df5ad1SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*b9df5ad1SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*b9df5ad1SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*b9df5ad1SAndroid Build Coastguard Worker  * limitations under the License.
15*b9df5ad1SAndroid Build Coastguard Worker  */
16*b9df5ad1SAndroid Build Coastguard Worker 
17*b9df5ad1SAndroid Build Coastguard Worker #include <audio_utils/FdToString.h>
18*b9df5ad1SAndroid Build Coastguard Worker 
19*b9df5ad1SAndroid Build Coastguard Worker #include <signal.h>
20*b9df5ad1SAndroid Build Coastguard Worker #include <chrono>
21*b9df5ad1SAndroid Build Coastguard Worker 
22*b9df5ad1SAndroid Build Coastguard Worker #include <gtest/gtest.h>
23*b9df5ad1SAndroid Build Coastguard Worker 
24*b9df5ad1SAndroid Build Coastguard Worker using namespace android::audio_utils;
25*b9df5ad1SAndroid Build Coastguard Worker 
TEST(audio_utils_fdtostring,basic)26*b9df5ad1SAndroid Build Coastguard Worker TEST(audio_utils_fdtostring, basic) {
27*b9df5ad1SAndroid Build Coastguard Worker     signal(SIGPIPE, SIG_IGN);
28*b9df5ad1SAndroid Build Coastguard Worker     const std::string PREFIX{"aa "};
29*b9df5ad1SAndroid Build Coastguard Worker     const std::string TEST_STRING{"hello world\n"};
30*b9df5ad1SAndroid Build Coastguard Worker 
31*b9df5ad1SAndroid Build Coastguard Worker     auto writer_opt = FdToString::createWriter(PREFIX);
32*b9df5ad1SAndroid Build Coastguard Worker     ASSERT_TRUE(writer_opt.has_value());
33*b9df5ad1SAndroid Build Coastguard Worker     FdToString::Writer& writer = *writer_opt;
34*b9df5ad1SAndroid Build Coastguard Worker     const int fd = writer.borrowFdUnsafe();
35*b9df5ad1SAndroid Build Coastguard Worker     ASSERT_TRUE(fd >= 0);
36*b9df5ad1SAndroid Build Coastguard Worker 
37*b9df5ad1SAndroid Build Coastguard Worker     write(fd, TEST_STRING.c_str(), TEST_STRING.size());
38*b9df5ad1SAndroid Build Coastguard Worker 
39*b9df5ad1SAndroid Build Coastguard Worker     const std::string result = FdToString::closeWriterAndGetString(std::move(writer));
40*b9df5ad1SAndroid Build Coastguard Worker     ASSERT_EQ((PREFIX + TEST_STRING), result);
41*b9df5ad1SAndroid Build Coastguard Worker }
42*b9df5ad1SAndroid Build Coastguard Worker 
TEST(audio_utils_fdtostring,multiline)43*b9df5ad1SAndroid Build Coastguard Worker TEST(audio_utils_fdtostring, multiline) {
44*b9df5ad1SAndroid Build Coastguard Worker     signal(SIGPIPE, SIG_IGN);
45*b9df5ad1SAndroid Build Coastguard Worker     const std::string PREFIX{"aa "};
46*b9df5ad1SAndroid Build Coastguard Worker     const std::string INPUT[] = {"hello\n", "pt1", "pt2 ", "\n", "\n", "pt3\n", "pt4"};
47*b9df5ad1SAndroid Build Coastguard Worker     const std::string GOLDEN = "aa hello\naa pt1pt2 \naa \naa pt3\npt4";
48*b9df5ad1SAndroid Build Coastguard Worker 
49*b9df5ad1SAndroid Build Coastguard Worker     auto writer_opt = FdToString::createWriter(PREFIX);
50*b9df5ad1SAndroid Build Coastguard Worker     ASSERT_TRUE(writer_opt.has_value());
51*b9df5ad1SAndroid Build Coastguard Worker     FdToString::Writer& writer = *writer_opt;
52*b9df5ad1SAndroid Build Coastguard Worker     const int fd = writer.borrowFdUnsafe();
53*b9df5ad1SAndroid Build Coastguard Worker     ASSERT_TRUE(fd >= 0);
54*b9df5ad1SAndroid Build Coastguard Worker 
55*b9df5ad1SAndroid Build Coastguard Worker     for (const auto& str : INPUT) {
56*b9df5ad1SAndroid Build Coastguard Worker         write(fd, str.c_str(), str.size());
57*b9df5ad1SAndroid Build Coastguard Worker     }
58*b9df5ad1SAndroid Build Coastguard Worker 
59*b9df5ad1SAndroid Build Coastguard Worker     ASSERT_EQ(FdToString::closeWriterAndGetString(std::move(writer)), GOLDEN);
60*b9df5ad1SAndroid Build Coastguard Worker }
61*b9df5ad1SAndroid Build Coastguard Worker 
TEST(audio_utils_fdtostring,blocking)62*b9df5ad1SAndroid Build Coastguard Worker TEST(audio_utils_fdtostring, blocking) {
63*b9df5ad1SAndroid Build Coastguard Worker     signal(SIGPIPE, SIG_IGN);
64*b9df5ad1SAndroid Build Coastguard Worker     const std::string PREFIX{"- "};
65*b9df5ad1SAndroid Build Coastguard Worker     const std::string INPUT[] = {"1\n", "2\n", "3\n", "4\n", "5\n"};
66*b9df5ad1SAndroid Build Coastguard Worker     const std::string GOLDEN = "- 1\n- 2\n- 3\n- 4\n- 5\n";
67*b9df5ad1SAndroid Build Coastguard Worker 
68*b9df5ad1SAndroid Build Coastguard Worker     auto writer_opt = FdToString::createWriter(PREFIX, std::chrono::milliseconds{200});
69*b9df5ad1SAndroid Build Coastguard Worker 
70*b9df5ad1SAndroid Build Coastguard Worker     ASSERT_TRUE(writer_opt.has_value());
71*b9df5ad1SAndroid Build Coastguard Worker     FdToString::Writer& writer = *writer_opt;
72*b9df5ad1SAndroid Build Coastguard Worker     const int fd = writer.borrowFdUnsafe();
73*b9df5ad1SAndroid Build Coastguard Worker     ASSERT_TRUE(fd >= 0);
74*b9df5ad1SAndroid Build Coastguard Worker 
75*b9df5ad1SAndroid Build Coastguard Worker     // Chosen so that we shouldn't finish the entire array before the timeout
76*b9df5ad1SAndroid Build Coastguard Worker     constexpr auto WAIT = std::chrono::milliseconds{90};
77*b9df5ad1SAndroid Build Coastguard Worker 
78*b9df5ad1SAndroid Build Coastguard Worker     int count = 0;
79*b9df5ad1SAndroid Build Coastguard Worker     for (const auto& str : INPUT) {
80*b9df5ad1SAndroid Build Coastguard Worker         ASSERT_LT(count, 4) << "The reader has timed out, write should have failed by now";
81*b9df5ad1SAndroid Build Coastguard Worker         if (write(fd, str.c_str(), str.size()) < 0) break;
82*b9df5ad1SAndroid Build Coastguard Worker         std::this_thread::sleep_for(WAIT);
83*b9df5ad1SAndroid Build Coastguard Worker         count++;
84*b9df5ad1SAndroid Build Coastguard Worker     }
85*b9df5ad1SAndroid Build Coastguard Worker 
86*b9df5ad1SAndroid Build Coastguard Worker     ASSERT_EQ(FdToString::closeWriterAndGetString(std::move(writer)).substr(0, 8),
87*b9df5ad1SAndroid Build Coastguard Worker             GOLDEN.substr(0, 8)) << "Format mistake";
88*b9df5ad1SAndroid Build Coastguard Worker }
89