OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/memory/scoped_ptr.h" | 6 #include "base/memory/scoped_ptr.h" |
7 #include "chrome/browser/chromeos/cros/mock_network_library.h" | 7 #include "chrome/browser/chromeos/cros/mock_network_library.h" |
8 #include "chrome/browser/chromeos/login/screens/mock_error_screen.h" | 8 #include "chrome/browser/chromeos/login/screens/mock_error_screen.h" |
9 #include "chrome/browser/chromeos/login/screens/mock_screen_observer.h" | 9 #include "chrome/browser/chromeos/login/screens/mock_screen_observer.h" |
10 #include "chrome/browser/chromeos/login/screens/update_screen.h" | 10 #include "chrome/browser/chromeos/login/screens/update_screen.h" |
11 #include "chrome/browser/chromeos/login/wizard_controller.h" | 11 #include "chrome/browser/chromeos/login/wizard_controller.h" |
12 #include "chrome/browser/chromeos/login/wizard_in_process_browser_test.h" | 12 #include "chrome/browser/chromeos/login/wizard_in_process_browser_test.h" |
13 #include "chrome/browser/chromeos/net/network_portal_detector.h" | 13 #include "chrome/browser/chromeos/net/network_portal_detector.h" |
14 #include "chrome/browser/chromeos/net/network_portal_detector_stub.h" | 14 #include "chrome/browser/chromeos/net/network_portal_detector_stub.h" |
15 #include "chromeos/chromeos_switches.h" | 15 #include "chromeos/chromeos_switches.h" |
16 #include "chromeos/dbus/mock_dbus_thread_manager.h" | 16 #include "chromeos/dbus/mock_dbus_thread_manager.h" |
17 #include "chromeos/dbus/mock_session_manager_client.h" | 17 #include "chromeos/dbus/mock_session_manager_client.h" |
18 #include "chromeos/dbus/mock_update_engine_client.h" | 18 #include "chromeos/dbus/mock_update_engine_client.h" |
19 #include "chromeos/network/network_state.h" | |
19 #include "testing/gmock/include/gmock/gmock.h" | 20 #include "testing/gmock/include/gmock/gmock.h" |
20 #include "testing/gtest/include/gtest/gtest.h" | 21 #include "testing/gtest/include/gtest/gtest.h" |
21 | 22 |
22 using ::testing::_; | 23 using ::testing::_; |
23 using ::testing::AnyNumber; | 24 using ::testing::AnyNumber; |
24 using ::testing::AtLeast; | 25 using ::testing::AtLeast; |
25 using ::testing::Invoke; | 26 using ::testing::Invoke; |
26 using ::testing::Return; | 27 using ::testing::Return; |
27 | 28 |
28 namespace chromeos { | 29 namespace chromeos { |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
71 // should be set up here. | 72 // should be set up here. |
72 EXPECT_CALL(*mock_update_engine_client_, AddObserver(_)) | 73 EXPECT_CALL(*mock_update_engine_client_, AddObserver(_)) |
73 .Times(AtLeast(1)); | 74 .Times(AtLeast(1)); |
74 EXPECT_CALL(*mock_update_engine_client_, RemoveObserver(_)) | 75 EXPECT_CALL(*mock_update_engine_client_, RemoveObserver(_)) |
75 .Times(AtLeast(1)); | 76 .Times(AtLeast(1)); |
76 EXPECT_CALL(*mock_update_engine_client_, RequestUpdateCheck(_)) | 77 EXPECT_CALL(*mock_update_engine_client_, RequestUpdateCheck(_)) |
77 .Times(1) | 78 .Times(1) |
78 .WillOnce(Invoke(RequestUpdateCheckSuccess)); | 79 .WillOnce(Invoke(RequestUpdateCheckSuccess)); |
79 | 80 |
80 mock_network_library_ = cros_mock_->mock_network_library(); | 81 mock_network_library_ = cros_mock_->mock_network_library(); |
81 stub_ethernet_.reset(new EthernetNetwork(kDefaultEthernetServicePath)); | |
82 stub_wifi_.reset(new WifiNetwork(kDefaultWifiServicePath)); | |
83 EXPECT_CALL(*mock_network_library_, SetDefaultCheckPortalList()) | 82 EXPECT_CALL(*mock_network_library_, SetDefaultCheckPortalList()) |
84 .Times(1); | 83 .Times(1); |
85 EXPECT_CALL(*mock_network_library_, AddNetworkManagerObserver(_)) | |
86 .Times(1) | |
87 .RetiresOnSaturation(); | |
88 EXPECT_CALL(*mock_network_library_, AddUserActionObserver(_)) | |
89 .Times(AnyNumber()); | |
90 EXPECT_CALL(*mock_network_library_, FindWifiDevice()) | |
91 .Times(AnyNumber()); | |
92 EXPECT_CALL(*mock_network_library_, FindEthernetDevice()) | |
93 .Times(AnyNumber()); | |
94 EXPECT_CALL(*mock_network_library_, LoadOncNetworks(_, _)) | 84 EXPECT_CALL(*mock_network_library_, LoadOncNetworks(_, _)) |
95 .Times(AnyNumber()); | 85 .Times(AnyNumber()); |
96 EXPECT_CALL(*mock_network_library_, | |
97 FindNetworkByPath(kDefaultEthernetServicePath)) | |
98 .Times(AnyNumber()) | |
99 .WillRepeatedly((Return(stub_ethernet_.get()))); | |
100 EXPECT_CALL(*mock_network_library_, | |
101 FindNetworkByPath(kDefaultWifiServicePath)) | |
102 .Times(AnyNumber()) | |
103 .WillRepeatedly((Return(stub_wifi_.get()))); | |
104 | 86 |
105 // Setup network portal detector to return online state for both | 87 // Setup network portal detector to return online state for both |
106 // ethernet and wifi networks. Ethernet is an active network by | 88 // ethernet and wifi networks. Ethernet is an active network by |
107 // default. | 89 // default. |
108 network_portal_detector_stub_ = | 90 network_portal_detector_stub_ = |
109 static_cast<NetworkPortalDetectorStub*>( | 91 static_cast<NetworkPortalDetectorStub*>( |
110 NetworkPortalDetector::GetInstance()); | 92 NetworkPortalDetector::GetInstance()); |
111 NetworkPortalDetector::CaptivePortalState online_state; | 93 NetworkPortalDetector::CaptivePortalState online_state; |
112 online_state.status = NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE; | 94 online_state.status = NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE; |
113 online_state.response_code = 204; | 95 online_state.response_code = 204; |
114 SetActiveNetwork(stub_ethernet_.get()); | 96 stub_ethernet_.reset(new NetworkState(kDefaultEthernetServicePath)); |
97 stub_wifi_.reset(new NetworkState(kDefaultWifiServicePath)); | |
98 SetDefaultNetwork(stub_ethernet_.get()); | |
115 SetDetectionResults(stub_ethernet_.get(), online_state); | 99 SetDetectionResults(stub_ethernet_.get(), online_state); |
116 SetDetectionResults(stub_wifi_.get(), online_state); | 100 SetDetectionResults(stub_wifi_.get(), online_state); |
117 } | 101 } |
118 | 102 |
119 virtual void SetUpOnMainThread() OVERRIDE { | 103 virtual void SetUpOnMainThread() OVERRIDE { |
120 WizardInProcessBrowserTest::SetUpOnMainThread(); | 104 WizardInProcessBrowserTest::SetUpOnMainThread(); |
121 | 105 |
122 mock_screen_observer_.reset(new MockScreenObserver()); | 106 mock_screen_observer_.reset(new MockScreenObserver()); |
123 mock_error_screen_actor_.reset(new MockErrorScreenActor()); | 107 mock_error_screen_actor_.reset(new MockErrorScreenActor()); |
124 mock_error_screen_.reset( | 108 mock_error_screen_.reset( |
(...skipping 11 matching lines...) Expand all Loading... | |
136 ASSERT_EQ(WizardController::default_controller()->current_screen(), | 120 ASSERT_EQ(WizardController::default_controller()->current_screen(), |
137 update_screen_); | 121 update_screen_); |
138 update_screen_->screen_observer_ = mock_screen_observer_.get(); | 122 update_screen_->screen_observer_ = mock_screen_observer_.get(); |
139 } | 123 } |
140 | 124 |
141 virtual void TearDownInProcessBrowserTestFixture() OVERRIDE { | 125 virtual void TearDownInProcessBrowserTestFixture() OVERRIDE { |
142 WizardInProcessBrowserTest::TearDownInProcessBrowserTestFixture(); | 126 WizardInProcessBrowserTest::TearDownInProcessBrowserTestFixture(); |
143 DBusThreadManager::Shutdown(); | 127 DBusThreadManager::Shutdown(); |
144 } | 128 } |
145 | 129 |
146 void SetActiveNetwork(const Network* network) { | 130 void SetDefaultNetwork(const NetworkState* network) { |
147 DCHECK(network_portal_detector_stub_); | 131 DCHECK(network_portal_detector_stub_); |
148 network_portal_detector_stub_->SetActiveNetworkForTesting(network); | 132 network_portal_detector_stub_->SetDefaultNetworkForTesting(network); |
149 } | 133 } |
150 | 134 |
151 void SetDetectionResults( | 135 void SetDetectionResults( |
152 const Network* network, | 136 const NetworkState* network, |
153 const NetworkPortalDetector::CaptivePortalState& state) { | 137 const NetworkPortalDetector::CaptivePortalState& state) { |
154 DCHECK(network_portal_detector_stub_); | 138 DCHECK(network_portal_detector_stub_); |
155 network_portal_detector_stub_->SetDetectionResultsForTesting(network, | 139 network_portal_detector_stub_->SetDetectionResultsForTesting(network, |
156 state); | 140 state); |
157 } | 141 } |
158 | 142 |
159 void NotifyPortalDetectionCompleted() { | 143 void NotifyPortalDetectionCompleted() { |
160 DCHECK(network_portal_detector_stub_); | 144 DCHECK(network_portal_detector_stub_); |
161 network_portal_detector_stub_->NotifyObserversForTesting(); | 145 network_portal_detector_stub_->NotifyObserversForTesting(); |
162 } | 146 } |
163 | 147 |
164 MockUpdateEngineClient* mock_update_engine_client_; | 148 MockUpdateEngineClient* mock_update_engine_client_; |
165 MockNetworkLibrary* mock_network_library_; | 149 MockNetworkLibrary* mock_network_library_; |
166 scoped_ptr<Network> stub_ethernet_; | 150 scoped_ptr<NetworkState> stub_ethernet_; |
pneubeck (no reviews)
2013/05/02 22:11:13
scoped_ptr is not necessary, you can use normal me
gauravsh
2013/05/07 23:38:10
Done.
| |
167 scoped_ptr<Network> stub_wifi_; | 151 scoped_ptr<NetworkState> stub_wifi_; |
168 scoped_ptr<MockScreenObserver> mock_screen_observer_; | 152 scoped_ptr<MockScreenObserver> mock_screen_observer_; |
169 scoped_ptr<MockErrorScreenActor> mock_error_screen_actor_; | 153 scoped_ptr<MockErrorScreenActor> mock_error_screen_actor_; |
170 scoped_ptr<MockErrorScreen> mock_error_screen_; | 154 scoped_ptr<MockErrorScreen> mock_error_screen_; |
171 UpdateScreen* update_screen_; | 155 UpdateScreen* update_screen_; |
172 NetworkPortalDetectorStub* network_portal_detector_stub_; | 156 NetworkPortalDetectorStub* network_portal_detector_stub_; |
173 | 157 |
174 private: | 158 private: |
175 DISALLOW_COPY_AND_ASSIGN(UpdateScreenTest); | 159 DISALLOW_COPY_AND_ASSIGN(UpdateScreenTest); |
176 }; | 160 }; |
177 | 161 |
(...skipping 184 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
362 EXPECT_CALL(*mock_screen_observer_, ShowErrorScreen()) | 346 EXPECT_CALL(*mock_screen_observer_, ShowErrorScreen()) |
363 .Times(1); | 347 .Times(1); |
364 | 348 |
365 update_screen_->StartNetworkCheck(); | 349 update_screen_->StartNetworkCheck(); |
366 | 350 |
367 // Change active network to the wifi behind proxy. | 351 // Change active network to the wifi behind proxy. |
368 NetworkPortalDetector::CaptivePortalState proxy_state; | 352 NetworkPortalDetector::CaptivePortalState proxy_state; |
369 proxy_state.status = | 353 proxy_state.status = |
370 NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_PROXY_AUTH_REQUIRED; | 354 NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_PROXY_AUTH_REQUIRED; |
371 proxy_state.response_code = -1; | 355 proxy_state.response_code = -1; |
372 SetActiveNetwork(stub_wifi_.get()); | 356 SetDefaultNetwork(stub_wifi_.get()); |
373 SetDetectionResults(stub_wifi_.get(), proxy_state); | 357 SetDetectionResults(stub_wifi_.get(), proxy_state); |
374 | 358 |
375 // Update screen will show message about proxy error because wifie | 359 // Update screen will show message about proxy error because wifie |
376 // network requires proxy authentication. | 360 // network requires proxy authentication. |
377 EXPECT_CALL(*mock_error_screen_actor_, | 361 EXPECT_CALL(*mock_error_screen_actor_, |
378 SetErrorState(ErrorScreen::ERROR_STATE_PROXY, std::string())) | 362 SetErrorState(ErrorScreen::ERROR_STATE_PROXY, std::string())) |
379 .Times(1); | 363 .Times(1); |
380 | 364 |
381 NotifyPortalDetectionCompleted(); | 365 NotifyPortalDetectionCompleted(); |
382 } | 366 } |
383 | 367 |
384 } // namespace chromeos | 368 } // namespace chromeos |
OLD | NEW |