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

Unified Diff: device/bluetooth/bluetooth_adapter_profile_chromeos_unittest.cc

Issue 982593002: Fix BluetoothAdapterProfileChromeOS lifecycle management (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: address nits, remove test debug logging Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: device/bluetooth/bluetooth_adapter_profile_chromeos_unittest.cc
diff --git a/device/bluetooth/bluetooth_adapter_profile_chromeos_unittest.cc b/device/bluetooth/bluetooth_adapter_profile_chromeos_unittest.cc
index 6b29dd241c0b53fe1354d14ff21489bc5fd279ef..e690c9d90b2e148b0cdc7e2680203a89276f6aa3 100644
--- a/device/bluetooth/bluetooth_adapter_profile_chromeos_unittest.cc
+++ b/device/bluetooth/bluetooth_adapter_profile_chromeos_unittest.cc
@@ -20,25 +20,17 @@
using device::BluetoothAdapter;
using device::BluetoothUUID;
-namespace {
-
-void DoNothingDBusErrorCallback(const std::string& error_name,
- const std::string& error_message) {
-}
-
-} // namespace
-
namespace chromeos {
class BluetoothAdapterProfileChromeOSTest : public testing::Test {
public:
BluetoothAdapterProfileChromeOSTest()
- : fake_delegate_paired_(FakeBluetoothDeviceClient::kPairedDevicePath),
+ : success_callback_count_(0),
+ error_callback_count_(0),
+ fake_delegate_paired_(FakeBluetoothDeviceClient::kPairedDevicePath),
fake_delegate_autopair_(FakeBluetoothDeviceClient::kLegacyAutopairPath),
fake_delegate_listen_(""),
- profile_(nullptr),
- success_callback_count_(0),
- error_callback_count_(0) {}
+ profile_user_ptr_(nullptr) {}
void SetUp() override {
scoped_ptr<DBusThreadManagerSetter> dbus_setter =
@@ -70,6 +62,7 @@ class BluetoothAdapterProfileChromeOSTest : public testing::Test {
}
void TearDown() override {
+ profile_.reset();
adapter_ = nullptr;
DBusThreadManager::Shutdown();
}
@@ -95,24 +88,20 @@ class BluetoothAdapterProfileChromeOSTest : public testing::Test {
scoped_ptr<dbus::FileDescriptor> fd,
const BluetoothProfileServiceProvider::Delegate::Options& options,
const ConfirmationCallback& callback) override {
- VLOG(1) << "connection for " << device_path.value() << " on "
- << device_path_.value();
++connections_;
fd->CheckValidity();
close(fd->TakeValue());
callback.Run(SUCCESS);
if (device_path_.value() != "")
- ASSERT_TRUE(device_path == device_path_);
+ ASSERT_EQ(device_path_, device_path);
}
void RequestDisconnection(const dbus::ObjectPath& device_path,
const ConfirmationCallback& callback) override {
- VLOG(1) << "disconnect " << device_path.value();
++disconnections_;
}
void Cancel() override {
- VLOG(1) << "cancel";
// noop
}
@@ -121,17 +110,30 @@ class BluetoothAdapterProfileChromeOSTest : public testing::Test {
dbus::ObjectPath device_path_;
};
- FakeDelegate fake_delegate_paired_;
- FakeDelegate fake_delegate_autopair_;
- FakeDelegate fake_delegate_listen_;
+ void ProfileSuccessCallback(
+ scoped_ptr<BluetoothAdapterProfileChromeOS> profile) {
+ profile_.swap(profile);
+ ++success_callback_count_;
+ }
- BluetoothAdapterProfileChromeOS* profile_;
+ void ProfileUserSuccessCallback(BluetoothAdapterProfileChromeOS* profile) {
+ profile_user_ptr_ = profile;
+ ++success_callback_count_;
+ }
+
+ void MatchedProfileCallback(BluetoothAdapterProfileChromeOS* profile) {
+ ASSERT_EQ(profile_user_ptr_, profile);
+ ++success_callback_count_;
+ }
void DBusConnectSuccessCallback() { ++success_callback_count_; }
void DBusErrorCallback(const std::string& error_name,
const std::string& error_message) {
- VLOG(1) << "DBus Connect Error: " << error_name << " - " << error_message;
+ ++error_callback_count_;
+ }
+
+ void BasicErrorCallback(const std::string& error_message) {
++error_callback_count_;
}
@@ -142,6 +144,16 @@ class BluetoothAdapterProfileChromeOSTest : public testing::Test {
unsigned int success_callback_count_;
unsigned int error_callback_count_;
+
+ FakeDelegate fake_delegate_paired_;
+ FakeDelegate fake_delegate_autopair_;
+ FakeDelegate fake_delegate_listen_;
+
+ scoped_ptr<BluetoothAdapterProfileChromeOS> profile_;
+
+ // unowned pointer as expected to be used by clients of
+ // BluetoothAdapterChromeOS::UseProfile like BluetoothSocketChromeOS
+ BluetoothAdapterProfileChromeOS* profile_user_ptr_;
};
TEST_F(BluetoothAdapterProfileChromeOSTest, DelegateCount) {
@@ -150,13 +162,18 @@ TEST_F(BluetoothAdapterProfileChromeOSTest, DelegateCount) {
options.require_authentication.reset(new bool(false));
- profile_ = BluetoothAdapterProfileChromeOS::Register(
- static_cast<BluetoothAdapterChromeOS*>(adapter_.get()), uuid, options,
- base::Bind(&base::DoNothing), base::Bind(&DoNothingDBusErrorCallback));
+ BluetoothAdapterProfileChromeOS::Register(
+ uuid, options,
+ base::Bind(&BluetoothAdapterProfileChromeOSTest::ProfileSuccessCallback,
+ base::Unretained(this)),
+ base::Bind(&BluetoothAdapterProfileChromeOSTest::DBusErrorCallback,
+ base::Unretained(this)));
message_loop_.RunUntilIdle();
EXPECT_TRUE(profile_);
+ EXPECT_EQ(1U, success_callback_count_);
+ EXPECT_EQ(0U, error_callback_count_);
EXPECT_EQ(0U, profile_->DelegateCount());
@@ -174,8 +191,6 @@ TEST_F(BluetoothAdapterProfileChromeOSTest, DelegateCount) {
base::Bind(&base::DoNothing));
EXPECT_EQ(0U, profile_->DelegateCount());
-
- delete profile_;
};
TEST_F(BluetoothAdapterProfileChromeOSTest, BlackHole) {
@@ -184,11 +199,10 @@ TEST_F(BluetoothAdapterProfileChromeOSTest, BlackHole) {
options.require_authentication.reset(new bool(false));
- profile_ = BluetoothAdapterProfileChromeOS::Register(
- static_cast<BluetoothAdapterChromeOS*>(adapter_.get()), uuid, options,
- base::Bind(
- &BluetoothAdapterProfileChromeOSTest::DBusConnectSuccessCallback,
- base::Unretained(this)),
+ BluetoothAdapterProfileChromeOS::Register(
+ uuid, options,
+ base::Bind(&BluetoothAdapterProfileChromeOSTest::ProfileSuccessCallback,
+ base::Unretained(this)),
base::Bind(&BluetoothAdapterProfileChromeOSTest::DBusErrorCallback,
base::Unretained(this)));
@@ -213,8 +227,6 @@ TEST_F(BluetoothAdapterProfileChromeOSTest, BlackHole) {
EXPECT_EQ(1U, error_callback_count_);
EXPECT_EQ(0U, fake_delegate_paired_.connections_);
-
- delete profile_;
};
TEST_F(BluetoothAdapterProfileChromeOSTest, Routing) {
@@ -223,17 +235,18 @@ TEST_F(BluetoothAdapterProfileChromeOSTest, Routing) {
options.require_authentication.reset(new bool(false));
- profile_ = BluetoothAdapterProfileChromeOS::Register(
- static_cast<BluetoothAdapterChromeOS*>(adapter_.get()), uuid, options,
- base::Bind(
- &BluetoothAdapterProfileChromeOSTest::DBusConnectSuccessCallback,
- base::Unretained(this)),
+ BluetoothAdapterProfileChromeOS::Register(
+ uuid, options,
+ base::Bind(&BluetoothAdapterProfileChromeOSTest::ProfileSuccessCallback,
+ base::Unretained(this)),
base::Bind(&BluetoothAdapterProfileChromeOSTest::DBusErrorCallback,
base::Unretained(this)));
message_loop_.RunUntilIdle();
ASSERT_TRUE(profile_);
+ ASSERT_EQ(1U, success_callback_count_);
+ ASSERT_EQ(0U, error_callback_count_);
profile_->SetDelegate(fake_delegate_paired_.device_path_,
&fake_delegate_paired_);
@@ -290,8 +303,81 @@ TEST_F(BluetoothAdapterProfileChromeOSTest, Routing) {
EXPECT_EQ(0U, error_callback_count_);
EXPECT_EQ(1U, fake_delegate_listen_.connections_);
+};
+
+TEST_F(BluetoothAdapterProfileChromeOSTest, SimultaneousRegister) {
+ BluetoothUUID uuid(FakeBluetoothProfileManagerClient::kRfcommUuid);
+ BluetoothProfileManagerClient::Options options;
+ BluetoothAdapterChromeOS* adapter =
+ static_cast<BluetoothAdapterChromeOS*>(adapter_.get());
+
+ options.require_authentication.reset(new bool(false));
+
+ success_callback_count_ = 0;
+ error_callback_count_ = 0;
+
+ adapter->UseProfile(
+ uuid, fake_delegate_paired_.device_path_, options, &fake_delegate_paired_,
+ base::Bind(
+ &BluetoothAdapterProfileChromeOSTest::ProfileUserSuccessCallback,
+ base::Unretained(this)),
+ base::Bind(&BluetoothAdapterProfileChromeOSTest::BasicErrorCallback,
+ base::Unretained(this)));
+
+ adapter->UseProfile(
+ uuid, fake_delegate_autopair_.device_path_, options,
+ &fake_delegate_autopair_,
+ base::Bind(&BluetoothAdapterProfileChromeOSTest::MatchedProfileCallback,
+ base::Unretained(this)),
+ base::Bind(&BluetoothAdapterProfileChromeOSTest::BasicErrorCallback,
+ base::Unretained(this)));
+
+ message_loop_.RunUntilIdle();
+
+ EXPECT_TRUE(profile_user_ptr_);
+ EXPECT_EQ(2U, success_callback_count_);
+ EXPECT_EQ(0U, error_callback_count_);
+
+ adapter->ReleaseProfile(fake_delegate_paired_.device_path_,
+ profile_user_ptr_);
+ adapter->ReleaseProfile(fake_delegate_autopair_.device_path_,
+ profile_user_ptr_);
+
+ message_loop_.RunUntilIdle();
+};
+
+TEST_F(BluetoothAdapterProfileChromeOSTest, SimultaneousRegisterFail) {
+ BluetoothUUID uuid(FakeBluetoothProfileManagerClient::kUnregisterableUuid);
+ BluetoothProfileManagerClient::Options options;
+ BluetoothAdapterChromeOS* adapter =
+ static_cast<BluetoothAdapterChromeOS*>(adapter_.get());
+
+ options.require_authentication.reset(new bool(false));
+
+ success_callback_count_ = 0;
+ error_callback_count_ = 0;
+
+ adapter->UseProfile(
+ uuid, fake_delegate_paired_.device_path_, options, &fake_delegate_paired_,
+ base::Bind(
+ &BluetoothAdapterProfileChromeOSTest::ProfileUserSuccessCallback,
+ base::Unretained(this)),
+ base::Bind(&BluetoothAdapterProfileChromeOSTest::BasicErrorCallback,
+ base::Unretained(this)));
+
+ adapter->UseProfile(
+ uuid, fake_delegate_autopair_.device_path_, options,
+ &fake_delegate_autopair_,
+ base::Bind(&BluetoothAdapterProfileChromeOSTest::MatchedProfileCallback,
+ base::Unretained(this)),
+ base::Bind(&BluetoothAdapterProfileChromeOSTest::BasicErrorCallback,
+ base::Unretained(this)));
+
+ message_loop_.RunUntilIdle();
- delete profile_;
+ EXPECT_FALSE(profile_user_ptr_);
+ EXPECT_EQ(0U, success_callback_count_);
+ EXPECT_EQ(2U, error_callback_count_);
};
} // namespace chromeos
« no previous file with comments | « device/bluetooth/bluetooth_adapter_profile_chromeos.cc ('k') | device/bluetooth/bluetooth_chromeos_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698