Index: chromeos/dbus/dbus_client_bundle.cc |
diff --git a/chromeos/dbus/dbus_client_bundle.cc b/chromeos/dbus/dbus_client_bundle.cc |
index b5ccb8ed95ec70d709fd8f759236435b976f95c5..4ab8f3ed763bce1c6605ec1d869db076a7057223 100644 |
--- a/chromeos/dbus/dbus_client_bundle.cc |
+++ b/chromeos/dbus/dbus_client_bundle.cc |
@@ -4,8 +4,10 @@ |
#include "chromeos/dbus/dbus_client_bundle.h" |
+#include "base/command_line.h" |
#include "base/strings/string_split.h" |
#include "base/strings/string_util.h" |
+#include "chromeos/chromeos_switches.h" |
#include "chromeos/dbus/bluetooth_adapter_client.h" |
#include "chromeos/dbus/bluetooth_agent_manager_client.h" |
#include "chromeos/dbus/bluetooth_device_client.h" |
@@ -16,11 +18,42 @@ |
#include "chromeos/dbus/bluetooth_input_client.h" |
#include "chromeos/dbus/bluetooth_profile_manager_client.h" |
#include "chromeos/dbus/cras_audio_client.h" |
+#include "chromeos/dbus/cras_audio_client_stub_impl.h" |
#include "chromeos/dbus/cros_disks_client.h" |
#include "chromeos/dbus/cryptohome_client.h" |
#include "chromeos/dbus/dbus_thread_manager.h" |
#include "chromeos/dbus/debug_daemon_client.h" |
#include "chromeos/dbus/easy_unlock_client.h" |
+#include "chromeos/dbus/fake_bluetooth_adapter_client.h" |
+#include "chromeos/dbus/fake_bluetooth_agent_manager_client.h" |
+#include "chromeos/dbus/fake_bluetooth_device_client.h" |
+#include "chromeos/dbus/fake_bluetooth_gatt_characteristic_client.h" |
+#include "chromeos/dbus/fake_bluetooth_gatt_descriptor_client.h" |
+#include "chromeos/dbus/fake_bluetooth_gatt_manager_client.h" |
+#include "chromeos/dbus/fake_bluetooth_gatt_service_client.h" |
+#include "chromeos/dbus/fake_bluetooth_input_client.h" |
+#include "chromeos/dbus/fake_bluetooth_profile_manager_client.h" |
+#include "chromeos/dbus/fake_cryptohome_client.h" |
+#include "chromeos/dbus/fake_debug_daemon_client.h" |
+#include "chromeos/dbus/fake_easy_unlock_client.h" |
+#include "chromeos/dbus/fake_gsm_sms_client.h" |
+#include "chromeos/dbus/fake_image_burner_client.h" |
+#include "chromeos/dbus/fake_introspectable_client.h" |
+#include "chromeos/dbus/fake_lorgnette_manager_client.h" |
+#include "chromeos/dbus/fake_modem_messaging_client.h" |
+#include "chromeos/dbus/fake_nfc_adapter_client.h" |
+#include "chromeos/dbus/fake_nfc_device_client.h" |
+#include "chromeos/dbus/fake_nfc_manager_client.h" |
+#include "chromeos/dbus/fake_nfc_record_client.h" |
+#include "chromeos/dbus/fake_nfc_tag_client.h" |
+#include "chromeos/dbus/fake_permission_broker_client.h" |
+#include "chromeos/dbus/fake_shill_device_client.h" |
+#include "chromeos/dbus/fake_shill_ipconfig_client.h" |
+#include "chromeos/dbus/fake_shill_manager_client.h" |
+#include "chromeos/dbus/fake_shill_profile_client.h" |
+#include "chromeos/dbus/fake_shill_service_client.h" |
+#include "chromeos/dbus/fake_sms_client.h" |
+#include "chromeos/dbus/fake_system_clock_client.h" |
#include "chromeos/dbus/gsm_sms_client.h" |
#include "chromeos/dbus/image_burner_client.h" |
#include "chromeos/dbus/introspectable_client.h" |
@@ -89,8 +122,6 @@ DBusClientBundle::DBusClientType GetDBusClientType( |
} // namespace |
DBusClientBundle::DBusClientBundle() { |
- const DBusClientImplementationType type = REAL_DBUS_CLIENT_IMPLEMENTATION; |
- |
if (!DBusThreadManager::IsUsingStub(BLUETOOTH)) { |
bluetooth_adapter_client_.reset(BluetoothAdapterClient::Create()); |
bluetooth_agent_manager_client_.reset( |
@@ -107,25 +138,50 @@ DBusClientBundle::DBusClientBundle() { |
BluetoothGattManagerClient::Create()); |
bluetooth_gatt_service_client_.reset( |
BluetoothGattServiceClient::Create()); |
+ } else { |
+ bluetooth_adapter_client_.reset(new FakeBluetoothAdapterClient); |
+ bluetooth_agent_manager_client_.reset(new FakeBluetoothAgentManagerClient); |
+ bluetooth_device_client_.reset(new FakeBluetoothDeviceClient); |
+ bluetooth_input_client_.reset(new FakeBluetoothInputClient); |
+ bluetooth_profile_manager_client_.reset( |
+ new FakeBluetoothProfileManagerClient); |
+ bluetooth_gatt_characteristic_client_.reset( |
+ new FakeBluetoothGattCharacteristicClient); |
+ bluetooth_gatt_descriptor_client_.reset( |
+ new FakeBluetoothGattDescriptorClient); |
+ bluetooth_gatt_manager_client_.reset(new FakeBluetoothGattManagerClient); |
+ bluetooth_gatt_service_client_.reset(new FakeBluetoothGattServiceClient); |
} |
if (!DBusThreadManager::IsUsingStub(CRAS)) |
cras_audio_client_.reset(CrasAudioClient::Create()); |
+ else |
+ cras_audio_client_.reset(new CrasAudioClientStubImpl); |
- if (!DBusThreadManager::IsUsingStub(CROS_DISKS)) |
- cros_disks_client_.reset(CrosDisksClient::Create(type)); |
+ cros_disks_client_.reset(CrosDisksClient::Create( |
+ DBusThreadManager::IsUsingStub(CROS_DISKS) ? |
+ STUB_DBUS_CLIENT_IMPLEMENTATION : |
+ REAL_DBUS_CLIENT_IMPLEMENTATION)); |
if (!DBusThreadManager::IsUsingStub(CRYPTOHOME)) |
cryptohome_client_.reset(CryptohomeClient::Create()); |
+ else |
+ cryptohome_client_.reset(new FakeCryptohomeClient); |
if (!DBusThreadManager::IsUsingStub(DEBUG_DAEMON)) |
debug_daemon_client_.reset(DebugDaemonClient::Create()); |
+ else |
+ debug_daemon_client_.reset(new FakeDebugDaemonClient); |
if (!DBusThreadManager::IsUsingStub(EASY_UNLOCK)) |
easy_unlock_client_.reset(EasyUnlockClient::Create()); |
+ else |
+ easy_unlock_client_.reset(new FakeEasyUnlockClient); |
if (!DBusThreadManager::IsUsingStub(LORGNETTE_MANAGER)) |
lorgnette_manager_client_.reset(LorgnetteManagerClient::Create()); |
+ else |
+ lorgnette_manager_client_.reset(new FakeLorgnetteManagerClient); |
if (!DBusThreadManager::IsUsingStub(SHILL)) { |
shill_manager_client_.reset(ShillManagerClient::Create()); |
@@ -133,19 +189,38 @@ DBusClientBundle::DBusClientBundle() { |
shill_ipconfig_client_.reset(ShillIPConfigClient::Create()); |
shill_service_client_.reset(ShillServiceClient::Create()); |
shill_profile_client_.reset(ShillProfileClient::Create()); |
+ } else { |
+ shill_manager_client_.reset(new FakeShillManagerClient); |
+ shill_device_client_.reset(new FakeShillDeviceClient); |
+ shill_ipconfig_client_.reset(new FakeShillIPConfigClient); |
+ shill_service_client_.reset(new FakeShillServiceClient); |
+ shill_profile_client_.reset(new FakeShillProfileClient); |
} |
- if (!DBusThreadManager::IsUsingStub(GSM_SMS)) |
+ if (!DBusThreadManager::IsUsingStub(GSM_SMS)) { |
gsm_sms_client_.reset(GsmSMSClient::Create()); |
+ } else { |
+ FakeGsmSMSClient* gsm_sms_client = new FakeGsmSMSClient(); |
+ gsm_sms_client->set_sms_test_message_switch_present( |
+ CommandLine::ForCurrentProcess()->HasSwitch( |
+ chromeos::switches::kSmsTestMessages)); |
+ gsm_sms_client_.reset(gsm_sms_client); |
+ } |
if (!DBusThreadManager::IsUsingStub(IMAGE_BURNER)) |
image_burner_client_.reset(ImageBurnerClient::Create()); |
+ else |
+ image_burner_client_.reset(new FakeImageBurnerClient); |
if (!DBusThreadManager::IsUsingStub(INTROSPECTABLE)) |
introspectable_client_.reset(IntrospectableClient::Create()); |
+ else |
+ introspectable_client_.reset(new FakeIntrospectableClient); |
if (!DBusThreadManager::IsUsingStub(MODEM_MESSAGING)) |
modem_messaging_client_.reset(ModemMessagingClient::Create()); |
+ else |
+ modem_messaging_client_.reset(ModemMessagingClient::Create()); |
// Create the NFC clients in the correct order based on their dependencies. |
if (!DBusThreadManager::IsUsingStub(NFC)) { |
@@ -157,30 +232,55 @@ DBusClientBundle::DBusClientBundle() { |
nfc_tag_client_.reset(NfcTagClient::Create(nfc_adapter_client_.get())); |
nfc_record_client_.reset(NfcRecordClient::Create(nfc_device_client_.get(), |
nfc_tag_client_.get())); |
+ } else { |
+ nfc_manager_client_.reset(new FakeNfcManagerClient); |
+ nfc_adapter_client_.reset(new FakeNfcAdapterClient); |
+ nfc_device_client_.reset(new FakeNfcDeviceClient); |
+ nfc_tag_client_.reset(new FakeNfcTagClient); |
+ nfc_record_client_.reset(new FakeNfcRecordClient); |
} |
if (!DBusThreadManager::IsUsingStub(PERMISSION_BROKER)) |
permission_broker_client_.reset(PermissionBrokerClient::Create()); |
+ else |
+ permission_broker_client_.reset(new FakePermissionBrokerClient); |
- if (!DBusThreadManager::IsUsingStub(POWER_MANAGER)) |
- power_manager_client_.reset(PowerManagerClient::Create(type)); |
+ power_manager_client_.reset(PowerManagerClient::Create( |
+ DBusThreadManager::IsUsingStub(CROS_DISKS) ? |
+ STUB_DBUS_CLIENT_IMPLEMENTATION : |
+ REAL_DBUS_CLIENT_IMPLEMENTATION)); |
- if (!DBusThreadManager::IsUsingStub(SESSION_MANAGER)) |
- session_manager_client_.reset(SessionManagerClient::Create(type)); |
+ session_manager_client_.reset(SessionManagerClient::Create( |
+ DBusThreadManager::IsUsingStub(CROS_DISKS) ? |
+ STUB_DBUS_CLIENT_IMPLEMENTATION : |
+ REAL_DBUS_CLIENT_IMPLEMENTATION)); |
if (!DBusThreadManager::IsUsingStub(SMS)) |
sms_client_.reset(SMSClient::Create()); |
+ else |
+ sms_client_.reset(new FakeSMSClient); |
if (!DBusThreadManager::IsUsingStub(SYSTEM_CLOCK)) |
system_clock_client_.reset(SystemClockClient::Create()); |
+ else |
+ system_clock_client_.reset(new FakeSystemClockClient); |
- if (!DBusThreadManager::IsUsingStub(UPDATE_ENGINE)) |
- update_engine_client_.reset(UpdateEngineClient::Create(type)); |
+ update_engine_client_.reset(UpdateEngineClient::Create( |
+ DBusThreadManager::IsUsingStub(CROS_DISKS) ? |
+ STUB_DBUS_CLIENT_IMPLEMENTATION : |
+ REAL_DBUS_CLIENT_IMPLEMENTATION)); |
} |
DBusClientBundle::~DBusClientBundle() { |
} |
+void DBusClientBundle::SetupDefaultEnvironment() { |
+ ShillManagerClient::TestInterface* manager = |
+ shill_manager_client_->GetTestInterface(); |
+ if (manager) |
+ manager->SetupDefaultEnvironment(); |
+} |
+ |
// static |
DBusClientBundle::DBusClientTypeMask DBusClientBundle::ParseUnstubList( |
const std::string& unstub_list) { |