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