Chromium Code Reviews| Index: content/browser/net_info_browsertest.cc |
| diff --git a/content/browser/net_info_browsertest.cc b/content/browser/net_info_browsertest.cc |
| index 67d939176a2c0e29520bf9a4af4ff83e5a0c1211..4a083c360ab7cda44846771fee2ad57060ea58f3 100644 |
| --- a/content/browser/net_info_browsertest.cc |
| +++ b/content/browser/net_info_browsertest.cc |
| @@ -4,6 +4,7 @@ |
| #include "base/command_line.h" |
| #include "base/run_loop.h" |
| +#include "base/strings/string_number_conversions.h" |
| #include "content/public/common/content_switches.h" |
| #include "content/public/test/browser_test_utils.h" |
| #include "content/public/test/content_browser_test.h" |
| @@ -12,22 +13,31 @@ |
| #include "net/base/network_change_notifier.h" |
| #include "net/base/network_change_notifier_factory.h" |
| +namespace content { |
| + |
| +using net::NetworkChangeNotifier; |
| + |
| class NetInfoBrowserTest : public content::ContentBrowserTest { |
| protected: |
| void SetUpCommandLine(base::CommandLine* command_line) override { |
| // TODO(jkarlin): Once NetInfo is enabled on all platforms remove this |
| // switch. |
| command_line->AppendSwitch(switches::kEnableNetworkInformation); |
| + |
| + // TODO(jkarlin): Remove this once downlinkMax is no longer |
| + // experimental. |
| + command_line->AppendSwitch( |
| + switches::kEnableExperimentalWebPlatformFeatures); |
| } |
| void SetUp() override { |
| - net::NetworkChangeNotifier::SetTestNotificationsOnly(true); |
| + NetworkChangeNotifier::SetTestNotificationsOnly(true); |
| #if defined(OS_CHROMEOS) |
| // ChromeOS's NetworkChangeNotifier isn't known to content and therefore |
| // doesn't get created in content_browsertests. Insert a mock |
| // NetworkChangeNotifier. |
| - net::NetworkChangeNotifier::CreateMock(); |
| + NetworkChangeNotifier::CreateMock(); |
| #endif |
| content::ContentBrowserTest::SetUp(); |
| @@ -38,12 +48,18 @@ class NetInfoBrowserTest : public content::ContentBrowserTest { |
| } |
| static void SetConnectionType( |
| - net::NetworkChangeNotifier::ConnectionType type) { |
| - net::NetworkChangeNotifier::NotifyObserversOfConnectionTypeChangeForTests( |
| - type); |
| + NetworkChangeNotifier::ConnectionType type, |
| + NetworkChangeNotifier::ConnectionSubtype subtype) { |
| + NetworkChangeNotifier::NotifyObserversOfMaxBandwidthChangeForTests( |
| + type, GetMaxBandwidthForSubtype(subtype)); |
| base::RunLoop().RunUntilIdle(); |
| } |
| + static double GetMaxBandwidthForSubtype( |
| + NetworkChangeNotifier::ConnectionSubtype subtype) { |
| + return NetworkChangeNotifier::GetMaxBandwidthForConnectionSubtype(subtype); |
| + } |
|
pauljensen
2015/09/11 14:25:37
Now that you unprotected NCN::GetMaxBandwidthForCo
jkarlin
2015/09/11 20:15:21
Done.
|
| + |
| std::string RunScriptExtractString(const std::string& script) { |
| std::string data; |
| EXPECT_TRUE( |
| @@ -57,26 +73,45 @@ class NetInfoBrowserTest : public content::ContentBrowserTest { |
| ExecuteScriptAndExtractBool(shell()->web_contents(), script, &data)); |
| return data; |
| } |
| + |
| + double RunScriptExtractDouble(const std::string& script) { |
| + double data = 0.0; |
| + EXPECT_TRUE(base::StringToDouble(RunScriptExtractString(script), &data)); |
| + return data; |
| + } |
| }; |
| // Make sure that type changes in the browser make their way to |
| // navigator.connection.type. |
| IN_PROC_BROWSER_TEST_F(NetInfoBrowserTest, NetworkChangePlumbsToNavigator) { |
| NavigateToURL(shell(), content::GetTestUrl("", "net_info.html")); |
| - SetConnectionType(net::NetworkChangeNotifier::CONNECTION_WIFI); |
| + SetConnectionType(NetworkChangeNotifier::CONNECTION_WIFI, |
| + NetworkChangeNotifier::SUBTYPE_WIFI_N); |
| EXPECT_EQ("wifi", RunScriptExtractString("getType()")); |
| - SetConnectionType(net::NetworkChangeNotifier::CONNECTION_ETHERNET); |
| + EXPECT_EQ(GetMaxBandwidthForSubtype(NetworkChangeNotifier::SUBTYPE_WIFI_N), |
| + RunScriptExtractDouble("getDownlinkMax()")); |
| + |
| + SetConnectionType(NetworkChangeNotifier::CONNECTION_ETHERNET, |
| + NetworkChangeNotifier::SUBTYPE_GIGABIT_ETHERNET); |
| EXPECT_EQ("ethernet", RunScriptExtractString("getType()")); |
| + EXPECT_EQ(GetMaxBandwidthForSubtype( |
| + NetworkChangeNotifier::SUBTYPE_GIGABIT_ETHERNET), |
| + RunScriptExtractDouble("getDownlinkMax()")); |
| } |
| // Make sure that type changes in the browser make their way to |
| // navigator.isOnline. |
| IN_PROC_BROWSER_TEST_F(NetInfoBrowserTest, IsOnline) { |
| NavigateToURL(shell(), content::GetTestUrl("", "net_info.html")); |
| - SetConnectionType(net::NetworkChangeNotifier::CONNECTION_ETHERNET); |
| + SetConnectionType(NetworkChangeNotifier::CONNECTION_ETHERNET, |
| + NetworkChangeNotifier::SUBTYPE_GIGABIT_ETHERNET); |
| EXPECT_TRUE(RunScriptExtractBool("getOnLine()")); |
| - SetConnectionType(net::NetworkChangeNotifier::CONNECTION_NONE); |
| + SetConnectionType(NetworkChangeNotifier::CONNECTION_NONE, |
| + NetworkChangeNotifier::SUBTYPE_NONE); |
| EXPECT_FALSE(RunScriptExtractBool("getOnLine()")); |
| - SetConnectionType(net::NetworkChangeNotifier::CONNECTION_WIFI); |
| + SetConnectionType(NetworkChangeNotifier::CONNECTION_WIFI, |
| + NetworkChangeNotifier::SUBTYPE_WIFI_N); |
| EXPECT_TRUE(RunScriptExtractBool("getOnLine()")); |
| } |
| + |
| +} // namespace content |