Commit 084ff8d9 authored by Alex Yarmula's avatar Alex Yarmula Committed by Facebook Github Bot

Handle timekeeperSingleton being nullptr in within()

Summary: When timekeeper singleton no longer exists during shutdown and folly::Singleton::try_get() can return nullptr, make sure nullptr is handled gracefully.

Reviewed By: yfeldblum

Differential Revision: D6101311

fbshipit-source-id: fefeddfbd048d1a7632688bb3526db15b685dd72
parent c7813369
......@@ -1218,9 +1218,13 @@ Future<T> Future<T>::within(Duration dur, E e, Timekeeper* tk) {
}
std::shared_ptr<Timekeeper> tks;
if (!tk) {
if (LIKELY(!tk)) {
tks = folly::detail::getTimekeeperSingleton();
tk = DCHECK_NOTNULL(tks.get());
tk = tks.get();
}
if (UNLIKELY(!tk)) {
return makeFuture<T>(NoTimekeeper());
}
auto ctx = std::make_shared<Context>(std::move(e));
......
......@@ -88,6 +88,16 @@ TEST(Timekeeper, futureSleepHandlesNullTimekeeperSingleton) {
EXPECT_THROW(futures::sleep(one_ms).get(), NoTimekeeper);
}
TEST(Timekeeper, futureWithinHandlesNullTimekeeperSingleton) {
Singleton<ThreadWheelTimekeeper>::make_mock([] { return nullptr; });
SCOPE_EXIT {
Singleton<ThreadWheelTimekeeper>::make_mock();
};
Promise<int> p;
auto f = p.getFuture().within(one_ms);
EXPECT_THROW(f.get(), NoTimekeeper);
}
TEST(Timekeeper, futureDelayed) {
auto t1 = now();
auto dur = makeFuture()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment