This source file includes following definitions.
- QuitWhenSignaled
- OnWaitableEventSignaled
- RunTest_BasicSignal
- RunTest_BasicCancel
- RunTest_CancelAfterSet
- RunTest_OutlivesMessageLoop
- RunTest_DeleteUnder
- TEST
- TEST
- TEST
- TEST
- TEST
#include "base/synchronization/waitable_event_watcher.h"
#include "base/bind.h"
#include "base/callback.h"
#include "base/message_loop/message_loop.h"
#include "base/run_loop.h"
#include "base/synchronization/waitable_event.h"
#include "base/threading/platform_thread.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace base {
namespace {
const MessageLoop::Type testing_message_loops[] = {
MessageLoop::TYPE_DEFAULT,
MessageLoop::TYPE_IO,
#if !defined(OS_IOS)
MessageLoop::TYPE_UI,
#endif
};
const int kNumTestingMessageLoops = arraysize(testing_message_loops);
void QuitWhenSignaled(WaitableEvent* event) {
MessageLoop::current()->QuitWhenIdle();
}
class DecrementCountContainer {
public:
explicit DecrementCountContainer(int* counter) : counter_(counter) {
}
void OnWaitableEventSignaled(WaitableEvent* object) {
--(*counter_);
}
private:
int* counter_;
};
void RunTest_BasicSignal(MessageLoop::Type message_loop_type) {
MessageLoop message_loop(message_loop_type);
WaitableEvent event(true, false);
WaitableEventWatcher watcher;
EXPECT_TRUE(watcher.GetWatchedEvent() == NULL);
watcher.StartWatching(&event, Bind(&QuitWhenSignaled));
EXPECT_EQ(&event, watcher.GetWatchedEvent());
event.Signal();
MessageLoop::current()->Run();
EXPECT_TRUE(watcher.GetWatchedEvent() == NULL);
}
void RunTest_BasicCancel(MessageLoop::Type message_loop_type) {
MessageLoop message_loop(message_loop_type);
WaitableEvent event(true, false);
WaitableEventWatcher watcher;
watcher.StartWatching(&event, Bind(&QuitWhenSignaled));
watcher.StopWatching();
}
void RunTest_CancelAfterSet(MessageLoop::Type message_loop_type) {
MessageLoop message_loop(message_loop_type);
WaitableEvent event(true, false);
WaitableEventWatcher watcher;
int counter = 1;
DecrementCountContainer delegate(&counter);
WaitableEventWatcher::EventCallback callback =
Bind(&DecrementCountContainer::OnWaitableEventSignaled,
Unretained(&delegate));
watcher.StartWatching(&event, callback);
event.Signal();
base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds(30));
watcher.StopWatching();
RunLoop().RunUntilIdle();
EXPECT_EQ(1, counter);
}
void RunTest_OutlivesMessageLoop(MessageLoop::Type message_loop_type) {
WaitableEvent event(true, false);
{
WaitableEventWatcher watcher;
{
MessageLoop message_loop(message_loop_type);
watcher.StartWatching(&event, Bind(&QuitWhenSignaled));
}
}
}
void RunTest_DeleteUnder(MessageLoop::Type message_loop_type) {
MessageLoop message_loop(message_loop_type);
{
WaitableEventWatcher watcher;
WaitableEvent* event = new WaitableEvent(false, false);
watcher.StartWatching(event, Bind(&QuitWhenSignaled));
delete event;
}
}
}
TEST(WaitableEventWatcherTest, BasicSignal) {
for (int i = 0; i < kNumTestingMessageLoops; i++) {
RunTest_BasicSignal(testing_message_loops[i]);
}
}
TEST(WaitableEventWatcherTest, BasicCancel) {
for (int i = 0; i < kNumTestingMessageLoops; i++) {
RunTest_BasicCancel(testing_message_loops[i]);
}
}
TEST(WaitableEventWatcherTest, CancelAfterSet) {
for (int i = 0; i < kNumTestingMessageLoops; i++) {
RunTest_CancelAfterSet(testing_message_loops[i]);
}
}
TEST(WaitableEventWatcherTest, OutlivesMessageLoop) {
for (int i = 0; i < kNumTestingMessageLoops; i++) {
RunTest_OutlivesMessageLoop(testing_message_loops[i]);
}
}
#if defined(OS_WIN)
#define MAYBE_DeleteUnder DISABLED_DeleteUnder
#else
#define MAYBE_DeleteUnder DeleteUnder
#endif
TEST(WaitableEventWatcherTest, MAYBE_DeleteUnder) {
for (int i = 0; i < kNumTestingMessageLoops; i++) {
RunTest_DeleteUnder(testing_message_loops[i]);
}
}
}