Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 <algorithm> | |
| 6 #include <array> | |
| 7 | |
| 5 #include "base/values.h" | 8 #include "base/values.h" |
| 6 #include "chrome/browser/devtools/device/devtools_android_bridge.h" | 9 #include "chrome/browser/devtools/device/devtools_android_bridge.h" |
| 7 #include "chrome/browser/devtools/device/tcp_device_provider.h" | 10 #include "chrome/browser/devtools/device/tcp_device_provider.h" |
| 8 #include "chrome/browser/profiles/profile.h" | 11 #include "chrome/browser/profiles/profile.h" |
| 9 #include "chrome/browser/ui/browser.h" | 12 #include "chrome/browser/ui/browser.h" |
| 10 #include "chrome/common/chrome_switches.h" | 13 #include "chrome/common/chrome_switches.h" |
| 11 #include "chrome/common/pref_names.h" | 14 #include "chrome/common/pref_names.h" |
| 12 #include "chrome/test/base/in_process_browser_test.h" | 15 #include "chrome/test/base/in_process_browser_test.h" |
| 13 #include "chrome/test/base/ui_test_utils.h" | 16 #include "chrome/test/base/ui_test_utils.h" |
| 14 #include "components/prefs/pref_service.h" | 17 #include "components/prefs/pref_service.h" |
| 15 | 18 |
| 16 class DevToolsAndroidBridgeTest : public InProcessBrowserTest { | 19 class DevToolsAndroidBridgeTest : public InProcessBrowserTest { |
| 17 }; | 20 }; |
| 18 | 21 |
| 19 static void assign_from_callback(scoped_refptr<TCPDeviceProvider>* store, | 22 static void assign_from_callback(scoped_refptr<TCPDeviceProvider>* store, |
| 20 int* invocation_counter, | 23 int* invocation_counter, |
| 21 scoped_refptr<TCPDeviceProvider> value) { | 24 scoped_refptr<TCPDeviceProvider> value) { |
| 22 (*invocation_counter)++; | 25 (*invocation_counter)++; |
| 23 *store = value; | 26 *store = value; |
| 24 } | 27 } |
| 25 | 28 |
| 26 IN_PROC_BROWSER_TEST_F(DevToolsAndroidBridgeTest, UpdatesTargetDiscovery) { | 29 static std::string all_targets_string( |
|
dgozman
2016/08/29 22:28:21
AllTargetsString
eostroukhov
2016/08/29 23:19:36
Done.
| |
| 30 scoped_refptr<TCPDeviceProvider> provider) { | |
| 31 std::set<std::string> actual; | |
| 32 for (const net::HostPortPair& hostport : provider->get_targets_for_test()) | |
| 33 actual.insert(hostport.ToString()); | |
| 34 std::ostringstream result; | |
| 35 std::copy(actual.begin(), actual.end(), | |
| 36 std::ostream_iterator<std::string>(result, ", ")); | |
| 37 std::string result_string = result.str(); | |
| 38 return result_string.substr(0, result_string.length() - 2); | |
| 39 } | |
| 40 | |
| 41 IN_PROC_BROWSER_TEST_F(DevToolsAndroidBridgeTest, DiscoveryListChanges) { | |
| 27 Profile* profile = browser()->profile(); | 42 Profile* profile = browser()->profile(); |
| 28 | 43 |
| 29 PrefService* service = profile->GetPrefs(); | 44 PrefService* service = profile->GetPrefs(); |
| 30 service->ClearPref(prefs::kDevToolsTargetDiscoveryConfig); | 45 service->ClearPref(prefs::kDevToolsTCPDiscoveryConfig); |
| 46 service->SetBoolean(prefs::kDevToolsDiscoverTCPTargetsEnabled, true); | |
| 31 | 47 |
| 32 DevToolsAndroidBridge* bridge = | 48 DevToolsAndroidBridge* bridge = |
| 33 DevToolsAndroidBridge::Factory::GetForProfile(profile); | 49 DevToolsAndroidBridge::Factory::GetForProfile(profile); |
| 34 | 50 |
| 35 scoped_refptr<TCPDeviceProvider> provider; | 51 scoped_refptr<TCPDeviceProvider> provider; |
| 36 int called = 0; | 52 int called = 0; |
| 37 bridge->set_tcp_provider_callback_for_test( | 53 bridge->set_tcp_provider_callback_for_test( |
| 38 base::Bind(assign_from_callback, &provider, &called)); | 54 base::Bind(assign_from_callback, &provider, &called)); |
| 39 | 55 |
| 40 EXPECT_LT(0, called); | 56 EXPECT_LT(0, called); |
| 41 EXPECT_EQ(nullptr, provider); | 57 EXPECT_NE(nullptr, provider); |
| 58 | |
| 59 EXPECT_STREQ("localhost:9222, localhost:9229", | |
| 60 all_targets_string(provider).c_str()); | |
| 42 | 61 |
| 43 int invocations = called; | 62 int invocations = called; |
| 44 base::ListValue list; | 63 base::ListValue list; |
| 45 list.AppendString("somehost:2000"); | 64 list.AppendString("somehost:2000"); |
| 46 | 65 |
| 47 service->Set(prefs::kDevToolsTargetDiscoveryConfig, list); | 66 service->Set(prefs::kDevToolsTCPDiscoveryConfig, list); |
| 48 | 67 |
| 49 EXPECT_LT(invocations, called); | 68 EXPECT_LT(invocations, called); |
| 50 EXPECT_NE(nullptr, provider); | 69 EXPECT_NE(nullptr, provider); |
| 51 std::set<net::HostPortPair> pairs = provider->get_targets_for_test(); | 70 EXPECT_STREQ("somehost:2000", all_targets_string(provider).c_str()); |
| 52 EXPECT_EQ(1UL, pairs.size()); | |
| 53 net::HostPortPair pair = *pairs.begin(); | |
| 54 EXPECT_EQ(2000, pair.port()); | |
| 55 EXPECT_EQ("somehost", pair.HostForURL()); | |
| 56 | 71 |
| 57 invocations = called; | 72 invocations = called; |
| 58 list.Clear(); | 73 list.Clear(); |
| 59 service->Set(prefs::kDevToolsTargetDiscoveryConfig, list); | 74 service->Set(prefs::kDevToolsTCPDiscoveryConfig, list); |
| 60 | 75 |
| 61 EXPECT_LT(invocations, called); | 76 EXPECT_LT(invocations, called); |
| 62 EXPECT_EQ(nullptr, provider); | 77 EXPECT_EQ(nullptr, provider); |
| 63 invocations = called; | 78 invocations = called; |
| 64 | 79 |
| 65 list.AppendString("b:1"); | 80 list.AppendString("b:1"); |
| 66 list.AppendString("c:2"); | 81 list.AppendString("c:2"); |
| 67 list.AppendString("<not really a good address."); | 82 list.AppendString("<not really a good address."); |
| 68 list.AppendString("d:3"); | 83 list.AppendString("d:3"); |
| 69 list.AppendString("c:2"); | 84 list.AppendString("c:2"); |
| 70 service->Set(prefs::kDevToolsTargetDiscoveryConfig, list); | 85 service->Set(prefs::kDevToolsTCPDiscoveryConfig, list); |
| 71 | 86 |
| 72 EXPECT_LT(invocations, called); | 87 EXPECT_LT(invocations, called); |
| 73 EXPECT_NE(nullptr, provider); | 88 EXPECT_NE(nullptr, provider); |
| 74 pairs = provider->get_targets_for_test(); | 89 EXPECT_STREQ("b:1, c:2, d:3", all_targets_string(provider).c_str()); |
| 75 EXPECT_EQ(3UL, pairs.size()); | 90 } |
| 76 for (const net::HostPortPair pair : pairs) { | 91 |
| 77 EXPECT_EQ(pair.port(), pair.HostForURL()[0] - 'a'); | 92 |
| 93 IN_PROC_BROWSER_TEST_F(DevToolsAndroidBridgeTest, DefaultValues) { | |
| 94 Profile* profile = browser()->profile(); | |
| 95 | |
| 96 PrefService* service = profile->GetPrefs(); | |
| 97 DevToolsAndroidBridge::Factory::GetForProfile(profile); | |
| 98 service->ClearPref(prefs::kDevToolsDiscoverTCPTargetsEnabled); | |
| 99 service->ClearPref(prefs::kDevToolsTCPDiscoveryConfig); | |
| 100 | |
| 101 const base::ListValue* targets = | |
| 102 service->GetList(prefs::kDevToolsTCPDiscoveryConfig); | |
| 103 EXPECT_NE(nullptr, targets); | |
| 104 EXPECT_EQ(2ul, targets->GetSize()); | |
| 105 | |
| 106 int matched_mask = 0; | |
| 107 std::array<std::string, 2> EXPECTED_TARGETS = | |
|
dgozman
2016/08/29 22:28:21
expected_targets
eostroukhov
2016/08/29 23:19:36
Done (by removing this line - no longer needed).
| |
| 108 {{"localhost:9222", "localhost:9229"}}; | |
| 109 | |
| 110 for (size_t i = 0; i < targets->GetSize(); i++) { | |
| 111 std::string target; | |
| 112 EXPECT_TRUE(targets->GetString(i, &target)); | |
| 113 for (size_t j = 0; j < EXPECTED_TARGETS.size(); j++) { | |
| 114 if (target == EXPECTED_TARGETS[j]) { | |
| 115 matched_mask |= 1 << j; | |
| 116 } | |
| 117 } | |
| 78 } | 118 } |
| 119 | |
| 120 EXPECT_FALSE(service->GetBoolean(prefs::kDevToolsDiscoverTCPTargetsEnabled)); | |
| 121 | |
| 122 EXPECT_EQ(3, matched_mask); | |
|
dgozman
2016/08/29 22:28:21
I still don't understand why not just sort them?
eostroukhov
2016/08/29 23:19:36
At some point I was outputting indexes... Fixed.
| |
| 79 } | 123 } |
| 124 | |
| 125 | |
| 126 IN_PROC_BROWSER_TEST_F(DevToolsAndroidBridgeTest, TCPEnableChange) { | |
| 127 Profile* profile = browser()->profile(); | |
| 128 | |
| 129 PrefService* service = profile->GetPrefs(); | |
| 130 service->ClearPref(prefs::kDevToolsTCPDiscoveryConfig); | |
| 131 service->ClearPref(prefs::kDevToolsDiscoverTCPTargetsEnabled); | |
| 132 | |
| 133 DevToolsAndroidBridge* bridge = | |
| 134 DevToolsAndroidBridge::Factory::GetForProfile(profile); | |
| 135 | |
| 136 scoped_refptr<TCPDeviceProvider> provider; | |
| 137 int called = 0; | |
| 138 bridge->set_tcp_provider_callback_for_test( | |
| 139 base::Bind(assign_from_callback, &provider, &called)); | |
| 140 | |
| 141 EXPECT_EQ(nullptr, provider); | |
| 142 | |
| 143 service->SetBoolean(prefs::kDevToolsDiscoverTCPTargetsEnabled, true); | |
| 144 | |
| 145 EXPECT_NE(nullptr, provider); | |
| 146 EXPECT_STREQ("localhost:9222, localhost:9229", | |
| 147 all_targets_string(provider).c_str()); | |
| 148 | |
| 149 service->SetBoolean(prefs::kDevToolsDiscoverTCPTargetsEnabled, false); | |
| 150 | |
| 151 EXPECT_EQ(nullptr, provider); | |
| 152 } | |
| OLD | NEW |