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

Side by Side Diff: services/video_capture/video_capture_service.h

Issue 2471613005: [Mojo Video Capture] Use actual factory instances implementing media::VideoCaptureDeviceFactory (Closed)
Patch Set: Created 4 years, 1 month 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
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef SERVICES_VIDEO_CAPTURE_VIDEO_CAPTURE_SERVICE_H_ 5 #ifndef SERVICES_VIDEO_CAPTURE_VIDEO_CAPTURE_SERVICE_H_
6 #define SERVICES_VIDEO_CAPTURE_VIDEO_CAPTURE_SERVICE_H_ 6 #define SERVICES_VIDEO_CAPTURE_VIDEO_CAPTURE_SERVICE_H_
7 7
8 #include <memory> 8 #include <memory>
9 9
10 #include "mojo/public/cpp/bindings/binding_set.h" 10 #include "mojo/public/cpp/bindings/binding_set.h"
11 #include "services/service_manager/public/cpp/service.h" 11 #include "services/service_manager/public/cpp/service.h"
12 #include "services/video_capture/public/interfaces/video_capture_service.mojom.h " 12 #include "services/video_capture/public/interfaces/video_capture_service.mojom.h "
13 13
14 namespace video_capture { 14 namespace video_capture {
15 15
16 class VideoCaptureDeviceFactoryImpl; 16 class DeviceFactoryMediaToMojoAdapter;
17 class MockDeviceFactory;
17 18
18 // Implementation of mojom::VideoCaptureService as a Service Manager service. 19 // Implementation of mojom::VideoCaptureService as a Service Manager service.
19 class VideoCaptureService 20 class VideoCaptureService
20 : public service_manager::Service, 21 : public service_manager::Service,
21 public service_manager::InterfaceFactory<mojom::VideoCaptureService>, 22 public service_manager::InterfaceFactory<mojom::VideoCaptureService>,
22 public mojom::VideoCaptureService { 23 public mojom::VideoCaptureService {
23 public: 24 public:
24 VideoCaptureService(); 25 VideoCaptureService();
25 ~VideoCaptureService() override; 26 ~VideoCaptureService() override;
26 27
(...skipping 13 matching lines...) Expand all
40 void ConnectToMockDeviceFactory( 41 void ConnectToMockDeviceFactory(
41 mojom::VideoCaptureDeviceFactoryRequest request) override; 42 mojom::VideoCaptureDeviceFactoryRequest request) override;
42 void AddDeviceToMockFactory( 43 void AddDeviceToMockFactory(
43 mojom::MockVideoCaptureDevicePtr device, 44 mojom::MockVideoCaptureDevicePtr device,
44 const media::VideoCaptureDeviceDescriptor& descriptor, 45 const media::VideoCaptureDeviceDescriptor& descriptor,
45 const AddDeviceToMockFactoryCallback& callback) override; 46 const AddDeviceToMockFactoryCallback& callback) override;
46 47
47 private: 48 private:
48 void LazyInitializeDeviceFactory(); 49 void LazyInitializeDeviceFactory();
49 void LazyInitializeFakeDeviceFactory(); 50 void LazyInitializeFakeDeviceFactory();
50 void LazyInitializeMockDeviceFactory(); 51 void LazyInitializeMockDeviceFactory();
mcasas 2016/11/04 23:24:29 Unrelated nit: shouldn't we add a ForTesting suffi
chfremer 2016/11/07 18:42:37 You are correct. The mock factory is indeed testin
51 52
52 mojo::BindingSet<mojom::VideoCaptureService> service_bindings_; 53 mojo::BindingSet<mojom::VideoCaptureService> service_bindings_;
53 mojo::BindingSet<mojom::VideoCaptureDeviceFactory> factory_bindings_; 54 mojo::BindingSet<mojom::VideoCaptureDeviceFactory> factory_bindings_;
54 mojo::BindingSet<mojom::VideoCaptureDeviceFactory> fake_factory_bindings_; 55 mojo::BindingSet<mojom::VideoCaptureDeviceFactory> fake_factory_bindings_;
55 mojo::BindingSet<mojom::VideoCaptureDeviceFactory> mock_factory_bindings_; 56 mojo::BindingSet<mojom::VideoCaptureDeviceFactory> mock_factory_bindings_;
56 std::unique_ptr<VideoCaptureDeviceFactoryImpl> device_factory_; 57 std::unique_ptr<DeviceFactoryMediaToMojoAdapter> device_factory_;
57 std::unique_ptr<VideoCaptureDeviceFactoryImpl> fake_device_factory_; 58 std::unique_ptr<DeviceFactoryMediaToMojoAdapter> fake_device_factory_;
58 std::unique_ptr<VideoCaptureDeviceFactoryImpl> mock_device_factory_; 59 std::unique_ptr<DeviceFactoryMediaToMojoAdapter> mock_device_factory_adapter_;
60 MockDeviceFactory* mock_device_factory_;
59 }; 61 };
60 62
61 } // namespace video_capture 63 } // namespace video_capture
62 64
63 #endif // SERVICES_VIDEO_CAPTURE_VIDEO_CAPTURE_SERVICE_H_ 65 #endif // SERVICES_VIDEO_CAPTURE_VIDEO_CAPTURE_SERVICE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698