Summary: This class was initially in Host because its implementation used to be very OS-specific. However, with C++11, it has become a very simple std::condition_variable wrapper, with no host-specific code. It is also a general purpose utility class, so it makes sense for it to live in a place where it can be used by everyone. This has no effect on the layering right now, but it enables me to later move the Listener+Broadcaster+Event combo to a lower layer, which is important, as these are used in a lot of places (notably for launching a process in Host code). Reviewers: jingham, zturner, teemperor Reviewed By: zturner Subscribers: xiaobai, mgorny, lldb-commits Differential Revision: https://reviews.llvm.org/D50384 llvm-svn: 341089
76 lines
2.6 KiB
C++
76 lines
2.6 KiB
C++
//===-- BroadcasterTest.cpp -------------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
#include "lldb/Core/Broadcaster.h"
|
|
#include "lldb/Core/Event.h"
|
|
#include "lldb/Core/Listener.h"
|
|
#include "lldb/Utility/Predicate.h"
|
|
|
|
#include <thread>
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
|
|
TEST(BroadcasterTest, BroadcastEvent) {
|
|
EventSP event_sp;
|
|
Broadcaster broadcaster(nullptr, "test-broadcaster");
|
|
std::chrono::seconds timeout(0);
|
|
|
|
// Create a listener, sign it up, make sure it recieves an event.
|
|
ListenerSP listener1_sp = Listener::MakeListener("test-listener1");
|
|
const uint32_t event_mask1 = 1;
|
|
EXPECT_EQ(event_mask1,
|
|
listener1_sp->StartListeningForEvents(&broadcaster, event_mask1));
|
|
broadcaster.BroadcastEvent(event_mask1, nullptr);
|
|
EXPECT_TRUE(listener1_sp->GetEvent(event_sp, timeout));
|
|
EXPECT_EQ(event_mask1, event_sp->GetType());
|
|
|
|
{
|
|
// Add one more listener, make sure it works as well.
|
|
ListenerSP listener2_sp = Listener::MakeListener("test-listener2");
|
|
const uint32_t event_mask2 = 1;
|
|
EXPECT_EQ(event_mask2, listener2_sp->StartListeningForEvents(
|
|
&broadcaster, event_mask1 | event_mask2));
|
|
broadcaster.BroadcastEvent(event_mask2, nullptr);
|
|
EXPECT_TRUE(listener2_sp->GetEvent(event_sp, timeout));
|
|
EXPECT_EQ(event_mask2, event_sp->GetType());
|
|
|
|
// Both listeners should get this event.
|
|
broadcaster.BroadcastEvent(event_mask1, nullptr);
|
|
EXPECT_TRUE(listener1_sp->GetEvent(event_sp, timeout));
|
|
EXPECT_EQ(event_mask1, event_sp->GetType());
|
|
EXPECT_TRUE(listener2_sp->GetEvent(event_sp, timeout));
|
|
EXPECT_EQ(event_mask2, event_sp->GetType());
|
|
}
|
|
|
|
// Now again only one listener should be active.
|
|
broadcaster.BroadcastEvent(event_mask1, nullptr);
|
|
EXPECT_TRUE(listener1_sp->GetEvent(event_sp, timeout));
|
|
EXPECT_EQ(event_mask1, event_sp->GetType());
|
|
}
|
|
|
|
TEST(BroadcasterTest, EventTypeHasListeners) {
|
|
EventSP event_sp;
|
|
Broadcaster broadcaster(nullptr, "test-broadcaster");
|
|
|
|
const uint32_t event_mask = 1;
|
|
EXPECT_FALSE(broadcaster.EventTypeHasListeners(event_mask));
|
|
|
|
{
|
|
ListenerSP listener_sp = Listener::MakeListener("test-listener");
|
|
EXPECT_EQ(event_mask,
|
|
listener_sp->StartListeningForEvents(&broadcaster, event_mask));
|
|
EXPECT_TRUE(broadcaster.EventTypeHasListeners(event_mask));
|
|
}
|
|
|
|
EXPECT_FALSE(broadcaster.EventTypeHasListeners(event_mask));
|
|
}
|