This CL adds AddAdaptationResource to Call and AddAdaptationResource/GetAdaptationResources method to relevant VideoSendStream and VideoStreamEncoder interfaces and implementations. Unittests are added to ensure that resources can be added to the Call both before and after the creation of a VideoSendStream and that the resources always gets added to the streams. In a follow-up CL, we will continue to plumb the resources all the way to PeerConnectionInterface, and an integration test will then be added to ensure that injected resources are capable of triggering adaptation. Bug: webrtc:11525 Change-Id: I499e9c23c3e359df943414d420b2e0ce2e9b2d56 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/177002 Reviewed-by: Ilya Nikolaevskiy <ilnik@webrtc.org> Reviewed-by: Evan Shrubsole <eshr@google.com> Reviewed-by: Stefan Holmer <stefan@webrtc.org> Commit-Queue: Henrik Boström <hbos@webrtc.org> Cr-Commit-Position: refs/heads/master@{#31499}
71 lines
2.4 KiB
C++
71 lines
2.4 KiB
C++
/*
|
|
* Copyright 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 VIDEO_TEST_MOCK_VIDEO_STREAM_ENCODER_H_
|
|
#define VIDEO_TEST_MOCK_VIDEO_STREAM_ENCODER_H_
|
|
|
|
#include <vector>
|
|
|
|
#include "api/video/video_stream_encoder_interface.h"
|
|
#include "test/gmock.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class MockVideoStreamEncoder : public VideoStreamEncoderInterface {
|
|
public:
|
|
MOCK_METHOD(void,
|
|
AddAdaptationResource,
|
|
(rtc::scoped_refptr<Resource>),
|
|
(override));
|
|
MOCK_METHOD(std::vector<rtc::scoped_refptr<Resource>>,
|
|
GetAdaptationResources,
|
|
(),
|
|
(override));
|
|
MOCK_METHOD(void,
|
|
SetSource,
|
|
(rtc::VideoSourceInterface<VideoFrame>*,
|
|
const DegradationPreference&),
|
|
(override));
|
|
MOCK_METHOD(void, SetSink, (EncoderSink*, bool), (override));
|
|
MOCK_METHOD(void, SetStartBitrate, (int), (override));
|
|
MOCK_METHOD(void, SendKeyFrame, (), (override));
|
|
MOCK_METHOD(void,
|
|
OnLossNotification,
|
|
(const VideoEncoder::LossNotification&),
|
|
(override));
|
|
MOCK_METHOD(void,
|
|
OnBitrateUpdated,
|
|
(DataRate, DataRate, DataRate, uint8_t, int64_t, double),
|
|
(override));
|
|
MOCK_METHOD(void, OnFrame, (const VideoFrame&), (override));
|
|
MOCK_METHOD(void,
|
|
SetBitrateAllocationObserver,
|
|
(VideoBitrateAllocationObserver*),
|
|
(override));
|
|
MOCK_METHOD(void,
|
|
SetFecControllerOverride,
|
|
(FecControllerOverride*),
|
|
(override));
|
|
MOCK_METHOD(void, Stop, (), (override));
|
|
|
|
MOCK_METHOD(void,
|
|
MockedConfigureEncoder,
|
|
(const VideoEncoderConfig&, size_t));
|
|
// gtest generates implicit copy which is not allowed on VideoEncoderConfig,
|
|
// so we can't mock ConfigureEncoder directly.
|
|
void ConfigureEncoder(VideoEncoderConfig config,
|
|
size_t max_data_payload_length) {
|
|
MockedConfigureEncoder(config, max_data_payload_length);
|
|
}
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // VIDEO_TEST_MOCK_VIDEO_STREAM_ENCODER_H_
|