[libc-commits] [libc] [libc] Add the MSG_ flags (PR #194375)
Pavel Labath via libc-commits
libc-commits at lists.llvm.org
Tue Apr 28 01:39:39 PDT 2026
================
@@ -46,6 +46,46 @@ TEST_F(LlvmLibcSendRecvTest, SucceedsWithSocketPair) {
ASSERT_THAT(LIBC_NAMESPACE::close(sockpair[1]), Succeeds(0));
}
+TEST_F(LlvmLibcSendRecvTest, MsgFlagsTest) {
+ int sockpair[2] = {0, 0};
+
+ ASSERT_THAT(LIBC_NAMESPACE::socketpair(AF_UNIX, SOCK_SEQPACKET, 0, sockpair),
+ Succeeds(0));
+
+ char buffer[256];
+
+ // MSG_DONTWAIT on an empty socket returns EAGAIN
+ ASSERT_THAT(
+ LIBC_NAMESPACE::recv(sockpair[1], buffer, sizeof(buffer), MSG_DONTWAIT),
+ Fails<ssize_t>(EAGAIN));
+
+ const char TEST_MESSAGE[] = "this is a long message";
+ const size_t MESSAGE_LEN = sizeof(TEST_MESSAGE);
+
+ ASSERT_THAT(LIBC_NAMESPACE::send(sockpair[0], TEST_MESSAGE, MESSAGE_LEN, 0),
+ Succeeds(static_cast<ssize_t>(MESSAGE_LEN)));
+
+ // MSG_PEEK does not remove the message from the socket
+ ASSERT_THAT(
+ LIBC_NAMESPACE::recv(sockpair[1], buffer, sizeof(buffer), MSG_PEEK),
+ Succeeds(static_cast<ssize_t>(MESSAGE_LEN)));
+ ASSERT_STREQ(buffer, TEST_MESSAGE);
+ LIBC_NAMESPACE::memset(buffer, 0, sizeof(buffer));
----------------
labath wrote:
Using a new buffer.
https://github.com/llvm/llvm-project/pull/194375
More information about the libc-commits
mailing list