Chromium Code Reviews| 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 |