summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2016-01-03 09:00:30 -0800
committerNick Mathewson <nickm@torproject.org>2016-01-03 09:00:30 -0800
commit7660471054e2ee6568ddbbadbd9190f9ca4efb5a (patch)
tree6be1491cedbe68f911f47d64eeecbf605a91136e
parentc941240f325f312fb8485a2d018ccc183c2b1591 (diff)
downloadtor-7660471054e2ee6568ddbbadbd9190f9ca4efb5a.tar.gz
tor-7660471054e2ee6568ddbbadbd9190f9ca4efb5a.zip
Unit tests for getpw* functions
-rw-r--r--src/test/test_util.c42
1 files changed, 42 insertions, 0 deletions
diff --git a/src/test/test_util.c b/src/test/test_util.c
index 73b430767a..bf789c596b 100644
--- a/src/test/test_util.c
+++ b/src/test/test_util.c
@@ -14,6 +14,9 @@
#include "memarea.h"
#include "util_process.h"
+#ifdef HAVE_PWD_H
+#include <pwd.h>
+#endif
#ifdef HAVE_SYS_UTIME_H
#include <sys/utime.h>
#endif
@@ -4626,6 +4629,44 @@ test_util_touch_file(void *arg)
;
}
+#ifndef _WIN32
+static void
+test_util_pwdb(void *arg)
+{
+ (void) arg;
+ const struct passwd *me = NULL, *me2, *me3;
+ char *name = NULL;
+ char *dir = NULL;
+
+ /* Uncached case. */
+ /* Let's assume that we exist. */
+ me = tor_getpwuid(getuid());
+ tt_assert(me != NULL);
+ name = tor_strdup(me->pw_name);
+
+ /* Uncached case */
+ me2 = tor_getpwnam(name);
+ tt_assert(me2 != NULL);
+ tt_int_op(me2->pw_uid, OP_EQ, getuid());
+
+ /* Cached case */
+ me3 = tor_getpwuid(getuid());
+ tt_assert(me3 != NULL);
+ tt_str_op(me3->pw_name, OP_EQ, name);
+
+ me3 = tor_getpwnam(name);
+ tt_assert(me3 != NULL);
+ tt_int_op(me3->pw_uid, OP_EQ, getuid());
+
+ dir = get_user_homedir(name);
+ tt_assert(dir != NULL);
+
+ done:
+ tor_free(name);
+ tor_free(dir);
+}
+#endif
+
#define UTIL_LEGACY(name) \
{ #name, test_util_ ## name , 0, NULL, NULL }
@@ -4710,6 +4751,7 @@ struct testcase_t util_tests[] = {
UTIL_TEST(writepid, 0),
UTIL_TEST(get_avail_disk_space, 0),
UTIL_TEST(touch_file, 0),
+ UTIL_TEST_NO_WIN(pwdb, TT_FORK),
END_OF_TESTCASES
};