blob: f40e69daa8b2d985dff8e7ab46d553e42ca4f403 [file] [log] [blame]
/*
* Copyright (c) 2018 The WebRTC project authors. All Rights Reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#ifndef TEST_VIDEO_ENCODER_PROXY_FACTORY_H_
#define TEST_VIDEO_ENCODER_PROXY_FACTORY_H_
#include <memory>
#include <vector>
#include "api/video_codecs/video_encoder.h"
#include "api/video_codecs/video_encoder_factory.h"
namespace webrtc {
namespace test {
namespace {
const VideoEncoder::Capabilities kCapabilities(false);
}
// An encoder factory with a single underlying VideoEncoder object,
// intended for test purposes. Each call to CreateVideoEncoder returns
// a proxy for the same encoder, typically an instance of FakeEncoder.
class VideoEncoderProxyFactory final : public VideoEncoderFactory {
public:
explicit VideoEncoderProxyFactory(VideoEncoder* encoder)
: VideoEncoderProxyFactory(encoder, nullptr) {}
explicit VideoEncoderProxyFactory(VideoEncoder* encoder,
EncoderSelectorInterface* encoder_selector)
: encoder_(encoder),
encoder_selector_(encoder_selector),
num_simultaneous_encoder_instances_(0),
max_num_simultaneous_encoder_instances_(0) {
codec_info_.has_internal_source = false;
}
// Unused by tests.
std::vector<SdpVideoFormat> GetSupportedFormats() const override {
RTC_DCHECK_NOTREACHED();
return {};
}
CodecInfo QueryVideoEncoder(const SdpVideoFormat& format) const override {
return codec_info_;
}
std::unique_ptr<VideoEncoder> CreateVideoEncoder(
const SdpVideoFormat& format) override {
++num_simultaneous_encoder_instances_;
max_num_simultaneous_encoder_instances_ =
std::max(max_num_simultaneous_encoder_instances_,
num_simultaneous_encoder_instances_);
return std::make_unique<EncoderProxy>(encoder_, this);
}
std::unique_ptr<EncoderSelectorInterface> GetEncoderSelector()
const override {
if (encoder_selector_ != nullptr) {
return std::make_unique<EncoderSelectorProxy>(encoder_selector_);
}
return nullptr;
}
void SetHasInternalSource(bool has_internal_source) {
codec_info_.has_internal_source = has_internal_source;
}
int GetMaxNumberOfSimultaneousEncoderInstances() {
return max_num_simultaneous_encoder_instances_;
}
private:
void OnDestroyVideoEncoder() {
RTC_CHECK_GT(num_simultaneous_encoder_instances_, 0);
--num_simultaneous_encoder_instances_;
}
// Wrapper class, since CreateVideoEncoder needs to surrender
// ownership to the object it returns.
class EncoderProxy final : public VideoEncoder {
public:
explicit EncoderProxy(VideoEncoder* encoder,
VideoEncoderProxyFactory* encoder_factory)
: encoder_(encoder), encoder_factory_(encoder_factory) {}
~EncoderProxy() { encoder_factory_->OnDestroyVideoEncoder(); }
private:
void SetFecControllerOverride(
FecControllerOverride* fec_controller_override) override {
encoder_->SetFecControllerOverride(fec_controller_override);
}
int32_t Encode(const VideoFrame& input_image,
const std::vector<VideoFrameType>* frame_types) override {
return encoder_->Encode(input_image, frame_types);
}
int32_t InitEncode(const VideoCodec* config,
const Settings& settings) override {
return encoder_->InitEncode(config, settings);
}
int32_t RegisterEncodeCompleteCallback(
EncodedImageCallback* callback) override {
return encoder_->RegisterEncodeCompleteCallback(callback);
}
int32_t Release() override { return encoder_->Release(); }
void SetRates(const RateControlParameters& parameters) override {
encoder_->SetRates(parameters);
}
VideoEncoder::EncoderInfo GetEncoderInfo() const override {
return encoder_->GetEncoderInfo();
}
VideoEncoder* const encoder_;
VideoEncoderProxyFactory* const encoder_factory_;
};
class EncoderSelectorProxy final : public EncoderSelectorInterface {
public:
explicit EncoderSelectorProxy(EncoderSelectorInterface* encoder_selector)
: encoder_selector_(encoder_selector) {}
void OnCurrentEncoder(const SdpVideoFormat& format) override {
encoder_selector_->OnCurrentEncoder(format);
}
absl::optional<SdpVideoFormat> OnAvailableBitrate(
const DataRate& rate) override {
return encoder_selector_->OnAvailableBitrate(rate);
}
absl::optional<SdpVideoFormat> OnEncoderBroken() override {
return encoder_selector_->OnEncoderBroken();
}
private:
EncoderSelectorInterface* const encoder_selector_;
};
VideoEncoder* const encoder_;
EncoderSelectorInterface* const encoder_selector_;
CodecInfo codec_info_;
int num_simultaneous_encoder_instances_;
int max_num_simultaneous_encoder_instances_;
};
} // namespace test
} // namespace webrtc
#endif // TEST_VIDEO_ENCODER_PROXY_FACTORY_H_