|
15 | 15 | #include "gmock/gmock.h" |
16 | 16 | #include "gtest/gtest.h" |
17 | 17 | #include <chrono> |
| 18 | +#if __linux__ |
| 19 | +#include <lldb/Host/linux/AbstractSocket.h> |
| 20 | +#endif |
18 | 21 |
|
19 | 22 | using namespace lldb_private; |
20 | 23 |
|
@@ -337,6 +340,47 @@ TEST_F(SocketTest, DomainGetConnectURI) { |
337 | 340 |
|
338 | 341 | EXPECT_EQ(socket_b_up->GetRemoteConnectionURI(), ""); |
339 | 342 | } |
| 343 | + |
| 344 | +TEST_F(SocketTest, DomainSocketFromBoundNativeSocket) { |
| 345 | + // Generate a name for the domain socket. |
| 346 | + llvm::SmallString<64> name; |
| 347 | + std::error_code EC = llvm::sys::fs::createUniqueDirectory( |
| 348 | + "DomainSocketFromBoundNativeSocket", name); |
| 349 | + ASSERT_FALSE(EC); |
| 350 | + llvm::sys::path::append(name, "test"); |
| 351 | + |
| 352 | + DomainSocket socket(true); |
| 353 | + Status error = socket.Listen(name, /*backlog=*/10); |
| 354 | + ASSERT_THAT_ERROR(error.takeError(), llvm::Succeeded()); |
| 355 | + NativeSocket native_socket = socket.GetNativeSocket(); |
| 356 | + |
| 357 | + llvm::Expected<std::unique_ptr<DomainSocket>> sock = |
| 358 | + DomainSocket::FromBoundNativeSocket(native_socket, |
| 359 | + /*should_close=*/false); |
| 360 | + ASSERT_THAT_EXPECTED(sock, llvm::Succeeded()); |
| 361 | + ASSERT_EQ(Socket::ProtocolUnixDomain, sock->get()->GetSocketProtocol()); |
| 362 | +} |
| 363 | +#endif |
| 364 | + |
| 365 | +#if __linux__ |
| 366 | +TEST_F(SocketTest, AbstractSocketFromBoundNativeSocket) { |
| 367 | + // Generate a name for the abstract socket. |
| 368 | + llvm::SmallString<100> name; |
| 369 | + llvm::sys::fs::createUniquePath("AbstractSocketFromBoundNativeSocket", name, |
| 370 | + true); |
| 371 | + llvm::sys::path::append(name, "test"); |
| 372 | + |
| 373 | + AbstractSocket socket; |
| 374 | + Status error = socket.Listen(name, /*backlog=*/10); |
| 375 | + ASSERT_THAT_ERROR(error.takeError(), llvm::Succeeded()); |
| 376 | + NativeSocket native_socket = socket.GetNativeSocket(); |
| 377 | + |
| 378 | + llvm::Expected<std::unique_ptr<DomainSocket>> sock = |
| 379 | + DomainSocket::FromBoundNativeSocket(native_socket, |
| 380 | + /*should_close=*/false); |
| 381 | + ASSERT_THAT_EXPECTED(sock, llvm::Succeeded()); |
| 382 | + ASSERT_EQ(Socket::ProtocolUnixAbstract, sock->get()->GetSocketProtocol()); |
| 383 | +} |
340 | 384 | #endif |
341 | 385 |
|
342 | 386 | INSTANTIATE_TEST_SUITE_P( |
|
0 commit comments