Mercurial > gnulib
view tests/test-getlogin_r.c @ 17663:59df01cdab26
getlogin_r-tests: avoid false failure under sudo/ssh etc.
* tests/test-getlogin_r.c (main): Sync up with test-getlogin.c
changes from commit 97249cf29 to not depend on environment variables.
author | Pádraig Brady <P@draigBrady.com> |
---|---|
date | Mon, 19 May 2014 13:04:23 +0100 |
parents | 344018b6e5d7 |
children | c25d6a669147 |
line wrap: on
line source
/* Test of getting user name. Copyright (C) 2010-2014 Free Software Foundation, Inc. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ /* Written by Bruno Haible <bruno@clisp.org>, 2010. */ #include <config.h> #include <unistd.h> #include "signature.h" SIGNATURE_CHECK (getlogin_r, int, (char *, size_t)); #include <errno.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include "macros.h" int main (void) { /* Test with a large enough buffer. */ char buf[1024]; int err; err = getlogin_r (buf, sizeof (buf)); if (err != 0) { if (errno == ENOENT) { /* This can happen on GNU/Linux. */ fprintf (stderr, "Skipping test: no entry in utmp file.\n"); return 77; } /* getlogin_r() fails when stdin is not connected to a tty. */ ASSERT (err == ENOTTY || errno == EINVAL /* seen on Linux/SPARC */ || errno == ENXIO ); #if !defined __hpux /* On HP-UX 11.11 it fails anyway. */ ASSERT (! isatty (0)); #endif fprintf (stderr, "Skipping test: stdin is not a tty.\n"); return 77; } /* Compare against the value from the environment. */ #if !((defined _WIN32 || defined __WIN32__) && !defined __CYGWIN__) /* Unix platform */ { # if HAVE_TTYNAME const char *tty; struct stat stat_buf; struct passwd *pwd; tty = ttyname (STDIN_FILENO); if (tty == NULL) { fprintf (stderr, "Skipping test: stdin is not a tty.\n"); return 77; } ASSERT (stat (tty, &stat_buf) == 0); pwd = getpwuid (stat_buf.st_uid); if (! pwd) { fprintf (stderr, "Skipping test: no name found for uid %d\n", stat_buf.st_uid); return 77; } ASSERT (strcmp (pwd->pw_name, buf) == 0); # endif } #endif #if (defined _WIN32 || defined __WIN32__) && !defined __CYGWIN__ /* Native Windows platform. Note: This test would fail on Cygwin in an ssh session, because sshd sets USERNAME=SYSTEM. */ { const char *name = getenv ("USERNAME"); if (name != NULL && name[0] != '\0') ASSERT (strcmp (buf, name) == 0); } #endif /* Test with a small buffer. */ { char smallbuf[1024]; size_t n = strlen (buf); size_t i; for (i = 0; i <= n; i++) { err = getlogin_r (smallbuf, i); if (i == 0) ASSERT (err == ERANGE || err == EINVAL); else ASSERT (err == ERANGE); } } /* Test with a huge buffer. */ { static char hugebuf[70000]; ASSERT (getlogin_r (hugebuf, sizeof (hugebuf)) == 0); ASSERT (strcmp (hugebuf, buf) == 0); } return 0; }