summaryrefslogtreecommitdiffstats
path: root/chromeos/dbus/shill_device_client_unittest.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chromeos/dbus/shill_device_client_unittest.cc')
-rw-r--r--chromeos/dbus/shill_device_client_unittest.cc357
1 files changed, 357 insertions, 0 deletions
diff --git a/chromeos/dbus/shill_device_client_unittest.cc b/chromeos/dbus/shill_device_client_unittest.cc
new file mode 100644
index 0000000..9ecf5fc
--- /dev/null
+++ b/chromeos/dbus/shill_device_client_unittest.cc
@@ -0,0 +1,357 @@
+// 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.
+
+#include "base/bind.h"
+#include "base/values.h"
+#include "chromeos/dbus/shill_client_unittest_base.h"
+#include "chromeos/dbus/shill_device_client.h"
+#include "dbus/message.h"
+#include "dbus/object_path.h"
+#include "dbus/values_util.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "third_party/cros_system_api/dbus/service_constants.h"
+
+namespace chromeos {
+
+namespace {
+
+const char kExampleDevicePath[] = "/foo/bar";
+
+// Expects the reader to have a string and a bool.
+void ExpectStringAndBoolArguments(const std::string& expected_string,
+ bool expected_bool,
+ dbus::MessageReader* reader) {
+ std::string arg1;
+ ASSERT_TRUE(reader->PopString(&arg1));
+ EXPECT_EQ(expected_string, arg1);
+ bool arg2 = false;
+ ASSERT_TRUE(reader->PopBool(&arg2));
+ EXPECT_EQ(expected_bool, arg2);
+ EXPECT_FALSE(reader->HasMoreData());
+}
+
+// Expects the reader to have two strings.
+void ExpectTwoStringArguments(const std::string& expected_string1,
+ const std::string& expected_string2,
+ dbus::MessageReader* reader) {
+ std::string arg1;
+ ASSERT_TRUE(reader->PopString(&arg1));
+ EXPECT_EQ(expected_string1, arg1);
+ std::string arg2;
+ ASSERT_TRUE(reader->PopString(&arg2));
+ EXPECT_EQ(expected_string2, arg2);
+ EXPECT_FALSE(reader->HasMoreData());
+}
+
+} // namespace
+
+class ShillDeviceClientTest : public ShillClientUnittestBase {
+ public:
+ ShillDeviceClientTest()
+ : ShillClientUnittestBase(flimflam::kFlimflamDeviceInterface,
+ dbus::ObjectPath(kExampleDevicePath)) {
+ }
+
+ virtual void SetUp() {
+ ShillClientUnittestBase::SetUp();
+ // Create a client with the mock bus.
+ client_.reset(ShillDeviceClient::Create(REAL_DBUS_CLIENT_IMPLEMENTATION,
+ mock_bus_));
+ // Run the message loop to run the signal connection result callback.
+ message_loop_.RunAllPending();
+ }
+
+ virtual void TearDown() {
+ ShillClientUnittestBase::TearDown();
+ }
+
+ protected:
+ scoped_ptr<ShillDeviceClient> client_;
+};
+
+TEST_F(ShillDeviceClientTest, PropertyChanged) {
+ const bool kValue = true;
+ // Create a signal.
+ dbus::Signal signal(flimflam::kFlimflamDeviceInterface,
+ flimflam::kMonitorPropertyChanged);
+ dbus::MessageWriter writer(&signal);
+ writer.AppendString(flimflam::kCellularAllowRoamingProperty);
+ writer.AppendVariantOfBool(kValue);
+
+ // Set expectations.
+ const base::FundamentalValue value(kValue);
+ client_->SetPropertyChangedHandler(
+ dbus::ObjectPath(kExampleDevicePath),
+ base::Bind(&ExpectPropertyChanged,
+ flimflam::kCellularAllowRoamingProperty,
+ &value));
+ // Run the signal callback.
+ SendPropertyChangedSignal(&signal);
+
+ // Reset the handler.
+ client_->ResetPropertyChangedHandler(dbus::ObjectPath(kExampleDevicePath));
+}
+
+TEST_F(ShillDeviceClientTest, GetProperties) {
+ const bool kValue = true;
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+ dbus::MessageWriter writer(response.get());
+ dbus::MessageWriter array_writer(NULL);
+ writer.OpenArray("{sv}", &array_writer);
+ dbus::MessageWriter entry_writer(NULL);
+ array_writer.OpenDictEntry(&entry_writer);
+ entry_writer.AppendString(flimflam::kCellularAllowRoamingProperty);
+ entry_writer.AppendVariantOfBool(kValue);
+ array_writer.CloseContainer(&entry_writer);
+ writer.CloseContainer(&array_writer);
+
+ // Set expectations.
+ base::DictionaryValue value;
+ value.SetWithoutPathExpansion(flimflam::kCellularAllowRoamingProperty,
+ base::Value::CreateBooleanValue(kValue));
+ PrepareForMethodCall(flimflam::kGetPropertiesFunction,
+ base::Bind(&ExpectNoArgument),
+ response.get());
+ // Call method.
+ client_->GetProperties(dbus::ObjectPath(kExampleDevicePath),
+ base::Bind(&ExpectDictionaryValueResult, &value));
+ // Run the message loop.
+ message_loop_.RunAllPending();
+}
+
+TEST_F(ShillDeviceClientTest, CallGetPropertiesAndBlock) {
+ const bool kValue = true;
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+ dbus::MessageWriter writer(response.get());
+ dbus::MessageWriter array_writer(NULL);
+ writer.OpenArray("{sv}", &array_writer);
+ dbus::MessageWriter entry_writer(NULL);
+ array_writer.OpenDictEntry(&entry_writer);
+ entry_writer.AppendString(flimflam::kCellularAllowRoamingProperty);
+ entry_writer.AppendVariantOfBool(kValue);
+ array_writer.CloseContainer(&entry_writer);
+ writer.CloseContainer(&array_writer);
+
+ // Set expectations.
+ base::DictionaryValue value;
+ value.SetWithoutPathExpansion(flimflam::kCellularAllowRoamingProperty,
+ base::Value::CreateBooleanValue(kValue));
+ PrepareForMethodCall(flimflam::kGetPropertiesFunction,
+ base::Bind(&ExpectNoArgument),
+ response.get());
+ // Call method.
+ scoped_ptr<base::DictionaryValue> result(
+ client_->CallGetPropertiesAndBlock(dbus::ObjectPath(kExampleDevicePath)));
+ ASSERT_TRUE(result.get());
+ EXPECT_TRUE(result->Equals(&value));
+}
+
+TEST_F(ShillDeviceClientTest, ProposeScan) {
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+
+ // Set expectations.
+ PrepareForMethodCall(flimflam::kProposeScanFunction,
+ base::Bind(&ExpectNoArgument),
+ response.get());
+ // Call method.
+ client_->ProposeScan(dbus::ObjectPath(kExampleDevicePath),
+ base::Bind(&ExpectNoResultValue));
+ // Run the message loop.
+ message_loop_.RunAllPending();
+}
+
+TEST_F(ShillDeviceClientTest, SetProperty) {
+ const bool kValue = true;
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+
+ // Set expectations.
+ const base::FundamentalValue value(kValue);
+ PrepareForMethodCall(flimflam::kSetPropertyFunction,
+ base::Bind(&ExpectStringAndValueArguments,
+ flimflam::kCellularAllowRoamingProperty,
+ &value),
+ response.get());
+ // Call method.
+ client_->SetProperty(dbus::ObjectPath(kExampleDevicePath),
+ flimflam::kCellularAllowRoamingProperty,
+ value,
+ base::Bind(&ExpectNoResultValue));
+ // Run the message loop.
+ message_loop_.RunAllPending();
+}
+
+TEST_F(ShillDeviceClientTest, ClearProperty) {
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+
+ // Set expectations.
+ PrepareForMethodCall(flimflam::kClearPropertyFunction,
+ base::Bind(&ExpectStringArgument,
+ flimflam::kCellularAllowRoamingProperty),
+ response.get());
+ // Call method.
+ client_->ClearProperty(dbus::ObjectPath(kExampleDevicePath),
+ flimflam::kCellularAllowRoamingProperty,
+ base::Bind(&ExpectNoResultValue));
+ // Run the message loop.
+ message_loop_.RunAllPending();
+}
+
+TEST_F(ShillDeviceClientTest, AddIPConfig) {
+ const dbus::ObjectPath expected_result("/result/path");
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+ dbus::MessageWriter writer(response.get());
+ writer.AppendObjectPath(expected_result);
+
+ // Set expectations.
+ PrepareForMethodCall(flimflam::kAddIPConfigFunction,
+ base::Bind(&ExpectStringArgument, flimflam::kTypeDHCP),
+ response.get());
+ // Call method.
+ client_->AddIPConfig(dbus::ObjectPath(kExampleDevicePath),
+ flimflam::kTypeDHCP,
+ base::Bind(&ExpectObjectPathResult, expected_result));
+ // Run the message loop.
+ message_loop_.RunAllPending();
+}
+
+TEST_F(ShillDeviceClientTest, CallAddIPConfigAndBlock) {
+ const dbus::ObjectPath expected_result("/result/path");
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+ dbus::MessageWriter writer(response.get());
+ writer.AppendObjectPath(expected_result);
+
+ // Set expectations.
+ PrepareForMethodCall(flimflam::kAddIPConfigFunction,
+ base::Bind(&ExpectStringArgument, flimflam::kTypeDHCP),
+ response.get());
+ // Call method.
+ const dbus::ObjectPath result = client_->CallAddIPConfigAndBlock(
+ dbus::ObjectPath(kExampleDevicePath), flimflam::kTypeDHCP);
+ EXPECT_EQ(expected_result, result);
+}
+
+TEST_F(ShillDeviceClientTest, RequirePin) {
+ const char kPin[] = "123456";
+ const bool kRequired = true;
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+
+ // Set expectations.
+ MockClosure mock_closure;
+ MockErrorCallback mock_error_callback;
+ PrepareForMethodCall(flimflam::kRequirePinFunction,
+ base::Bind(&ExpectStringAndBoolArguments,
+ kPin,
+ kRequired),
+ response.get());
+ EXPECT_CALL(mock_closure, Run()).Times(1);
+ // Call method.
+ client_->RequirePin(dbus::ObjectPath(kExampleDevicePath),
+ kPin,
+ kRequired,
+ mock_closure.GetCallback(),
+ mock_error_callback.GetCallback());
+ // Run the message loop.
+ message_loop_.RunAllPending();
+}
+
+TEST_F(ShillDeviceClientTest, EnterPin) {
+ const char kPin[] = "123456";
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+
+ // Set expectations.
+ MockClosure mock_closure;
+ MockErrorCallback mock_error_callback;
+ PrepareForMethodCall(flimflam::kEnterPinFunction,
+ base::Bind(&ExpectStringArgument,
+ kPin),
+ response.get());
+ EXPECT_CALL(mock_closure, Run()).Times(1);
+ // Call method.
+ client_->EnterPin(dbus::ObjectPath(kExampleDevicePath),
+ kPin,
+ mock_closure.GetCallback(),
+ mock_error_callback.GetCallback());
+ // Run the message loop.
+ message_loop_.RunAllPending();
+}
+
+TEST_F(ShillDeviceClientTest, UnblockPin) {
+ const char kPuk[] = "987654";
+ const char kPin[] = "123456";
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+
+ // Set expectations.
+ MockClosure mock_closure;
+ MockErrorCallback mock_error_callback;
+ PrepareForMethodCall(flimflam::kUnblockPinFunction,
+ base::Bind(&ExpectTwoStringArguments, kPuk, kPin),
+ response.get());
+ EXPECT_CALL(mock_closure, Run()).Times(1);
+ // Call method.
+ client_->UnblockPin(dbus::ObjectPath(kExampleDevicePath),
+ kPuk,
+ kPin,
+ mock_closure.GetCallback(),
+ mock_error_callback.GetCallback());
+ // Run the message loop.
+ message_loop_.RunAllPending();
+}
+
+TEST_F(ShillDeviceClientTest, ChangePin) {
+ const char kOldPin[] = "123456";
+ const char kNewPin[] = "234567";
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+
+ // Set expectations.
+ MockClosure mock_closure;
+ MockErrorCallback mock_error_callback;
+ PrepareForMethodCall(flimflam::kChangePinFunction,
+ base::Bind(&ExpectTwoStringArguments,
+ kOldPin,
+ kNewPin),
+ response.get());
+ EXPECT_CALL(mock_closure, Run()).Times(1);
+ // Call method.
+ client_->ChangePin(dbus::ObjectPath(kExampleDevicePath),
+ kOldPin,
+ kNewPin,
+ mock_closure.GetCallback(),
+ mock_error_callback.GetCallback());
+ // Run the message loop.
+ message_loop_.RunAllPending();
+}
+
+TEST_F(ShillDeviceClientTest, Register) {
+ const char kNetworkId[] = "networkid";
+ // Create response.
+ scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty());
+
+ // Set expectations.
+ MockClosure mock_closure;
+ MockErrorCallback mock_error_callback;
+ PrepareForMethodCall(flimflam::kRegisterFunction,
+ base::Bind(&ExpectStringArgument, kNetworkId),
+ response.get());
+ EXPECT_CALL(mock_closure, Run()).Times(1);
+ // Call method.
+ client_->Register(dbus::ObjectPath(kExampleDevicePath),
+ kNetworkId,
+ mock_closure.GetCallback(),
+ mock_error_callback.GetCallback());
+ // Run the message loop.
+ message_loop_.RunAllPending();
+}
+
+} // namespace chromeos