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

Side by Side Diff: chrome/browser/chromeos/net/delay_network_call.cc

Issue 299403012: Clean up shill fake implementations (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase Created 6 years, 6 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 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 "chrome/browser/chromeos/net/delay_network_call.h" 5 #include "chrome/browser/chromeos/net/delay_network_call.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/callback.h" 8 #include "base/callback.h"
9 #include "chrome/browser/chromeos/net/network_portal_detector.h" 9 #include "chrome/browser/chromeos/net/network_portal_detector.h"
10 #include "chromeos/network/network_handler.h" 10 #include "chromeos/network/network_handler.h"
11 #include "chromeos/network/network_state.h" 11 #include "chromeos/network/network_state.h"
12 #include "chromeos/network/network_state_handler.h" 12 #include "chromeos/network/network_state_handler.h"
13 #include "content/public/browser/browser_thread.h" 13 #include "content/public/browser/browser_thread.h"
14 #include "third_party/cros_system_api/dbus/service_constants.h" 14 #include "third_party/cros_system_api/dbus/service_constants.h"
15 15
16 const unsigned chromeos::kDefaultNetworkRetryDelayMS = 3000; 16 const unsigned chromeos::kDefaultNetworkRetryDelayMS = 3000;
17 17
18 void chromeos::DelayNetworkCall(const base::Closure& callback, 18 void chromeos::DelayNetworkCall(const base::Closure& callback,
19 base::TimeDelta retry) { 19 base::TimeDelta retry) {
20 bool delay_network_call = false;
20 const NetworkState* default_network = 21 const NetworkState* default_network =
21 NetworkHandler::Get()->network_state_handler()->DefaultNetwork(); 22 NetworkHandler::Get()->network_state_handler()->DefaultNetwork();
22 bool delay_network_call = !default_network || 23 if (!default_network) {
23 !NetworkState::StateIsConnected(default_network->connection_state()); 24 delay_network_call = true;
25 DVLOG(1) << "DelayNetworkCall: No default network.";
26 } else {
27 std:: string default_connection_state = default_network->connection_state();
28 if (!NetworkState::StateIsConnected(default_connection_state)) {
29 delay_network_call = true;
30 DVLOG(1) << "DelayNetworkCall: "
31 << "Default network: " << default_network->name()
32 << " State: " << default_connection_state;
33 }
34 }
24 if (!delay_network_call && NetworkPortalDetector::IsInitialized()) { 35 if (!delay_network_call && NetworkPortalDetector::IsInitialized()) {
25 NetworkPortalDetector* detector = NetworkPortalDetector::Get(); 36 NetworkPortalDetector* detector = NetworkPortalDetector::Get();
26 if (detector->GetCaptivePortalState(default_network->path()).status != 37 NetworkPortalDetector::CaptivePortalStatus status =
27 NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE) 38 detector->GetCaptivePortalState(default_network->path()).status;
39 if (status != NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE) {
28 delay_network_call = true; 40 delay_network_call = true;
41 DVLOG(1) << "DelayNetworkCall: Captive portal status for "
42 << default_network->name() << ": "
43 << NetworkPortalDetector::CaptivePortalStatusString(status);
44 }
29 } 45 }
30 if (delay_network_call) { 46 if (delay_network_call) {
31 content::BrowserThread::PostDelayedTask( 47 content::BrowserThread::PostDelayedTask(
32 content::BrowserThread::UI, 48 content::BrowserThread::UI,
33 FROM_HERE, 49 FROM_HERE,
34 base::Bind(&chromeos::DelayNetworkCall, callback, retry), 50 base::Bind(&chromeos::DelayNetworkCall, callback, retry),
35 retry); 51 retry);
36 } else { 52 } else {
37 callback.Run(); 53 callback.Run();
38 } 54 }
39 } 55 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698