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