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

Side by Side Diff: services/device/device_service_test_base.cc

Issue 2774783003: [DeviceService] Add service tests for VibrationManager. (Closed)
Patch Set: Created 3 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "services/device/device_service_test_base.h"
6
7 #include <memory>
8
9 #include "base/memory/ptr_util.h"
10 #include "mojo/public/cpp/bindings/binding_set.h"
11 #include "services/device/device_service.h"
12 #include "services/device/public/interfaces/constants.mojom.h"
13 #include "services/service_manager/public/cpp/interface_factory.h"
14 #include "services/service_manager/public/cpp/interface_registry.h"
15 #include "services/service_manager/public/cpp/service_context.h"
16 #include "services/service_manager/public/interfaces/service_factory.mojom.h"
17
18 namespace device {
19
20 namespace {
21
22 const char kTestServiceName[] = "device_unittests";
23
24 // The test service responsible to package Device Service.
25 class ServiceTestClient : public service_manager::test::ServiceTestClient,
26 public service_manager::mojom::ServiceFactory,
27 public service_manager::InterfaceFactory<
28 service_manager::mojom::ServiceFactory> {
29 public:
30 explicit ServiceTestClient(service_manager::test::ServiceTest* test)
31 : service_manager::test::ServiceTestClient(test) {}
32 ~ServiceTestClient() override {}
33
34 protected:
35 bool OnConnect(const service_manager::ServiceInfo& remote_info,
36 service_manager::InterfaceRegistry* registry) override {
37 registry->AddInterface<service_manager::mojom::ServiceFactory>(this);
38 return true;
39 }
40
41 void CreateService(service_manager::mojom::ServiceRequest request,
42 const std::string& name) override {
43 if (name == device::mojom::kServiceName) {
44 // TODO(leonhsl): Prepare file/io task runner for Device Service.
blundell 2017/03/28 12:40:47 Can we do this in this CL?
leonhsl(Using Gerrit) 2017/03/29 07:37:16 Done. Before I was considering to do this when we
45 #if defined(OS_ANDROID)
46 device_service_context_.reset(new service_manager::ServiceContext(
47 CreateDeviceService(nullptr, nullptr, wake_lock_context_callback_),
48 std::move(request)));
49 #else
50 device_service_context_.reset(new service_manager::ServiceContext(
51 CreateDeviceService(nullptr, nullptr), std::move(request)));
52 #endif
53 }
54 }
55
56 void Create(const service_manager::Identity& remote_identity,
57 service_manager::mojom::ServiceFactoryRequest request) override {
58 service_factory_bindings_.AddBinding(this, std::move(request));
59 }
60
61 private:
62 mojo::BindingSet<service_manager::mojom::ServiceFactory>
63 service_factory_bindings_;
64 std::unique_ptr<service_manager::ServiceContext> device_service_context_;
65
66 WakeLockContextCallback wake_lock_context_callback_;
67 };
68
69 } // namespace
70
71 DeviceServiceTestBase::DeviceServiceTestBase()
72 : ServiceTest(kTestServiceName) {}
73
74 DeviceServiceTestBase::~DeviceServiceTestBase() {}
75
76 std::unique_ptr<service_manager::Service>
77 DeviceServiceTestBase::CreateService() {
78 return base::MakeUnique<ServiceTestClient>(this);
79 }
80
81 } // namespace device
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698