Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "chromeos/dbus/fake_shill_manager_client.h" | 5 #include "chromeos/dbus/fake_shill_manager_client.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/command_line.h" | |
| 9 #include "base/message_loop/message_loop.h" | 8 #include "base/message_loop/message_loop.h" |
| 9 #include "base/strings/string_number_conversions.h" | |
| 10 #include "base/strings/string_split.h" | |
| 11 #include "base/strings/string_util.h" | |
| 10 #include "base/values.h" | 12 #include "base/values.h" |
| 11 #include "chromeos/chromeos_switches.h" | 13 #include "chromeos/chromeos_switches.h" |
| 14 #include "chromeos/dbus/dbus_command_line_helper.h" | |
| 12 #include "chromeos/dbus/dbus_thread_manager.h" | 15 #include "chromeos/dbus/dbus_thread_manager.h" |
| 13 #include "chromeos/dbus/shill_device_client.h" | 16 #include "chromeos/dbus/shill_device_client.h" |
| 14 #include "chromeos/dbus/shill_profile_client.h" | 17 #include "chromeos/dbus/shill_profile_client.h" |
| 15 #include "chromeos/dbus/shill_property_changed_observer.h" | 18 #include "chromeos/dbus/shill_property_changed_observer.h" |
| 16 #include "chromeos/dbus/shill_service_client.h" | 19 #include "chromeos/dbus/shill_service_client.h" |
| 17 #include "dbus/bus.h" | 20 #include "dbus/bus.h" |
| 18 #include "dbus/message.h" | 21 #include "dbus/message.h" |
| 19 #include "dbus/object_path.h" | 22 #include "dbus/object_path.h" |
| 20 #include "dbus/values_util.h" | 23 #include "dbus/values_util.h" |
| 21 #include "third_party/cros_system_api/dbus/service_constants.h" | 24 #include "third_party/cros_system_api/dbus/service_constants.h" |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 66 state == shill::kStateConfiguration || | 69 state == shill::kStateConfiguration || |
| 67 state == shill::kStatePortal || | 70 state == shill::kStatePortal || |
| 68 state == shill::kStateReady) { | 71 state == shill::kStateReady) { |
| 69 active_service_list_out->push_back(service_path); | 72 active_service_list_out->push_back(service_path); |
| 70 } else { | 73 } else { |
| 71 inactive_service_list_out->push_back(service_path); | 74 inactive_service_list_out->push_back(service_path); |
| 72 } | 75 } |
| 73 } | 76 } |
| 74 } | 77 } |
| 75 | 78 |
| 79 void UpdatePortalledWifiState(const std::string& service_path) { | |
| 80 DBusThreadManager::Get()->GetShillServiceClient()->GetTestInterface() | |
| 81 ->SetServiceProperty(service_path, | |
| 82 shill::kStateProperty, | |
| 83 base::StringValue(shill::kStatePortal)); | |
| 84 } | |
| 85 | |
| 76 } // namespace | 86 } // namespace |
| 77 | 87 |
| 78 FakeShillManagerClient::FakeShillManagerClient() | 88 FakeShillManagerClient::FakeShillManagerClient() |
| 79 : weak_ptr_factory_(this) { | 89 : interactive_delay_(0), |
| 90 weak_ptr_factory_(this) { | |
| 91 ParseCommandLineSwitch(); | |
| 80 } | 92 } |
| 81 | 93 |
| 82 FakeShillManagerClient::~FakeShillManagerClient() {} | 94 FakeShillManagerClient::~FakeShillManagerClient() {} |
| 83 | 95 |
| 84 // ShillManagerClient overrides. | 96 // ShillManagerClient overrides. |
| 85 | 97 |
| 86 void FakeShillManagerClient::Init(dbus::Bus* bus) {} | 98 void FakeShillManagerClient::Init(dbus::Bus* bus) { |
| 99 // Note: This will occur *before* Init() is called on Service/Device/Profile | |
| 100 // clients. | |
| 101 SetupDefaultEnvironment(); | |
|
pneubeck (no reviews)
2014/02/28 09:37:59
IIRC, the idea at some time was that this DefaultE
stevenjb
2014/02/28 17:43:06
Anything that calls InitializeWithStub is going to
| |
| 102 } | |
| 87 | 103 |
| 88 void FakeShillManagerClient::AddPropertyChangedObserver( | 104 void FakeShillManagerClient::AddPropertyChangedObserver( |
| 89 ShillPropertyChangedObserver* observer) { | 105 ShillPropertyChangedObserver* observer) { |
| 90 observer_list_.AddObserver(observer); | 106 observer_list_.AddObserver(observer); |
| 91 } | 107 } |
| 92 | 108 |
| 93 void FakeShillManagerClient::RemovePropertyChangedObserver( | 109 void FakeShillManagerClient::RemovePropertyChangedObserver( |
| 94 ShillPropertyChangedObserver* observer) { | 110 ShillPropertyChangedObserver* observer) { |
| 95 observer_list_.RemoveObserver(observer); | 111 observer_list_.RemoveObserver(observer); |
| 96 } | 112 } |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 111 &FakeShillManagerClient::PassStubGeoNetworks, | 127 &FakeShillManagerClient::PassStubGeoNetworks, |
| 112 weak_ptr_factory_.GetWeakPtr(), | 128 weak_ptr_factory_.GetWeakPtr(), |
| 113 callback)); | 129 callback)); |
| 114 } | 130 } |
| 115 | 131 |
| 116 void FakeShillManagerClient::SetProperty(const std::string& name, | 132 void FakeShillManagerClient::SetProperty(const std::string& name, |
| 117 const base::Value& value, | 133 const base::Value& value, |
| 118 const base::Closure& callback, | 134 const base::Closure& callback, |
| 119 const ErrorCallback& error_callback) { | 135 const ErrorCallback& error_callback) { |
| 120 stub_properties_.SetWithoutPathExpansion(name, value.DeepCopy()); | 136 stub_properties_.SetWithoutPathExpansion(name, value.DeepCopy()); |
| 121 CallNotifyObserversPropertyChanged(name, 0); | 137 CallNotifyObserversPropertyChanged(name); |
| 122 base::MessageLoop::current()->PostTask(FROM_HERE, callback); | 138 base::MessageLoop::current()->PostTask(FROM_HERE, callback); |
| 123 } | 139 } |
| 124 | 140 |
| 125 void FakeShillManagerClient::RequestScan(const std::string& type, | 141 void FakeShillManagerClient::RequestScan(const std::string& type, |
| 126 const base::Closure& callback, | 142 const base::Closure& callback, |
| 127 const ErrorCallback& error_callback) { | 143 const ErrorCallback& error_callback) { |
| 128 // For Stub purposes, default to a Wifi scan. | 144 // For Stub purposes, default to a Wifi scan. |
| 129 std::string device_type = shill::kTypeWifi; | 145 std::string device_type = shill::kTypeWifi; |
| 130 if (!type.empty()) | 146 if (!type.empty()) |
| 131 device_type = type; | 147 device_type = type; |
| 132 ShillDeviceClient::TestInterface* device_client = | 148 ShillDeviceClient::TestInterface* device_client = |
| 133 DBusThreadManager::Get()->GetShillDeviceClient()->GetTestInterface(); | 149 DBusThreadManager::Get()->GetShillDeviceClient()->GetTestInterface(); |
| 134 std::string device_path = device_client->GetDevicePathForType(device_type); | 150 std::string device_path = device_client->GetDevicePathForType(device_type); |
| 135 if (!device_path.empty()) { | 151 if (!device_path.empty()) { |
| 136 device_client->SetDeviceProperty(device_path, | 152 device_client->SetDeviceProperty( |
| 137 shill::kScanningProperty, | 153 device_path, shill::kScanningProperty, base::FundamentalValue(true)); |
| 138 base::FundamentalValue(true)); | |
| 139 } | |
| 140 const int kScanDurationSeconds = 3; | |
| 141 int scan_duration_seconds = kScanDurationSeconds; | |
| 142 if (!CommandLine::ForCurrentProcess()->HasSwitch( | |
| 143 chromeos::switches::kEnableStubInteractive)) { | |
| 144 scan_duration_seconds = 0; | |
| 145 } | 154 } |
| 146 base::MessageLoop::current()->PostDelayedTask( | 155 base::MessageLoop::current()->PostDelayedTask( |
| 147 FROM_HERE, | 156 FROM_HERE, |
| 148 base::Bind(&FakeShillManagerClient::ScanCompleted, | 157 base::Bind(&FakeShillManagerClient::ScanCompleted, |
| 149 weak_ptr_factory_.GetWeakPtr(), device_path, callback), | 158 weak_ptr_factory_.GetWeakPtr(), |
| 150 base::TimeDelta::FromSeconds(scan_duration_seconds)); | 159 device_path, |
| 160 callback), | |
| 161 base::TimeDelta::FromSeconds(interactive_delay_)); | |
| 151 } | 162 } |
| 152 | 163 |
| 153 void FakeShillManagerClient::EnableTechnology( | 164 void FakeShillManagerClient::EnableTechnology( |
| 154 const std::string& type, | 165 const std::string& type, |
| 155 const base::Closure& callback, | 166 const base::Closure& callback, |
| 156 const ErrorCallback& error_callback) { | 167 const ErrorCallback& error_callback) { |
| 157 base::ListValue* enabled_list = NULL; | 168 base::ListValue* enabled_list = NULL; |
| 158 if (!stub_properties_.GetListWithoutPathExpansion( | 169 if (!stub_properties_.GetListWithoutPathExpansion( |
| 159 shill::kEnabledTechnologiesProperty, &enabled_list)) { | 170 shill::kEnabledTechnologiesProperty, &enabled_list)) { |
| 160 base::MessageLoop::current()->PostTask(FROM_HERE, callback); | 171 base::MessageLoop::current()->PostTask(FROM_HERE, callback); |
| 161 base::MessageLoop::current()->PostTask( | 172 base::MessageLoop::current()->PostTask( |
| 162 FROM_HERE, | 173 FROM_HERE, |
| 163 base::Bind(error_callback, "StubError", "Property not found")); | 174 base::Bind(error_callback, "StubError", "Property not found")); |
| 164 return; | 175 return; |
| 165 } | 176 } |
| 166 if (CommandLine::ForCurrentProcess()->HasSwitch( | 177 if (interactive_delay_) { |
| 167 chromeos::switches::kEnableStubInteractive)) { | |
| 168 const int kEnableTechnologyDelaySeconds = 3; | |
| 169 base::MessageLoop::current()->PostDelayedTask( | 178 base::MessageLoop::current()->PostDelayedTask( |
| 170 FROM_HERE, | 179 FROM_HERE, |
| 171 base::Bind(&FakeShillManagerClient::SetTechnologyEnabled, | 180 base::Bind(&FakeShillManagerClient::SetTechnologyEnabled, |
| 172 weak_ptr_factory_.GetWeakPtr(), type, callback, true), | 181 weak_ptr_factory_.GetWeakPtr(), |
| 173 base::TimeDelta::FromSeconds(kEnableTechnologyDelaySeconds)); | 182 type, |
| 183 callback, | |
| 184 true), | |
| 185 base::TimeDelta::FromSeconds(interactive_delay_)); | |
| 174 } else { | 186 } else { |
| 175 SetTechnologyEnabled(type, callback, true); | 187 SetTechnologyEnabled(type, callback, true); |
| 176 } | 188 } |
| 177 } | 189 } |
| 178 | 190 |
| 179 void FakeShillManagerClient::DisableTechnology( | 191 void FakeShillManagerClient::DisableTechnology( |
| 180 const std::string& type, | 192 const std::string& type, |
| 181 const base::Closure& callback, | 193 const base::Closure& callback, |
| 182 const ErrorCallback& error_callback) { | 194 const ErrorCallback& error_callback) { |
| 183 base::ListValue* enabled_list = NULL; | 195 base::ListValue* enabled_list = NULL; |
| 184 if (!stub_properties_.GetListWithoutPathExpansion( | 196 if (!stub_properties_.GetListWithoutPathExpansion( |
| 185 shill::kEnabledTechnologiesProperty, &enabled_list)) { | 197 shill::kEnabledTechnologiesProperty, &enabled_list)) { |
| 186 base::MessageLoop::current()->PostTask( | 198 base::MessageLoop::current()->PostTask( |
| 187 FROM_HERE, | 199 FROM_HERE, |
| 188 base::Bind(error_callback, "StubError", "Property not found")); | 200 base::Bind(error_callback, "StubError", "Property not found")); |
| 189 return; | 201 return; |
| 190 } | 202 } |
| 191 if (CommandLine::ForCurrentProcess()->HasSwitch( | 203 if (interactive_delay_) { |
| 192 chromeos::switches::kEnableStubInteractive)) { | |
| 193 const int kDisableTechnologyDelaySeconds = 3; | |
| 194 base::MessageLoop::current()->PostDelayedTask( | 204 base::MessageLoop::current()->PostDelayedTask( |
| 195 FROM_HERE, | 205 FROM_HERE, |
| 196 base::Bind(&FakeShillManagerClient::SetTechnologyEnabled, | 206 base::Bind(&FakeShillManagerClient::SetTechnologyEnabled, |
| 197 weak_ptr_factory_.GetWeakPtr(), type, callback, false), | 207 weak_ptr_factory_.GetWeakPtr(), |
| 198 base::TimeDelta::FromSeconds(kDisableTechnologyDelaySeconds)); | 208 type, |
| 209 callback, | |
| 210 false), | |
| 211 base::TimeDelta::FromSeconds(interactive_delay_)); | |
| 199 } else { | 212 } else { |
| 200 SetTechnologyEnabled(type, callback, false); | 213 SetTechnologyEnabled(type, callback, false); |
| 201 } | 214 } |
| 202 } | 215 } |
| 203 | 216 |
| 204 void FakeShillManagerClient::ConfigureService( | 217 void FakeShillManagerClient::ConfigureService( |
| 205 const base::DictionaryValue& properties, | 218 const base::DictionaryValue& properties, |
| 206 const ObjectPathCallback& callback, | 219 const ObjectPathCallback& callback, |
| 207 const ErrorCallback& error_callback) { | 220 const ErrorCallback& error_callback) { |
| 208 ShillServiceClient::TestInterface* service_client = | 221 ShillServiceClient::TestInterface* service_client = |
| (...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 299 const ErrorCallback& error_callback) { | 312 const ErrorCallback& error_callback) { |
| 300 base::MessageLoop::current()->PostTask( | 313 base::MessageLoop::current()->PostTask( |
| 301 FROM_HERE, base::Bind(callback, "encrypted_credentials")); | 314 FROM_HERE, base::Bind(callback, "encrypted_credentials")); |
| 302 } | 315 } |
| 303 | 316 |
| 304 void FakeShillManagerClient::VerifyAndEncryptData( | 317 void FakeShillManagerClient::VerifyAndEncryptData( |
| 305 const VerificationProperties& properties, | 318 const VerificationProperties& properties, |
| 306 const std::string& data, | 319 const std::string& data, |
| 307 const StringCallback& callback, | 320 const StringCallback& callback, |
| 308 const ErrorCallback& error_callback) { | 321 const ErrorCallback& error_callback) { |
| 309 base::MessageLoop::current()->PostTask(FROM_HERE, | 322 base::MessageLoop::current()->PostTask( |
| 310 base::Bind(callback, "encrypted_data")); | 323 FROM_HERE, base::Bind(callback, "encrypted_data")); |
| 311 } | 324 } |
| 312 | 325 |
| 313 void FakeShillManagerClient::ConnectToBestServices( | 326 void FakeShillManagerClient::ConnectToBestServices( |
| 314 const base::Closure& callback, | 327 const base::Closure& callback, |
| 315 const ErrorCallback& error_callback) { | 328 const ErrorCallback& error_callback) { |
| 316 } | 329 } |
| 317 | 330 |
| 318 ShillManagerClient::TestInterface* FakeShillManagerClient::GetTestInterface() { | 331 ShillManagerClient::TestInterface* FakeShillManagerClient::GetTestInterface() { |
| 319 return this; | 332 return this; |
| 320 } | 333 } |
| 321 | 334 |
| 322 // ShillManagerClient::TestInterface overrides. | 335 // ShillManagerClient::TestInterface overrides. |
| 323 | 336 |
| 324 void FakeShillManagerClient::AddDevice(const std::string& device_path) { | 337 void FakeShillManagerClient::AddDevice(const std::string& device_path) { |
| 325 if (GetListProperty(shill::kDevicesProperty)->AppendIfNotPresent( | 338 if (GetListProperty(shill::kDevicesProperty) |
| 326 base::Value::CreateStringValue(device_path))) { | 339 ->AppendIfNotPresent(base::Value::CreateStringValue(device_path))) { |
| 327 CallNotifyObserversPropertyChanged(shill::kDevicesProperty, 0); | 340 CallNotifyObserversPropertyChanged(shill::kDevicesProperty); |
| 328 } | 341 } |
| 329 } | 342 } |
| 330 | 343 |
| 331 void FakeShillManagerClient::RemoveDevice(const std::string& device_path) { | 344 void FakeShillManagerClient::RemoveDevice(const std::string& device_path) { |
| 332 base::StringValue device_path_value(device_path); | 345 base::StringValue device_path_value(device_path); |
| 333 if (GetListProperty(shill::kDevicesProperty)->Remove( | 346 if (GetListProperty(shill::kDevicesProperty) |
| 334 device_path_value, NULL)) { | 347 ->Remove(device_path_value, NULL)) { |
| 335 CallNotifyObserversPropertyChanged(shill::kDevicesProperty, 0); | 348 CallNotifyObserversPropertyChanged(shill::kDevicesProperty); |
| 336 } | 349 } |
| 337 } | 350 } |
| 338 | 351 |
| 339 void FakeShillManagerClient::ClearDevices() { | 352 void FakeShillManagerClient::ClearDevices() { |
| 340 GetListProperty(shill::kDevicesProperty)->Clear(); | 353 GetListProperty(shill::kDevicesProperty)->Clear(); |
| 341 CallNotifyObserversPropertyChanged(shill::kDevicesProperty, 0); | 354 CallNotifyObserversPropertyChanged(shill::kDevicesProperty); |
| 342 } | 355 } |
| 343 | 356 |
| 344 void FakeShillManagerClient::AddTechnology(const std::string& type, | 357 void FakeShillManagerClient::AddTechnology(const std::string& type, |
| 345 bool enabled) { | 358 bool enabled) { |
| 346 if (GetListProperty(shill::kAvailableTechnologiesProperty)-> | 359 if (GetListProperty(shill::kAvailableTechnologiesProperty) |
| 347 AppendIfNotPresent(base::Value::CreateStringValue(type))) { | 360 ->AppendIfNotPresent(base::Value::CreateStringValue(type))) { |
| 348 CallNotifyObserversPropertyChanged( | 361 CallNotifyObserversPropertyChanged(shill::kAvailableTechnologiesProperty); |
| 349 shill::kAvailableTechnologiesProperty, 0); | |
| 350 } | 362 } |
| 351 if (enabled && | 363 if (enabled && |
| 352 GetListProperty(shill::kEnabledTechnologiesProperty)-> | 364 GetListProperty(shill::kEnabledTechnologiesProperty) |
| 353 AppendIfNotPresent(base::Value::CreateStringValue(type))) { | 365 ->AppendIfNotPresent(base::Value::CreateStringValue(type))) { |
| 354 CallNotifyObserversPropertyChanged( | 366 CallNotifyObserversPropertyChanged(shill::kEnabledTechnologiesProperty); |
| 355 shill::kEnabledTechnologiesProperty, 0); | |
| 356 } | 367 } |
| 357 } | 368 } |
| 358 | 369 |
| 359 void FakeShillManagerClient::RemoveTechnology(const std::string& type) { | 370 void FakeShillManagerClient::RemoveTechnology(const std::string& type) { |
| 360 base::StringValue type_value(type); | 371 base::StringValue type_value(type); |
| 361 if (GetListProperty(shill::kAvailableTechnologiesProperty)->Remove( | 372 if (GetListProperty(shill::kAvailableTechnologiesProperty) |
| 362 type_value, NULL)) { | 373 ->Remove(type_value, NULL)) { |
| 363 CallNotifyObserversPropertyChanged( | 374 CallNotifyObserversPropertyChanged(shill::kAvailableTechnologiesProperty); |
| 364 shill::kAvailableTechnologiesProperty, 0); | |
| 365 } | 375 } |
| 366 if (GetListProperty(shill::kEnabledTechnologiesProperty)->Remove( | 376 if (GetListProperty(shill::kEnabledTechnologiesProperty) |
| 367 type_value, NULL)) { | 377 ->Remove(type_value, NULL)) { |
| 368 CallNotifyObserversPropertyChanged( | 378 CallNotifyObserversPropertyChanged(shill::kEnabledTechnologiesProperty); |
| 369 shill::kEnabledTechnologiesProperty, 0); | |
| 370 } | 379 } |
| 371 } | 380 } |
| 372 | 381 |
| 373 void FakeShillManagerClient::SetTechnologyInitializing(const std::string& type, | 382 void FakeShillManagerClient::SetTechnologyInitializing(const std::string& type, |
| 374 bool initializing) { | 383 bool initializing) { |
| 375 if (initializing) { | 384 if (initializing) { |
| 376 if (GetListProperty(shill::kUninitializedTechnologiesProperty)-> | 385 if (GetListProperty(shill::kUninitializedTechnologiesProperty) |
| 377 AppendIfNotPresent(base::Value::CreateStringValue(type))) { | 386 ->AppendIfNotPresent(base::Value::CreateStringValue(type))) { |
| 378 CallNotifyObserversPropertyChanged( | 387 CallNotifyObserversPropertyChanged( |
| 379 shill::kUninitializedTechnologiesProperty, 0); | 388 shill::kUninitializedTechnologiesProperty); |
| 380 } | 389 } |
| 381 } else { | 390 } else { |
| 382 if (GetListProperty(shill::kUninitializedTechnologiesProperty)->Remove( | 391 if (GetListProperty(shill::kUninitializedTechnologiesProperty) |
| 383 base::StringValue(type), NULL)) { | 392 ->Remove(base::StringValue(type), NULL)) { |
| 384 CallNotifyObserversPropertyChanged( | 393 CallNotifyObserversPropertyChanged( |
| 385 shill::kUninitializedTechnologiesProperty, 0); | 394 shill::kUninitializedTechnologiesProperty); |
| 386 } | 395 } |
| 387 } | 396 } |
| 388 } | 397 } |
| 389 | 398 |
| 399 void FakeShillManagerClient::AddGeoNetwork( | |
| 400 const std::string& technology, | |
| 401 const base::DictionaryValue& network) { | |
| 402 base::ListValue* list_value = NULL; | |
| 403 if (!stub_geo_networks_.GetListWithoutPathExpansion(technology, | |
| 404 &list_value)) { | |
| 405 list_value = new base::ListValue; | |
| 406 stub_geo_networks_.SetWithoutPathExpansion(technology, list_value); | |
| 407 } | |
| 408 list_value->Append(network.DeepCopy()); | |
| 409 } | |
| 410 | |
| 411 void FakeShillManagerClient::AddProfile(const std::string& profile_path) { | |
| 412 const char* key = shill::kProfilesProperty; | |
| 413 if (GetListProperty(key) | |
| 414 ->AppendIfNotPresent(new base::StringValue(profile_path))) { | |
| 415 CallNotifyObserversPropertyChanged(key); | |
| 416 } | |
| 417 } | |
| 418 | |
| 390 void FakeShillManagerClient::ClearProperties() { | 419 void FakeShillManagerClient::ClearProperties() { |
| 391 stub_properties_.Clear(); | 420 stub_properties_.Clear(); |
| 392 } | 421 } |
| 393 | 422 |
| 394 void FakeShillManagerClient::AddManagerService(const std::string& service_path, | 423 void FakeShillManagerClient::AddManagerService(const std::string& service_path, |
| 395 bool add_to_visible_list, | 424 bool add_to_visible_list, |
| 396 bool add_to_watch_list) { | 425 bool add_to_watch_list) { |
| 397 // Always add to ServiceCompleteListProperty. | 426 // Always add to ServiceCompleteListProperty. |
| 398 GetListProperty(shill::kServiceCompleteListProperty)->AppendIfNotPresent( | 427 GetListProperty(shill::kServiceCompleteListProperty)->AppendIfNotPresent( |
| 399 base::Value::CreateStringValue(service_path)); | 428 base::Value::CreateStringValue(service_path)); |
| 400 // If visible, add to Services and notify if new. | 429 // If visible, add to Services and notify if new. |
| 401 if (add_to_visible_list && | 430 if (add_to_visible_list && |
| 402 GetListProperty(shill::kServicesProperty)->AppendIfNotPresent( | 431 GetListProperty(shill::kServicesProperty) |
| 403 base::Value::CreateStringValue(service_path))) { | 432 ->AppendIfNotPresent(base::Value::CreateStringValue(service_path))) { |
| 404 CallNotifyObserversPropertyChanged(shill::kServicesProperty, 0); | 433 CallNotifyObserversPropertyChanged(shill::kServicesProperty); |
| 405 } | 434 } |
| 406 if (add_to_watch_list) | 435 if (add_to_watch_list) |
| 407 AddServiceToWatchList(service_path); | 436 AddServiceToWatchList(service_path); |
| 408 } | 437 } |
| 409 | 438 |
| 410 void FakeShillManagerClient::RemoveManagerService( | 439 void FakeShillManagerClient::RemoveManagerService( |
| 411 const std::string& service_path) { | 440 const std::string& service_path) { |
| 412 base::StringValue service_path_value(service_path); | 441 base::StringValue service_path_value(service_path); |
| 413 if (GetListProperty(shill::kServicesProperty)->Remove( | 442 if (GetListProperty(shill::kServicesProperty) |
| 414 service_path_value, NULL)) { | 443 ->Remove(service_path_value, NULL)) { |
| 415 CallNotifyObserversPropertyChanged(shill::kServicesProperty, 0); | 444 CallNotifyObserversPropertyChanged(shill::kServicesProperty); |
| 416 } | 445 } |
| 417 GetListProperty(shill::kServiceCompleteListProperty)->Remove( | 446 GetListProperty(shill::kServiceCompleteListProperty) |
| 418 service_path_value, NULL); | 447 ->Remove(service_path_value, NULL); |
| 419 if (GetListProperty(shill::kServiceWatchListProperty)->Remove( | 448 if (GetListProperty(shill::kServiceWatchListProperty) |
| 420 service_path_value, NULL)) { | 449 ->Remove(service_path_value, NULL)) { |
| 421 CallNotifyObserversPropertyChanged( | 450 CallNotifyObserversPropertyChanged(shill::kServiceWatchListProperty); |
| 422 shill::kServiceWatchListProperty, 0); | |
| 423 } | 451 } |
| 424 } | 452 } |
| 425 | 453 |
| 426 void FakeShillManagerClient::ClearManagerServices() { | 454 void FakeShillManagerClient::ClearManagerServices() { |
| 427 GetListProperty(shill::kServicesProperty)->Clear(); | 455 GetListProperty(shill::kServicesProperty)->Clear(); |
| 428 GetListProperty(shill::kServiceCompleteListProperty)->Clear(); | 456 GetListProperty(shill::kServiceCompleteListProperty)->Clear(); |
| 429 GetListProperty(shill::kServiceWatchListProperty)->Clear(); | 457 GetListProperty(shill::kServiceWatchListProperty)->Clear(); |
| 430 CallNotifyObserversPropertyChanged(shill::kServicesProperty, 0); | 458 CallNotifyObserversPropertyChanged(shill::kServicesProperty); |
| 431 CallNotifyObserversPropertyChanged(shill::kServiceWatchListProperty, 0); | 459 CallNotifyObserversPropertyChanged(shill::kServiceWatchListProperty); |
| 432 } | 460 } |
| 433 | 461 |
| 434 void FakeShillManagerClient::SortManagerServices() { | 462 void FakeShillManagerClient::SortManagerServices() { |
| 435 static const char* ordered_types[] = { | 463 static const char* ordered_types[] = { |
| 436 shill::kTypeEthernet, | 464 shill::kTypeEthernet, |
| 437 shill::kTypeWifi, | 465 shill::kTypeWifi, |
| 438 shill::kTypeCellular, | 466 shill::kTypeCellular, |
| 439 shill::kTypeWimax, | 467 shill::kTypeWimax, |
| 440 shill::kTypeVPN | 468 shill::kTypeVPN |
| 441 }; | 469 }; |
| 442 base::ListValue* service_list = GetListProperty(shill::kServicesProperty); | 470 base::ListValue* service_list = GetListProperty(shill::kServicesProperty); |
| 443 if (!service_list || service_list->empty()) | 471 if (!service_list || service_list->empty()) |
| 444 return; | 472 return; |
| 445 std::vector<std::string> active_services; | 473 std::vector<std::string> active_services; |
| 446 std::vector<std::string> inactive_services; | 474 std::vector<std::string> inactive_services; |
| 447 for (size_t i = 0; i < arraysize(ordered_types); ++i) { | 475 for (size_t i = 0; i < arraysize(ordered_types); ++i) { |
| 448 AppendServicesForType(service_list, ordered_types[i], | 476 AppendServicesForType(service_list, ordered_types[i], |
| 449 &active_services, &inactive_services); | 477 &active_services, &inactive_services); |
| 450 } | 478 } |
| 451 service_list->Clear(); | 479 service_list->Clear(); |
| 452 for (size_t i = 0; i < active_services.size(); ++i) | 480 for (size_t i = 0; i < active_services.size(); ++i) |
| 453 service_list->AppendString(active_services[i]); | 481 service_list->AppendString(active_services[i]); |
| 454 for (size_t i = 0; i < inactive_services.size(); ++i) | 482 for (size_t i = 0; i < inactive_services.size(); ++i) |
| 455 service_list->AppendString(inactive_services[i]); | 483 service_list->AppendString(inactive_services[i]); |
| 456 | 484 |
| 457 CallNotifyObserversPropertyChanged(shill::kServicesProperty, 0); | 485 CallNotifyObserversPropertyChanged(shill::kServicesProperty); |
| 458 } | 486 } |
| 459 | 487 |
| 460 void FakeShillManagerClient::AddGeoNetwork( | 488 |
| 461 const std::string& technology, | 489 int FakeShillManagerClient::GetInteractiveDelay() const { |
| 462 const base::DictionaryValue& network) { | 490 return interactive_delay_; |
| 463 base::ListValue* list_value = NULL; | |
| 464 if (!stub_geo_networks_.GetListWithoutPathExpansion( | |
| 465 technology, &list_value)) { | |
| 466 list_value = new base::ListValue; | |
| 467 stub_geo_networks_.SetWithoutPathExpansion(technology, list_value); | |
| 468 } | |
| 469 list_value->Append(network.DeepCopy()); | |
| 470 } | 491 } |
| 471 | 492 |
| 472 void FakeShillManagerClient::AddProfile(const std::string& profile_path) { | 493 std::string FakeShillManagerClient::GetInitialState( |
| 473 const char* key = shill::kProfilesProperty; | 494 const std::string& type) const { |
| 474 if (GetListProperty(key)->AppendIfNotPresent( | 495 std::map<std::string, std::string>::const_iterator iter = |
| 475 new base::StringValue(profile_path))) { | 496 shill_initial_state_map_.find(type); |
| 476 CallNotifyObserversPropertyChanged(key, 0); | 497 if (iter == shill_initial_state_map_.end()) |
| 477 } | 498 return shill::kStateOffline; // Not available |
| 499 return iter->second; | |
| 478 } | 500 } |
| 479 | 501 |
| 502 // Private methods | |
| 503 | |
| 480 void FakeShillManagerClient::AddServiceToWatchList( | 504 void FakeShillManagerClient::AddServiceToWatchList( |
| 481 const std::string& service_path) { | 505 const std::string& service_path) { |
| 482 // Remove and insert the service, moving it to the front of the watch list. | 506 // Remove and insert the service, moving it to the front of the watch list. |
| 483 GetListProperty(shill::kServiceWatchListProperty)->Remove( | 507 GetListProperty(shill::kServiceWatchListProperty) |
| 484 base::StringValue(service_path), NULL); | 508 ->Remove(base::StringValue(service_path), NULL); |
| 485 GetListProperty(shill::kServiceWatchListProperty)->Insert( | 509 GetListProperty(shill::kServiceWatchListProperty) |
| 486 0, base::Value::CreateStringValue(service_path)); | 510 ->Insert(0, base::Value::CreateStringValue(service_path)); |
| 487 CallNotifyObserversPropertyChanged( | 511 CallNotifyObserversPropertyChanged(shill::kServiceWatchListProperty); |
| 488 shill::kServiceWatchListProperty, 0); | |
| 489 } | 512 } |
| 490 | 513 |
| 491 void FakeShillManagerClient::PassStubProperties( | 514 void FakeShillManagerClient::PassStubProperties( |
| 492 const DictionaryValueCallback& callback) const { | 515 const DictionaryValueCallback& callback) const { |
| 493 scoped_ptr<base::DictionaryValue> stub_properties( | 516 scoped_ptr<base::DictionaryValue> stub_properties( |
| 494 stub_properties_.DeepCopy()); | 517 stub_properties_.DeepCopy()); |
| 495 // Remove disabled services from the list. | 518 // Remove disabled services from the list. |
| 496 stub_properties->SetWithoutPathExpansion( | 519 stub_properties->SetWithoutPathExpansion( |
| 497 shill::kServicesProperty, | 520 shill::kServicesProperty, |
| 498 GetEnabledServiceList(shill::kServicesProperty)); | 521 GetEnabledServiceList(shill::kServicesProperty)); |
| 499 stub_properties->SetWithoutPathExpansion( | 522 stub_properties->SetWithoutPathExpansion( |
| 500 shill::kServiceWatchListProperty, | 523 shill::kServiceWatchListProperty, |
| 501 GetEnabledServiceList(shill::kServiceWatchListProperty)); | 524 GetEnabledServiceList(shill::kServiceWatchListProperty)); |
| 502 callback.Run(DBUS_METHOD_CALL_SUCCESS, *stub_properties); | 525 callback.Run(DBUS_METHOD_CALL_SUCCESS, *stub_properties); |
| 503 } | 526 } |
| 504 | 527 |
| 505 void FakeShillManagerClient::PassStubGeoNetworks( | 528 void FakeShillManagerClient::PassStubGeoNetworks( |
| 506 const DictionaryValueCallback& callback) const { | 529 const DictionaryValueCallback& callback) const { |
| 507 callback.Run(DBUS_METHOD_CALL_SUCCESS, stub_geo_networks_); | 530 callback.Run(DBUS_METHOD_CALL_SUCCESS, stub_geo_networks_); |
| 508 } | 531 } |
| 509 | 532 |
| 510 void FakeShillManagerClient::CallNotifyObserversPropertyChanged( | 533 void FakeShillManagerClient::CallNotifyObserversPropertyChanged( |
| 511 const std::string& property, | 534 const std::string& property) { |
| 512 int delay_ms) { | |
| 513 // Avoid unnecessary delayed task if we have no observers (e.g. during | 535 // Avoid unnecessary delayed task if we have no observers (e.g. during |
| 514 // initial setup). | 536 // initial setup). |
| 515 if (!observer_list_.might_have_observers()) | 537 if (!observer_list_.might_have_observers()) |
| 516 return; | 538 return; |
| 517 if (!CommandLine::ForCurrentProcess()->HasSwitch( | 539 base::MessageLoop::current()->PostTask( |
| 518 chromeos::switches::kEnableStubInteractive)) { | |
| 519 delay_ms = 0; | |
| 520 } | |
| 521 base::MessageLoop::current()->PostDelayedTask( | |
| 522 FROM_HERE, | 540 FROM_HERE, |
| 523 base::Bind(&FakeShillManagerClient::NotifyObserversPropertyChanged, | 541 base::Bind(&FakeShillManagerClient::NotifyObserversPropertyChanged, |
| 524 weak_ptr_factory_.GetWeakPtr(), | 542 weak_ptr_factory_.GetWeakPtr(), |
| 525 property), | 543 property)); |
| 526 base::TimeDelta::FromMilliseconds(delay_ms)); | |
| 527 } | 544 } |
| 528 | 545 |
| 529 void FakeShillManagerClient::NotifyObserversPropertyChanged( | 546 void FakeShillManagerClient::NotifyObserversPropertyChanged( |
| 530 const std::string& property) { | 547 const std::string& property) { |
| 531 if (property == shill::kServicesProperty || | 548 if (property == shill::kServicesProperty || |
| 532 property == shill::kServiceWatchListProperty) { | 549 property == shill::kServiceWatchListProperty) { |
| 533 scoped_ptr<base::ListValue> services(GetEnabledServiceList(property)); | 550 scoped_ptr<base::ListValue> services(GetEnabledServiceList(property)); |
| 534 FOR_EACH_OBSERVER(ShillPropertyChangedObserver, | 551 FOR_EACH_OBSERVER(ShillPropertyChangedObserver, |
| 535 observer_list_, | 552 observer_list_, |
| 536 OnPropertyChanged(property, *(services.get()))); | 553 OnPropertyChanged(property, *(services.get()))); |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 586 const base::Closure& callback, | 603 const base::Closure& callback, |
| 587 bool enabled) { | 604 bool enabled) { |
| 588 base::ListValue* enabled_list = NULL; | 605 base::ListValue* enabled_list = NULL; |
| 589 stub_properties_.GetListWithoutPathExpansion( | 606 stub_properties_.GetListWithoutPathExpansion( |
| 590 shill::kEnabledTechnologiesProperty, &enabled_list); | 607 shill::kEnabledTechnologiesProperty, &enabled_list); |
| 591 DCHECK(enabled_list); | 608 DCHECK(enabled_list); |
| 592 if (enabled) | 609 if (enabled) |
| 593 enabled_list->AppendIfNotPresent(new base::StringValue(type)); | 610 enabled_list->AppendIfNotPresent(new base::StringValue(type)); |
| 594 else | 611 else |
| 595 enabled_list->Remove(base::StringValue(type), NULL); | 612 enabled_list->Remove(base::StringValue(type), NULL); |
| 596 CallNotifyObserversPropertyChanged( | 613 CallNotifyObserversPropertyChanged(shill::kEnabledTechnologiesProperty); |
| 597 shill::kEnabledTechnologiesProperty, 0 /* already delayed */); | |
| 598 base::MessageLoop::current()->PostTask(FROM_HERE, callback); | 614 base::MessageLoop::current()->PostTask(FROM_HERE, callback); |
| 599 // May affect available services | 615 // May affect available services |
| 600 CallNotifyObserversPropertyChanged(shill::kServicesProperty, 0); | 616 CallNotifyObserversPropertyChanged(shill::kServicesProperty); |
| 601 CallNotifyObserversPropertyChanged(shill::kServiceWatchListProperty, 0); | 617 CallNotifyObserversPropertyChanged(shill::kServiceWatchListProperty); |
| 602 } | 618 } |
| 603 | 619 |
| 604 base::ListValue* FakeShillManagerClient::GetEnabledServiceList( | 620 base::ListValue* FakeShillManagerClient::GetEnabledServiceList( |
| 605 const std::string& property) const { | 621 const std::string& property) const { |
| 606 base::ListValue* new_service_list = new base::ListValue; | 622 base::ListValue* new_service_list = new base::ListValue; |
| 607 const base::ListValue* service_list; | 623 const base::ListValue* service_list; |
| 608 if (stub_properties_.GetListWithoutPathExpansion(property, &service_list)) { | 624 if (stub_properties_.GetListWithoutPathExpansion(property, &service_list)) { |
| 609 ShillServiceClient::TestInterface* service_client = | 625 ShillServiceClient::TestInterface* service_client = |
| 610 DBusThreadManager::Get()->GetShillServiceClient()->GetTestInterface(); | 626 DBusThreadManager::Get()->GetShillServiceClient()->GetTestInterface(); |
| 611 for (base::ListValue::const_iterator iter = service_list->begin(); | 627 for (base::ListValue::const_iterator iter = service_list->begin(); |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 631 } | 647 } |
| 632 | 648 |
| 633 void FakeShillManagerClient::ScanCompleted(const std::string& device_path, | 649 void FakeShillManagerClient::ScanCompleted(const std::string& device_path, |
| 634 const base::Closure& callback) { | 650 const base::Closure& callback) { |
| 635 if (!device_path.empty()) { | 651 if (!device_path.empty()) { |
| 636 DBusThreadManager::Get()->GetShillDeviceClient()->GetTestInterface()-> | 652 DBusThreadManager::Get()->GetShillDeviceClient()->GetTestInterface()-> |
| 637 SetDeviceProperty(device_path, | 653 SetDeviceProperty(device_path, |
| 638 shill::kScanningProperty, | 654 shill::kScanningProperty, |
| 639 base::FundamentalValue(false)); | 655 base::FundamentalValue(false)); |
| 640 } | 656 } |
| 641 CallNotifyObserversPropertyChanged(shill::kServicesProperty, 0); | 657 CallNotifyObserversPropertyChanged(shill::kServicesProperty); |
| 642 CallNotifyObserversPropertyChanged(shill::kServiceWatchListProperty, 0); | 658 CallNotifyObserversPropertyChanged(shill::kServiceWatchListProperty); |
| 643 base::MessageLoop::current()->PostTask(FROM_HERE, callback); | 659 base::MessageLoop::current()->PostTask(FROM_HERE, callback); |
| 644 } | 660 } |
| 645 | 661 |
| 662 void FakeShillManagerClient::ParseCommandLineSwitch() { | |
| 663 if (dbus_command_line_helper::ParseOptions( | |
| 664 switches::kShillStub, | |
| 665 base::Bind(&FakeShillManagerClient::ParseOption, | |
| 666 base::Unretained(this)))) | |
| 667 return; | |
| 668 // Default setup | |
| 669 SetInitialNetworkState(shill::kTypeEthernet, shill::kStateOnline); | |
| 670 SetInitialNetworkState(shill::kTypeWifi, shill::kStateOnline); | |
| 671 SetInitialNetworkState(shill::kTypeCellular, shill::kStateIdle); | |
| 672 SetInitialNetworkState(shill::kTypeVPN, shill::kStateIdle); | |
| 673 } | |
| 674 | |
| 675 bool FakeShillManagerClient::ParseOption(const std::string& arg0, | |
| 676 const std::string& arg1) { | |
| 677 if (arg0 == "interactive") { | |
| 678 int seconds = 3; | |
| 679 if (!arg1.empty()) | |
| 680 base::StringToInt(arg1, &seconds); | |
| 681 interactive_delay_ = seconds; | |
| 682 return true; | |
| 683 } | |
| 684 return SetInitialNetworkState(arg0, arg1); | |
| 685 } | |
| 686 | |
| 687 bool FakeShillManagerClient::SetInitialNetworkState(std::string type_arg, | |
| 688 std::string state_arg) { | |
| 689 std::string state; | |
| 690 state_arg = StringToLowerASCII(state_arg); | |
| 691 if (state_arg == "0" || state_arg == "off" || state_arg == "inactive" || | |
| 692 state_arg == shill::kStateIdle) | |
| 693 state = shill::kStateIdle; // Enabled but not connected | |
| 694 else if (state_arg == "disabled" || state_arg == "disconnect") | |
| 695 state = shill::kStateDisconnect; // Diabled but available | |
| 696 else if (state_arg == "none" || state_arg == "offline") | |
| 697 state = shill::kStateOffline; // Not available | |
| 698 else if (state_arg == "portal") | |
| 699 state = shill::kStatePortal; // Connected to portal | |
| 700 else if (state_arg == "active" || state_arg == "activated") | |
| 701 state = shill::kActivationStateActivated; // Connected and activated | |
| 702 else | |
| 703 state = shill::kStateOnline; // Connected | |
| 704 | |
| 705 std::string type; | |
| 706 type_arg = StringToLowerASCII(type_arg); | |
| 707 if (type_arg == "ethernet" || type_arg == "eth") { | |
| 708 if (state == shill::kStateIdle || state == shill::kStateDisconnect) | |
| 709 state = shill::kStateOffline; // No unconnected or disabled ethernet. | |
| 710 shill_initial_state_map_[shill::kTypeEthernet] = state; | |
| 711 } else if (type_arg == "wifi") { | |
| 712 shill_initial_state_map_[shill::kTypeWifi] = state; | |
| 713 } else if (type_arg == "cellular") { | |
| 714 shill_initial_state_map_[shill::kTypeCellular] = state; | |
| 715 } else if (type_arg == "wireless") { | |
| 716 shill_initial_state_map_[shill::kTypeWifi] = state; | |
| 717 shill_initial_state_map_[shill::kTypeCellular] = state; | |
| 718 } else if (type_arg == "wimax") { | |
| 719 shill_initial_state_map_[shill::kTypeWimax] = state; | |
| 720 } else if (type_arg == "vpn") { | |
| 721 shill_initial_state_map_[shill::kTypeVPN] = state; | |
| 722 } else { | |
| 723 LOG(WARNING) << "Unrecognized Shill network type: " << type_arg; | |
| 724 return false; | |
| 725 } | |
| 726 return true; | |
| 727 } | |
| 728 | |
| 729 void FakeShillManagerClient::SetupDefaultEnvironment() { | |
| 730 DBusThreadManager* dbus_manager = DBusThreadManager::Get(); | |
| 731 ShillServiceClient::TestInterface* services = | |
| 732 dbus_manager->GetShillServiceClient()->GetTestInterface(); | |
| 733 ShillProfileClient::TestInterface* profiles = | |
| 734 dbus_manager->GetShillProfileClient()->GetTestInterface(); | |
| 735 ShillDeviceClient::TestInterface* devices = | |
| 736 dbus_manager->GetShillDeviceClient()->GetTestInterface(); | |
| 737 if (!services || !profiles || !devices) | |
| 738 return; | |
| 739 | |
| 740 const std::string shared_profile = ShillProfileClient::GetSharedProfilePath(); | |
| 741 profiles->AddProfile(shared_profile, std::string()); | |
| 742 | |
| 743 const bool add_to_visible = true; | |
| 744 const bool add_to_watchlist = true; | |
| 745 | |
| 746 bool enabled, portaled; | |
| 747 std::string state; | |
| 748 | |
| 749 // Ethernet. No service is not added unless connected. | |
| 750 state = ParseInitialState(shill::kTypeEthernet, &enabled, &portaled); | |
| 751 if (state == shill::kStateOnline) { | |
| 752 AddTechnology(shill::kTypeEthernet, enabled); | |
| 753 devices->AddDevice( | |
| 754 "/device/eth1", shill::kTypeEthernet, "stub_eth_device1"); | |
| 755 services->AddService("eth1", "eth1", | |
| 756 shill::kTypeEthernet, | |
| 757 state, | |
| 758 add_to_visible, add_to_watchlist); | |
| 759 profiles->AddService(shared_profile, "eth1"); | |
| 760 } | |
| 761 | |
| 762 // Wifi | |
| 763 state = ParseInitialState(shill::kTypeWifi, &enabled, &portaled); | |
| 764 if (state != shill::kStateOffline) { | |
| 765 AddTechnology(shill::kTypeWifi, enabled); | |
| 766 devices->AddDevice("/device/wifi1", shill::kTypeWifi, "stub_wifi_device1"); | |
| 767 | |
| 768 services->AddService("wifi1", | |
| 769 "wifi1", | |
| 770 shill::kTypeWifi, | |
| 771 state, | |
| 772 add_to_visible, add_to_watchlist); | |
| 773 services->SetServiceProperty("wifi1", | |
| 774 shill::kSecurityProperty, | |
| 775 base::StringValue(shill::kSecurityWep)); | |
| 776 profiles->AddService(shared_profile, "wifi1"); | |
| 777 | |
| 778 services->AddService("wifi2", | |
| 779 "wifi2_PSK", | |
| 780 shill::kTypeWifi, | |
| 781 shill::kStateIdle, | |
| 782 add_to_visible, add_to_watchlist); | |
| 783 services->SetServiceProperty("wifi2", | |
| 784 shill::kSecurityProperty, | |
| 785 base::StringValue(shill::kSecurityPsk)); | |
| 786 | |
| 787 base::FundamentalValue strength_value(80); | |
| 788 services->SetServiceProperty( | |
| 789 "wifi2", shill::kSignalStrengthProperty, strength_value); | |
| 790 profiles->AddService(shared_profile, "wifi2"); | |
| 791 | |
| 792 if (portaled) { | |
| 793 services->AddService("portalled_wifi", | |
| 794 "Portalled Wifi", | |
| 795 shill::kTypeWifi, | |
| 796 shill::kStatePortal, | |
| 797 add_to_visible, add_to_watchlist); | |
| 798 services->SetServiceProperty("portalled_wifi", | |
| 799 shill::kSecurityProperty, | |
| 800 base::StringValue(shill::kSecurityNone)); | |
| 801 services->SetConnectBehavior("portalled_wifi", | |
| 802 base::Bind(&UpdatePortalledWifiState, | |
| 803 "portalled_wifi")); | |
| 804 services->SetServiceProperty("portalled_wifi", | |
| 805 shill::kConnectableProperty, | |
| 806 base::FundamentalValue(true)); | |
| 807 profiles->AddService(shared_profile, "portalled_wifi"); | |
| 808 } | |
| 809 } | |
| 810 | |
| 811 // Wimax | |
| 812 state = ParseInitialState(shill::kTypeWimax, &enabled, &portaled); | |
| 813 if (state != shill::kStateOffline) { | |
| 814 AddTechnology(shill::kTypeWimax, enabled); | |
| 815 devices->AddDevice( | |
| 816 "/device/wimax1", shill::kTypeWimax, "stub_wimax_device1"); | |
| 817 | |
| 818 services->AddService("wimax1", | |
| 819 "wimax1", | |
| 820 shill::kTypeWimax, | |
| 821 state, | |
| 822 add_to_visible, add_to_watchlist); | |
| 823 services->SetServiceProperty( | |
| 824 "wimax1", shill::kConnectableProperty, base::FundamentalValue(true)); | |
| 825 } | |
| 826 | |
| 827 // Cellular | |
| 828 state = ParseInitialState(shill::kTypeCellular, &enabled, &portaled); | |
| 829 if (state != shill::kStateOffline) { | |
| 830 bool activated = false; | |
| 831 if (state == shill::kActivationStateActivated) { | |
| 832 activated = true; | |
| 833 state = shill::kStateIdle; | |
| 834 } | |
| 835 AddTechnology(shill::kTypeCellular, enabled); | |
| 836 devices->AddDevice( | |
| 837 "/device/cellular1", shill::kTypeCellular, "stub_cellular_device1"); | |
| 838 devices->SetDeviceProperty("/device/cellular1", | |
| 839 shill::kCarrierProperty, | |
| 840 base::StringValue(shill::kCarrierSprint)); | |
| 841 | |
| 842 services->AddService("cellular1", | |
| 843 "cellular1", | |
| 844 shill::kTypeCellular, | |
| 845 state, | |
| 846 add_to_visible, add_to_watchlist); | |
| 847 base::StringValue technology_value(shill::kNetworkTechnologyGsm); | |
| 848 services->SetServiceProperty( | |
| 849 "cellular1", shill::kNetworkTechnologyProperty, technology_value); | |
| 850 | |
| 851 if (activated) { | |
| 852 services->SetServiceProperty( | |
| 853 "cellular1", | |
| 854 shill::kActivationStateProperty, | |
| 855 base::StringValue(shill::kActivationStateActivated)); | |
| 856 services->SetServiceProperty("cellular1", | |
| 857 shill::kConnectableProperty, | |
| 858 base::FundamentalValue(true)); | |
| 859 } else { | |
| 860 services->SetServiceProperty( | |
| 861 "cellular1", | |
| 862 shill::kActivationStateProperty, | |
| 863 base::StringValue(shill::kActivationStateNotActivated)); | |
| 864 } | |
| 865 | |
| 866 services->SetServiceProperty("cellular1", | |
| 867 shill::kRoamingStateProperty, | |
| 868 base::StringValue(shill::kRoamingStateHome)); | |
| 869 } | |
| 870 | |
| 871 // VPN | |
| 872 state = ParseInitialState(shill::kTypeVPN, &enabled, &portaled); | |
| 873 if (state != shill::kStateOffline) { | |
| 874 // Set the "Provider" dictionary properties. Note: when setting these in | |
| 875 // Shill, "Provider.Type", etc keys are used, but when reading the values | |
| 876 // "Provider" . "Type", etc keys are used. Here we are setting the values | |
| 877 // that will be read (by the UI, tests, etc). | |
| 878 base::DictionaryValue provider_properties; | |
| 879 provider_properties.SetString(shill::kTypeProperty, | |
| 880 shill::kProviderOpenVpn); | |
| 881 provider_properties.SetString(shill::kHostProperty, "vpn_host"); | |
| 882 | |
| 883 services->AddService("vpn1", | |
| 884 "vpn1", | |
| 885 shill::kTypeVPN, | |
| 886 state, | |
| 887 add_to_visible, add_to_watchlist); | |
| 888 services->SetServiceProperty( | |
| 889 "vpn1", shill::kProviderProperty, provider_properties); | |
| 890 profiles->AddService(shared_profile, "vpn1"); | |
| 891 | |
| 892 services->AddService("vpn2", | |
| 893 "vpn2", | |
| 894 shill::kTypeVPN, | |
| 895 shill::kStateIdle, | |
| 896 add_to_visible, add_to_watchlist); | |
| 897 services->SetServiceProperty( | |
| 898 "vpn2", shill::kProviderProperty, provider_properties); | |
| 899 } | |
| 900 | |
| 901 SortManagerServices(); | |
| 902 } | |
| 903 | |
| 904 std::string FakeShillManagerClient::ParseInitialState(const std::string& type, | |
| 905 bool* enabled, | |
| 906 bool* portaled) { | |
| 907 std::string state = GetInitialState(type); | |
| 908 if (state == shill::kStateDisconnect) { | |
| 909 *enabled = false; | |
| 910 *portaled = false; | |
| 911 return shill::kStateIdle; | |
| 912 } | |
| 913 if (state == shill::kStatePortal) { | |
| 914 if (type != shill::kTypeWifi) | |
| 915 LOG(WARNING) << "Invalid state: " << state << " for " << type; | |
| 916 *enabled = true; | |
| 917 *portaled = true; | |
| 918 return shill::kStateIdle; | |
| 919 } | |
| 920 if (state == shill::kActivationStateActivated && | |
| 921 type != shill::kTypeCellular) { | |
| 922 LOG(WARNING) << "Invalid state: " << state << " for " << type; | |
| 923 state = shill::kStateIdle; | |
| 924 } | |
| 925 *enabled = true; | |
| 926 *portaled = false; | |
| 927 return state; | |
| 928 } | |
| 929 | |
| 646 } // namespace chromeos | 930 } // namespace chromeos |
| OLD | NEW |