blob: 7c412bacfafce8a672b98a78fe52fe7d9c0e0938 [file] [log] [blame]
Niels Möller4db138e2018-04-19 09:04:13 +02001/*
2 * Copyright (c) 2018 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Niels Möllercbcbc222018-09-28 09:07:24 +020011#ifndef TEST_VIDEO_ENCODER_PROXY_FACTORY_H_
12#define TEST_VIDEO_ENCODER_PROXY_FACTORY_H_
Niels Möller4db138e2018-04-19 09:04:13 +020013
14#include <memory>
15#include <vector>
16
17#include "api/video_codecs/video_encoder.h"
18#include "api/video_codecs/video_encoder_factory.h"
Niels Möller4db138e2018-04-19 09:04:13 +020019
20namespace webrtc {
21namespace test {
22
Elad Alon370f93a2019-06-11 14:57:57 +020023namespace {
24const VideoEncoder::Capabilities kCapabilities(false);
25}
26
Niels Möller4db138e2018-04-19 09:04:13 +020027// An encoder factory with a single underlying VideoEncoder object,
28// intended for test purposes. Each call to CreateVideoEncoder returns
29// a proxy for the same encoder, typically an instance of FakeEncoder.
Niels Möllercbcbc222018-09-28 09:07:24 +020030class VideoEncoderProxyFactory final : public VideoEncoderFactory {
Niels Möller4db138e2018-04-19 09:04:13 +020031 public:
Sergey Silkin443b7ee2019-06-28 12:53:07 +020032 explicit VideoEncoderProxyFactory(VideoEncoder* encoder)
philipel9b058032020-02-10 11:30:00 +010033 : VideoEncoderProxyFactory(encoder, nullptr) {}
34
35 explicit VideoEncoderProxyFactory(VideoEncoder* encoder,
36 EncoderSelectorInterface* encoder_selector)
Sergey Silkin443b7ee2019-06-28 12:53:07 +020037 : encoder_(encoder),
philipel9b058032020-02-10 11:30:00 +010038 encoder_selector_(encoder_selector),
Sergey Silkin443b7ee2019-06-28 12:53:07 +020039 num_simultaneous_encoder_instances_(0),
40 max_num_simultaneous_encoder_instances_(0) {
Mirta Dvornicic1ec2a162018-12-10 09:47:34 +000041 codec_info_.has_internal_source = false;
42 }
Niels Möller4db138e2018-04-19 09:04:13 +020043
44 // Unused by tests.
45 std::vector<SdpVideoFormat> GetSupportedFormats() const override {
46 RTC_NOTREACHED();
47 return {};
48 }
49
Mirta Dvornicic1ec2a162018-12-10 09:47:34 +000050 CodecInfo QueryVideoEncoder(const SdpVideoFormat& format) const override {
51 return codec_info_;
52 }
53
Niels Möller4db138e2018-04-19 09:04:13 +020054 std::unique_ptr<VideoEncoder> CreateVideoEncoder(
55 const SdpVideoFormat& format) override {
Sergey Silkin443b7ee2019-06-28 12:53:07 +020056 ++num_simultaneous_encoder_instances_;
57 max_num_simultaneous_encoder_instances_ =
58 std::max(max_num_simultaneous_encoder_instances_,
59 num_simultaneous_encoder_instances_);
Mirko Bonadei317a1f02019-09-17 17:06:18 +020060 return std::make_unique<EncoderProxy>(encoder_, this);
Niels Möller4db138e2018-04-19 09:04:13 +020061 }
62
philipel9b058032020-02-10 11:30:00 +010063 std::unique_ptr<EncoderSelectorInterface> GetEncoderSelector()
64 const override {
65 if (encoder_selector_ != nullptr) {
66 return std::make_unique<EncoderSelectorProxy>(encoder_selector_);
67 }
68
69 return nullptr;
70 }
71
Mirta Dvornicic1ec2a162018-12-10 09:47:34 +000072 void SetHasInternalSource(bool has_internal_source) {
73 codec_info_.has_internal_source = has_internal_source;
74 }
75
Sergey Silkin443b7ee2019-06-28 12:53:07 +020076 int GetMaxNumberOfSimultaneousEncoderInstances() {
77 return max_num_simultaneous_encoder_instances_;
78 }
79
Niels Möller4db138e2018-04-19 09:04:13 +020080 private:
Sergey Silkin443b7ee2019-06-28 12:53:07 +020081 void OnDestroyVideoEncoder() {
82 RTC_CHECK_GT(num_simultaneous_encoder_instances_, 0);
83 --num_simultaneous_encoder_instances_;
84 }
85
Niels Möller4db138e2018-04-19 09:04:13 +020086 // Wrapper class, since CreateVideoEncoder needs to surrender
87 // ownership to the object it returns.
88 class EncoderProxy final : public VideoEncoder {
89 public:
Sergey Silkin443b7ee2019-06-28 12:53:07 +020090 explicit EncoderProxy(VideoEncoder* encoder,
91 VideoEncoderProxyFactory* encoder_factory)
92 : encoder_(encoder), encoder_factory_(encoder_factory) {}
93 ~EncoderProxy() { encoder_factory_->OnDestroyVideoEncoder(); }
Niels Möller4db138e2018-04-19 09:04:13 +020094
95 private:
Elad Alon8f01c4e2019-06-28 15:19:43 +020096 void SetFecControllerOverride(
97 FecControllerOverride* fec_controller_override) override {
98 encoder_->SetFecControllerOverride(fec_controller_override);
99 }
100
Niels Möller4db138e2018-04-19 09:04:13 +0200101 int32_t Encode(const VideoFrame& input_image,
Niels Möller87e2d782019-03-07 10:18:23 +0100102 const std::vector<VideoFrameType>* frame_types) override {
Niels Möllerc8d2e732019-03-06 12:00:33 +0100103 return encoder_->Encode(input_image, frame_types);
Niels Möller4db138e2018-04-19 09:04:13 +0200104 }
Elad Alon8f01c4e2019-06-28 15:19:43 +0200105
Niels Möller4db138e2018-04-19 09:04:13 +0200106 int32_t InitEncode(const VideoCodec* config,
Elad Alon370f93a2019-06-11 14:57:57 +0200107 const Settings& settings) override {
108 return encoder_->InitEncode(config, settings);
Niels Möller4db138e2018-04-19 09:04:13 +0200109 }
Elad Alon8f01c4e2019-06-28 15:19:43 +0200110
Niels Möller4db138e2018-04-19 09:04:13 +0200111 int32_t RegisterEncodeCompleteCallback(
112 EncodedImageCallback* callback) override {
113 return encoder_->RegisterEncodeCompleteCallback(callback);
114 }
Elad Alon8f01c4e2019-06-28 15:19:43 +0200115
Niels Möller4db138e2018-04-19 09:04:13 +0200116 int32_t Release() override { return encoder_->Release(); }
Elad Alon8f01c4e2019-06-28 15:19:43 +0200117
Erik Språng16cb8f52019-04-12 13:59:09 +0200118 void SetRates(const RateControlParameters& parameters) override {
119 encoder_->SetRates(parameters);
Niels Möller4db138e2018-04-19 09:04:13 +0200120 }
Elad Alon8f01c4e2019-06-28 15:19:43 +0200121
Erik Språnga1ead6f2018-11-01 17:45:06 +0100122 VideoEncoder::EncoderInfo GetEncoderInfo() const override {
123 return encoder_->GetEncoderInfo();
Niels Möller4db138e2018-04-19 09:04:13 +0200124 }
125
126 VideoEncoder* const encoder_;
Sergey Silkin443b7ee2019-06-28 12:53:07 +0200127 VideoEncoderProxyFactory* const encoder_factory_;
Niels Möller4db138e2018-04-19 09:04:13 +0200128 };
129
philipel9b058032020-02-10 11:30:00 +0100130 class EncoderSelectorProxy final : public EncoderSelectorInterface {
131 public:
132 explicit EncoderSelectorProxy(EncoderSelectorInterface* encoder_selector)
133 : encoder_selector_(encoder_selector) {}
134
135 void OnCurrentEncoder(const SdpVideoFormat& format) override {
136 encoder_selector_->OnCurrentEncoder(format);
137 }
138
Mirta Dvornicic4f34d782020-02-26 13:01:19 +0100139 absl::optional<SdpVideoFormat> OnAvailableBitrate(
philipel9b058032020-02-10 11:30:00 +0100140 const DataRate& rate) override {
Mirta Dvornicic4f34d782020-02-26 13:01:19 +0100141 return encoder_selector_->OnAvailableBitrate(rate);
philipel9b058032020-02-10 11:30:00 +0100142 }
143
144 absl::optional<SdpVideoFormat> OnEncoderBroken() override {
145 return encoder_selector_->OnEncoderBroken();
146 }
147
148 private:
149 EncoderSelectorInterface* const encoder_selector_;
150 };
151
Niels Möller4db138e2018-04-19 09:04:13 +0200152 VideoEncoder* const encoder_;
philipel9b058032020-02-10 11:30:00 +0100153 EncoderSelectorInterface* const encoder_selector_;
Mirta Dvornicic1ec2a162018-12-10 09:47:34 +0000154 CodecInfo codec_info_;
Sergey Silkin443b7ee2019-06-28 12:53:07 +0200155
156 int num_simultaneous_encoder_instances_;
157 int max_num_simultaneous_encoder_instances_;
Niels Möller4db138e2018-04-19 09:04:13 +0200158};
159
160} // namespace test
161} // namespace webrtc
162
Niels Möllercbcbc222018-09-28 09:07:24 +0200163#endif // TEST_VIDEO_ENCODER_PROXY_FACTORY_H_