tests: fix running with non-root user
Refs: #3418
Change-Id: If7f5c05baaff0cf748c87c77057517928539df0d
diff --git a/tests/daemon/mgmt/face-manager-create-face.t.cpp b/tests/daemon/mgmt/face-manager-create-face.t.cpp
index 8c41e63..b827c85 100644
--- a/tests/daemon/mgmt/face-manager-create-face.t.cpp
+++ b/tests/daemon/mgmt/face-manager-create-face.t.cpp
@@ -1,6 +1,6 @@
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/**
- * Copyright (c) 2014-2015, Regents of the University of California,
+ * Copyright (c) 2014-2016, Regents of the University of California,
* Arizona Board of Regents,
* Colorado State University,
* University Pierre & Marie Curie, Sorbonne University,
@@ -62,6 +62,11 @@
" udp\n"
" {\n"
" port " + port + "\n"
+ " mcast no\n"
+ " }\n"
+ " ether\n"
+ " {\n"
+ " mcast no\n"
" }\n"
"}\n"
"authorizations\n"
@@ -457,5 +462,5 @@
BOOST_AUTO_TEST_SUITE_END() // TestFaceManager
BOOST_AUTO_TEST_SUITE_END() // Mgmt
-} // tests
-} // nfd
+} // namespace tests
+} // namespace nfd
diff --git a/tests/daemon/mgmt/face-manager-process-config.t.cpp b/tests/daemon/mgmt/face-manager-process-config.t.cpp
index 0b1a156..6296fc8 100644
--- a/tests/daemon/mgmt/face-manager-process-config.t.cpp
+++ b/tests/daemon/mgmt/face-manager-process-config.t.cpp
@@ -157,6 +157,8 @@
BOOST_AUTO_TEST_CASE(ProcessSectionUdp)
{
+ SKIP_IF_NOT_SUPERUSER();
+
const std::string CONFIG =
"face_system\n"
"{\n"
@@ -294,6 +296,8 @@
BOOST_AUTO_TEST_CASE(ProcessSectionUdpMulticastReinit)
{
+ SKIP_IF_NOT_SUPERUSER();
+
const std::string CONFIG_WITH_MCAST =
"face_system\n"
"{\n"
diff --git a/tests/daemon/mgmt/general-config-section.t.cpp b/tests/daemon/mgmt/general-config-section.t.cpp
index debd2b8..d3af366 100644
--- a/tests/daemon/mgmt/general-config-section.t.cpp
+++ b/tests/daemon/mgmt/general-config-section.t.cpp
@@ -1,6 +1,6 @@
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/**
- * Copyright (c) 2014-2015, Regents of the University of California,
+ * Copyright (c) 2014-2016, Regents of the University of California,
* Arizona Board of Regents,
* Colorado State University,
* University Pierre & Marie Curie, Sorbonne University,
@@ -66,6 +66,8 @@
BOOST_AUTO_TEST_CASE(UserAndGroupConfig)
{
+ SKIP_IF_NOT_SUPERUSER();
+
const std::string CONFIG =
"general\n"
"{\n"
@@ -81,6 +83,8 @@
BOOST_AUTO_TEST_CASE(NoUserConfig)
{
+ SKIP_IF_NOT_SUPERUSER();
+
const std::string CONFIG =
"general\n"
"{\n"
diff --git a/tests/test-common.hpp b/tests/test-common.hpp
index 7c9c60d..fea503b 100644
--- a/tests/test-common.hpp
+++ b/tests/test-common.hpp
@@ -1,6 +1,6 @@
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/**
- * Copyright (c) 2014-2015, Regents of the University of California,
+ * Copyright (c) 2014-2016, Regents of the University of California,
* Arizona Board of Regents,
* Colorado State University,
* University Pierre & Marie Curie, Sorbonne University,
@@ -34,6 +34,19 @@
#include <ndn-cxx/util/time-unit-test-clock.hpp>
#include <ndn-cxx/security/key-chain.hpp>
+#ifdef HAVE_PRIVILEGE_DROP_AND_ELEVATE
+#include <unistd.h>
+#define SKIP_IF_NOT_SUPERUSER() \
+ do { \
+ if (::geteuid() != 0) { \
+ BOOST_TEST_MESSAGE("This test case needs to be run as superuser, skipping"); \
+ return; \
+ } \
+ } while (false)
+#else
+#define SKIP_IF_NOT_SUPERUSER()
+#endif // HAVE_PRIVILEGE_DROP_AND_ELEVATE
+
namespace nfd {
namespace tests {
diff --git a/wscript b/wscript
index d169a5a..f174342 100644
--- a/wscript
+++ b/wscript
@@ -97,6 +97,9 @@
int ret = setegid(grp.gr_gid);
ret = seteuid(pwd.pw_uid);
(void)(ret);
+
+ getegid();
+ geteuid();
return 0;
}
'''):