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 "base/command_line.h" | 5 #include "base/command_line.h" |
6 #include "base/run_loop.h" | 6 #include "base/run_loop.h" |
7 #include "content/public/common/content_switches.h" | 7 #include "content/public/common/content_switches.h" |
8 #include "content/public/test/browser_test_utils.h" | 8 #include "content/public/test/browser_test_utils.h" |
9 #include "content/public/test/content_browser_test.h" | 9 #include "content/public/test/content_browser_test.h" |
10 #include "content/public/test/content_browser_test_utils.h" | 10 #include "content/public/test/content_browser_test_utils.h" |
11 #include "content/shell/browser/shell.h" | 11 #include "content/shell/browser/shell.h" |
12 #include "net/base/network_change_notifier.h" | 12 #include "net/base/network_change_notifier.h" |
13 #include "net/base/network_change_notifier_factory.h" | 13 #include "net/base/network_change_notifier_factory.h" |
14 | 14 |
15 class NetInfoBrowserTest : public content::ContentBrowserTest { | 15 class NetInfoBrowserTest : public content::ContentBrowserTest { |
16 protected: | 16 protected: |
17 void SetUpCommandLine(base::CommandLine* command_line) override { | 17 void SetUpCommandLine(base::CommandLine* command_line) override { |
18 // TODO(jkarlin): Once NetInfo is enabled on all platforms remove this | 18 // TODO(jkarlin): Once NetInfo is enabled on all platforms remove this |
19 // switch. | 19 // switch. |
20 command_line->AppendSwitch(switches::kEnableNetworkInformation); | 20 command_line->AppendSwitch(switches::kEnableNetworkInformation); |
21 } | 21 } |
22 | 22 |
| 23 void SetUp() override { |
| 24 net::NetworkChangeNotifier::SetTestNotificationsOnly(true); |
| 25 |
23 #if defined(OS_CHROMEOS) | 26 #if defined(OS_CHROMEOS) |
24 void SetUp() override { | |
25 // ChromeOS's NetworkChangeNotifier isn't known to content and therefore | 27 // ChromeOS's NetworkChangeNotifier isn't known to content and therefore |
26 // doesn't get created in content_browsertests. Insert a mock | 28 // doesn't get created in content_browsertests. Insert a mock |
27 // NetworkChangeNotifier. | 29 // NetworkChangeNotifier. |
28 net::NetworkChangeNotifier::CreateMock(); | 30 net::NetworkChangeNotifier::CreateMock(); |
| 31 #endif |
| 32 |
29 content::ContentBrowserTest::SetUp(); | 33 content::ContentBrowserTest::SetUp(); |
30 } | 34 } |
31 #endif | |
32 | 35 |
33 void SetUpOnMainThread() override { | 36 void SetUpOnMainThread() override { |
34 net::NetworkChangeNotifier::SetTestNotificationsOnly(true); | |
35 base::RunLoop().RunUntilIdle(); | 37 base::RunLoop().RunUntilIdle(); |
36 } | 38 } |
37 | 39 |
38 static void SetConnectionType( | 40 static void SetConnectionType( |
39 net::NetworkChangeNotifier::ConnectionType type) { | 41 net::NetworkChangeNotifier::ConnectionType type) { |
40 net::NetworkChangeNotifier::NotifyObserversOfConnectionTypeChangeForTests( | 42 net::NetworkChangeNotifier::NotifyObserversOfConnectionTypeChangeForTests( |
41 type); | 43 type); |
42 base::RunLoop().RunUntilIdle(); | 44 base::RunLoop().RunUntilIdle(); |
43 } | 45 } |
44 | 46 |
(...skipping 26 matching lines...) Expand all Loading... |
71 // navigator.isOnline. | 73 // navigator.isOnline. |
72 IN_PROC_BROWSER_TEST_F(NetInfoBrowserTest, IsOnline) { | 74 IN_PROC_BROWSER_TEST_F(NetInfoBrowserTest, IsOnline) { |
73 NavigateToURL(shell(), content::GetTestUrl("", "net_info.html")); | 75 NavigateToURL(shell(), content::GetTestUrl("", "net_info.html")); |
74 SetConnectionType(net::NetworkChangeNotifier::CONNECTION_ETHERNET); | 76 SetConnectionType(net::NetworkChangeNotifier::CONNECTION_ETHERNET); |
75 EXPECT_TRUE(RunScriptExtractBool("getOnLine()")); | 77 EXPECT_TRUE(RunScriptExtractBool("getOnLine()")); |
76 SetConnectionType(net::NetworkChangeNotifier::CONNECTION_NONE); | 78 SetConnectionType(net::NetworkChangeNotifier::CONNECTION_NONE); |
77 EXPECT_FALSE(RunScriptExtractBool("getOnLine()")); | 79 EXPECT_FALSE(RunScriptExtractBool("getOnLine()")); |
78 SetConnectionType(net::NetworkChangeNotifier::CONNECTION_WIFI); | 80 SetConnectionType(net::NetworkChangeNotifier::CONNECTION_WIFI); |
79 EXPECT_TRUE(RunScriptExtractBool("getOnLine()")); | 81 EXPECT_TRUE(RunScriptExtractBool("getOnLine()")); |
80 } | 82 } |
OLD | NEW |