Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(295)

Side by Side Diff: chrome/browser/chromeos/login/screens/update_screen_browsertest.cc

Issue 14134007: NetworkPortalDetector/NetworkStateInformer: Switch over to use NetworkStateHandler (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: add proxy_config Created 7 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698