| Index: content/browser/devtools/devtools_manager_unittest.cc
|
| diff --git a/content/browser/devtools/devtools_manager_unittest.cc b/content/browser/devtools/devtools_manager_unittest.cc
|
| index deac3c13f540930f92b71a2f78ef2b7b72fa0aed..fc7d0f6a1148acaa11196426a58bf8cd3d7e5ed3 100644
|
| --- a/content/browser/devtools/devtools_manager_unittest.cc
|
| +++ b/content/browser/devtools/devtools_manager_unittest.cc
|
| @@ -11,6 +11,7 @@
|
| #include "content/public/browser/content_browser_client.h"
|
| #include "content/public/browser/devtools_agent_host.h"
|
| #include "content/public/browser/devtools_client_host.h"
|
| +#include "content/public/browser/devtools_remote_agent_connector.h"
|
| #include "content/public/browser/web_contents_delegate.h"
|
| #include "content/test/test_content_browser_client.h"
|
| #include "content/test/test_web_contents.h"
|
| @@ -237,4 +238,61 @@ TEST_F(DevToolsManagerTest, ReattachOnCancelPendingNavigation) {
|
| client_host.Close(DevToolsManager::GetInstance());
|
| }
|
|
|
| +class TestRemoteAgentDelegate: public DevToolsRemoteAgentConnector::Delegate {
|
| + std::map<std::string,int> event_counter_;
|
| +
|
| + void recordEvent(const std::string& name) {
|
| + if (event_counter_.find(name) == event_counter_.end()) {
|
| + event_counter_[name] = 0;
|
| + }
|
| + event_counter_[name] = event_counter_[name] + 1;
|
| + }
|
| +
|
| + void expectEvent(int count, const std::string& name) {
|
| + EXPECT_EQ(count, event_counter_[name]);
|
| + }
|
| +
|
| + virtual void Attach() OVERRIDE {
|
| + recordEvent("Attach");
|
| + };
|
| +
|
| + virtual void Detach() OVERRIDE {
|
| + recordEvent("Detach");
|
| + };
|
| +
|
| + virtual void Send(const std::string& message) OVERRIDE {
|
| + recordEvent(std::string("Send.") + message);
|
| + };
|
| +
|
| + public :
|
| + ~TestRemoteAgentDelegate() {
|
| + expectEvent(1, "Attach");
|
| + expectEvent(1, "Detach");
|
| + expectEvent(0, "Send.message0");
|
| + expectEvent(1, "Send.message1");
|
| + expectEvent(2, "Send.message2");
|
| + }
|
| +};
|
| +
|
| +TEST_F(DevToolsManagerTest, TestRemoteConnector) {
|
| + TestRemoteAgentDelegate delegate;
|
| +
|
| + DevToolsRemoteAgentConnector* connector =
|
| + DevToolsRemoteAgentConnector::CreateFor(&delegate);
|
| +
|
| + scoped_refptr<DevToolsAgentHost> agent_host = connector->GetAgentHost();
|
| + EXPECT_EQ(agent_host, DevToolsAgentHost::GetForId(agent_host->GetId()));
|
| +
|
| + DevToolsManager* manager = DevToolsManager::GetInstance();
|
| +
|
| + TestDevToolsClientHost client_host;
|
| + manager->RegisterDevToolsClientHostFor(agent_host, &client_host);
|
| +
|
| + manager->DispatchOnInspectorBackend(&client_host, "message1");
|
| + manager->DispatchOnInspectorBackend(&client_host, "message2");
|
| + manager->DispatchOnInspectorBackend(&client_host, "message2");
|
| +
|
| + client_host.Close(manager);
|
| +}
|
| +
|
| } // namespace content
|
|
|