OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "chrome/browser/devtools/device/adb/adb_device_provider.h" | 5 #include "chrome/browser/devtools/device/adb/adb_device_provider.h" |
6 #include "chrome/browser/devtools/device/adb/mock_adb_server.h" | 6 #include "chrome/browser/devtools/device/adb/mock_adb_server.h" |
7 #include "chrome/browser/devtools/device/devtools_android_bridge.h" | 7 #include "chrome/browser/devtools/device/devtools_android_bridge.h" |
8 #include "chrome/browser/devtools/devtools_target_impl.h" | 8 #include "chrome/browser/devtools/devtools_target_impl.h" |
9 #include "chrome/browser/ui/browser.h" | 9 #include "chrome/browser/ui/browser.h" |
10 #include "chrome/test/base/in_process_browser_test.h" | 10 #include "chrome/test/base/in_process_browser_test.h" |
11 #include "content/public/browser/browser_thread.h" | 11 #include "content/public/browser/browser_thread.h" |
12 #include "content/public/test/test_utils.h" | 12 #include "content/public/test/test_utils.h" |
13 #include "net/base/net_errors.h" | |
13 | 14 |
14 using content::BrowserThread; | 15 using content::BrowserThread; |
15 | 16 |
16 static scoped_refptr<DevToolsAndroidBridge::RemoteBrowser> | 17 static scoped_refptr<DevToolsAndroidBridge::RemoteBrowser> |
17 FindBrowserByDisplayName(DevToolsAndroidBridge::RemoteBrowsers browsers, | 18 FindBrowserByDisplayName(DevToolsAndroidBridge::RemoteBrowsers browsers, |
18 const std::string& name) { | 19 const std::string& name) { |
19 for (DevToolsAndroidBridge::RemoteBrowsers::iterator it = browsers.begin(); | 20 for (DevToolsAndroidBridge::RemoteBrowsers::iterator it = browsers.begin(); |
20 it != browsers.end(); ++it) | 21 it != browsers.end(); ++it) |
21 if ((*it)->display_name() == name) | 22 if ((*it)->display_name() == name) |
22 return *it; | 23 return *it; |
23 return NULL; | 24 return NULL; |
24 } | 25 } |
25 | 26 |
27 static void ResponseReceived(int result, const std::string& response) { | |
28 ASSERT_EQ(net::OK, result); | |
29 base::MessageLoop::current()->QuitWhenIdle(); | |
30 } | |
31 | |
32 static void ConnectedReceived(bool expected, bool received) { | |
33 ASSERT_EQ(expected, received); | |
34 base::MessageLoop::current()->QuitWhenIdle(); | |
35 } | |
36 | |
26 class AdbClientSocketTest : public InProcessBrowserTest, | 37 class AdbClientSocketTest : public InProcessBrowserTest, |
27 public DevToolsAndroidBridge::DeviceListListener { | 38 public DevToolsAndroidBridge::DeviceListListener { |
28 | 39 |
29 public: | 40 public: |
30 void StartTest() { | 41 void StartTest() { |
31 Profile* profile = browser()->profile(); | 42 Profile* profile = browser()->profile(); |
32 android_bridge_ = DevToolsAndroidBridge::Factory::GetForProfile(profile); | 43 android_bridge_ = DevToolsAndroidBridge::Factory::GetForProfile(profile); |
33 AndroidDeviceManager::DeviceProviders device_providers; | 44 AndroidDeviceManager::DeviceProviders device_providers; |
34 device_providers.push_back(new AdbDeviceProvider()); | 45 device_providers.push_back(new AdbDeviceProvider()); |
35 android_bridge_->set_device_providers_for_test(device_providers); | 46 android_bridge_->set_device_providers_for_test(device_providers); |
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
110 | 121 |
111 ASSERT_EQ(GURL("http://www.chromium.org/"), | 122 ASSERT_EQ(GURL("http://www.chromium.org/"), |
112 chrome_pages[0]->GetTarget()->GetURL()); | 123 chrome_pages[0]->GetTarget()->GetURL()); |
113 ASSERT_EQ("The Chromium Projects", | 124 ASSERT_EQ("The Chromium Projects", |
114 chrome_pages[0]->GetTarget()->GetTitle()); | 125 chrome_pages[0]->GetTarget()->GetTitle()); |
115 | 126 |
116 STLDeleteElements(&chrome_pages); | 127 STLDeleteElements(&chrome_pages); |
117 STLDeleteElements(&webview_pages); | 128 STLDeleteElements(&webview_pages); |
118 } | 129 } |
119 | 130 |
131 void CheckConnection() { | |
132 ASSERT_EQ(2U, devices_.size()); | |
133 scoped_refptr<DevToolsAndroidBridge::RemoteDevice> connected = | |
134 devices_[0]->is_connected() ? devices_[0] : devices_[1]; | |
135 const DevToolsAndroidBridge::RemoteBrowsers& browsers = | |
136 connected->browsers(); | |
137 scoped_refptr<DevToolsAndroidBridge::RemoteBrowser> chrome = | |
138 FindBrowserByDisplayName(browsers, "Chrome"); | |
139 ASSERT_TRUE(chrome); | |
140 chrome->SendJsonRequest("GET /json/version HTTP/1.1\r\n\r\n", | |
Vladislav Kaznacheev
2014/05/19 10:32:11
Heads up: you will need to rebase because https://
vkuzkokov
2014/05/20 12:34:29
Done.
| |
141 base::Bind(&ResponseReceived)); | |
142 } | |
143 | |
144 void CheckCleanup() { | |
145 android_bridge_->IsConnectedForTest("01498B321301A00A", | |
146 base::Bind(&ConnectedReceived, true)); | |
147 content::RunMessageLoop(); | |
148 devices_.clear(); | |
149 android_bridge_->IsConnectedForTest("01498B321301A00A", | |
150 base::Bind(&ConnectedReceived, false)); | |
151 content::RunMessageLoop(); | |
152 } | |
153 | |
120 private: | 154 private: |
121 scoped_refptr<DevToolsAndroidBridge> android_bridge_; | 155 scoped_refptr<DevToolsAndroidBridge> android_bridge_; |
122 DevToolsAndroidBridge::RemoteDevices devices_; | 156 DevToolsAndroidBridge::RemoteDevices devices_; |
123 }; | 157 }; |
124 | 158 |
125 IN_PROC_BROWSER_TEST_F(AdbClientSocketTest, TestAdbClientSocket) { | 159 IN_PROC_BROWSER_TEST_F(AdbClientSocketTest, TestAdbClientSocket) { |
126 StartMockAdbServer(); | 160 StartMockAdbServer(); |
127 StartTest(); | 161 StartTest(); |
128 content::RunMessageLoop(); | 162 content::RunMessageLoop(); |
129 CheckDevices(); | 163 CheckDevices(); |
130 StopMockAdbServer(); | 164 StopMockAdbServer(); |
131 } | 165 } |
166 | |
167 // DevToolsAndroidBridge used to free connected devices when there are no | |
168 // listeners. We test that it's no longer the case. | |
169 IN_PROC_BROWSER_TEST_F(AdbClientSocketTest, TestRemoteConnection) { | |
170 StartMockAdbServer(); | |
171 StartTest(); | |
172 content::RunMessageLoop(); | |
Vladislav Kaznacheev
2014/05/19 10:32:11
We have discussed this but I forgot to write this
vkuzkokov
2014/05/20 12:34:29
Done.
| |
173 CheckConnection(); | |
174 content::RunMessageLoop(); | |
175 CheckCleanup(); | |
176 StopMockAdbServer(); | |
177 } | |
OLD | NEW |