James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 1 | #include "aos/util/scoped_pipe.h" |
| 2 | |
James Kuszmaul | d42edb4 | 2022-01-07 18:00:16 -0800 | [diff] [blame] | 3 | #include <fcntl.h> |
| 4 | |
James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 5 | #include <array> |
| 6 | #include <string> |
| 7 | |
| 8 | #include "gtest/gtest.h" |
| 9 | |
Stephan Pleines | f63bde8 | 2024-01-13 15:59:33 -0800 | [diff] [blame] | 10 | namespace aos::util::testing { |
James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 11 | |
| 12 | // Tests using uint32_t read/write methods on the ScopedPipe objects. |
| 13 | TEST(ScopedPipeTest, IntegerPipe) { |
James Kuszmaul | d42edb4 | 2022-01-07 18:00:16 -0800 | [diff] [blame] | 14 | ScopedPipe::PipePair pipe = ScopedPipe::MakePipe(); |
| 15 | ASSERT_FALSE(pipe.read->Read().has_value()) |
James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 16 | << "Shouldn't get anything on empty read."; |
James Kuszmaul | d42edb4 | 2022-01-07 18:00:16 -0800 | [diff] [blame] | 17 | pipe.write->Write(971); |
| 18 | ASSERT_EQ(971, pipe.read->Read().value()); |
James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 19 | } |
| 20 | |
| 21 | // Tests using string read/write methods on the ScopedPipe objects. |
| 22 | TEST(ScopedPipeTest, StringPipe) { |
James Kuszmaul | d42edb4 | 2022-01-07 18:00:16 -0800 | [diff] [blame] | 23 | ScopedPipe::PipePair pipe = ScopedPipe::MakePipe(); |
James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 24 | std::string buffer; |
James Kuszmaul | d42edb4 | 2022-01-07 18:00:16 -0800 | [diff] [blame] | 25 | ASSERT_EQ(0u, pipe.read->Read(&buffer)) |
James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 26 | << "Shouldn't get anything on empty read."; |
| 27 | ASSERT_TRUE(buffer.empty()); |
| 28 | |
| 29 | const char *const kAbc = "abcdef"; |
James Kuszmaul | d42edb4 | 2022-01-07 18:00:16 -0800 | [diff] [blame] | 30 | pipe.write->Write( |
James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 31 | absl::Span<const uint8_t>(reinterpret_cast<const uint8_t *>(kAbc), 6)); |
James Kuszmaul | d42edb4 | 2022-01-07 18:00:16 -0800 | [diff] [blame] | 32 | ASSERT_EQ(6u, pipe.read->Read(&buffer)); |
James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 33 | ASSERT_EQ("abcdef", buffer); |
| 34 | |
| 35 | std::array<uint8_t, 10000> large_buffer; |
| 36 | large_buffer.fill(99); |
James Kuszmaul | d42edb4 | 2022-01-07 18:00:16 -0800 | [diff] [blame] | 37 | pipe.write->Write( |
James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 38 | absl::Span<const uint8_t>(large_buffer.data(), large_buffer.size())); |
James Kuszmaul | d42edb4 | 2022-01-07 18:00:16 -0800 | [diff] [blame] | 39 | ASSERT_EQ(large_buffer.size(), pipe.read->Read(&buffer)); |
James Kuszmaul | 731a05d | 2022-01-07 17:59:26 -0800 | [diff] [blame] | 40 | for (size_t ii = 0; ii < large_buffer.size(); ++ii) { |
| 41 | ASSERT_EQ(large_buffer[ii], buffer[ii + 6]); |
| 42 | } |
| 43 | } |
| 44 | |
Austin Schuh | 0d16411 | 2023-08-17 12:50:51 -0700 | [diff] [blame] | 45 | // Tests using string read/write methods on the ScopedPipe objects. |
| 46 | TEST(ScopedPipeTest, StringPipe2048) { |
| 47 | ScopedPipe::PipePair pipe = ScopedPipe::MakePipe(); |
| 48 | std::string buffer; |
| 49 | ASSERT_EQ(0u, pipe.read->Read(&buffer)) |
| 50 | << "Shouldn't get anything on empty read."; |
| 51 | ASSERT_TRUE(buffer.empty()); |
| 52 | |
| 53 | std::string a(2048, 'a'); |
| 54 | pipe.write->Write(absl::Span<const uint8_t>( |
| 55 | reinterpret_cast<const uint8_t *>(a.data()), a.size())); |
| 56 | ASSERT_EQ(2048u, pipe.read->Read(&buffer)); |
| 57 | ASSERT_EQ(a, buffer); |
| 58 | } |
| 59 | |
James Kuszmaul | d42edb4 | 2022-01-07 18:00:16 -0800 | [diff] [blame] | 60 | // Tests that calling SetCloexec succeeds and does indeed set FD_CLOEXEC. |
| 61 | TEST(ScopedPipeTest, SetCloexec) { |
| 62 | ScopedPipe::PipePair pipe = ScopedPipe::MakePipe(); |
| 63 | ASSERT_EQ(0, fcntl(pipe.read->fd(), F_GETFD) & FD_CLOEXEC); |
| 64 | pipe.read->SetCloexec(); |
| 65 | ASSERT_NE(0, fcntl(pipe.read->fd(), F_GETFD) & FD_CLOEXEC); |
| 66 | } |
| 67 | |
Stephan Pleines | f63bde8 | 2024-01-13 15:59:33 -0800 | [diff] [blame] | 68 | } // namespace aos::util::testing |