diff options
Diffstat (limited to 'tests/fdtrack_test.cpp')
-rw-r--r-- | tests/fdtrack_test.cpp | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/tests/fdtrack_test.cpp b/tests/fdtrack_test.cpp index 13f1b2e18..9fcb40283 100644 --- a/tests/fdtrack_test.cpp +++ b/tests/fdtrack_test.cpp @@ -57,8 +57,13 @@ void DumpEvent(std::vector<android_fdtrack_event>* events, size_t index) { } } -std::vector<android_fdtrack_event> FdtrackRun(void (*func)()) { +std::vector<android_fdtrack_event> FdtrackRun(void (*func)(), bool reenable = true) { // Each bionic test is run in separate process, so we can safely use a static here. + // However, since they're all forked, we need to reenable fdtrack. + if (reenable) { + android_fdtrack_set_globally_enabled(true); + } + static std::vector<android_fdtrack_event> events; events.clear(); @@ -129,6 +134,21 @@ TEST(fdtrack, close) { #endif } +TEST(fdtrack, fork) { +#if defined(__BIONIC__) + ASSERT_EXIT( + []() { + static int fd = open("/dev/null", O_WRONLY | O_CLOEXEC); + ASSERT_NE(-1, fd); + + auto events = FdtrackRun([]() { close(fd); }, false); + ASSERT_EQ(0U, events.size()); + exit(0); + }(), + testing::ExitedWithCode(0), ""); +#endif +} + TEST(fdtrack, enable_disable) { #if defined(__BIONIC__) static int fd1 = -1; |