summaryrefslogtreecommitdiffstats
path: root/device/hid
diff options
context:
space:
mode:
authorAlbert J. Wong <ajwong@chromium.org>2014-08-27 17:25:24 -0700
committerAlbert J. Wong <ajwong@chromium.org>2014-08-28 00:26:53 +0000
commit80b00e579d615035a2693ed5a16fe4576671841c (patch)
tree0dd3b8a63b7d8281491a16a4030df054783785b1 /device/hid
parent500986e5074fea2f069a0e16fd9f0cf03e6302dd (diff)
downloadchromium_src-80b00e579d615035a2693ed5a16fe4576671841c.zip
chromium_src-80b00e579d615035a2693ed5a16fe4576671841c.tar.gz
chromium_src-80b00e579d615035a2693ed5a16fe4576671841c.tar.bz2
Revert of Adding Select Action Bar Unit test case for input (patchset #3 of https://codereview.chromium.org/506423003/)
Reason for revert: Failed compile on Android builders. Original issue's description: > [Android] Add unit tests for SelectActionBar appearance > > The SelectActionBar currently lacks test coverage. Add several test > cases covering the appearance of the bar when interacting with an input > field. > > Committed: https://chromium.googlesource.com/chromium/src/+/0bc56569817a24acea46748c599d77b59157d84d BR=jdduke@chromium.org,aurimas@chromium.org,ajith.v@samsung.com NOTREECHECKS=true NOTRY=true Review URL: https://codereview.chromium.org/514493004 Cr-Commit-Position: refs/heads/master@{#292276}
Diffstat (limited to 'device/hid')
-rw-r--r--device/hid/hid_connection_unittest.cc3
-rw-r--r--device/hid/hid_service.cc51
-rw-r--r--device/hid/hid_service.h2
-rw-r--r--device/hid/hid_service_unittest.cc4
4 files changed, 10 insertions, 50 deletions
diff --git a/device/hid/hid_connection_unittest.cc b/device/hid/hid_connection_unittest.cc
index ecc51b7c..e5f215f 100644
--- a/device/hid/hid_connection_unittest.cc
+++ b/device/hid/hid_connection_unittest.cc
@@ -73,8 +73,7 @@ class HidConnectionTest : public testing::Test {
if (!UsbTestGadget::IsTestEnabled()) return;
message_loop_.reset(new base::MessageLoopForIO());
- service_.reset(HidService::GetInstance(
- message_loop_->message_loop_proxy()));
+ service_.reset(HidService::Create(message_loop_->message_loop_proxy()));
ASSERT_TRUE(service_);
test_gadget_ = UsbTestGadget::Claim();
diff --git a/device/hid/hid_service.cc b/device/hid/hid_service.cc
index 8b7cc0a..0e2f0d4 100644
--- a/device/hid/hid_service.cc
+++ b/device/hid/hid_service.cc
@@ -7,7 +7,6 @@
#include "base/lazy_instance.h"
#include "base/logging.h"
#include "base/memory/scoped_vector.h"
-#include "base/message_loop/message_loop.h"
#include "base/stl_util.h"
#include "base/threading/thread_restrictions.h"
@@ -21,55 +20,17 @@
namespace device {
-namespace {
-
-// TODO(rockot/reillyg): This is pretty awful all around. There is a combination
-// of constraints here: HidService doesn't know about //content, it must be able
-// to talk to the PermissionBrokerClient on ChromeOS (UI thread), and it's
-// expected to live and die on the FILE thread (for now). Solution? Make it a
-// singleton whose instance getter takes a UI message loop proxy, and let the
-// lifetime of the HidService be managed by a MessageLoop::DestructionObserver.
-//
-// The right long-term solution is probably a mojo service. A tolerable
-// medium-term solution is up for debate.
-class HidServiceDestroyer : public base::MessageLoop::DestructionObserver {
- public:
- explicit HidServiceDestroyer(HidService* hid_service)
- : hid_service_(hid_service) {}
- virtual ~HidServiceDestroyer() {}
-
- private:
- // base::MessageLoop::DestructionObserver implementation.
- virtual void WillDestroyCurrentMessageLoop() OVERRIDE {
- base::MessageLoop::current()->RemoveDestructionObserver(this);
- delete hid_service_;
- delete this;
- hid_service_ = NULL;
- }
-
- HidService* hid_service_;
-};
-
-HidService* g_service = NULL;
-
-} // namespace
-
-HidService* HidService::GetInstance(
+HidService* HidService::Create(
scoped_refptr<base::MessageLoopProxy> ui_message_loop) {
- if (g_service == NULL) {
#if defined(OS_LINUX) && defined(USE_UDEV)
- g_service = new HidServiceLinux(ui_message_loop);
+ return new HidServiceLinux(ui_message_loop);
#elif defined(OS_MACOSX)
- g_service = new HidServiceMac();
+ return new HidServiceMac();
#elif defined(OS_WIN)
- g_service = new HidServiceWin();
+ return new HidServiceWin();
+#else
+ return NULL;
#endif
- if (g_service != NULL) {
- HidServiceDestroyer* destroyer = new HidServiceDestroyer(g_service);
- base::MessageLoop::current()->AddDestructionObserver(destroyer);
- }
- }
- return g_service;
}
HidService::~HidService() {
diff --git a/device/hid/hid_service.h b/device/hid/hid_service.h
index 6a39cdd..c8e4e41 100644
--- a/device/hid/hid_service.h
+++ b/device/hid/hid_service.h
@@ -20,7 +20,7 @@ class HidConnection;
class HidService {
public:
- static HidService* GetInstance(
+ static HidService* Create(
scoped_refptr<base::MessageLoopProxy> ui_message_loop);
virtual ~HidService();
diff --git a/device/hid/hid_service_unittest.cc b/device/hid/hid_service_unittest.cc
index 2291300..a807579 100644
--- a/device/hid/hid_service_unittest.cc
+++ b/device/hid/hid_service_unittest.cc
@@ -13,8 +13,8 @@ namespace device {
TEST(HidServiceTest, Create) {
base::MessageLoopForIO message_loop;
- HidService* service = HidService::GetInstance(
- message_loop.message_loop_proxy());
+ scoped_ptr<HidService> service(
+ HidService::Create(message_loop.message_loop_proxy()));
ASSERT_TRUE(service);
std::vector<HidDeviceInfo> devices;