Fix unistd.getpid_caching_and_clone.

This test only works if you're root (strictly: if you have permission to
CLONE_NEWNS), so it's useful to us when we're doing ad hoc testing (since
that's usually done as root), but it's not useful as part of CTS or when
running the tests on the host.

Bug: 16705621
Bug: 17170200
Change-Id: Ia92c871b15f7e45fc174bb59bc95540fd00ae745
This commit is contained in:
Elliott Hughes 2014-08-21 19:23:53 -07:00
parent 2d80400a9e
commit 84d0683a82

View File

@ -431,6 +431,10 @@ TEST(unistd, getpid_caching_and_clone) {
void* child_stack[1024]; void* child_stack[1024];
int clone_result = clone(GetPidCachingCloneStartRoutine, &child_stack[1024], CLONE_NEWNS | SIGCHLD, NULL); int clone_result = clone(GetPidCachingCloneStartRoutine, &child_stack[1024], CLONE_NEWNS | SIGCHLD, NULL);
if (clone_result == -1 && errno == EPERM && getuid() != 0) {
GTEST_LOG_(INFO) << "This test only works if you have permission to CLONE_NEWNS; try running as root.\n";
return;
}
ASSERT_NE(clone_result, -1); ASSERT_NE(clone_result, -1);
ASSERT_EQ(parent_pid, getpid()); ASSERT_EQ(parent_pid, getpid());