| OLD | NEW |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 |
| OLD | NEW |