forked from chromium/chromium
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Reuse existing object proxies and exported objects, if these exist.
The Bus object shouldn't return new objects if the bus object already owns the requested object proxies, or the exported objects. BUG=90036 TEST=dbus_unittests Review URL: http://codereview.chromium.org/7702001 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@97898 0039d316-1c4b-4281-b951-d872f2087c98
- Loading branch information
satorux@chromium.org
committed
Aug 23, 2011
1 parent
99dcd2e
commit 2ef498f
Showing
4 changed files
with
118 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
// Copyright (c) 2011 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 "dbus/bus.h" | ||
|
||
#include "base/memory/ref_counted.h" | ||
#include "dbus/exported_object.h" | ||
#include "dbus/object_proxy.h" | ||
|
||
#include "testing/gtest/include/gtest/gtest.h" | ||
|
||
TEST(BusTest, GetObjectProxy) { | ||
dbus::Bus::Options options; | ||
scoped_refptr<dbus::Bus> bus = new dbus::Bus(options); | ||
|
||
dbus::ObjectProxy* object_proxy1 = | ||
bus->GetObjectProxy("org.chromium.TestService", | ||
"/org/chromium/TestObject"); | ||
ASSERT_TRUE(object_proxy1); | ||
|
||
// This should return the same object. | ||
dbus::ObjectProxy* object_proxy2 = | ||
bus->GetObjectProxy("org.chromium.TestService", | ||
"/org/chromium/TestObject"); | ||
ASSERT_TRUE(object_proxy2); | ||
EXPECT_EQ(object_proxy1, object_proxy2); | ||
|
||
// This should not. | ||
dbus::ObjectProxy* object_proxy3 = | ||
bus->GetObjectProxy("org.chromium.TestService", | ||
"/org/chromium/DifferentTestObject"); | ||
ASSERT_TRUE(object_proxy3); | ||
EXPECT_NE(object_proxy1, object_proxy3); | ||
} | ||
|
||
TEST(BusTest, GetExportedObject) { | ||
dbus::Bus::Options options; | ||
scoped_refptr<dbus::Bus> bus = new dbus::Bus(options); | ||
|
||
dbus::ExportedObject* object_proxy1 = | ||
bus->GetExportedObject("org.chromium.TestService", | ||
"/org/chromium/TestObject"); | ||
ASSERT_TRUE(object_proxy1); | ||
|
||
// This should return the same object. | ||
dbus::ExportedObject* object_proxy2 = | ||
bus->GetExportedObject("org.chromium.TestService", | ||
"/org/chromium/TestObject"); | ||
ASSERT_TRUE(object_proxy2); | ||
EXPECT_EQ(object_proxy1, object_proxy2); | ||
|
||
// This should not. | ||
dbus::ExportedObject* object_proxy3 = | ||
bus->GetExportedObject("org.chromium.TestService", | ||
"/org/chromium/DifferentTestObject"); | ||
ASSERT_TRUE(object_proxy3); | ||
EXPECT_NE(object_proxy1, object_proxy3); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters