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

Side by Side Diff: content/browser/devtools/devtools_manager_unittest.cc

Issue 442303002: DevTools: migrate DevTools APIs to use WebContents instead of RenderViewHost. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Review comments addressed. Created 6 years, 4 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "base/basictypes.h" 5 #include "base/basictypes.h"
6 #include "base/memory/scoped_ptr.h" 6 #include "base/memory/scoped_ptr.h"
7 #include "base/time/time.h" 7 #include "base/time/time.h"
8 #include "content/browser/devtools/devtools_manager_impl.h" 8 #include "content/browser/devtools/devtools_manager_impl.h"
9 #include "content/browser/devtools/render_view_devtools_agent_host.h" 9 #include "content/browser/devtools/render_view_devtools_agent_host.h"
10 #include "content/common/view_messages.h" 10 #include "content/common/view_messages.h"
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after
94 virtual void SetUp() OVERRIDE { 94 virtual void SetUp() OVERRIDE {
95 RenderViewHostImplTestHarness::SetUp(); 95 RenderViewHostImplTestHarness::SetUp();
96 TestDevToolsClientHost::ResetCounters(); 96 TestDevToolsClientHost::ResetCounters();
97 } 97 }
98 }; 98 };
99 99
100 TEST_F(DevToolsManagerTest, OpenAndManuallyCloseDevToolsClientHost) { 100 TEST_F(DevToolsManagerTest, OpenAndManuallyCloseDevToolsClientHost) {
101 DevToolsManager* manager = DevToolsManager::GetInstance(); 101 DevToolsManager* manager = DevToolsManager::GetInstance();
102 102
103 scoped_refptr<DevToolsAgentHost> agent( 103 scoped_refptr<DevToolsAgentHost> agent(
104 DevToolsAgentHost::GetOrCreateFor(rvh())); 104 DevToolsAgentHost::GetOrCreateFor(web_contents()));
105 EXPECT_FALSE(agent->IsAttached()); 105 EXPECT_FALSE(agent->IsAttached());
106 106
107 TestDevToolsClientHost client_host; 107 TestDevToolsClientHost client_host;
108 manager->RegisterDevToolsClientHostFor(agent.get(), &client_host); 108 manager->RegisterDevToolsClientHostFor(agent.get(), &client_host);
109 // Test that the connection is established. 109 // Test that the connection is established.
110 EXPECT_TRUE(agent->IsAttached()); 110 EXPECT_TRUE(agent->IsAttached());
111 EXPECT_EQ(agent, manager->GetDevToolsAgentHostFor(&client_host)); 111 EXPECT_EQ(agent, manager->GetDevToolsAgentHostFor(&client_host));
112 EXPECT_EQ(0, TestDevToolsClientHost::close_counter); 112 EXPECT_EQ(0, TestDevToolsClientHost::close_counter);
113 113
114 client_host.Close(manager); 114 client_host.Close(manager);
115 EXPECT_EQ(1, TestDevToolsClientHost::close_counter); 115 EXPECT_EQ(1, TestDevToolsClientHost::close_counter);
116 EXPECT_FALSE(agent->IsAttached()); 116 EXPECT_FALSE(agent->IsAttached());
117 } 117 }
118 118
119 TEST_F(DevToolsManagerTest, ForwardMessageToClient) { 119 TEST_F(DevToolsManagerTest, ForwardMessageToClient) {
120 DevToolsManagerImpl* manager = DevToolsManagerImpl::GetInstance(); 120 DevToolsManagerImpl* manager = DevToolsManagerImpl::GetInstance();
121 121
122 TestDevToolsClientHost client_host; 122 TestDevToolsClientHost client_host;
123 scoped_refptr<DevToolsAgentHost> agent_host( 123 scoped_refptr<DevToolsAgentHost> agent_host(
124 DevToolsAgentHost::GetOrCreateFor(rvh())); 124 DevToolsAgentHost::GetOrCreateFor(web_contents()));
125 manager->RegisterDevToolsClientHostFor(agent_host.get(), &client_host); 125 manager->RegisterDevToolsClientHostFor(agent_host.get(), &client_host);
126 EXPECT_EQ(0, TestDevToolsClientHost::close_counter); 126 EXPECT_EQ(0, TestDevToolsClientHost::close_counter);
127 127
128 std::string m = "test message"; 128 std::string m = "test message";
129 agent_host = DevToolsAgentHost::GetOrCreateFor(rvh()); 129 agent_host = DevToolsAgentHost::GetOrCreateFor(web_contents());
130 manager->DispatchOnInspectorFrontend(agent_host.get(), m); 130 manager->DispatchOnInspectorFrontend(agent_host.get(), m);
131 EXPECT_TRUE(&m == client_host.last_sent_message); 131 EXPECT_TRUE(&m == client_host.last_sent_message);
132 132
133 client_host.Close(manager); 133 client_host.Close(manager);
134 EXPECT_EQ(1, TestDevToolsClientHost::close_counter); 134 EXPECT_EQ(1, TestDevToolsClientHost::close_counter);
135 } 135 }
136 136
137 TEST_F(DevToolsManagerTest, NoUnresponsiveDialogInInspectedContents) { 137 TEST_F(DevToolsManagerTest, NoUnresponsiveDialogInInspectedContents) {
138 TestRenderViewHost* inspected_rvh = test_rvh(); 138 TestRenderViewHost* inspected_rvh = test_rvh();
139 inspected_rvh->set_render_view_created(true); 139 inspected_rvh->set_render_view_created(true);
140 EXPECT_FALSE(contents()->GetDelegate()); 140 EXPECT_FALSE(contents()->GetDelegate());
141 TestWebContentsDelegate delegate; 141 TestWebContentsDelegate delegate;
142 contents()->SetDelegate(&delegate); 142 contents()->SetDelegate(&delegate);
143 143
144 TestDevToolsClientHost client_host; 144 TestDevToolsClientHost client_host;
145 scoped_refptr<DevToolsAgentHost> agent_host( 145 scoped_refptr<DevToolsAgentHost> agent_host(DevToolsAgentHost::GetOrCreateFor(
146 DevToolsAgentHost::GetOrCreateFor(inspected_rvh)); 146 WebContents::FromRenderViewHost(inspected_rvh)));
147 DevToolsManager::GetInstance()->RegisterDevToolsClientHostFor( 147 DevToolsManager::GetInstance()->RegisterDevToolsClientHostFor(
148 agent_host.get(), &client_host); 148 agent_host.get(), &client_host);
149 149
150 // Start with a short timeout. 150 // Start with a short timeout.
151 inspected_rvh->StartHangMonitorTimeout(TimeDelta::FromMilliseconds(10)); 151 inspected_rvh->StartHangMonitorTimeout(TimeDelta::FromMilliseconds(10));
152 // Wait long enough for first timeout and see if it fired. 152 // Wait long enough for first timeout and see if it fired.
153 base::MessageLoop::current()->PostDelayedTask( 153 base::MessageLoop::current()->PostDelayedTask(
154 FROM_HERE, 154 FROM_HERE,
155 base::MessageLoop::QuitClosure(), 155 base::MessageLoop::QuitClosure(),
156 TimeDelta::FromMilliseconds(10)); 156 TimeDelta::FromMilliseconds(10));
(...skipping 19 matching lines...) Expand all
176 // Navigate to URL. First URL should use first RenderViewHost. 176 // Navigate to URL. First URL should use first RenderViewHost.
177 const GURL url("http://www.google.com"); 177 const GURL url("http://www.google.com");
178 controller().LoadURL( 178 controller().LoadURL(
179 url, Referrer(), PAGE_TRANSITION_TYPED, std::string()); 179 url, Referrer(), PAGE_TRANSITION_TYPED, std::string());
180 contents()->TestDidNavigate(rvh(), 1, url, PAGE_TRANSITION_TYPED); 180 contents()->TestDidNavigate(rvh(), 1, url, PAGE_TRANSITION_TYPED);
181 EXPECT_FALSE(contents()->cross_navigation_pending()); 181 EXPECT_FALSE(contents()->cross_navigation_pending());
182 182
183 TestDevToolsClientHost client_host; 183 TestDevToolsClientHost client_host;
184 DevToolsManager* devtools_manager = DevToolsManager::GetInstance(); 184 DevToolsManager* devtools_manager = DevToolsManager::GetInstance();
185 devtools_manager->RegisterDevToolsClientHostFor( 185 devtools_manager->RegisterDevToolsClientHostFor(
186 DevToolsAgentHost::GetOrCreateFor(rvh()).get(), &client_host); 186 DevToolsAgentHost::GetOrCreateFor(web_contents()).get(), &client_host);
187 187
188 // Navigate to new site which should get a new RenderViewHost. 188 // Navigate to new site which should get a new RenderViewHost.
189 const GURL url2("http://www.yahoo.com"); 189 const GURL url2("http://www.yahoo.com");
190 controller().LoadURL( 190 controller().LoadURL(
191 url2, Referrer(), PAGE_TRANSITION_TYPED, std::string()); 191 url2, Referrer(), PAGE_TRANSITION_TYPED, std::string());
192 EXPECT_TRUE(contents()->cross_navigation_pending()); 192 EXPECT_TRUE(contents()->cross_navigation_pending());
193 EXPECT_EQ(devtools_manager->GetDevToolsAgentHostFor(&client_host), 193 EXPECT_EQ(devtools_manager->GetDevToolsAgentHostFor(&client_host),
194 DevToolsAgentHost::GetOrCreateFor(pending_rvh())); 194 DevToolsAgentHost::GetOrCreateFor(web_contents()));
195 195
196 // Interrupt pending navigation and navigate back to the original site. 196 // Interrupt pending navigation and navigate back to the original site.
197 controller().LoadURL( 197 controller().LoadURL(
198 url, Referrer(), PAGE_TRANSITION_TYPED, std::string()); 198 url, Referrer(), PAGE_TRANSITION_TYPED, std::string());
199 contents()->TestDidNavigate(rvh(), 1, url, PAGE_TRANSITION_TYPED); 199 contents()->TestDidNavigate(rvh(), 1, url, PAGE_TRANSITION_TYPED);
200 EXPECT_FALSE(contents()->cross_navigation_pending()); 200 EXPECT_FALSE(contents()->cross_navigation_pending());
201 EXPECT_EQ(devtools_manager->GetDevToolsAgentHostFor(&client_host), 201 EXPECT_EQ(devtools_manager->GetDevToolsAgentHostFor(&client_host),
202 DevToolsAgentHost::GetOrCreateFor(rvh())); 202 DevToolsAgentHost::GetOrCreateFor(web_contents()));
203 client_host.Close(DevToolsManager::GetInstance()); 203 client_host.Close(DevToolsManager::GetInstance());
204 } 204 }
205 205
206 class TestExternalAgentDelegate: public DevToolsExternalAgentProxyDelegate { 206 class TestExternalAgentDelegate: public DevToolsExternalAgentProxyDelegate {
207 std::map<std::string,int> event_counter_; 207 std::map<std::string,int> event_counter_;
208 208
209 void recordEvent(const std::string& name) { 209 void recordEvent(const std::string& name) {
210 if (event_counter_.find(name) == event_counter_.end()) 210 if (event_counter_.find(name) == event_counter_.end())
211 event_counter_[name] = 0; 211 event_counter_[name] = 0;
212 event_counter_[name] = event_counter_[name] + 1; 212 event_counter_[name] = event_counter_[name] + 1;
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
251 manager->RegisterDevToolsClientHostFor(agent_host.get(), &client_host); 251 manager->RegisterDevToolsClientHostFor(agent_host.get(), &client_host);
252 252
253 manager->DispatchOnInspectorBackend(&client_host, "message1"); 253 manager->DispatchOnInspectorBackend(&client_host, "message1");
254 manager->DispatchOnInspectorBackend(&client_host, "message2"); 254 manager->DispatchOnInspectorBackend(&client_host, "message2");
255 manager->DispatchOnInspectorBackend(&client_host, "message2"); 255 manager->DispatchOnInspectorBackend(&client_host, "message2");
256 256
257 client_host.Close(manager); 257 client_host.Close(manager);
258 } 258 }
259 259
260 } // namespace content 260 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698