4ae4be9263
The close_range() test in particular has been confusing a lot of partners. I think the sys_epoll_test.cpp idiom is the clearest of the ones in use, so let's use that everywhere. (I haven't actually touched the SysV IPC tests, because if we do touch them, _deleting_ them -- since all those syscalls are not allowed on Android -- is probably the change to be made!) I'm on the fence about factoring this idiom out into a macro. There should never be too many of these, and we should probably be removing them? Is anyone still running the current bionic tests on 4.3 kernels without membarrier(2), and if they are --- why?! For now though, I haven't removed any of our existing tests; I've just moved them over to the sys_epoll_test.cpp style. Test: treehugger Change-Id: Ie69a0bb8f416c79957188e187610ff8a3c4d1e8f
168 lines
4.4 KiB
C++
168 lines
4.4 KiB
C++
/*
|
|
* Copyright (C) 2013 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <errno.h>
|
|
#include <fcntl.h>
|
|
#include <signal.h>
|
|
#include <sys/epoll.h>
|
|
#include <unistd.h>
|
|
|
|
#include "utils.h"
|
|
|
|
TEST(sys_epoll, epoll_wait) {
|
|
int epoll_fd = epoll_create(1);
|
|
ASSERT_NE(-1, epoll_fd);
|
|
|
|
// Regular epoll_wait.
|
|
epoll_event events[1] = {};
|
|
ASSERT_EQ(0, epoll_wait(epoll_fd, events, 1, 1));
|
|
}
|
|
|
|
TEST(sys_epoll, epoll_pwait_no_sigset) {
|
|
int epoll_fd = epoll_create(1);
|
|
ASSERT_NE(-1, epoll_fd);
|
|
|
|
// epoll_pwait without a sigset (which is equivalent to epoll_wait).
|
|
epoll_event events[1] = {};
|
|
ASSERT_EQ(0, epoll_pwait(epoll_fd, events, 1, 1, nullptr));
|
|
}
|
|
|
|
TEST(sys_epoll, epoll_pwait64_no_sigset) {
|
|
#if defined(__BIONIC__)
|
|
int epoll_fd = epoll_create(1);
|
|
ASSERT_NE(-1, epoll_fd);
|
|
|
|
// epoll_pwait64 without a sigset (which is equivalent to epoll_wait).
|
|
epoll_event events[1] = {};
|
|
ASSERT_EQ(0, epoll_pwait64(epoll_fd, events, 1, 1, nullptr));
|
|
#else
|
|
GTEST_SKIP() << "epoll_pwait64 is bionic-only";
|
|
#endif
|
|
}
|
|
|
|
TEST(sys_epoll, epoll_pwait2_no_sigset) {
|
|
#if defined(__BIONIC__)
|
|
int epoll_fd = epoll_create(1);
|
|
ASSERT_NE(-1, epoll_fd);
|
|
|
|
// epoll_pwait2 without a sigset (which is equivalent to epoll_wait).
|
|
epoll_event events[1] = {};
|
|
timespec ts = {.tv_nsec = 500};
|
|
int rc = epoll_pwait2(epoll_fd, events, 1, &ts, nullptr);
|
|
if (rc == -1 && errno == ENOSYS) GTEST_SKIP() << "no epoll_pwait2() in this kernel";
|
|
ASSERT_EQ(0, rc) << strerror(errno);
|
|
#else
|
|
GTEST_SKIP() << "epoll_pwait2 is only in glibc 2.35+";
|
|
#endif
|
|
}
|
|
|
|
TEST(sys_epoll, epoll_pwait_with_sigset) {
|
|
int epoll_fd = epoll_create(1);
|
|
ASSERT_NE(-1, epoll_fd);
|
|
|
|
// epoll_pwait with a sigset.
|
|
epoll_event events[1] = {};
|
|
sigset_t ss;
|
|
sigemptyset(&ss);
|
|
sigaddset(&ss, SIGPIPE);
|
|
ASSERT_EQ(0, epoll_pwait(epoll_fd, events, 1, 1, &ss));
|
|
}
|
|
|
|
TEST(sys_epoll, epoll_pwait2_with_sigset) {
|
|
int epoll_fd = epoll_create(1);
|
|
ASSERT_NE(-1, epoll_fd);
|
|
|
|
#if defined(__BIONIC__)
|
|
epoll_event events[1] = {};
|
|
timespec ts = {.tv_nsec = 500};
|
|
sigset_t ss2;
|
|
sigemptyset(&ss2);
|
|
sigaddset(&ss2, SIGPIPE);
|
|
int rc = epoll_pwait2(epoll_fd, events, 1, &ts, &ss2);
|
|
if (rc == -1 && errno == ENOSYS) GTEST_SKIP() << "no epoll_pwait2() in this kernel";
|
|
ASSERT_EQ(0, rc) << strerror(errno);
|
|
#else
|
|
GTEST_SKIP() << "epoll_pwait2 is only in glibc 2.35+";
|
|
#endif
|
|
}
|
|
|
|
TEST(sys_epoll, epoll_pwait2_64_with_sigset) {
|
|
int epoll_fd = epoll_create(1);
|
|
ASSERT_NE(-1, epoll_fd);
|
|
|
|
#if defined(__BIONIC__)
|
|
epoll_event events[1] = {};
|
|
timespec ts = {.tv_nsec = 500};
|
|
sigset64_t ss2;
|
|
sigemptyset64(&ss2);
|
|
sigaddset64(&ss2, SIGPIPE);
|
|
int rc = epoll_pwait2_64(epoll_fd, events, 1, &ts, &ss2);
|
|
if (rc == -1 && errno == ENOSYS) GTEST_SKIP() << "no epoll_pwait2() in this kernel";
|
|
ASSERT_EQ(0, rc) << strerror(errno);
|
|
#else
|
|
GTEST_SKIP() << "epoll_pwait2_64 is bionic-only";
|
|
#endif
|
|
}
|
|
|
|
TEST(sys_epoll, epoll_create_invalid_size) {
|
|
errno = 0;
|
|
ASSERT_EQ(-1, epoll_create(0));
|
|
ASSERT_ERRNO(EINVAL);
|
|
}
|
|
|
|
TEST(sys_epoll, epoll_event_data) {
|
|
int epoll_fd = epoll_create(1);
|
|
ASSERT_NE(-1, epoll_fd) << strerror(errno);
|
|
|
|
int fds[2];
|
|
ASSERT_NE(-1, pipe(fds));
|
|
|
|
const uint64_t expected = 0x123456789abcdef0;
|
|
|
|
// Get ready to poll on read end of pipe.
|
|
epoll_event ev;
|
|
ev.events = EPOLLIN;
|
|
ev.data.u64 = expected;
|
|
ASSERT_NE(-1, epoll_ctl(epoll_fd, EPOLL_CTL_ADD, fds[0], &ev));
|
|
|
|
// Ensure there's something in the pipe.
|
|
ASSERT_EQ(1, write(fds[1], "\n", 1));
|
|
|
|
// Poll.
|
|
epoll_event events[1];
|
|
ASSERT_EQ(1, epoll_wait(epoll_fd, events, 1, 1));
|
|
ASSERT_EQ(expected, events[0].data.u64);
|
|
|
|
close(fds[0]);
|
|
close(fds[1]);
|
|
}
|
|
|
|
TEST(sys_epoll, epoll_create1) {
|
|
int fd;
|
|
fd = epoll_create(1);
|
|
ASSERT_FALSE(CloseOnExec(fd));
|
|
close(fd);
|
|
|
|
fd = epoll_create1(0);
|
|
ASSERT_FALSE(CloseOnExec(fd));
|
|
close(fd);
|
|
|
|
fd = epoll_create1(EPOLL_CLOEXEC);
|
|
ASSERT_TRUE(CloseOnExec(fd));
|
|
close(fd);
|
|
}
|