selftests/tls: Add test for recv(PEEK) spanning across multiple records
authorVakul Garg <vakul.garg@nxp.com>
Wed, 29 Aug 2018 10:00:14 +0000 (15:30 +0530)
committerDavid S. Miller <davem@davemloft.net>
Sun, 2 Sep 2018 02:52:50 +0000 (19:52 -0700)
Added test case to receive multiple records with a single recvmsg()
operation with a MSG_PEEK set.

Signed-off-by: David S. Miller <davem@davemloft.net>
tools/testing/selftests/net/tls.c

index b3ebf2646e52f3e15e7d69c648369f4c510a54b4..07daff076ce02563c0dfea6f97341f9fdfa1410b 100644 (file)
@@ -502,6 +502,28 @@ TEST_F(tls, recv_peek_multiple)
        EXPECT_EQ(memcmp(test_str, buf, send_len), 0);
 }
 
+TEST_F(tls, recv_peek_large_buf_mult_recs)
+{
+       char const *test_str = "test_read_peek_mult_recs";
+       char const *test_str_first = "test_read_peek";
+       char const *test_str_second = "_mult_recs";
+       int len;
+       char buf[64];
+
+       len = strlen(test_str_first);
+       EXPECT_EQ(send(self->fd, test_str_first, len, 0), len);
+
+       len = strlen(test_str_second) + 1;
+       EXPECT_EQ(send(self->fd, test_str_second, len, 0), len);
+
+       len = sizeof(buf);
+       memset(buf, 0, len);
+       EXPECT_NE(recv(self->cfd, buf, len, MSG_PEEK), -1);
+
+       len = strlen(test_str) + 1;
+       EXPECT_EQ(memcmp(test_str, buf, len), 0);
+}
+
 TEST_F(tls, pollin)
 {
        char const *test_str = "test_poll";