OLD | NEW |
---|---|
(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 | |
OLD | NEW |