Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1003)

Unified Diff: content/browser/devtools/devtools_manager_unittest.cc

Issue 12950002: Introduce DevToolsExternalAgentProxy interface (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed comments Created 7 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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

Powered by Google App Engine
This is Rietveld 408576698