Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/tests/net/net Add a test demonstrating thst LOCAL_PEEREID is...



details:   https://anonhg.NetBSD.org/src/rev/b4d95cd24363
branches:  trunk
changeset: 359615:b4d95cd24363
user:      christos <christos%NetBSD.org@localhost>
date:      Sat Feb 17 16:34:18 2018 +0000

description:
Add a test demonstrating thst LOCAL_PEEREID is busted.

diffstat:

 tests/net/net/t_unix.c |  196 +++++++++++++++++++++++++++++++------------------
 1 files changed, 124 insertions(+), 72 deletions(-)

diffs (292 lines):

diff -r 4859d6897341 -r b4d95cd24363 tests/net/net/t_unix.c
--- a/tests/net/net/t_unix.c    Sat Feb 17 15:22:22 2018 +0000
+++ b/tests/net/net/t_unix.c    Sat Feb 17 16:34:18 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: t_unix.c,v 1.15 2018/02/16 22:17:17 christos Exp $     */
+/*     $NetBSD: t_unix.c,v 1.16 2018/02/17 16:34:18 christos Exp $     */
 
 /*-
  * Copyright (c) 2011 The NetBSD Foundation, Inc.
@@ -38,7 +38,7 @@
 
 #include <sys/cdefs.h>
 #ifdef __RCSID
-__RCSID("$Id: t_unix.c,v 1.15 2018/02/16 22:17:17 christos Exp $");
+__RCSID("$Id: t_unix.c,v 1.16 2018/02/17 16:34:18 christos Exp $");
 #else
 #define getprogname() argv[0]
 #endif
@@ -51,6 +51,7 @@
 #include <sys/param.h>
 #include <sys/socket.h>
 #include <sys/un.h>
+#include <sys/wait.h>
 #include <stdio.h>
 #include <err.h>
 #include <errno.h>
@@ -126,18 +127,19 @@
 }
 
 static int
-test(bool closeit, size_t len)
+test(bool forkit, bool closeit, size_t len)
 {
        size_t slen;
-       socklen_t sl;
+       socklen_t sl, crl;
        int srvr = -1, clnt = -1, acpt = -1;
-       uid_t euid;
-       gid_t egid;
+       pid_t srvrpid, clntpid;
        struct sockaddr_un *sock_addr = NULL, *sun = NULL;
        socklen_t sock_addrlen;
        socklen_t peer_addrlen;
        struct sockaddr_un peer_addr;
+       struct unpcbid cred;
 
+       srvrpid = clntpid = getpid();
        srvr = socket(AF_UNIX, SOCK_STREAM, 0);
        if (srvr == -1)
                FAIL("socket(srvrer)");
@@ -172,70 +174,99 @@
        if (listen(srvr, SOMAXCONN) == -1)
                FAIL("listen");
 
-       clnt = socket(AF_UNIX, SOCK_STREAM, 0);
-       if (clnt == -1)
-               FAIL("socket(client)");
+       if (forkit) {
+               switch (clntpid = fork()) {
+               case 0: /* child */
+                       srvrpid = getppid();
+                       clntpid = getpid();
+                       break;
+               case -1:
+                       FAIL("fork");
+               default:
+                       break;
+               }
+       }
 
-       if (connect(clnt, (const struct sockaddr *)sun, sl) == -1)
-               FAIL("connect");
-
-       if (getpeereid(clnt, &euid, &egid) == -1)
-               FAIL("getpeereid(clnt)");
-       CHECK_EQUAL(euid, geteuid(), "client");
-       CHECK_EQUAL(egid, getegid(), "client");
-
+       if (clntpid == getpid()) {
+               clnt = socket(AF_UNIX, SOCK_STREAM, 0);
+               if (clnt == -1)
+                       FAIL("socket(client)");
 
-       acpt = acc(srvr);
+               if (connect(clnt, (const struct sockaddr *)sun, sl) == -1)
+                       FAIL("connect");
 
-       peer_addrlen = sizeof(peer_addr);
-       memset(&peer_addr, 0, sizeof(peer_addr));
-       if (getpeername(acpt, (struct sockaddr *)&peer_addr,
-           &peer_addrlen) == -1)
-               FAIL("getpeername");
-       print("peer", &peer_addr, peer_addrlen);
+               crl = sizeof(cred);
+               if (getsockopt(clnt, 0, LOCAL_PEEREID, &cred, &crl) == -1)
+                       FAIL("getsockopt()");
+               CHECK_EQUAL(cred.unp_euid, geteuid(), "client");
+               CHECK_EQUAL(cred.unp_egid, getegid(), "client");
+               CHECK_EQUAL(cred.unp_pid, srvrpid, "client");
+       }
 
-       if (closeit) {
-               if (close(clnt) == -1)
-                       FAIL("close");
-               clnt = -1;
+       if (srvrpid == getpid()) {
+               acpt = acc(srvr);
+
+               peer_addrlen = sizeof(peer_addr);
+               memset(&peer_addr, 0, sizeof(peer_addr));
+               if (getpeername(acpt, (struct sockaddr *)&peer_addr,
+                   &peer_addrlen) == -1)
+                       FAIL("getpeername");
+               print("peer", &peer_addr, peer_addrlen);
        }
 
-       /* This is not symmetric? It is supposed to work! */
-       if (getpeereid(acpt, &euid, &egid) == -1)
-               FAIL("getpeereid(srvr)");
-       CHECK_EQUAL(euid, geteuid(), "server");
-       CHECK_EQUAL(egid, getegid(), "server");
+       if (clntpid == getpid()) {
+               if (closeit) {
+                       if (close(clnt) == -1)
+                               FAIL("close");
+                       clnt = -1;
+               }
+       }
 
-       if ((sock_addr = calloc(1, slen)) == NULL)
-               FAIL("calloc");
-       sock_addrlen = slen;
-       if (getsockname(srvr, (struct sockaddr *)sock_addr, &sock_addrlen)
-           == -1)
-               FAIL("getsockname");
-       print("sock", sock_addr, sock_addrlen);
+       if (srvrpid == getpid()) {
+               crl = sizeof(cred);
+               if (getsockopt(acpt, 0, LOCAL_PEEREID, &cred, &crl) == -1)
+                       FAIL("getsockopt()");
+               CHECK_EQUAL(cred.unp_euid, geteuid(), "server");
+               CHECK_EQUAL(cred.unp_egid, getegid(), "server");
+               CHECK_EQUAL(cred.unp_pid, clntpid, "client");
 
-       if (sock_addr->sun_family != AF_UNIX)
-               FAIL("sock_addr->sun_family %d != AF_UNIX",
-                   sock_addr->sun_family);
+               if ((sock_addr = calloc(1, slen)) == NULL)
+                       FAIL("calloc");
+               sock_addrlen = slen;
+               if (getsockname(srvr, (struct sockaddr *)sock_addr,
+                   &sock_addrlen) == -1)
+                       FAIL("getsockname");
+               print("sock", sock_addr, sock_addrlen);
 
-       len += OF;
-       if (sock_addrlen LX != len)
-               FAIL("sock_addr_len %zu != %zu", (size_t)sock_addrlen, len);
+               if (sock_addr->sun_family != AF_UNIX)
+                       FAIL("sock_addr->sun_family %d != AF_UNIX",
+                           sock_addr->sun_family);
+
+               len += OF;
+               if (sock_addrlen LX != len)
+                       FAIL("sock_addr_len %zu != %zu", (size_t)sock_addrlen,
+                           len);
 #ifdef BSD4_4
-       if (sock_addr->sun_len != sl)
-               FAIL("sock_addr.sun_len %d != %zu", sock_addr->sun_len,
-                   (size_t)sl);
+               if (sock_addr->sun_len != sl)
+                       FAIL("sock_addr.sun_len %d != %zu", sock_addr->sun_len,
+                           (size_t)sl);
 #endif
-       for (size_t i = 0; i < slen - OF; i++)
-               if (sock_addr->sun_path[i] != sun->sun_path[i])
-                       FAIL("sock_addr.sun_path[%zu] %d != "
-                           "sun->sun_path[%zu] %d\n", i, 
-                           sock_addr->sun_path[i], i, sun->sun_path[i]);
+               for (size_t i = 0; i < slen - OF; i++)
+                       if (sock_addr->sun_path[i] != sun->sun_path[i])
+                               FAIL("sock_addr.sun_path[%zu] %d != "
+                                   "sun->sun_path[%zu] %d\n", i, 
+                                   sock_addr->sun_path[i], i,
+                                   sun->sun_path[i]);
 
-       if (acpt != -1)
-               (void)close(acpt);
-       if (srvr != -1)
-               (void)close(srvr);
+               if (acpt != -1)
+                       (void)close(acpt);
+               if (srvr != -1)
+                       (void)close(srvr);
+               free(sock_addr);
+               sock_addr = NULL;
+               if (forkit && waitpid(clntpid, NULL, 0) == -1)
+                       FAIL("waitpid");
+       }
        if (clnt != -1 && !closeit)
                (void)close(clnt);
 
@@ -243,12 +274,16 @@
        free(sun);
        return 0;
 fail:
-       if (acpt != -1)
-               (void)close(acpt);
-       if (srvr != -1)
-               (void)close(srvr);
-       if (clnt != -1 && !closeit)
-               (void)close(clnt);
+       if (srvrpid == getpid()) {
+               if (acpt != -1)
+                       (void)close(acpt);
+               if (srvr != -1)
+                       (void)close(srvr);
+       }
+       if (clntpid == getpid()) {
+               if (clnt != -1 && !closeit)
+                       (void)close(clnt);
+       }
        free(sock_addr);
        free(sun);
        return -1;
@@ -267,8 +302,8 @@
 
 ATF_TC_BODY(sockaddr_un_len_exceed, tc)
 {
-       ATF_REQUIRE_MSG(test(false, 254) == -1, "test(false, 254): %s",
-           strerror(errno));
+       ATF_REQUIRE_MSG(test(false, false, 254) == -1,
+           "test(false, false, 254): %s", strerror(errno));
 }
 
 ATF_TC(sockaddr_un_len_max);
@@ -282,8 +317,8 @@
 
 ATF_TC_BODY(sockaddr_un_len_max, tc)
 {
-       ATF_REQUIRE_MSG(test(false, 253) == 0, "test(false, 253): %s",
-           strerror(errno));
+       ATF_REQUIRE_MSG(test(false, false, 253) == 0,
+           "test(false, false, 253): %s", strerror(errno));
 }
 
 ATF_TC(sockaddr_un_closed);
@@ -296,8 +331,22 @@
 
 ATF_TC_BODY(sockaddr_un_closed, tc)
 {
-       ATF_REQUIRE_MSG(test(true, 100) == 0, "test(true, 100): %s",
-           strerror(errno));
+       ATF_REQUIRE_MSG(test(false, true, 100) == 0,
+           "test(false, true, 100): %s", strerror(errno));
+}
+
+ATF_TC(sockaddr_un_local_peereid);
+ATF_TC_HEAD(sockaddr_un_local_peereid, tc)
+{
+
+       atf_tc_set_md_var(tc, "descr", "Check that we get the right information"
+           " from LOCAL_PEEREID");
+}
+
+ATF_TC_BODY(sockaddr_un_local_peereid, tc)
+{
+       ATF_REQUIRE_MSG(test(true, true, 100) == 0,
+           "test(true, true, 100): %s", strerror(errno));
 }
 
 ATF_TP_ADD_TCS(tp)
@@ -306,6 +355,7 @@
        ATF_TP_ADD_TC(tp, sockaddr_un_len_exceed);
        ATF_TP_ADD_TC(tp, sockaddr_un_len_max);
        ATF_TP_ADD_TC(tp, sockaddr_un_closed);
+       ATF_TP_ADD_TC(tp, sockaddr_un_local_peereid);
        return atf_no_error();
 }
 #else
@@ -318,7 +368,9 @@
                fprintf(stderr, "Usage: %s <len>\n", getprogname());
                return EXIT_FAILURE;
        }
-       test(false, atoi(argv[1]));
-       test(true, atoi(argv[1]));
+       test(false, false, atoi(argv[1]));
+       test(false, true, atoi(argv[1]));
+       test(true, false, atoi(argv[1]));
+       test(true, true, atoi(argv[1]));
 }
 #endif



Home | Main Index | Thread Index | Old Index