diff options
author | stevenjb@google.com <stevenjb@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-06-19 22:46:20 +0000 |
---|---|---|
committer | stevenjb@google.com <stevenjb@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-06-19 22:46:20 +0000 |
commit | 7aef595332fb0070e8bbcd99ea5539ece1e20fc0 (patch) | |
tree | 2c13bc407f29da9907a0fdb724ff01cb94dc24c6 | |
parent | d44c8884770a03e81726ab774ecd4a501c2c2a69 (diff) | |
download | chromium_src-7aef595332fb0070e8bbcd99ea5539ece1e20fc0.zip chromium_src-7aef595332fb0070e8bbcd99ea5539ece1e20fc0.tar.gz chromium_src-7aef595332fb0070e8bbcd99ea5539ece1e20fc0.tar.bz2 |
Add a CONNECT_REQUESTED state to Network ConnectionState.
When a connection request is made, Chrome now sets the state to CONNECT_REQUESTED and ignores "Idle" state updates while in that state.
This informs the UI to show "connecting" icons / text until the connection attempt succeeds or fails.
Also: Don't update the network icon while scanning.
Also: includes a bunch of logging changes for improved debugging.
This alos fixes the mock expectations so that browser_tests should pass.
Original CL: https://chromiumcodereview.appspot.com/10554013
BUG=125121
TEST=See issue, test connecting between networks, UI should behave correctly.
For chrome/browser/chromeos/gdata:
TBR=gspencer@chromium.org, tbarzic@chromium.org
Review URL: https://chromiumcodereview.appspot.com/10579022
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@143072 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/app/generated_resources.grd | 3 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/cros_mock.cc | 5 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/cros_network_functions.cc | 1 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/network_constants.h | 3 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/network_library.cc | 72 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/network_library.h | 25 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/network_library_impl_base.cc | 2 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/network_library_impl_cros.cc | 12 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/network_library_impl_stub.cc | 14 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/network_library_unittest.cc | 4 | ||||
-rw-r--r-- | chrome/browser/chromeos/cros/network_parser.cc | 12 | ||||
-rw-r--r-- | chrome/browser/chromeos/gdata/gdata_sync_client_unittest.cc | 9 | ||||
-rw-r--r-- | chrome/browser/chromeos/status/network_menu_icon.cc | 3 | ||||
-rw-r--r-- | chrome/browser/chromeos/status/network_menu_icon_unittest.cc | 37 | ||||
-rw-r--r-- | dbus/object_proxy.cc | 1 |
15 files changed, 121 insertions, 82 deletions
diff --git a/chrome/app/generated_resources.grd b/chrome/app/generated_resources.grd index 0bcb10f..e7b8275 100644 --- a/chrome/app/generated_resources.grd +++ b/chrome/app/generated_resources.grd @@ -15156,6 +15156,9 @@ Battery full <message name="IDS_CHROMEOS_NETWORK_STATE_ONLINE" desc="Network state in about:network: Online"> Online state </message> + <message name="IDS_CHROMEOS_NETWORK_STATE_CONNECT_REQUESTED" desc="Network state in about:network: Connect Requested"> + Connect Requested + </message> <!-- Network error strings for ChromeOS --> <message name="IDS_CHROMEOS_NETWORK_ERROR_UNKNOWN" desc="Network error in about:network: UNKNOWN"> diff --git a/chrome/browser/chromeos/cros/cros_mock.cc b/chrome/browser/chromeos/cros/cros_mock.cc index 2917fd6..5134974 100644 --- a/chrome/browser/chromeos/cros/cros_mock.cc +++ b/chrome/browser/chromeos/cros/cros_mock.cc @@ -1,4 +1,4 @@ -// Copyright (c) 2011 The Chromium Authors. All rights reserved. +// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. @@ -175,6 +175,9 @@ void CrosMock::SetNetworkLibraryStatusAreaExpectations() { EXPECT_CALL(*mock_network_library_, virtual_network_connected()) .Times(AnyNumber()) .WillRepeatedly((Return(false))); + EXPECT_CALL(*mock_network_library_, wifi_scanning()) + .Times(AnyNumber()) + .WillRepeatedly((Return(false))); // Set specific expectations for interesting functions: diff --git a/chrome/browser/chromeos/cros/cros_network_functions.cc b/chrome/browser/chromeos/cros/cros_network_functions.cc index 3bd0ca0..bbcb00e 100644 --- a/chrome/browser/chromeos/cros/cros_network_functions.cc +++ b/chrome/browser/chromeos/cros/cros_network_functions.cc @@ -344,6 +344,7 @@ void OnGetService(const NetworkPropertiesCallback& callback, DBusMethodCallStatus call_status, const dbus::ObjectPath& service_path) { if (call_status == DBUS_METHOD_CALL_SUCCESS) { + VLOG(1) << "OnGetServiceService: " << service_path.value(); DBusThreadManager::Get()->GetFlimflamServiceClient()->GetProperties( service_path, base::Bind(&RunCallbackWithDictionaryValue, callback, diff --git a/chrome/browser/chromeos/cros/network_constants.h b/chrome/browser/chromeos/cros/network_constants.h index 5fb7e77..332d8c4 100644 --- a/chrome/browser/chromeos/cros/network_constants.h +++ b/chrome/browser/chromeos/cros/network_constants.h @@ -226,7 +226,8 @@ enum ConnectionState { STATE_FAILURE = 7, STATE_ACTIVATION_FAILURE = 8, STATE_PORTAL = 9, - STATE_ONLINE = 10 + STATE_ONLINE = 10, + STATE_CONNECT_REQUESTED = 11, // Chrome only state }; // Network enums (see flimflam/include/network.h) diff --git a/chrome/browser/chromeos/cros/network_library.cc b/chrome/browser/chromeos/cros/network_library.cc index bcca34a..e6c4f1a 100644 --- a/chrome/browser/chromeos/cros/network_library.cc +++ b/chrome/browser/chromeos/cros/network_library.cc @@ -134,6 +134,38 @@ void ValidateUTF8(const std::string& str, std::string* output) { } } +std::string ConnectionStateString(ConnectionState state) { + switch (state) { + case STATE_UNKNOWN: + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_UNKNOWN); + case STATE_IDLE: + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_IDLE); + case STATE_CARRIER: + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_CARRIER); + case STATE_ASSOCIATION: + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_ASSOCIATION); + case STATE_CONFIGURATION: + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_CONFIGURATION); + case STATE_READY: + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_READY); + case STATE_DISCONNECT: + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_DISCONNECT); + case STATE_FAILURE: + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_FAILURE); + case STATE_ACTIVATION_FAILURE: + return l10n_util::GetStringUTF8( + IDS_CHROMEOS_NETWORK_STATE_ACTIVATION_FAILURE); + case STATE_PORTAL: + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_PORTAL); + case STATE_ONLINE: + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_ONLINE); + case STATE_CONNECT_REQUESTED: + return l10n_util::GetStringUTF8( + IDS_CHROMEOS_NETWORK_STATE_CONNECT_REQUESTED); + } + return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_UNRECOGNIZED); +} + } // namespace //////////////////////////////////////////////////////////////////////////////// @@ -225,12 +257,12 @@ void Network::UpdatePropertyMap(PropertyIndex index, const base::Value* value) { Value*& entry = property_map_[index]; delete entry; entry = value->DeepCopy(); - if (VLOG_IS_ON(2)) { + if (VLOG_IS_ON(3)) { std::string value_json; base::JSONWriter::WriteWithOptions(value, base::JSONWriter::OPTIONS_PRETTY_PRINT, &value_json); - VLOG(2) << "Updated property map on network: " + VLOG(3) << "Updated property map on network: " << unique_id() << "[" << index << "] = " << value_json; } } @@ -253,6 +285,12 @@ Network* Network::CreateForTesting(ConnectionType type) { void Network::SetState(ConnectionState new_state) { if (new_state == state_) return; + if (state_ == STATE_CONNECT_REQUESTED && new_state == STATE_IDLE) { + // CONNECT_REQUESTED is set internally. Shill/flimflam do not update the + // state immediately, so ignore any Idle state updates sent while a + // connection attempt is in progress. + return; + } ConnectionState old_state = state_; state_ = new_state; if (!IsConnectingState(new_state)) @@ -274,7 +312,8 @@ void Network::SetState(ConnectionState new_state) { // Note: blocking DBus call. TODO(stevenjb): refactor this. InitIPAddress(); } - VLOG(1) << name() << ".State = " << GetStateString(); + VLOG(1) << name() << ".State [" << service_path() << "]: " << GetStateString() + << " (was: " << ConnectionStateString(old_state) << ")"; } void Network::SetName(const std::string& name) { @@ -389,32 +428,7 @@ void Network::SetProfilePath(const std::string& profile_path) { } std::string Network::GetStateString() const { - switch (state_) { - case STATE_UNKNOWN: - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_UNKNOWN); - case STATE_IDLE: - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_IDLE); - case STATE_CARRIER: - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_CARRIER); - case STATE_ASSOCIATION: - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_ASSOCIATION); - case STATE_CONFIGURATION: - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_CONFIGURATION); - case STATE_READY: - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_READY); - case STATE_DISCONNECT: - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_DISCONNECT); - case STATE_FAILURE: - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_FAILURE); - case STATE_ACTIVATION_FAILURE: - return l10n_util::GetStringUTF8( - IDS_CHROMEOS_NETWORK_STATE_ACTIVATION_FAILURE); - case STATE_PORTAL: - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_PORTAL); - case STATE_ONLINE: - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_ONLINE); - } - return l10n_util::GetStringUTF8(IDS_CHROMEOS_NETWORK_STATE_UNRECOGNIZED); + return ConnectionStateString(state_); } std::string Network::GetErrorString() const { diff --git a/chrome/browser/chromeos/cros/network_library.h b/chrome/browser/chromeos/cros/network_library.h index 7df2a9f..935cd6e 100644 --- a/chrome/browser/chromeos/cros/network_library.h +++ b/chrome/browser/chromeos/cros/network_library.h @@ -299,11 +299,14 @@ class Network { class TestApi { public: explicit TestApi(Network* network) : network_(network) {} - void SetConnected(bool connected) { - network_->set_connected(connected); + void SetConnected() { + network_->set_connected(); } - void SetConnecting(bool connecting) { - network_->set_connecting(connecting); + void SetConnecting() { + network_->set_connecting(); + } + void SetDisconnected() { + network_->set_disconnected(); } private: Network* network_; @@ -407,7 +410,8 @@ class Network { state == STATE_PORTAL); } static bool IsConnectingState(ConnectionState state) { - return (state == STATE_ASSOCIATION || + return (state == STATE_CONNECT_REQUESTED || + state == STATE_ASSOCIATION || state == STATE_CONFIGURATION || state == STATE_CARRIER); } @@ -520,11 +524,14 @@ class Network { } void set_name(const std::string& name) { name_ = name; } void set_mode(ConnectionMode mode) { mode_ = mode; } - void set_connecting(bool connecting) { - state_ = (connecting ? STATE_ASSOCIATION : STATE_IDLE); + void set_connecting() { + state_ = STATE_CONNECT_REQUESTED; + } + void set_connected() { + state_ = STATE_ONLINE; } - void set_connected(bool connected) { - state_ = (connected ? STATE_ONLINE : STATE_IDLE); + void set_disconnected() { + state_ = STATE_IDLE; } void set_connectable(bool connectable) { connectable_ = connectable; } void set_connection_started(bool started) { connection_started_ = started; } diff --git a/chrome/browser/chromeos/cros/network_library_impl_base.cc b/chrome/browser/chromeos/cros/network_library_impl_base.cc index fc765b4..1cdbd51 100644 --- a/chrome/browser/chromeos/cros/network_library_impl_base.cc +++ b/chrome/browser/chromeos/cros/network_library_impl_base.cc @@ -842,7 +842,7 @@ void NetworkLibraryImplBase::NetworkConnectStart( // In order to be certain to trigger any notifications, set the connecting // state locally and notify observers. Otherwise there might be a state // change without a forced notify. - network->set_connecting(true); + network->set_connecting(); // Distinguish between user-initiated connection attempts // and auto-connect. network->set_connection_started(true); diff --git a/chrome/browser/chromeos/cros/network_library_impl_cros.cc b/chrome/browser/chromeos/cros/network_library_impl_cros.cc index 0ea08cf..b94fbd8 100644 --- a/chrome/browser/chromeos/cros/network_library_impl_cros.cc +++ b/chrome/browser/chromeos/cros/network_library_impl_cros.cc @@ -708,7 +708,7 @@ bool NetworkLibraryImplCros::NetworkManagerStatusChanged( // Currently we ignore PortalURL and ArpGateway. break; default: - LOG(WARNING) << "Manager: Unhandled key: " << key; + VLOG(2) << "Manager: Unhandled key: " << key; break; } base::TimeDelta delta = base::TimeTicks::Now() - start; @@ -827,6 +827,7 @@ void NetworkLibraryImplCros::UpdateNetworkServiceList( // Use update_request map to store network priority. network_update_requests_[service_path] = network_priority_order++; wifi_scanning_ = true; + VLOG(2) << "UpdateNetworkServiceList, Service: " << service_path; CrosRequestNetworkServiceProperties( service_path, base::Bind(&NetworkLibraryImplCros::NetworkServiceUpdate, @@ -886,6 +887,7 @@ void NetworkLibraryImplCros::NetworkServiceUpdate( const base::DictionaryValue* properties) { if (!properties) return; // Network no longer in visible list, ignore. + VLOG(2) << "NetworkServiceUpdate: " << service_path; ParseNetwork(service_path, *properties); } @@ -1027,7 +1029,7 @@ void NetworkLibraryImplCros::UpdateProfile( LOG(WARNING) << "Empty service path in profile."; continue; } - VLOG(1) << " Remembered service: " << service_path; + VLOG(2) << " Remembered service: " << service_path; // Add service to profile list. profile.services.insert(service_path); // Request update for remembered network. @@ -1082,7 +1084,7 @@ Network* NetworkLibraryImplCros::ParseRememberedNetwork( SetProfileTypeFromPath(remembered); - VLOG(1) << "ParseRememberedNetwork: " << remembered->name() + VLOG(2) << "ParseRememberedNetwork: " << remembered->name() << " path: " << remembered->service_path() << " profile: " << remembered->profile_path_; NotifyNetworkManagerChanged(false); // Not forced. @@ -1093,7 +1095,7 @@ Network* NetworkLibraryImplCros::ParseRememberedNetwork( if (!FindNetworkByUniqueId(remembered->unique_id())) { VirtualNetwork* vpn = static_cast<VirtualNetwork*>(remembered); std::string provider_type = ProviderTypeToString(vpn->provider_type()); - VLOG(1) << "Requesting VPN: " << vpn->name() + VLOG(2) << "Requesting VPN: " << vpn->name() << " Server: " << vpn->server_hostname() << " Type: " << provider_type; CrosRequestVirtualNetworkProperties( @@ -1171,7 +1173,7 @@ void NetworkLibraryImplCros::ParseNetworkDevice(const std::string& device_path, } CHECK(device) << "Attempted to add NULL device for path: " << device_path; } - VLOG(1) << "ParseNetworkDevice:" << device->name(); + VLOG(2) << "ParseNetworkDevice:" << device->name(); if (device && device->type() == TYPE_CELLULAR) { if (!device->data_roaming_allowed() && IsCellularAlwaysInRoaming()) { SetCellularDataRoamingAllowed(true); diff --git a/chrome/browser/chromeos/cros/network_library_impl_stub.cc b/chrome/browser/chromeos/cros/network_library_impl_stub.cc index 90030b4..7a8111e 100644 --- a/chrome/browser/chromeos/cros/network_library_impl_stub.cc +++ b/chrome/browser/chromeos/cros/network_library_impl_stub.cc @@ -79,13 +79,13 @@ void NetworkLibraryImplStub::Init() { Network* ethernet = new EthernetNetwork("eth1"); ethernet->set_name("Fake Ethernet"); ethernet->set_is_active(true); - ethernet->set_connected(true); + ethernet->set_connected(); AddStubNetwork(ethernet, PROFILE_SHARED); WifiNetwork* wifi1 = new WifiNetwork("wifi1"); wifi1->set_name("Fake WiFi1"); wifi1->set_strength(100); - wifi1->set_connected(true); + wifi1->set_connected(); wifi1->set_encryption(SECURITY_NONE); AddStubNetwork(wifi1, PROFILE_SHARED); @@ -163,7 +163,7 @@ void NetworkLibraryImplStub::Init() { CellularNetwork* cellular1 = new CellularNetwork("cellular1"); cellular1->set_name("Fake Cellular 1"); cellular1->set_strength(100); - cellular1->set_connected(true); + cellular1->set_connected(); cellular1->set_activation_state(ACTIVATION_STATE_ACTIVATED); cellular1->set_payment_url(std::string("http://www.google.com")); cellular1->set_usage_url(std::string("http://www.google.com")); @@ -249,7 +249,7 @@ void NetworkLibraryImplStub::Init() { WimaxNetwork* wimax2 = new WimaxNetwork("wimax2"); wimax2->set_name("Fake WiMAX Open"); wimax2->set_strength(50); - wimax2->set_connected(true); + wimax2->set_connected(); wimax2->set_passphrase_required(false); AddStubNetwork(wimax2, PROFILE_NONE); @@ -408,7 +408,7 @@ void NetworkLibraryImplStub::ConnectToNetwork(Network* network) { } // Set connected state. - network->set_connected(true); + network->set_connected(); network->set_connection_started(false); // Make the connected network the highest priority network. @@ -424,7 +424,7 @@ void NetworkLibraryImplStub::ConnectToNetwork(Network* network) { other->priority_order_++; if (other->type() == network->type()) { other->set_is_active(false); - other->set_connected(false); + other->set_disconnected(); } } @@ -640,7 +640,7 @@ void NetworkLibraryImplStub::DisconnectFromNetwork(const Network* network) { // Update the network state here since no network manager in stub impl. Network* modify_network = const_cast<Network*>(network); modify_network->set_is_active(false); - modify_network->set_connected(false); + modify_network->set_disconnected(); if (network == active_wifi_) active_wifi_ = NULL; else if (network == active_cellular_) diff --git a/chrome/browser/chromeos/cros/network_library_unittest.cc b/chrome/browser/chromeos/cros/network_library_unittest.cc index d97e885..568bd96 100644 --- a/chrome/browser/chromeos/cros/network_library_unittest.cc +++ b/chrome/browser/chromeos/cros/network_library_unittest.cc @@ -283,12 +283,12 @@ TEST_F(NetworkLibraryStubTest, NetworkLibraryAccessors) { WifiNetwork* wifi2 = cros_->FindWifiNetworkByPath("wifi2"); ASSERT_NE(static_cast<const Network*>(NULL), wifi2); Network::TestApi test_wifi2(wifi2); - test_wifi2.SetConnecting(true); + test_wifi2.SetConnecting(); // Set cellular1->connecting for these tests. CellularNetwork* cellular1 = cros_->FindCellularNetworkByPath("cellular1"); ASSERT_NE(static_cast<const Network*>(NULL), cellular1); Network::TestApi test_cellular1(cellular1); - test_cellular1.SetConnecting(true); + test_cellular1.SetConnecting(); // Ethernet ASSERT_NE(static_cast<const EthernetNetwork*>(NULL), diff --git a/chrome/browser/chromeos/cros/network_parser.cc b/chrome/browser/chromeos/cros/network_parser.cc index 74fb9e1..9fcdcaf 100644 --- a/chrome/browser/chromeos/cros/network_parser.cc +++ b/chrome/browser/chromeos/cros/network_parser.cc @@ -63,15 +63,15 @@ bool NetworkDeviceParser::UpdateStatus(const std::string& key, if (index) *index = found_index; if (!ParseValue(found_index, value, device)) { - VLOG(1) << "NetworkDeviceParser: Unhandled key: " << key; + VLOG(3) << "NetworkDeviceParser: Unhandled key: " << key; return false; } - if (VLOG_IS_ON(2)) { + if (VLOG_IS_ON(3)) { std::string value_json; base::JSONWriter::WriteWithOptions(&value, base::JSONWriter::OPTIONS_PRETTY_PRINT, &value_json); - VLOG(2) << "Updated value on device: " + VLOG(3) << "Updated value on device: " << device->device_path() << "[" << key << "] = " << value_json; } return true; @@ -135,17 +135,17 @@ bool NetworkParser::UpdateStatus(const std::string& key, *index = found_index; network->UpdatePropertyMap(found_index, &value); if (!ParseValue(found_index, value, network)) { - VLOG(1) << "Unhandled key '" << key << "' in Network: " << network->name() + VLOG(3) << "Unhandled key '" << key << "' in Network: " << network->name() << " ID: " << network->unique_id() << " Type: " << ConnectionTypeToString(network->type()); return false; } - if (VLOG_IS_ON(2)) { + if (VLOG_IS_ON(3)) { std::string value_json; base::JSONWriter::WriteWithOptions(&value, base::JSONWriter::OPTIONS_PRETTY_PRINT, &value_json); - VLOG(2) << "Updated value on network: " + VLOG(3) << "Updated value on network: " << network->unique_id() << "[" << key << "] = " << value_json; } return true; diff --git a/chrome/browser/chromeos/gdata/gdata_sync_client_unittest.cc b/chrome/browser/chromeos/gdata/gdata_sync_client_unittest.cc index c23c26c..12c3e8e 100644 --- a/chrome/browser/chromeos/gdata/gdata_sync_client_unittest.cc +++ b/chrome/browser/chromeos/gdata/gdata_sync_client_unittest.cc @@ -101,7 +101,7 @@ class GDataSyncClientTest : public testing::Test { EXPECT_CALL(*mock_network_library_, active_network()) .Times(AnyNumber()) .WillRepeatedly((Return(active_network_.get()))); - chromeos::Network::TestApi(active_network_.get()).SetConnected(true); + chromeos::Network::TestApi(active_network_.get()).SetConnected(); // Notify the sync client that the network is changed. This is done via // NetworkLibrary in production, but here, we simulate the behavior by // directly calling OnNetworkManagerChanged(). @@ -115,7 +115,7 @@ class GDataSyncClientTest : public testing::Test { EXPECT_CALL(*mock_network_library_, active_network()) .Times(AnyNumber()) .WillRepeatedly((Return(active_network_.get()))); - chromeos::Network::TestApi(active_network_.get()).SetConnected(true); + chromeos::Network::TestApi(active_network_.get()).SetConnected(); sync_client_->OnNetworkManagerChanged(mock_network_library_); } @@ -126,7 +126,7 @@ class GDataSyncClientTest : public testing::Test { EXPECT_CALL(*mock_network_library_, active_network()) .Times(AnyNumber()) .WillRepeatedly((Return(active_network_.get()))); - chromeos::Network::TestApi(active_network_.get()).SetConnected(true); + chromeos::Network::TestApi(active_network_.get()).SetConnected(); sync_client_->OnNetworkManagerChanged(mock_network_library_); } @@ -137,8 +137,7 @@ class GDataSyncClientTest : public testing::Test { EXPECT_CALL(*mock_network_library_, active_network()) .Times(AnyNumber()) .WillRepeatedly((Return(active_network_.get()))); - // Here false is passed to make it disconnected. - chromeos::Network::TestApi(active_network_.get()).SetConnected(false); + chromeos::Network::TestApi(active_network_.get()).SetDisconnected(); sync_client_->OnNetworkManagerChanged(mock_network_library_); } diff --git a/chrome/browser/chromeos/status/network_menu_icon.cc b/chrome/browser/chromeos/status/network_menu_icon.cc index 52db566..c6c08ff 100644 --- a/chrome/browser/chromeos/status/network_menu_icon.cc +++ b/chrome/browser/chromeos/status/network_menu_icon.cc @@ -634,6 +634,9 @@ void NetworkMenuIcon::SetIconAndText() { NetworkLibrary* cros = CrosLibrary::Get()->GetNetworkLibrary(); DCHECK(cros); + if (cros->wifi_scanning()) + return; // Don't update icon while scanning + icon_->ClearIconAndBadges(); // If we are connecting to a network, display that. diff --git a/chrome/browser/chromeos/status/network_menu_icon_unittest.cc b/chrome/browser/chromeos/status/network_menu_icon_unittest.cc index b890000..356b4f0 100644 --- a/chrome/browser/chromeos/status/network_menu_icon_unittest.cc +++ b/chrome/browser/chromeos/status/network_menu_icon_unittest.cc @@ -144,14 +144,19 @@ class NetworkMenuIconTest : public testing::Test { } protected: - void SetConnected(Network* network, bool connected) { + void SetConnected(Network* network) { Network::TestApi test_network(network); - test_network.SetConnected(connected); + test_network.SetConnected(); } - void SetConnecting(Network* network, bool connecting) { + void SetConnecting(Network* network) { Network::TestApi test_network(network); - test_network.SetConnecting(connecting); + test_network.SetConnecting(); + } + + void SetDisconnected(Network* network) { + Network::TestApi test_network(network); + test_network.SetDisconnected(); } void SetActive(Network* network, bool active) { @@ -214,12 +219,12 @@ class NetworkMenuIconTest : public testing::Test { TEST_F(NetworkMenuIconTest, EthernetIcon) { Network* network = cros_->FindNetworkByPath("eth1"); ASSERT_NE(static_cast<const Network*>(NULL), network); - SetConnected(network, true); + SetConnected(network); gfx::ImageSkia icon = NetworkMenuIcon::GetImage(network, NetworkMenuIcon::COLOR_DARK); EXPECT_TRUE(CompareImages(icon, ethernet_connected_image_)); - SetConnected(network, false); + SetDisconnected(network); icon = NetworkMenuIcon::GetImage(network, NetworkMenuIcon::COLOR_DARK); EXPECT_TRUE(CompareImages(icon, ethernet_disconnected_image_)); @@ -238,7 +243,7 @@ TEST_F(NetworkMenuIconTest, WifiIcon) { NetworkMenuIcon::COLOR_DARK); EXPECT_TRUE(CompareImages(icon, wifi_encrypted_50_image_)); - SetConnected(network, false); + SetDisconnected(network); SetStrength(network, 0); SetEncryption(network, SECURITY_NONE); icon = NetworkMenuIcon::GetImage(network, @@ -249,7 +254,7 @@ TEST_F(NetworkMenuIconTest, WifiIcon) { TEST_F(NetworkMenuIconTest, CellularIcon) { CellularNetwork* network = cros_->FindCellularNetworkByPath("cellular1"); ASSERT_NE(static_cast<const Network*>(NULL), network); - SetConnected(network, true); + SetConnected(network); SetStrength(network, 100); SetRoamingState(network, ROAMING_STATE_HOME); gfx::ImageSkia icon = NetworkMenuIcon::GetImage(network, @@ -262,7 +267,7 @@ TEST_F(NetworkMenuIconTest, CellularIcon) { NetworkMenuIcon::COLOR_DARK); EXPECT_TRUE(CompareImages(icon, cellular_roaming_50_image_)); - SetConnected(network, false); + SetDisconnected(network); SetStrength(network, 0); SetRoamingState(network, ROAMING_STATE_HOME); icon = NetworkMenuIcon::GetImage(network, @@ -318,14 +323,14 @@ TEST_F(NetworkMenuIconTest, StatusIconMenuMode) { CellularNetwork* cellular1 = cros_->FindCellularNetworkByPath("cellular1"); ASSERT_NE(static_cast<const Network*>(NULL), cellular1); SetRoamingState(cellular1, ROAMING_STATE_HOME); // Clear romaing state - SetConnecting(cellular1, true); + SetConnecting(cellular1); // For MENU_MODE, we always display the connecting icon (cellular1). icon = menu_icon.GetIconAndText(NULL); EXPECT_TRUE(CompareImages(icon, cellular_connecting_image_)); // Set cellular1 to connected; ethernet icon should be shown. - SetConnected(cellular1, true); + SetConnected(cellular1); icon = menu_icon.GetIconAndText(NULL); EXPECT_TRUE(CompareImages(icon, ethernet_connected_image_)); @@ -333,7 +338,7 @@ TEST_F(NetworkMenuIconTest, StatusIconMenuMode) { Network* eth1 = cros_->FindNetworkByPath("eth1"); ASSERT_NE(static_cast<const Network*>(NULL), eth1); SetActive(eth1, false); - SetConnected(eth1, false); + SetDisconnected(eth1); icon = menu_icon.GetIconAndText(NULL); EXPECT_TRUE(CompareImages(icon, wifi_connected_100_image_)); } @@ -345,7 +350,7 @@ TEST_F(NetworkMenuIconTest, StatusIconDropdownMode) { // Set wifi1 to connecting. WifiNetwork* wifi1 = cros_->FindWifiNetworkByPath("wifi1"); ASSERT_NE(static_cast<const Network*>(NULL), wifi1); - SetConnecting(wifi1, true); + SetConnecting(wifi1); // For DROPDOWN_MODE, we prioritize the connected network (ethernet). icon = menu_icon.GetIconAndText(NULL); @@ -355,7 +360,7 @@ TEST_F(NetworkMenuIconTest, StatusIconDropdownMode) { Network* ethernet = cros_->FindNetworkByPath("eth1"); ASSERT_NE(static_cast<const Network*>(NULL), ethernet); SetActive(ethernet, false); - SetConnected(ethernet, false); + SetDisconnected(ethernet); // Icon should now be cellular connected icon. icon = menu_icon.GetIconAndText(NULL); @@ -364,12 +369,12 @@ TEST_F(NetworkMenuIconTest, StatusIconDropdownMode) { // Set cellular1 to disconnected; Icon should now be wimax icon. CellularNetwork* cellular1 = cros_->FindCellularNetworkByPath("cellular1"); ASSERT_NE(static_cast<const Network*>(NULL), cellular1); - SetConnected(cellular1, false); + SetDisconnected(cellular1); icon = menu_icon.GetIconAndText(NULL); EXPECT_TRUE(CompareImages(icon, wimax_connected_50_image_)); // Set wifi1 to connected. Icon should now be wifi connected icon. - SetConnected(wifi1, true); + SetConnected(wifi1); icon = menu_icon.GetIconAndText(NULL); EXPECT_TRUE(CompareImages(icon, wifi_connected_100_image_)); } diff --git a/dbus/object_proxy.cc b/dbus/object_proxy.cc index 62c0eb8..ba51efa 100644 --- a/dbus/object_proxy.cc +++ b/dbus/object_proxy.cc @@ -494,6 +494,7 @@ void ObjectProxy::LogMethodCallFailure( return; LOG(ERROR) << "Failed to call method: " << interface_name << "." << method_name + << ": object_path= " << object_path_.value() << ": " << error_name << ": " << error_message; } |